Salome HOME
Merge from V6_main 01/04/2013
[modules/kernel.git] / src / SALOMEDS / Test / SALOMEDSTest_UseCase.cxx
1 // Copyright (C) 2007-2013  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
10 //
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 // Lesser General Public License for more details.
15 //
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22
23 /*!
24  * Check all methods of SALOMEDS_UseCaseBuilder and UseCaseIterator
25  * Use code of SALOMEDS_UseCaseBuilder.cxx and SALOMEDS_UseCaseIterator.cxx
26  */
27
28 #define SALOMEDS_ALL_TESTS
29
30 void SALOMEDSTest::testUseCase()
31 {
32   //Create or find the Study manager
33   _PTR(StudyManager) sm ( new SALOMEDS_StudyManager(_sm) );
34   CPPUNIT_ASSERT(sm);
35
36   //Create a new study
37   _PTR(Study) study = sm->NewStudy("TestSObject");
38   CPPUNIT_ASSERT(study);
39
40   //Create Study Builder
41   _PTR(StudyBuilder) studyBuilder = study->NewBuilder();
42   CPPUNIT_ASSERT(studyBuilder);
43
44   //Create a new UseCaseBuilder
45   _PTR(UseCaseBuilder) builder = study->GetUseCaseBuilder();
46   CPPUNIT_ASSERT(builder);
47
48   //Check method AddUseCase
49   _PTR(SObject) root1 = builder->AddUseCase("UseCase_1");
50   _PTR(SObject) root2 = builder->AddUseCase("UseCase_2");
51   CPPUNIT_ASSERT(root1 && root2);
52
53   //Check method SetCurrentObject
54   builder->SetCurrentObject(root1);
55
56   //Check method GetCurrentObject
57   CPPUNIT_ASSERT(builder->GetCurrentObject() && builder->GetCurrentObject()->GetID() == root1->GetID());
58
59   //Check method SetRootCurrent
60   CPPUNIT_ASSERT(builder->SetRootCurrent());
61   CPPUNIT_ASSERT(builder->GetCurrentObject()->GetID() == "0:2"); //Root in UseCases is always placed at label 0:2
62
63   //Check method IsUseCase
64   CPPUNIT_ASSERT(builder->IsUseCase(root1) && builder->IsUseCase(root2));
65
66   //Check method SetName
67   builder->SetName("A root use case");
68
69   //Check method GetName
70   CPPUNIT_ASSERT(builder->GetName() == "A root use case");
71
72 #ifdef SALOMEDS_ALL_TESTS
73   //Check method GetUseCaseIterator
74   builder->SetRootCurrent();
75   _PTR(SObject) nullObject;
76   _PTR(UseCaseIterator) root_it = builder->GetUseCaseIterator(nullObject); //The iterator on all UseCases
77   root_it->Init(false); //Only the first level
78   CPPUNIT_ASSERT(root_it->More());
79   CPPUNIT_ASSERT(root_it->Value()->GetID() == root1->GetID());
80   root_it->Next();
81   CPPUNIT_ASSERT(root_it->More());
82   CPPUNIT_ASSERT(root_it->Value()->GetID() == root2->GetID());
83   root_it->Next();
84   CPPUNIT_ASSERT(!root_it->More());
85 #else
86   cout << endl << "THE TEST IS NOT COMPLETE !!!" << endl;
87 #endif
88
89   builder->SetCurrentObject(root1);
90   _PTR(UseCaseIterator) it = builder->GetUseCaseIterator(root1); //The iterator on the given UseCase
91
92   //Check method Append
93   _PTR(SObject) so1 = study->CreateObjectID("0:1:1");
94   _PTR(SObject) so2 = study->CreateObjectID("0:1:2");
95   CPPUNIT_ASSERT(builder->Append(so1));
96
97   //Check methods Init, More, Next and Value of UseCaseIterator
98   it->Init(false);
99   CPPUNIT_ASSERT(it->More());
100   CPPUNIT_ASSERT(it->Value()->GetID() == so1->GetID());
101   it->Next();
102   CPPUNIT_ASSERT(!it->More());
103
104   //Check method AppendTo
105   CPPUNIT_ASSERT(builder->AppendTo(so1, so2));
106
107   //Check method HasChildren
108   CPPUNIT_ASSERT(builder->HasChildren(so1));
109   CPPUNIT_ASSERT(!builder->HasChildren(so2));
110
111   //Check method Init of UseCaseIterator
112   it->Init(false); //Only the first level
113   CPPUNIT_ASSERT(it->More());
114   CPPUNIT_ASSERT(it->Value()->GetID() == so1->GetID());
115   it->Next();
116   CPPUNIT_ASSERT(!it->More());
117
118   it->Init(true); //All levels
119   CPPUNIT_ASSERT(it->More());
120   CPPUNIT_ASSERT(it->Value()->GetID() == so1->GetID());
121   it->Next();
122   CPPUNIT_ASSERT(it->More());
123   CPPUNIT_ASSERT(it->Value()->GetID() == so2->GetID());
124   it->Next();
125   CPPUNIT_ASSERT(!it->More());
126
127   //Check method Remove
128   CPPUNIT_ASSERT(builder->Remove(so2));
129   it->Init(true);
130   CPPUNIT_ASSERT(it->More());
131   CPPUNIT_ASSERT(it->Value()->GetID() == so1->GetID());
132   it->Next();
133   CPPUNIT_ASSERT(!it->More());
134
135   CPPUNIT_ASSERT(builder->Append(so2));
136
137   //Check method InsertBefore
138   CPPUNIT_ASSERT(builder->InsertBefore(so2, so1));
139
140   it->Init(false);
141   CPPUNIT_ASSERT(it->More());
142   CPPUNIT_ASSERT(it->Value()->GetID() == so2->GetID());
143   it->Next();
144   CPPUNIT_ASSERT(it->More());
145   CPPUNIT_ASSERT(it->Value()->GetID() == so1->GetID());
146
147   sm->Close(study);
148 }
149 #undef SALOMEDS_ALL_TESTS
150
151