Salome HOME
Add copyright header according to request of CEA from 06.06.2017
[modules/shaper.git] / test.squish / suite_FEATURE_EXTRUSION / tst_extrusion_002 / test.py
1 ## Copyright (C) 2014-2017  CEA/DEN, EDF R&D
2 ##
3 ## This library is free software; you can redistribute it and/or
4 ## modify it under the terms of the GNU Lesser General Public
5 ## License as published by the Free Software Foundation; either
6 ## version 2.1 of the License, or (at your option) any later version.
7 ##
8 ## This library is distributed in the hope that it will be useful,
9 ## but WITHOUT ANY WARRANTY; without even the implied warranty of
10 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 ## Lesser General Public License for more details.
12 ##
13 ## You should have received a copy of the GNU Lesser General Public
14 ## License along with this library; if not, write to the Free Software
15 ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 ##
17 ## See http:##www.salome-platform.org/ or
18 ## email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
19 ##
20
21 def main():
22     # [project] SHAPER
23     # [Scenario] Extrusion_002
24     # [Topic] 'Extrusion by boarding planes and offsets' functionality
25     # [Tested functionality]
26     # [Summary description]
27     # [Expected results]
28     # [General comments]
29
30     source(findFile("scripts", "common.py"))
31
32     # [section] Application start
33     # [step] Launch SALOME
34     startApplication("salome_run.sh")
35
36     set_defaults()
37
38     # [step] Open 'for_extrusion_001.hdf'
39     open(DATA_PATH + "/for_extrusion_002.hdf")
40
41     # [step] Activate SHAPER
42     clickButton(waitForObject(":SALOME*.Shaper_QToolButton"))
43
44     # [step] Activate Part_1
45     waitForObjectItem(":Object browser_XGUI_DataTree", "Part\\_1 (Not loaded)")
46     clickItem(":Object browser_XGUI_DataTree", "Part\\_1 (Not loaded)", 48, 10, 0, Qt.LeftButton)
47     openItemContextMenu(waitForObject(":Object browser_XGUI_DataTree"), "Part\\_1 (Not loaded)", 48, 10, 0)
48     activateItem(waitForObjectItem(":_QMenu", "Activate"))
49
50     # [step] Fit all
51     fit_all()
52     test.vp("INIT")
53
54     # [step] Execute extrusion for sketch_1
55     mouseClick(waitForObjectItem(":SALOME*_QMenuBar", "Features"))
56     mouseClick(waitForObjectItem(":_QMenu", "Extrusion"))
57
58     # [step] Select sketch_1 as base
59     mouseClick(waitForObject(":SALOME*.3D View Operations_OCCViewer_ViewPort3d"), 324, 222, 0, Qt.LeftButton)
60
61     # [step] Select 'By boarding planes and offsets' button
62     clickButton(waitForObject(":Extrusion_QToolButton"))
63
64     # [check] Check that no result is previewed [vp NO_PREVIEW]
65     fit_all()
66     test.vp("NO_PREVIEW")
67
68     # [step] Select upper face as face 'To'
69     mouseClick(waitForObject(":Extrusion.Select a sketch face_QListWidget"), 80, 47, 0, Qt.LeftButton)
70     mouseClick(waitForObject(":SALOME*.3D View Operations_OCCViewer_ViewPort3d"), 350, 231, 0, Qt.LeftButton)
71     mouseClick(waitForObject(":To_QLineEdit"), 31, 11, 0, Qt.LeftButton)
72     mouseClick(waitForObject(":SALOME*.3D View Operations_OCCViewer_ViewPort3d"), 369, 87, 0, Qt.LeftButton)
73
74     # [check] Check that preview is updated [vp PREVIEW_TO]
75     fit_all()
76     test.vp("PREVIEW_TO")
77
78     # [step] Select lower face as face 'From'
79     mouseClick(waitForObject(":From_QLineEdit"), 80, 11, 0, Qt.LeftButton)
80     mouseClick(waitForObject(":SALOME*.3D View Operations_OCCViewer_ViewPort3d"), 350, 413, 0, Qt.LeftButton)
81
82     # [check] Check that preview is updated [vp PREVIEW_FROM]
83     test.vp("PREVIEW_FROM")
84
85     # [step] Define offset for face 'To'
86     type(waitForObject(":To.to_offset_ModuleBase_ParamSpinBox"), "<Ctrl+A>")
87     type(waitForObject(":To.to_offset_ModuleBase_ParamSpinBox"), 200)
88     type(waitForObject(":To.to_offset_ModuleBase_ParamSpinBox"), "<Return>")
89
90     # [step] Fit all
91     fit_all()
92
93     # [check] Check that preview is updated [vp PREVIEW_TO_OFFSET]
94     test.vp("PREVIEW_TO_OFFSET")
95
96     # [step] Define offset for face 'From'
97     type(waitForObject(":From.from_offset_ModuleBase_ParamSpinBox"), "<Ctrl+A>")
98     type(waitForObject(":From.from_offset_ModuleBase_ParamSpinBox"), 200)
99     type(waitForObject(":From.from_offset_ModuleBase_ParamSpinBox"), "<Return>")
100
101     # [step] Fit all
102     fit_all()
103
104     # [check] Check that preview is updated [vp PREVIEW_FROM_OFFSET]
105     test.vp("PREVIEW_FROM_OFFSET")
106
107     # [step] Ok
108     clickButton(waitForObject(":Extrusion.property_panel_ok_QToolButton"))
109
110     # [step] Fit all
111     fit_all()
112
113     # [check] Check that extrusion is built [vp EXTRUSION]
114     test.vp("EXTRUSION")
115
116     # [step] Close application without saving
117     close_application()