Salome HOME
cd6d3e33892ebbee621017b799df3528e49a50c4
[modules/shaper.git] / test.squish / suite_FEATURE_REVOLUTION / tst_revolution_001 / 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] Revolution_001
24     # [Topic] 'Revolution by angles' 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_revolution_001.hdf'
39     open(DATA_PATH + "/for_revolution_001.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)", 71, 10, 0, Qt.LeftButton)
47     openItemContextMenu(waitForObject(":Object browser_XGUI_DataTree"), "Part\\_1 (Not loaded)", 70, 9, 0)
48     activateItem(waitForObjectItem(":_QMenu", "Activate"))
49
50     # [step] Fit all [vp INIT]
51     fit_all()
52     test.vp("INIT")
53
54     # [step] Execute revolution by angles
55     mouseClick(waitForObjectItem(":SALOME*_QMenuBar", "Features"))
56     mouseClick(waitForObjectItem(":_QMenu", "Revolution"))
57
58     # [step] Click '+OY' button
59     clickButton(waitForObject(":SALOME*.+OY_QToolButton"))
60
61     # [step] Fit all [vp +OY]
62     fit_all()
63     test.vp("+OY")
64
65     # [step] Select sketch for revolution
66     mouseClick(waitForObject(":Revolution.Select a sketch face_QListWidget"), 10, 10, 0, Qt.LeftButton)
67     mouseClick(waitForObject(":SALOME*.3D View Operations_OCCViewer_ViewPort3d"), 431, 180, 0, Qt.LeftButton)
68     # [step] Select vector
69
70     mouseClick(waitForObject(":Revolution_QLineEdit"), 186, 8, 0, Qt.LeftButton)
71     mouseClick(waitForObject(":SALOME*.3D View Operations_OCCViewer_ViewPort3d"), 307, 328, 0, Qt.LeftButton)
72
73     # [step] Fit all [vp AFTER_SELECTION]
74     fit_all()
75     test.vp("AFTER_SELECTION")
76
77     # [step] Click 'Reset view' toolbar button
78     clickButton(waitForObject(":SALOME*.Reset_QToolButton_2"))
79     mouseClick(waitForObject(":SALOME*_OCCViewer_ViewPort3d"), 10, 450, 0, Qt.LeftButton)  # close tool bar extension bar
80
81     test.vp("AFTER_SELECTION_RESET")
82
83     # [step] Input angle 'To'
84     type(waitForObject(":Revolution.to_angle_ModuleBase_ParamSpinBox"), "<Ctrl+A>")
85     type(waitForObject(":Revolution.to_angle_ModuleBase_ParamSpinBox"), 90)
86
87     # [step] Input angle 'From'
88     type(waitForObject(":Revolution.from_angle_ModuleBase_ParamSpinBox"), "<Ctrl+A>")
89     type(waitForObject(":Revolution.from_angle_ModuleBase_ParamSpinBox"), 120)
90     type(waitForObject(":Revolution.from_angle_ModuleBase_ParamSpinBox"), "<Return>")
91
92     # [check] Check that preview is updated [cp AFTER_ANGLE_90_120]
93     fit_all()
94     test.vp("AFTER_ANGLE_90_120")
95
96     # [step] Clear the angle 'To'
97     mouseClick(waitForObject(":Revolution.qt_spinbox_lineedit_QLineEdit"), 10, 10, 0, Qt.LeftButton)
98     type(waitForObject(":Revolution.to_angle_ModuleBase_ParamSpinBox"), "<Ctrl+A>")
99     type(waitForObject(":Revolution.to_angle_ModuleBase_ParamSpinBox"), "<Delete>")
100
101     # [step] Input new angle 'From': 360
102     mouseClick(waitForObject(":Revolution.qt_spinbox_lineedit_QLineEdit_2"), 10, 10, 0, Qt.LeftButton)
103     type(waitForObject(":Revolution.from_angle_ModuleBase_ParamSpinBox"), "<Ctrl+A>")
104     type(waitForObject(":Revolution.from_angle_ModuleBase_ParamSpinBox"), 360)
105     type(waitForObject(":Revolution.from_angle_ModuleBase_ParamSpinBox"), "<Return>")
106
107     # [step] Apply the feature
108     clickButton(waitForObject(":Revolution.property_panel_ok_QToolButton"))
109
110     # [check] Check that operation has been executed successfully [cp AFTER_ANGLE_360]
111     fit_all()
112     test.vp("AFTER_ANGLE_360")
113
114     # [step] Close application without saving
115     close_application()