1 // Copyright (C) 2014-2015 EDF-R&D
2 // This library is free software; you can redistribute it and/or
3 // modify it under the terms of the GNU Lesser General Public
4 // License as published by the Free Software Foundation; either
5 // version 2.1 of the License, or (at your option) any later version.
7 // This library is distributed in the hope that it will be useful,
8 // but WITHOUT ANY WARRANTY; without even the implied warranty of
9 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
10 // Lesser General Public License for more details.
12 // You should have received a copy of the GNU Lesser General Public
13 // License along with this library; if not, write to the Free Software
14 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #undef HYDROGUI_EXPORTS
21 #include <test_HYDROGUI_ProfilesDlg.h>
23 #define private public
24 #include <HYDROGUI_ProfileDlg.h>
25 #include <CurveCreator_Widget.h>
28 #include <HYDROGUI_CurveCreatorProfile.h>
29 #include <CurveCreator_TableView.h>
30 #include <CurveCreator_Displayer.hxx>
31 #include <CurveCreator_Utils.hxx>
33 #include <HYDROData_Document.h>
34 #include <HYDROData_Profile.h>
37 #include <TestViewer.h>
38 #include <QApplication>
43 #define CPPUNIT_ASSERT_WIDGET( theWidget, theCase ) \
45 QPixmap aPixmap = QPixmap::grabWindow( theWidget->winId() ); \
46 QImage anImage = aPixmap.toImage(); \
48 if( !TestViewer::AssertImages( aMessage, &anImage, theCase, false ) ) \
50 TestViewer::showColorScale( false ); \
51 std::string aMessageStl = aMessage.toStdString(); \
52 CPPUNIT_FAIL( aMessageStl.c_str() ); \
57 void test_HYDROGUI_ProfilesDlg::test_default_size()
60 HYDROGUI_ProfileDlg* dlg = new HYDROGUI_ProfileDlg( 0, "test", true );
61 dlg->resize( 320, 640 );
63 QTest::qWaitForWindowExposed( dlg );
65 CPPUNIT_ASSERT_WIDGET( dlg, "profiles_dlg_presentation" );
68 qApp->processEvents();
71 HYDROGUI_CurveCreatorProfile* profile()
73 static HYDROGUI_CurveCreatorProfile* aProfile = 0;
77 aProfile = new HYDROGUI_CurveCreatorProfile();
78 CurveCreator::Coordinates coords;
79 coords.push_back( 0 );
80 coords.push_back( 20 );
81 coords.push_back( 30 );
82 coords.push_back( 0 );
83 coords.push_back( 60 );
84 coords.push_back( 0 );
85 coords.push_back( 90 );
86 coords.push_back( 20 );
87 aProfile->addPoints( coords, 0 );
91 void show_profile( HYDROGUI_ProfileDlg* dlg )
93 Handle(AIS_InteractiveContext) aCtx = dlg->getAISContext();
94 CurveCreator_Displayer* aDisplayer = new CurveCreator_Displayer( aCtx );
95 profile()->setDisplayer( aDisplayer );
96 aDisplayer->display( profile()->getAISObject( true ), true );
99 void select_points( HYDROGUI_ProfileDlg* dlg )
101 CurveCreator_ICurve::SectionToPointList sel;
102 sel.push_back( CurveCreator_ICurve::SectionToPoint( 0, 0 ) );
103 sel.push_back( CurveCreator_ICurve::SectionToPoint( 0, 1 ) );
104 sel.push_back( CurveCreator_ICurve::SectionToPoint( 0, 2 ) );
105 sel.push_back( CurveCreator_ICurve::SectionToPoint( 0, 3 ) );
106 dlg->myEditorWidget->getAction( CurveCreator_Widget::ModificationMode )->toggle();
107 dlg->myEditorWidget->onModificationMode( true );
108 dlg->myEditorWidget->setSelectedPoints( sel );
109 dlg->myEditorWidget->updateLocalPointView();
112 std::string coords( HYDROGUI_ProfileDlg* dlg, int col=2 )
114 int n = dlg->myEditorWidget->myLocalPointView->rowCount();
116 for( int r=0; r<n; r++ )
118 QString data = dlg->myEditorWidget->myLocalPointView->item(r, col)->data( Qt::DisplayRole ).toString();
119 datas.append( data );
121 return datas.join( ", " ).toStdString();
124 void setCoords( HYDROGUI_ProfileDlg* dlg, int theIndex, double theValue )
126 QAbstractItemModel* m = dlg->myEditorWidget->myLocalPointView->model();
127 QModelIndex index = m->index( theIndex, 2 );
129 m->setData( index, theValue, Qt::UserRole );
130 dlg->myEditorWidget->updateLocalPointView();
133 void test_HYDROGUI_ProfilesDlg::test_points_table()
136 HYDROGUI_ProfileDlg* dlg = new HYDROGUI_ProfileDlg( 0, "test", false );
137 dlg->resize( 320, 800 );
138 dlg->setProfile( profile() );
140 QTest::qWaitForWindowExposed( dlg );
143 select_points( dlg );
151 dlg->splitter()->setSizes( sizes );
152 qApp->processEvents();
154 CPPUNIT_ASSERT_WIDGET( dlg, "profiles_selected_points" );
155 CPPUNIT_ASSERT_EQUAL( std::string( "0, 30, 60, 90" ), coords( dlg ) );
156 CPPUNIT_ASSERT_EQUAL( std::string( "20, 0, 0, 20" ), coords( dlg, 3 ) );
158 setCoords( dlg, 0, 130 );
159 CPPUNIT_ASSERT_EQUAL( std::string( "130, 30, 60, 90" ), coords( dlg ) );
160 CPPUNIT_ASSERT_EQUAL( std::string( "20, 0, 0, 20" ), coords( dlg, 3 ) );
162 setCoords( dlg, 0, 0 );
163 CPPUNIT_ASSERT_EQUAL( std::string( "0, 30, 60, 90" ), coords( dlg ) );
164 CPPUNIT_ASSERT_EQUAL( std::string( "20, 0, 0, 20" ), coords( dlg, 3 ) );
166 setCoords( dlg, 0, 80 );
167 dlg->myEditorWidget->myLocalPointView->OnHeaderClick( 2 );
168 CPPUNIT_ASSERT_EQUAL( std::string( "30, 60, 80, 90" ), coords( dlg ) );
169 CPPUNIT_ASSERT_EQUAL( std::string( "0, 0, 20, 20" ), coords( dlg, 3 ) );
171 setCoords( dlg, 2, 0 );
172 CPPUNIT_ASSERT_EQUAL( std::string( "30, 60, 0, 90" ), coords( dlg ) );
173 CPPUNIT_ASSERT_EQUAL( std::string( "0, 0, 20, 20" ), coords( dlg, 3 ) );
175 //qApp->processEvents();
176 //QTest::qWait( 50000 );
179 qApp->processEvents();