First commit to utilize Travis CI.

for/release
dmatetelki 10 years ago
parent 81688e7b5b
commit 155aa18b45

@ -0,0 +1,19 @@
language: cpp
compiler:
- clang
- gcc
env:
- BUILD_TYPE=Debug
- BUILD_TYPE=Release
install:
- cmake -Hprojects/CMake -BBuild -DCMAKE_BUILD_TYPE=$BUILD_TYPE
- cd Build
- make
- cd ..
script:
- cd Build
- test_bin

@ -1,4 +1,10 @@
cmake_minimum_required (VERSION 2.6) cmake_minimum_required (VERSION 2.6)
project (PROJECT_GRAPH) project (PROJECT_GRAPH)
set (CXX_FLAGS "-std=c++11")
add_definitions(${CXX_FLAGS})
# set (CMAKE_CXX_COMPILER "/usr/bin/g++-4.9.2")
# set (CMAKE_CXX_COMPILER "/usr/bin/clang++-3.6.0")
add_subdirectory (test) add_subdirectory (test)

@ -1,47 +1,3 @@
# set(CMAKE_CXX_FLAGS " -Wall -Wextra -pedantic -Weffc++ -Wshadow --std=c++0x -ggdb") include_directories(../lib)
# set(CMAKE_CXX_COMPILER "/usr/lib/colorgcc/bin/g++")
# set(CMAKE_CXX_COMPILER "/usr/bin/g++-4.8.2")
# set(CMAKE_CXX_COMPILER "/home/denes/bin/colorgcc/g++") add_executable (test_bin test_main.cpp)
set (CXX_FLAGS "-Wall -Wextra -pedantic -Weffc++ -Wshadow "
# "-Wpointer-arith -Wcast-qual
"-std=c++11 "
"-ggdb -fprofile-arcs -ftest-coverage "
"-fopenmp -D_GLIBCXX_PARALLEL"
)
add_definitions( ${CXX_FLAGS} )
set (CMAKE_CXX_COMPILER "/usr/bin/g++-4.9.0")
find_package(CxxTest)
# if ( NOT CXXTEST_FOUND )
# message(FATAL_ERROR "Package CXXTEST required, but not found!")
# else()
if(CXXTEST_FOUND)
include_directories(${CXXTEST_INCLUDE_DIR}
../lib
/usr/include/libxml2)
enable_testing()
CXXTEST_ADD_TEST(test_graph
generated_main.cpp
graph/test_graph.hpp)
target_link_libraries(test_graph
gcov
gomp
xml2
)
endif()
add_custom_target( test
DEPENDS test_graph
COMMAND ./tools/run_test.sh ./test_graph
)

File diff suppressed because it is too large Load Diff

