• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdeedu API Reference
  • KDE Home
  • Contact Us
 

rocs/RocsCore

  • sources
  • kde-4.12
  • kdeedu
  • rocs
  • RocsCore
  • DataStructures
  • Graph
  • Tests
TestGraphStructure.cpp
Go to the documentation of this file.
1 /*
2  This file is part of Rocs.
3  Copyright 2004-2010 Tomaz Canabrava <tomaz.canabrava@gmail.com>
4  Copyright 2012 Andreas Cord-Landwehr <cola@uni-paderborn.de>
5 
6  This program is free software; you can redistribute it and/or
7  modify it under the terms of the GNU General Public License as
8  published by the Free Software Foundation; either version 2 of
9  the License, or (at your option) any later version.
10 
11  This program 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
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19 
20 #include "TestGraphStructure.h"
21 #include "DataStructure.h"
22 #include "../GraphStructure.h"
23 #include "Data.h"
24 #include "Pointer.h"
25 #include "KrossBackend.h"
26 #include "QtScriptBackend.h"
27 #include <qtest_kde.h>
28 
29 #include <kross/core/action.h>
30 #include <kross/core/manager.h>
31 #include <Document.h>
32 #include <DataStructureBackendManager.h>
33 #include <DocumentManager.h>
34 
35 TestGraphStructure::TestGraphStructure()
36 {
37  QVERIFY(DataStructureBackendManager::self().backends().count() > 0);
38  DocumentManager::self().addDocument(new Document("test"));
39 }
40 
41 void TestGraphStructure::cleanupTestCase()
42 {
43 }
44 
45 void TestGraphStructure::dataAddDeleteTest()
46 {
47  DataStructureBackendManager::self().setBackend("Graph");
48  DataStructurePtr ds = DocumentManager::self().activeDocument()->addDataStructure("AddDeleteTest");
49  DataList dataList;
50 
51  // create 10 data elements
52  for (int i = 0; i < 10; i++) {
53  dataList.append(ds->createData(QString(i), 0));
54  }
55  QVERIFY2(ds->dataList(0).size() == 10, "ERROR: Number of data elements is not 10");
56 
57  // remove all data elements
58  foreach(DataPtr data, dataList) {
59  data->remove();
60  }
61 
62  QVERIFY2(ds->dataList(0).size() == 0, "ERROR: Not all data elements were deleted");
63 }
64 
65 void TestGraphStructure::pointerAddDeleteTest()
66 {
67  // test for undirected pointers
68  DataStructureBackendManager::self().setBackend("Graph");
69  DataStructurePtr ds = DocumentManager::self().activeDocument()->addDataStructure("AddDeleteTest");
70  DataList dataList;
71 
72  // create 10 data elements
73  // x x x x x x x x x x
74  for (int i = 0; i < 10; i++) {
75  dataList.append(ds->createData(QString(i), 0));
76  }
77  QVERIFY2(ds->dataList(0).size() == 10, "ERROR: Number of data elements is not 10");
78 
79  // connect data elements to a line
80  // x-x-x-x-x-x-x-x-x-x
81  for (int i = 0; i < dataList.size() - 1; i++) {
82  ds->createPointer(dataList[i], dataList[i + 1], 0);
83  }
84  QVERIFY2(ds->pointers(0).size() == 9, "ERROR: Number of data elements is not 9");
85  QVERIFY2(dataList[0]->pointerList().size() == 1, "ERROR: data gives wrong number of pointers");
86  QVERIFY2(dataList[1]->pointerList().size() == 2, "ERROR: data gives wrong number of pointers");
87 
88  // remove first pointer from list
89  // x x-x-x-x-x-x-x-x-x
90  ds->pointers(0).first()->remove();
91  QVERIFY2(ds->pointers(0).size() == 8, "ERROR: pointer was not removed");
92  QVERIFY2(dataList[0]->pointerList().size() == 0, "ERROR: data gives wrong number of pointers");
93  QVERIFY2(dataList[1]->pointerList().size() == 1, "ERROR: data gives wrong number of pointers");
94 
95  // remove second node, should trigger deletion of second pointer
96  // x o x-x-x-x-x-x-x-x
97  dataList[1]->remove();
98  QVERIFY2(ds->pointers(0).size() == 7, "ERROR: data deletion did not remove its pointers");
99 
100  // remove fourth node, should trigger deletion of its two adjacend pointers
101  // x o x o x-x-x-x-x-x
102  dataList[3]->remove();
103  QVERIFY2(ds->pointers(0).size() == 5, "ERROR: data deletion did not remove its both pointers");
104 }
105 
106 void TestGraphStructure::createSimpleGraph()
107 {
108  QMap<QString, DataPtr> dataList;
109  /* Creates a simple Graph with 5 datums and connects them with pointers. */
110  DataStructureBackendManager::self().setBackend("Graph");
111  DataStructurePtr ds = DocumentManager::self().activeDocument()->addDataStructure("AddDeleteTest");
112 
113  ds->setProperty("name", "Graph1");
114  dataList.insert("a", ds->createData("a", 0));
115  dataList.insert("b", ds->createData("b", 0));
116  dataList.insert("c", ds->createData("c", 0));
117  dataList.insert("d", ds->createData("d", 0));
118  dataList.insert("e", ds->createData("e", 0));
119 
120  ds->createPointer(dataList["a"], dataList["b"], 0);
121  ds->createPointer(dataList["b"], dataList["c"], 0);
122  ds->createPointer(dataList["c"], dataList["d"], 0);
123  ds->createPointer(dataList["d"], dataList["e"], 0);
124  ds->createPointer(dataList["e"], dataList["a"], 0);
125 
126  QVERIFY2(ds->dataList(0).size() == 5, "ERROR: Number of data is not 5 ");
127  QVERIFY2(ds->pointers(0).size() == 5, "ERROR: Number of pointers is not 5 ");
128 
129  foreach(DataPtr n, ds->dataList(0)) {
130  QVERIFY2(n->outPointerList().size() == 1, "ERROR: Number of out pointers is not 1");
131  QVERIFY2(n->inPointerList().size() == 1, "ERROR: Number of in pointers is not 1");
132  QVERIFY2(n->adjacentDataList().size() == 2, "ERROR: Number of Adjacent Nodes is not 2");
133  QVERIFY2(n->pointerList().size() == 2, "ERROR: Number of adjacent pointers is not 2");
134  }
135 }
136 
137 void TestGraphStructure::dataTypesTest()
138 {
139  DataStructureBackendManager::self().setBackend("Graph");
140  DataStructurePtr ds = DocumentManager::self().activeDocument()->addDataStructure("AddDeleteTest");
141 
142  DataList dataListDefault, dataList1, dataList2;
143  QVERIFY2(ds->document()->dataTypeList().size() == 1, "ERROR: no default data type created");
144 
145  // register two further data types
146  int type1 = ds->document()->registerDataType("type1");
147  int type2 = ds->document()->registerDataType("type2");
148  QVERIFY2(ds->document()->dataTypeList().size() == 3, "ERROR: data types were not created");
149 
150  // create data elements
151  for (int i = 0; i < 3; i++) {
152  dataListDefault.append(ds->createData(QString(i), 0));
153  dataList1.append(ds->createData(QString(i), type1));
154  dataList2.append(ds->createData(QString(i), type2));
155  }
156  QVERIFY2(ds->dataList(0).size() == 3,
157  "list contains " + ds->dataList(0).size()
158  );
159  QVERIFY2(ds->dataList(type1).size() == 3,
160  "list contains " + ds->dataList(0).size()
161  );
162  QVERIFY2(ds->dataList(type2).size() == 3,
163  "list contains " + ds->dataList(0).size()
164  );
165  QVERIFY2(dataListDefault.at(0)->dataType() == 0, "ERROR: not correct autoset of type");
166  QVERIFY2(dataList1.at(0)->dataType() == type1, "ERROR: not correct autoset of type");
167  QVERIFY2(dataList2.at(0)->dataType() == type2, "ERROR: not correct autoset of type");
168 
169  // add pointers
170  ds->createPointer(dataListDefault[0], dataList1[0], 0);
171  ds->createPointer(dataList1[0], dataList2[0], 0);
172  ds->createPointer(dataList2[0], dataListDefault[0], 0);
173  QVERIFY2(ds->pointers(0).size() == 3, "ERROR: pointers were not correctly created");
174 
175  // remove data type
176  ds->document()->removeDataType(type2);
177  QVERIFY2(ds->pointers(0).size() == 1, "ERROR: pointers were not correctly deleted");
178 }
179 
180 
181 void TestGraphStructure::pointerTypesTest()
182 {
183  DataStructureBackendManager::self().setBackend("Graph");
184  DataStructurePtr ds = DocumentManager::self().activeDocument()->addDataStructure("AddDeleteTest");
185 
186  DataList dataList;
187  QVERIFY2(ds->document()->pointerTypeList().size() == 1, "ERROR: no default pointer type created");
188 
189  // create data elements
190  for (int i = 0; i < 10; i++) {
191  dataList.append(ds->createData(QString(i), 0));
192  }
193 
194  // register two further data types
195  int type1 = ds->document()->registerPointerType("type1");
196  QVERIFY2(ds->document()->pointerTypeList().size() == 2, "ERROR: pointer types were not created");
197 
198  // connect data elements to a lines
199  for (int i = 0; i < 4; i++) {
200  ds->createPointer(dataList[i], dataList[i + 1], 0);
201  }
202  for (int i = 0; i < 9; i++) {
203  ds->createPointer(dataList[i], dataList[i + 1], type1);
204  }
205  QVERIFY2(ds->pointers(0).size() == 4, "ERROR: wrong number of pointers");
206  QVERIFY2(ds->pointers(type1).size() == 9, "ERROR: wrong number of pointers");
207  QVERIFY(dataList[0]->adjacentDataList().size() == 1);
208  QVERIFY(dataList[1]->adjacentDataList().size() == 2);
209  QVERIFY(dataList[5]->adjacentDataList().size() == 2);
210 
211  // remove first node
212  dataList[0]->remove();
213  QVERIFY2(ds->pointers(0).size() == 3, "ERROR: wrong number of pointers");
214  QVERIFY2(ds->pointers(type1).size() == 8, "ERROR: wrong number of pointers");
215 
216  ds->document()->removePointerType(type1);
217  QVERIFY(dataList[2]->adjacentDataList().size() == 2);
218  QVERIFY(dataList[6]->adjacentDataList().size() == 0);
219 }
220 
221 void TestGraphStructure::serializeUnserializePluginExtraProperties()
222 {
223  DocumentManager::self().addDocument(new Document("testSerialization"));
224  Document* document = DocumentManager::self().activeDocument();
225  QMap<QString, DataPtr> dataList;
226 
227  // Creates a simple Graph with 5 data elements and connect them with pointers.
228  DataStructurePtr ds = document->activeDataStructure();
229  ds->setProperty("name", "Graph1");
230  boost::static_pointer_cast<Rocs::GraphStructure>(ds)->setGraphType(Rocs::GraphStructure::Multigraph);
231 
232  // serialize into file "serializetest.graph"
233  DocumentManager::self().activeDocument()->saveAs("graphserializetest");
234  DocumentManager::self().removeDocument(DocumentManager::self().activeDocument());
235  Document* testDoc = new Document("testDoc");
236 
237  //unserialize and test properties
238  DocumentManager::self().addDocument(testDoc);
239  DocumentManager::self().changeDocument(testDoc);
240  DocumentManager::self().openDocument(KUrl::fromLocalFile("graphserializetest.graph"));
241 
242  // compare graph type
243  QVERIFY2(DocumentManager::self().activeDocument()->dataStructures().count() == 1, "ERROR: DataStructure not loaded");
244  ds = DocumentManager::self().activeDocument()->dataStructures().at(0);
245  Rocs::GraphStructure::GRAPH_TYPE graphType = boost::static_pointer_cast<Rocs::GraphStructure>(ds)->graphType();
246  QVERIFY2(graphType == Rocs::GraphStructure::Multigraph, "ERROR: graph type not loaded correctly");
247 
248 }
249 
250 QTEST_KDEMAIN_CORE(TestGraphStructure)
KrossBackend.h
Rocs::GraphStructure
Definition: GraphStructure.h:29
DocumentManager.h
Rocs::GraphStructure::GRAPH_TYPE
GRAPH_TYPE
Definition: GraphStructure.h:35
DocumentManager::self
static DocumentManager & self()
Definition: DocumentManager.cpp:57
DataStructurePtr
boost::shared_ptr< DataStructure > DataStructurePtr
Definition: CoreTypes.h:38
GmlParser::document
Document * document
Definition: GmlGrammar.cpp:40
DocumentManager::activeDocument
Document * activeDocument() const
Returns the currently active document, or 0 if there document list is empty.
Definition: DocumentManager.cpp:96
DataList
QList< boost::shared_ptr< Data > > DataList
Definition: CoreTypes.h:30
TestGraphStructure.h
QtScriptBackend.h
Data.h
DataStructureBackendManager::self
static DataStructureBackendManager & self()
Returns self reference to backend manager.
Definition: DataStructureBackendManager.cpp:233
Document.h
DataStructure.h
Document::addDataStructure
DataStructurePtr addDataStructure(const QString &name=QString())
Add data structure to graph document with name name.
Definition: Document.cpp:333
Document::activeDataStructure
DataStructurePtr activeDataStructure() const
Definition: Document.cpp:431
DocumentManager::changeDocument
void changeDocument(Document *document)
Change active document to be document.
Definition: DocumentManager.cpp:143
Document
Definition: Document.h:41
TestGraphStructure
Definition: TestGraphStructure.h:30
Rocs::GraphStructure::Multigraph
Definition: GraphStructure.h:37
DataStructureBackendManager::setBackend
void setBackend(const QString &pluginIdentifier)
Change the active backend.
Definition: DataStructureBackendManager.cpp:240
Document::dataStructures
QList< DataStructurePtr > & dataStructures() const
Definition: Document.cpp:227
Pointer.h
DataPtr
boost::shared_ptr< Data > DataPtr
Definition: CoreTypes.h:34
TestGraphStructure::TestGraphStructure
TestGraphStructure()
Definition: TestGraphStructure.cpp:35
DocumentManager::addDocument
void addDocument(Document *document)
Add document to document list and set this document as active document.
Definition: DocumentManager.cpp:106
DataStructureBackendManager.h
Document::saveAs
void saveAs(const QString &fileUrl)
Save graph document under the given fileUrl.
Definition: Document.cpp:381
DocumentManager::openDocument
Document * openDocument(const KUrl &documentUrl)
Loads graph document specified by documentUrl and adds document to document list. ...
Definition: DocumentManager.cpp:245
DocumentManager::removeDocument
void removeDocument(Document *document)
Remove document from document list.
Definition: DocumentManager.cpp:173
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:42:26 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

rocs/RocsCore

Skip menu "rocs/RocsCore"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

kdeedu API Reference

Skip menu "kdeedu API Reference"
  • Analitza
  •     lib
  • kalgebra
  • kalzium
  •   libscience
  • kanagram
  • kig
  •   lib
  • klettres
  • kstars
  • libkdeedu
  •   keduvocdocument
  • marble
  • parley
  • rocs
  •   App
  •   RocsCore
  •   VisualEditor
  •   stepcore

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal