forked from lantian2012/CS207
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_nodes.cpp
executable file
·112 lines (86 loc) · 2.87 KB
/
test_nodes.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#include "Graph.hpp"
#include "CS207/Util.hpp"
// Define the GraphType HERE
typedef Graph<int> GraphType;
typedef GraphType::node_type Node;
using namespace std;
using namespace CS207;
static unsigned fail_count = 0;
template <typename T>
void sf_print(T a, string msg = "") {
(void) a;
cerr << msg << " [Success]" << endl;
}
void sf_print(bool sf, string msg = "") {
if (sf)
cerr << msg << " [Success]" << endl;
else {
cerr << msg << " [FAIL]" << endl;
++fail_count;
}
}
int main()
{
GraphType g;
Point p(CS207::random(), CS207::random(), CS207::random());
cerr << "Node is " << sizeof(Node) << " bytes";
sf_print(sizeof(Node) <= 16);
sf_print(g.add_node(p), "Inserting Node");
sf_print(g.num_nodes() == 1, "Graph has 1 Node");
sf_print(g.node(0), "Getting Node");
Node node = g.node(0);
sf_print(node.position() == p, "Node position conserved");
sf_print(node.index() == 0, "Index is 0");
sf_print(node.value() == 0, "Node value is default");
cerr << "Setting node value...";
g.node(0).value() = 2;
sf_print(node.value() == 2);
g.remove_node(node);
sf_print(g.num_nodes() == 0, "Removing Node...");
sf_print(g.num_nodes() == 0, "Graph has 0 Nodes");
cerr << "Adding 100 Nodes...";
for (int k = 0; k < 100; ++k)
g.add_node(Point(CS207::random(), CS207::random(), CS207::random()), k);
sf_print(g.num_nodes() == 100);
sf_print(g.node(0).value() == 0, "Node value set (0)");
sf_print(g.node(99).value() == 99, "Node value set (99)");
// Remove 50 Nodes...
for (unsigned k = 0; k < 50; ++k) {
unsigned n = unsigned(CS207::random(0, g.num_nodes()));
g.remove_node(g.node(n));
}
sf_print(g.num_nodes() == 50, "Removed 50 nodes");
cerr << "Checking Node indices...";
bool succ = true;
for (unsigned k = 0; succ && k < 50; ++k) {
Node node = g.node(k);
if (node.index() != k)
succ = false;
}
sf_print(succ);
cerr << "Clearing...";
g.clear();
sf_print(g.num_nodes() == 0, "Graph has 0 Nodes");
GraphType g2;
cerr << "Adding 50 Nodes to Graph1 and Graph2...";
for (unsigned k = 0; k < 50; ++k) {
Point p(CS207::random(), CS207::random(), CS207::random());
g.add_node(p);
g2.add_node(p);
}
sf_print(g.num_nodes() == 50 && g2.num_nodes() == 50);
sf_print(g2.node(23) == g2.node(23), "G2-G2 Node comparison ==");
sf_print(g2.node(23) != g2.node(21), "G2-G2 Node comparison !=");
sf_print(g2.node(23) != g.node(23), "G2-G1 Node comparison !=");
sf_print(g2.node(23) != g.node(21), "G2-G1 Node comparison !=");
sf_print(g.node(23) < g.node(21) || g.node(23) > g.node(21),
"G1-G1 Node comparison < >");
sf_print(g.node(23) < g2.node(21) || g.node(23) > g2.node(21),
"G1-G2 Node comparison < >");
if (fail_count) {
std::cerr << "\n" << fail_count
<< (fail_count > 1 ? " FAILURES" : " FAILURE") << std::endl;
return 1;
} else
return 0;
}