@ -1,483 +1,287 @@
#include <cxxtest/TestSuite.h> #include <graph/graph.hpp>
#include <graph/graphwd.hpp>
// #include <graph/graph_algorithms.hpp>
// #include <graph/mesh_algorithms.hpp>
// #include <graph/graph_xml.hpp>
// #include <graph/common.hpp>
namespace std {
template <>
struct hash<std::pair<float,float> >
{
std::size_t operator()(const std::pair<float,float>& k) const {
std::size_t h1 = std::hash<float>()(k.first);
std::size_t h2 = std::hash<float>()(k.second);
return h1 ^ (h2 << 1);
}
};
}
namespace test { class TestSubsystem1DummyClassSuite; } #include "/home/denes/projects/Catch/single_include/catch.hpp"
class test::TestSubsystem1DummyClassSuite : public CxxTest::TestSuite #include <algorithm>
{ #include <iostream>
#include <map>
public:
void test_trivial() TEST_CASE( "Graph creation", "[graph][data_structure]" ) {
{
GraphWD<std::string> g(false);
TS_ASSERT_EQUALS ( g.directed(), false );
GraphWD<int> g1; SECTION("Initial state") {
TS_ASSERT_EQUALS ( g1.directed(), true ); Graph<int> g;
REQUIRE( empty(g) == true );
GraphWD<float, std::string> g2; REQUIRE( numberOfVertices(g) == 0 );
TS_ASSERT_EQUALS ( g2.empty(), true ); REQUIRE( numberOfEdges(g) == 0 );
REQUIRE( g.edges().size() == 0 );
REQUIRE( g.vertices().size() == 0 );
}
GraphWD<std::pair<float, float> ,float> g3; SECTION("Initializer list of vertices") {
TS_ASSERT_EQUALS ( g3.numberOfVertices(), 0 ); Graph<int> g = { 1, 2, 3 };
TS_ASSERT_EQUALS ( g3.numberOfEdges(), 0 ); REQUIRE( empty(g) == false );
TS_ASSERT_EQUALS ( g3.contains(std::make_pair(2.4, 5.567)), false ); REQUIRE( numberOfVertices(g) == 3 );
TS_ASSERT_EQUALS ( g3.vertices().size(), 0 ); REQUIRE( numberOfEdges(g) == 0 );
TS_ASSERT_EQUALS ( g3.edges().size(), 0 ); REQUIRE( g.edges().size() == 0 );
TS_ASSERT_EQUALS ( g3.empty(), true ); REQUIRE( g.vertices().size() == 3 );
REQUIRE( contains(g, 1) == true );
REQUIRE( contains(g, 2) == true );
REQUIRE( contains(g, 3) == true );
} }
void test_basic_vertices() SECTION("Initializer list of vertices") {
{ Graph<int> g = { {1, 2}, {1, 3}, {3, 4} };
GraphWD<std::string> g; REQUIRE( empty(g) == false );
REQUIRE( numberOfVertices(g) == 4 );
REQUIRE( numberOfEdges(g) == 3*2 );
REQUIRE( g.edges().size() == 3*2 );
REQUIRE( g.vertices().size() == 4 );
REQUIRE( contains(g, 1) == true );
REQUIRE( contains(g, 2) == true );
REQUIRE( contains(g, 3) == true );
REQUIRE( contains(g, 4) == true );
}
g.addVertex("a"); SECTION("copy ctor") {
g.addVertex("b"); Graph<int> g = { {1, 2}, {1, 3}, {3, 4} };
g.addVertex("c"); Graph<int> g2(g);
TS_ASSERT_EQUALS ( g.vertices().size(), 3 ); REQUIRE( empty(g2) == false );
REQUIRE( numberOfVertices(g2) == 4 );
REQUIRE( numberOfEdges(g2) == 3*2 );
REQUIRE( g2.edges().size() == 3*2 );
REQUIRE( g2.vertices().size() == 4 );
REQUIRE( contains(g2, 1) == true );
REQUIRE( contains(g2, 2) == true );
REQUIRE( contains(g2, 3) == true );
REQUIRE( contains(g2, 4) == true );
}
g.addVertex("d"); SECTION("Assignment operator") {
g.addVertex("d"); Graph<int> g = { {1, 2}, {1, 3}, {3, 4} };
TS_ASSERT_EQUALS ( g.vertices().size(), 4 ); Graph<int> g2;
g2.clear();
g2 = g;
REQUIRE( empty(g2) == false );
REQUIRE( numberOfVertices(g2) == 4 );
REQUIRE( numberOfEdges(g2) == 3*2 );
REQUIRE( g2.edges().size() == 3*2 );
REQUIRE( g2.vertices().size() == 4 );
REQUIRE( contains(g2, 1) == true );
REQUIRE( contains(g2, 2) == true );
REQUIRE( contains(g2, 3) == true );
REQUIRE( contains(g2, 4) == true );
}
}
g.removeVertex("f"); TEST_CASE( "Graph adding vertices", "[graph][data_structure]" ) {
TS_ASSERT_EQUALS ( g.vertices().size(), 4 );
g.removeVertex("c"); SECTION("One element") {
TS_ASSERT_EQUALS ( g.vertices().size(), 3 ); Graph<int> g;
g.removeVertex("c"); g.addVertex(1);
TS_ASSERT_EQUALS ( g.vertices().size(), 3 ); REQUIRE( empty(g) == false );
REQUIRE( numberOfVertices(g) == 1 );
REQUIRE( numberOfEdges(g) == 0 );
REQUIRE( g.edges().size() == 0 );
REQUIRE( g.vertices().size() == 1 );
}
for(const std::string& s : g.vertices()) SECTION("Removing the only element") {
g.removeVertex(s); Graph<int> g;
g.addVertex(1);
g.removeVertex(1);
REQUIRE( empty(g) == true );
REQUIRE( numberOfVertices(g) == 0 );
REQUIRE( numberOfEdges(g) == 0 );
REQUIRE( g.edges().size() == 0 );
REQUIRE( g.vertices().size() == 0 );
}
TS_ASSERT_EQUALS ( g.vertices().size(), 0 ); SECTION("Adding some vertices, removing one by one") {
Graph<int> g;
g.addVertex(1);
REQUIRE( numberOfVertices(g) == 1 );
g.addVertex(2);
REQUIRE( numberOfVertices(g) == 2 );
g.addVertex(3);
REQUIRE( numberOfVertices(g) == 3 );
g.removeVertex(1);
REQUIRE( numberOfVertices(g) == 2 );
g.removeVertex(2);
REQUIRE( numberOfVertices(g) == 1 );
g.removeVertex(3);
REQUIRE( numberOfVertices(g) == 0 );
}
GraphWD<std::string> g2 = { "a", "b", "c" }; SECTION("Adding some vertices then clear") {
TS_ASSERT_EQUALS ( g2.vertices().size(), 3 ); Graph<int> g;
g.addVertex(1);
g.addVertex(2);
g.addVertex(3);
REQUIRE( numberOfVertices(g) == 3 );
g.clear();
REQUIRE( numberOfVertices(g) == 0 );
}
SECTION("Removing unexisting vertex") {
Graph<int> g;
g.addVertex(1);
REQUIRE( numberOfVertices(g) == 1 );
g.removeVertex(2);
REQUIRE( numberOfVertices(g) == 1 );
} }
void test_basic_edges() SECTION("Contains vertex") {
{ Graph<int> g;
GraphWD<std::string> g = { "a", "a", "b", "c", "d", "e" }; g.addVertex(1);
g.addEdge("a", "a", 1); g.addVertex(3);
g.addEdge("a", "b", 2); REQUIRE( contains(g, 1) == true );
g.addEdge("a", "c", 3); REQUIRE( contains(g, 2) == false );
REQUIRE( contains(g, 3) == true );
g.addEdge("c", "d", 4);
TS_ASSERT_EQUALS ( g.edges().size(), 4 );
TS_ASSERT_EQUALS ( g.neighboursOf("a").size(), 3 );
TS_ASSERT_EQUALS ( g.neighboursOf("b").size(), 0 );
TS_ASSERT_EQUALS ( g.neighboursOf("c").size(), 1 );
TS_ASSERT_EQUALS ( g.neighboursOf("d").size(), 0 );
TS_ASSERT_EQUALS ( g.neighboursOf("e").size(), 0 );
std::vector<std::string> n = g.neighboursOf("a");
TS_ASSERT_DIFFERS ( find(n.begin(), n.end(), "a"), n.end() );
TS_ASSERT_DIFFERS ( find(n.begin(), n.end(), "b"), n.end() );
TS_ASSERT_DIFFERS ( find(n.begin(), n.end(), "c"), n.end() );
TS_ASSERT_EQUALS ( find(n.begin(), n.end(), "d"), n.end() );
TS_ASSERT_EQUALS ( find(n.begin(), n.end(), "e"), n.end() );
std::vector<int> w = g.weights("a", "b");
TS_ASSERT_EQUALS ( w.size(), 1 );
TS_ASSERT_EQUALS ( w[0], 2 );
// undirected
GraphWD<std::string> g1(false);
g1.addVertex("a");
g1.addVertex("b");
g1.addVertex("c");
g1.addVertex("d");
g1.addVertex("e");
g1.addEdge("a", "a", 1);
g1.addEdge("a", "b", 2);
g1.addEdge("a", "c", 3);
g1.addEdge("c", "d", 4);
TS_ASSERT_EQUALS ( g1.edges().size(), 4*2 - 1 );
TS_ASSERT_EQUALS ( g1.neighboursOf("a").size(), 3 );
TS_ASSERT_EQUALS ( g1.neighboursOf("b").size(), 1 );
TS_ASSERT_EQUALS ( g1.neighboursOf("c").size(), 2 );
TS_ASSERT_EQUALS ( g1.neighboursOf("d").size(), 1 );
TS_ASSERT_EQUALS ( g1.neighboursOf("e").size(), 0 );
} }
void test_list_ctor_from_vertices() SECTION("Modify vertex") {
{ Graph<int> g;
GraphWD<std::string> g = { "a", "a", "b", "c", "d", "e" }; g.addVertex(1);
REQUIRE( contains(g, 1) == true );
REQUIRE( contains(g, 2) == false );
std::vector<std::string> v = g.vertices(); g.modifyVertex(1, 2);
REQUIRE( contains(g, 1) == false );
REQUIRE( contains(g, 2) == true );
}
TS_ASSERT_EQUALS ( v.size(), 5 ); SECTION("get array of vertices") {
Graph<int> g;
g.addVertex(1);
g.addVertex(2);
g.addVertex(3);
std::vector<int> v = g.vertices();
REQUIRE( v.size() == 3 );
REQUIRE( std::find(v.begin(), v.end(), 1) != v.end() );
REQUIRE( std::find(v.begin(), v.end(), 2) != v.end() );
REQUIRE( std::find(v.begin(), v.end(), 3) != v.end() );
} }
void test_move_ctor() SECTION("iterate over vertices") {
{ Graph<int> g;
g.addVertex(1);
GraphWD<std::string> g = { g.addVertex(2);
{"a", "a", 1}, g.addVertex(3);
{"a", "b", 2},
{"a", "c", 3}, std::map<int, int> found;
{"c", "d", 4} }; for (auto it : g) {
REQUIRE( contains(g, it) == true );
GraphWD<std::string> g1; ++found[it];
g1 = g; }
REQUIRE( found.size() == 3 );
TS_ASSERT_EQUALS ( g.edges().size(), 4 );
TS_ASSERT_EQUALS ( g.neighboursOf("a").size(), 3 );
TS_ASSERT_EQUALS ( g.neighboursOf("b").size(), 0 );
TS_ASSERT_EQUALS ( g.neighboursOf("c").size(), 1 );
TS_ASSERT_EQUALS ( g.neighboursOf("d").size(), 0 );
TS_ASSERT_EQUALS ( g1.edges().size(), 4 );
TS_ASSERT_EQUALS ( g1.neighboursOf("a").size(), 3 );
TS_ASSERT_EQUALS ( g1.neighboursOf("b").size(), 0 );
TS_ASSERT_EQUALS ( g1.neighboursOf("c").size(), 1 );
TS_ASSERT_EQUALS ( g1.neighboursOf("d").size(), 0 );
} }
}
void test_list_ctor_from_edges() TEST_CASE( "Graph adding edges", "[graph][data_structure]" ) {
{
GraphWD<std::string> g = { SECTION("One element") {
{"a", "a", 1}, Graph<int> g;
{"a", "b", 2}, g.addEdge(1, 2);
{"a", "c", 3}, REQUIRE( empty(g) == false );
{"c", "d", 4} }; REQUIRE( numberOfVertices(g) == 2 );
REQUIRE( numberOfEdges(g) == 1*2 );
REQUIRE( g.edges().size() == 1*2 );
REQUIRE( g.vertices().size() == 2 );
}
TS_ASSERT_EQUALS ( g.vertices().size(), 4 ); SECTION("Removing the only edge") {
TS_ASSERT_EQUALS ( g.edges().size(), 4 ); Graph<int> g;
g.addEdge(1, 2);
g.removeEdge(1, 2);
REQUIRE( empty(g) == false );
REQUIRE( numberOfVertices(g) == 2 );
REQUIRE( numberOfEdges(g) == 0 );
REQUIRE( g.edges().size() == 0 );
REQUIRE( g.vertices().size() == 2 );
}
/*
SECTION("Adding some edges, removing one by one") {
Graph<int> g;
g.addVertex(1);
REQUIRE( numberOfVertices(g) == 1 );
g.addVertex(2);
REQUIRE( numberOfVertices(g) == 2 );
g.addVertex(3);
REQUIRE( numberOfVertices(g) == 3 );
g.removeVertex(1);
REQUIRE( numberOfVertices(g) == 2 );
g.removeVertex(2);
REQUIRE( numberOfVertices(g) == 1 );
g.removeVertex(3);
REQUIRE( numberOfVertices(g) == 0 );
}
TS_ASSERT_EQUALS ( g.neighboursOf("a").size(), 3 ); SECTION("Adding some vertices then clear") {
TS_ASSERT_EQUALS ( g.neighboursOf("b").size(), 0 ); Graph<int> g;
TS_ASSERT_EQUALS ( g.neighboursOf("c").size(), 1 ); g.addVertex(1);
TS_ASSERT_EQUALS ( g.neighboursOf("d").size(), 0 ); g.addVertex(2);
TS_ASSERT_EQUALS ( g.neighboursOf("e").size(), 0 ); g.addVertex(3);
REQUIRE( numberOfVertices(g) == 3 );
g.clear();
REQUIRE( numberOfVertices(g) == 0 );
} }
void test_adding_and_removing_vertices() SECTION("Removing unexisting vertex") {
{ Graph<int> g;
GraphWD<std::string> g; g.addVertex(1);
g.addVertex("a"); REQUIRE( numberOfVertices(g) == 1 );
g.addVertex("b"); g.removeVertex(2);
g.addVertex("c"); REQUIRE( numberOfVertices(g) == 1 );
g.addVertex("d");
g.addVertex("e");
g.addVertex("f");
g.addVertex("g");
g.addEdge("a", "a", 1);
g.addEdge("a", "b", 2);
g.addEdge("a", "c", 3);
g.addEdge("c", "d", 4);
g.addEdge("c", "f", 5);
g.addEdge("f", "e", 6);
TS_ASSERT_EQUALS ( g.vertices().size(), 7 );
TS_ASSERT_EQUALS ( g.edges().size(), 6 );
g.removeVertex("c");
TS_ASSERT_EQUALS ( g.vertices().size(), 7-1 );
TS_ASSERT_EQUALS ( g.edges().size(), 6-3 );
std::vector<GraphWD<std::string>::Edge> es = g.edges();
// TS_ASSERT_EQUALS ( es[0].source, "a" );
// TS_ASSERT_EQUALS ( es[0].destination, "a" );
// TS_ASSERT_EQUALS ( es[0].weight, 1 );
//
// TS_ASSERT_EQUALS ( es[1].source, "a" );
// TS_ASSERT_EQUALS ( es[1].destination, "b" );
// TS_ASSERT_EQUALS ( es[1].weight, 2 );
//
// TS_ASSERT_EQUALS ( es[2].source, "f" );
// TS_ASSERT_EQUALS ( es[2].destination, "e" );
// TS_ASSERT_EQUALS ( es[2].weight, 6 );
} }
void test_removing_edges() SECTION("Contains vertex") {
{ Graph<int> g;
g.addVertex(1);
GraphWD<std::string> g; g.addVertex(3);
g.addVertex("a"); REQUIRE( contains(g, 1) == true );
g.addVertex("b"); REQUIRE( contains(g, 2) == false );
g.addVertex("c"); REQUIRE( contains(g, 3) == true );
g.addVertex("d");
g.addVertex("e");
g.addVertex("f");
g.addVertex("g");
g.addEdge("a", "a", 1);
g.addEdge("a", "b", 21); // multiple to b
g.addEdge("a", "b", 22);
g.addEdge("a", "b", 23);
g.addEdge("a", "c", 3);
g.addEdge("c", "d", 4);
g.addEdge("c", "f", 5);
g.addEdge("f", "e", 6);
g.removeEdge("c", "d", 4);
g.removeEdge("e", "f", 1234);
g.removeEdges("a", "b");
g.removeEdges("invalid", "b");
TS_ASSERT_EQUALS( g.vertices().size(), 7 );
TS_ASSERT_EQUALS ( g.edges().size(), 4 );
// int j; GraphWD<std::string>::edge_iterator e_it;
// for (j = 0, e_it = g.edge_begin();
// e_it != g.edge_end();
// ++e_it, ++j)
// switch (j) {
// case 0: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "a");
// TS_ASSERT_EQUALS (e_it->weight, 1);
// break;
// case 1: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "c");
// TS_ASSERT_EQUALS (e_it->weight, 3);
// break;
// case 2: TS_ASSERT_EQUALS (e_it->source, "c");
// TS_ASSERT_EQUALS (e_it->destination, "f");
// TS_ASSERT_EQUALS (e_it->weight, 5);
// break;
// case 3: TS_ASSERT_EQUALS (e_it->source, "f");
// TS_ASSERT_EQUALS (e_it->destination, "e");
// TS_ASSERT_EQUALS (e_it->weight, 6);
// break;
// }
} }
void test_iterator() SECTION("Modify vertex") {
{ Graph<int> g;
g.addVertex(1);
GraphWD<std::string> g; REQUIRE( contains(g, 1) == true );
g.addVertex("a"); REQUIRE( contains(g, 2) == false );
g.addVertex("b");
g.addVertex("c"); g.modifyVertex(1, 2);
g.addVertex("d"); REQUIRE( contains(g, 1) == false );
g.addVertex("e"); REQUIRE( contains(g, 2) == true );
g.addVertex("f");
g.addVertex("g");
g.addEdge("a", "a", 1);
g.addEdge("a", "b", 2);
g.addEdge("a", "c", 3);
g.addEdge("c", "d", 4);
g.addEdge("c", "f", 5);
g.addEdge("f", "e", 6);
// int i; GraphWD<std::string>::vertex_iterator v_it;
// for (i = 0, v_it = g.begin();
// v_it != g.end();
// ++v_it, ++i)
// switch (i) {
// case 0: TS_ASSERT_EQUALS (*v_it, "a"); break;
// case 1: TS_ASSERT_EQUALS (*v_it, "b"); break;
// case 2: TS_ASSERT_EQUALS (*v_it, "c"); break;
// case 3: TS_ASSERT_EQUALS (*v_it, "d"); break;
// case 4: TS_ASSERT_EQUALS (*v_it, "e"); break;
// case 5: TS_ASSERT_EQUALS (*v_it, "f"); break;
// case 6: TS_ASSERT_EQUALS (*v_it, "g"); break;
// }
// int j; GraphWD<std::string>::edge_iterator e_it;
// for (j = 0, e_it = g.edge_begin();
// e_it != g.edge_end();
// ++e_it, ++j)
// switch (j) {
// case 0: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "a");
// TS_ASSERT_EQUALS (e_it->weight, 1);
// break;
// case 1: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "b");
// TS_ASSERT_EQUALS (e_it->weight, 2);
// break;
// case 2: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "c");
// TS_ASSERT_EQUALS (e_it->weight, 3);
// break;
// case 3: TS_ASSERT_EQUALS (e_it->source, "c");
// TS_ASSERT_EQUALS (e_it->destination, "d");
// TS_ASSERT_EQUALS (e_it->weight, 4);
// break;
// case 4: TS_ASSERT_EQUALS (e_it->source, "c");
// TS_ASSERT_EQUALS (e_it->destination, "f");
// TS_ASSERT_EQUALS (e_it->weight, 5);
// break;
// case 5: TS_ASSERT_EQUALS (e_it->source, "f");
// TS_ASSERT_EQUALS (e_it->destination, "e");
// TS_ASSERT_EQUALS (e_it->weight, 6);
// break;
// }
// g.removeVertex("c");
//
// for (i = 0, v_it = g.vertex_begin();
// v_it != g.vertex_end();
// ++v_it, ++i)
// switch (i) {
// case 0: TS_ASSERT_EQUALS (*v_it, "a"); break;
// case 1: TS_ASSERT_EQUALS (*v_it, "b"); break;
// case 2: TS_ASSERT_EQUALS (*v_it, "d"); break;
// case 3: TS_ASSERT_EQUALS (*v_it, "e"); break;
// case 4: TS_ASSERT_EQUALS (*v_it, "f"); break;
// case 5: TS_ASSERT_EQUALS (*v_it, "g"); break;
// }
//
// for (j = 0, e_it = g.edge_begin();
// e_it != g.edge_end();
// ++e_it, ++j)
// switch (j) {
// case 0: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "a");
// TS_ASSERT_EQUALS (e_it->weight, 1);
// break;
// case 1: TS_ASSERT_EQUALS (e_it->source, "a");
// TS_ASSERT_EQUALS (e_it->destination, "b");
// TS_ASSERT_EQUALS (e_it->weight, 2);
// break;
// case 2: TS_ASSERT_EQUALS (e_it->source, "f");
// TS_ASSERT_EQUALS (e_it->destination, "e");
// TS_ASSERT_EQUALS (e_it->weight, 6);
// break;
// }
} }
void test_wights() SECTION("get array of vertices") {
{ Graph<int> g;
g.addVertex(1);
GraphWD<std::string> g; g.addVertex(2);
g.addVertex("a"); g.addVertex(3);
g.addVertex("b"); std::vector<int> v = g.vertices();
g.addVertex("c"); REQUIRE( v.size() == 3 );
g.addVertex("d"); REQUIRE( std::find(v.begin(), v.end(), 1) != v.end() );
g.addVertex("e"); REQUIRE( std::find(v.begin(), v.end(), 2) != v.end() );
g.addVertex("f"); REQUIRE( std::find(v.begin(), v.end(), 3) != v.end() );
g.addVertex("g");
g.addEdge("a", "a", 1);
g.addEdge("a", "b", 2);
g.addEdge("a", "c", 3);
g.addEdge("c", "d", 4);
g.addEdge("c", "f", 5);
g.addEdge("f", "e", 6);
TS_ASSERT_EQUALS ( g.weights("a", "a").size(), 1 );
TS_ASSERT_EQUALS ( g.weights("a", "b").size(), 1 );
TS_ASSERT_EQUALS ( g.weights("a", "c").size(), 1 );
TS_ASSERT_EQUALS ( g.weights("c", "d").size(), 1 );
TS_ASSERT_EQUALS ( g.weights("f", "e").size(), 1 );
TS_ASSERT_EQUALS ( g.weights("a", "d").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("a", "f").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("a", "e").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("a", "d").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("d", "e").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("b", "f").size(), 0 );
// directed
TS_ASSERT_EQUALS ( g.weights("a", "a").size(), 1 );
TS_ASSERT_EQUALS ( g.weights("b", "b").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("c", "a").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("d", "c").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("f", "c").size(), 0 );
TS_ASSERT_EQUALS ( g.weights("e", "f").size(), 0 );
} }
// /// @todo put algorithm tests to another suite SECTION("iterate over vertices") {
// void test_dijkstra() Graph<int> g;
// { g.addVertex(1);
// g.addVertex(2);
// // from http://en.wikipedia.org/wiki/File:Dijkstra_Animation.gif g.addVertex(3);
// GraphWDWD<int> d(false);
// d.addVertex(1); std::map<int, int> found;
// d.addVertex(2); for (auto it : g) {
// d.addVertex(3); REQUIRE( contains(g, it) == true );
// d.addVertex(4); ++found[it];
// d.addVertex(5); }
// d.addVertex(6); REQUIRE( found.size() == 3 );
// }*/
// d.addVertex(7); // unconnected extra }
// d.addVertex(8);
// d.addVertex(9);
//
// d.addEdge(1, 2, 7);
// d.addEdge(1, 3, 9);
// d.addEdge(1, 6, 14);
// d.addEdge(2, 3, 10);
// d.addEdge(2, 4, 15);
// d.addEdge(3, 4, 11);
// d.addEdge(3, 6, 2);
// d.addEdge(4, 5, 6);
// d.addEdge(5, 6, 9);
//
// d.addEdge(8, 9, 9);
//
// std::pair<std::unordered_map< int, int>, std::unordered_map< int, int> > shortest_path = dijkstra_shortest_path_v2(d, 1);
//
// TS_ASSERT_EQUALS ( shortest_path.first[1], 0 );
// TS_ASSERT_EQUALS ( shortest_path.first[2], 7 );
// TS_ASSERT_EQUALS ( shortest_path.first[3], 9 );
// TS_ASSERT_EQUALS ( shortest_path.first[4], 20 );
// TS_ASSERT_EQUALS ( shortest_path.first[5], 20 );
// TS_ASSERT_EQUALS ( shortest_path.first[6], 11 );
// TS_ASSERT_EQUALS ( shortest_path.first.size(), 6 );
//
// TS_ASSERT_EQUALS ( shortest_path.second[2], 1 );
// TS_ASSERT_EQUALS ( shortest_path.second[3], 1 );
// TS_ASSERT_EQUALS ( shortest_path.second[4], 3 );
// TS_ASSERT_EQUALS ( shortest_path.second[5], 6 );
// TS_ASSERT_EQUALS ( shortest_path.second[6], 3 );
// TS_ASSERT_EQUALS ( shortest_path.second.size(), 5 );
// }
//
// /// @todo put XML tests to another suite
// void test_read_from_XML()
// {
//
// GraphWD< std::pair<float, float> > g_xml = readGraphWD<float>("/home/denes/projects/graph/lib/graph/graph_example.xml");
// // for (std::pair<float, float> v : g_xml.vertices())
// // std::cout << TToStr(v) << std::endl;
// //
// // for (GraphWD< std::pair<float, float> >::Edge e : g_xml.edges())
// // std::cout << TToStr(e.source) << " -> " << TToStr(e.destination) << std::endl;
// }
// {
// std::vector< std::pair<float, float> > points = {
// {1, 1},
// };
// GraphWD< std::pair<float, float> > g_d = delaunay_triangulation(points);
// }
};

@ -0,0 +1,4 @@
#define CATCH_CONFIG_MAIN
#include "/home/denes/projects/Catch/single_include/catch.hpp"
#include "graph/test_graph.hpp"
Loading…
Cancel
Save