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 #include <test_HYDROData_StricklerTable.h>
20 #include <HYDROData_Document.h>
21 #include <HYDROData_Iterator.h>
22 #include <HYDROData_StricklerTable.h>
23 #include <HYDROData_Tool.h>
24 #include <HYDROGUI_StricklerTableDlg.h>
25 #include <TestViewer.h>
28 #include <QStringList>
29 #include <QTableWidget>
31 const QString DEF_STR_PATH = qgetenv( "HYDRO_ROOT_DIR" ) + "/share/salome/resources/hydro/def_strickler_table_06.txt";
32 extern QString TMP_DIR;
34 void test_HYDROData_StricklerTable::test_import()
36 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
38 Handle(HYDROData_StricklerTable) aTable =
39 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
41 CPPUNIT_ASSERT_EQUAL( true, aTable->Import( DEF_STR_PATH ) );
43 QStringList aTypes = aTable->GetTypes();
44 CPPUNIT_ASSERT_EQUAL( 44, aTypes.size() );
45 CPPUNIT_ASSERT_EQUAL( QString( "CODE_06" ), aTable->GetAttrName() );
47 QString aType = QString::fromUtf8("Périmètres irrigués en permanence");
48 CPPUNIT_ASSERT_EQUAL( aType, aTypes[25] );
49 CPPUNIT_ASSERT_EQUAL( QColor( 255, 255, 0 ), aTable->GetColor( aType ) );
50 CPPUNIT_ASSERT_EQUAL( QString( "212" ), aTable->GetAttrValue( aType ) );
52 aType = QString::fromUtf8("Végétation clairsemée");
53 CPPUNIT_ASSERT_EQUAL( aType, aTypes[38] );
54 CPPUNIT_ASSERT_EQUAL( QColor( 204, 255, 204 ), aTable->GetColor( aType ) );
55 CPPUNIT_ASSERT_EQUAL( QString( "333" ), aTable->GetAttrValue( aType ) );
60 void test_HYDROData_StricklerTable::test_import_export_equivalence()
62 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
64 Handle(HYDROData_StricklerTable) aTable =
65 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
67 CPPUNIT_ASSERT_EQUAL( true, aTable->Import( DEF_STR_PATH ) );
68 QString aTmpPath = TMP_DIR + "/stricker.txt";
69 CPPUNIT_ASSERT_EQUAL( true, aTable->Export( aTmpPath ) );
71 QFile aRefFile( DEF_STR_PATH ), aTmpFile( aTmpPath );
72 CPPUNIT_ASSERT_EQUAL( true, aRefFile.open( QFile::ReadOnly ) );
73 CPPUNIT_ASSERT_EQUAL( true, aTmpFile.open( QFile::ReadOnly ) );
75 QByteArray aRefContents = aRefFile.readAll();
76 QByteArray aTmpContents = aTmpFile.readAll();
78 // bool isEqual = aRefContents.size()==aTmpContents.size();
79 // CPPUNIT_ASSERT_EQUAL( true, isEqual );
80 // for( int i=0, n=aRefContents.size(); isEqual && i<n; i++ )
81 // if( aRefContents[i]!=aTmpContents[i] )
84 // CPPUNIT_ASSERT_EQUAL( true, isEqual );
91 void test_HYDROData_StricklerTable::test_type_by_attr()
93 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
95 Handle(HYDROData_StricklerTable) aTable =
96 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
98 CPPUNIT_ASSERT_EQUAL( true, aTable->Import( DEF_STR_PATH ) );
100 CPPUNIT_ASSERT_EQUAL( QString( "Plans d'eau" ), aTable->GetType( "512" ) );
101 CPPUNIT_ASSERT_EQUAL( QString( "" ), aTable->GetType( "125" ) );
102 CPPUNIT_ASSERT_EQUAL( QString( "" ), aTable->GetType( "" ) );
107 void test_HYDROData_StricklerTable::test_unique_attr_name()
109 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
111 Handle(HYDROData_StricklerTable) aTable1 =
112 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
113 Handle(HYDROData_StricklerTable) aTable2 =
114 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
116 CPPUNIT_ASSERT_EQUAL( true, aTable1->SetAttrName( "CODE_06" ) );
117 CPPUNIT_ASSERT_EQUAL( QString( "CODE_06" ), aTable1->GetAttrName() );
118 CPPUNIT_ASSERT_EQUAL( QString( "" ), aTable2->GetAttrName() );
120 CPPUNIT_ASSERT_EQUAL( false, aTable2->SetAttrName( "CODE_06" ) );
121 CPPUNIT_ASSERT_EQUAL( QString( "CODE_06" ), aTable1->GetAttrName() );
122 CPPUNIT_ASSERT_EQUAL( QString( "" ), aTable2->GetAttrName() );
124 CPPUNIT_ASSERT_EQUAL( true, aTable2->SetAttrName( "CODE_07" ) );
125 CPPUNIT_ASSERT_EQUAL( QString( "CODE_06" ), aTable1->GetAttrName() );
126 CPPUNIT_ASSERT_EQUAL( QString( "CODE_07" ), aTable2->GetAttrName() );
128 CPPUNIT_ASSERT_EQUAL( false, aTable1->SetAttrName( "CODE_07" ) );
129 CPPUNIT_ASSERT_EQUAL( QString( "CODE_06" ), aTable1->GetAttrName() );
130 CPPUNIT_ASSERT_EQUAL( QString( "CODE_07" ), aTable2->GetAttrName() );
135 void test_HYDROData_StricklerTable::test_colors_sync()
137 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
139 Handle(HYDROData_StricklerTable) aTable1 =
140 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
141 Handle(HYDROData_StricklerTable) aTable2 =
142 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
144 aTable1->Set( "test1", 10 );
145 aTable1->Set( "test2", 20 );
146 aTable1->SetColor( "test1", QColor( 255, 0, 0 ) );
147 aTable1->SetColor( "test2", QColor( 255, 0, 1 ) );
148 CPPUNIT_ASSERT_EQUAL( QColor( 255, 0, 0 ), aTable1->GetColor( "test1" ) );
149 CPPUNIT_ASSERT_EQUAL( QColor( 255, 0, 1 ), aTable1->GetColor( "test2" ) );
151 aTable2->Set( "test1", 15 );
152 aTable2->SetColor( "test1", QColor( 255, 255, 0 ) );
153 CPPUNIT_ASSERT_EQUAL( QColor( 255, 255, 0 ), aTable1->GetColor( "test1" ) );
154 CPPUNIT_ASSERT_EQUAL( QColor( 255, 255, 0 ), aTable2->GetColor( "test1" ) );
159 void test_HYDROData_StricklerTable::test_duplication_refs_613()
161 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
163 Handle(HYDROData_StricklerTable) aTable1 =
164 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
165 aTable1->Set( "type1", 1.5 );
166 aTable1->SetColor( "type1", QColor( 10, 20, 30 ) );
167 aTable1->SetName( "DefStrickler_1" );
169 Handle(HYDROData_StricklerTable) aTable2 =
170 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
171 aTable1->CopyTo( aTable2, true );
173 CPPUNIT_ASSERT_EQUAL( QString( "DefStrickler_2" ), aTable2->GetName() );
174 CPPUNIT_ASSERT_DOUBLES_EQUAL( 1.5, aTable2->Get( "type1", 0.0 ), 1E-5 );
175 CPPUNIT_ASSERT_EQUAL( QColor( 10, 20, 30 ), aTable2->GetColor( "type1" ) );
177 aDoc->StartOperation();
180 Handle(HYDROData_StricklerTable) aTable3 =
181 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
182 aTable3->SetName( "DefStrickler_1" );
183 aDoc->CommitOperation();
185 HYDROData_Iterator anIt1( aDoc, KIND_STRICKLER_TABLE );
186 CPPUNIT_ASSERT_EQUAL( true, anIt1.More() );
187 CPPUNIT_ASSERT_EQUAL( QString( "DefStrickler_1" ), anIt1.Current()->GetName() );
189 CPPUNIT_ASSERT_EQUAL( false, anIt1.More() );
193 HYDROData_Iterator anIt2( aDoc, KIND_STRICKLER_TABLE );
194 CPPUNIT_ASSERT_EQUAL( true, anIt2.More() );
195 CPPUNIT_ASSERT_EQUAL( QString( "DefStrickler_1" ), anIt2.Current()->GetName() );
197 CPPUNIT_ASSERT_EQUAL( true, anIt2.More() );
198 CPPUNIT_ASSERT_EQUAL( QString( "DefStrickler_2" ), anIt2.Current()->GetName() );
200 CPPUNIT_ASSERT_EQUAL( false, anIt2.More() );
205 void test_HYDROData_StricklerTable::test_dump_python()
207 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
209 Handle(HYDROData_StricklerTable) aTable =
210 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
211 aTable->SetName( "ST" );
212 CPPUNIT_ASSERT_EQUAL( true, aTable->Import( DEF_STR_PATH ) );
214 QString aTmpPath = TMP_DIR + "/st_dump.py";
216 CPPUNIT_ASSERT_EQUAL( true, aDoc->DumpToPython( aTmpPath, false ) );
218 CPPUNIT_ASSERT_SCRIPTS_EQUAL( "st_dump.py", true, true, 0 );
223 void test_HYDROData_StricklerTable::test_add_row_in_gui_refs_717()
225 Handle(HYDROData_Document) aDoc = HYDROData_Document::Document();
227 Handle(HYDROData_StricklerTable) aTable =
228 Handle(HYDROData_StricklerTable)::DownCast( aDoc->CreateObject( KIND_STRICKLER_TABLE ) );
230 CPPUNIT_ASSERT_EQUAL( true, aTable->Import( DEF_STR_PATH ) );
232 HYDROGUI_StricklerTableDlg* aDlg = new HYDROGUI_StricklerTableDlg( 0, "", 0 );
233 aDlg->setGuiData( aTable );
234 CPPUNIT_ASSERT_EQUAL( 44, aDlg->myTable->rowCount() );
235 aDlg->onAddCoefficient();
236 aDlg->getGuiData( aTable );