Add unit test for dynamic graph
Also simplify the unit tests.
This commit is contained in:
parent
94d7fd9112
commit
6d43d9f2b6
96
unit_tests/data_structures/dynamic_graph.cpp
Normal file
96
unit_tests/data_structures/dynamic_graph.cpp
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
/*
|
||||||
|
|
||||||
|
Copyright (c) 2014, Project OSRM contributors
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
Redistributions of source code must retain the above copyright notice, this list
|
||||||
|
of conditions and the following disclaimer.
|
||||||
|
Redistributions in binary form must reproduce the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer in the documentation and/or
|
||||||
|
other materials provided with the distribution.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "../../data_structures/dynamic_graph.hpp"
|
||||||
|
#include "../../util/make_unique.hpp"
|
||||||
|
#include "../../typedefs.h"
|
||||||
|
|
||||||
|
#include <boost/test/unit_test.hpp>
|
||||||
|
#include <boost/test/test_case_template.hpp>
|
||||||
|
#include <boost/mpl/list.hpp>
|
||||||
|
|
||||||
|
#include <random>
|
||||||
|
#include <unordered_map>
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_SUITE(dynamic_graph)
|
||||||
|
|
||||||
|
struct TestData
|
||||||
|
{
|
||||||
|
EdgeID id;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef DynamicGraph<TestData> TestDynamicGraph;
|
||||||
|
typedef TestDynamicGraph::InputEdge TestInputEdge;
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(find_test)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* (0) -1-> (1)
|
||||||
|
* ^ ^
|
||||||
|
* 2 5
|
||||||
|
* | |
|
||||||
|
* (3) -3-> (4)
|
||||||
|
* <-4-
|
||||||
|
*/
|
||||||
|
std::vector<TestInputEdge> input_edges = {
|
||||||
|
TestInputEdge{0, 1, TestData{1}},
|
||||||
|
TestInputEdge{3, 0, TestData{2}},
|
||||||
|
TestInputEdge{3, 4, TestData{3}},
|
||||||
|
TestInputEdge{4, 3, TestData{4}},
|
||||||
|
TestInputEdge{3, 0, TestData{5}}
|
||||||
|
};
|
||||||
|
TestDynamicGraph simple_graph(5, input_edges);
|
||||||
|
|
||||||
|
auto eit = simple_graph.FindEdge(0, 1);
|
||||||
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 1);
|
||||||
|
|
||||||
|
eit = simple_graph.FindEdge(1, 0);
|
||||||
|
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
||||||
|
|
||||||
|
eit = simple_graph.FindEdgeInEitherDirection(1, 0);
|
||||||
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 1);
|
||||||
|
|
||||||
|
bool reverse = false;
|
||||||
|
eit = simple_graph.FindEdgeIndicateIfReverse(1, 0, reverse);
|
||||||
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 1);
|
||||||
|
BOOST_CHECK(reverse);
|
||||||
|
|
||||||
|
eit = simple_graph.FindEdge(3, 1);
|
||||||
|
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
||||||
|
eit = simple_graph.FindEdge(0, 4);
|
||||||
|
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
||||||
|
|
||||||
|
eit = simple_graph.FindEdge(3, 4);
|
||||||
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 3);
|
||||||
|
eit = simple_graph.FindEdgeInEitherDirection(3, 4);
|
||||||
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 3);
|
||||||
|
|
||||||
|
eit = simple_graph.FindEdge(3, 0);
|
||||||
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_SUITE_END()
|
@ -40,15 +40,6 @@ BOOST_AUTO_TEST_SUITE(static_graph)
|
|||||||
struct TestData
|
struct TestData
|
||||||
{
|
{
|
||||||
EdgeID id;
|
EdgeID id;
|
||||||
bool shortcut;
|
|
||||||
unsigned distance;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct TestEdge
|
|
||||||
{
|
|
||||||
unsigned source;
|
|
||||||
unsigned target;
|
|
||||||
unsigned distance;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef StaticGraph<TestData> TestStaticGraph;
|
typedef StaticGraph<TestData> TestStaticGraph;
|
||||||
@ -58,7 +49,7 @@ typedef TestStaticGraph::InputEdge TestInputEdge;
|
|||||||
|
|
||||||
constexpr unsigned TEST_NUM_NODES = 100;
|
constexpr unsigned TEST_NUM_NODES = 100;
|
||||||
constexpr unsigned TEST_NUM_EDGES = 500;
|
constexpr unsigned TEST_NUM_EDGES = 500;
|
||||||
// Choosen by a fair W20 dice roll (this value is completely arbitrary)
|
// Chosen by a fair W20 dice roll (this value is completely arbitrary)
|
||||||
constexpr unsigned RANDOM_SEED = 15;
|
constexpr unsigned RANDOM_SEED = 15;
|
||||||
|
|
||||||
template <unsigned NUM_NODES, unsigned NUM_EDGES> struct RandomArrayEntryFixture
|
template <unsigned NUM_NODES, unsigned NUM_EDGES> struct RandomArrayEntryFixture
|
||||||
@ -94,8 +85,7 @@ template <unsigned NUM_NODES, unsigned NUM_EDGES> struct RandomArrayEntryFixture
|
|||||||
for (unsigned i = 0; i < NUM_EDGES; i++)
|
for (unsigned i = 0; i < NUM_EDGES; i++)
|
||||||
{
|
{
|
||||||
edges.emplace_back(
|
edges.emplace_back(
|
||||||
TestEdgeArrayEntry{static_cast<unsigned>(node_udist(g)),
|
TestEdgeArrayEntry{static_cast<unsigned>(node_udist(g)), TestData{i}});
|
||||||
TestData{i, false, static_cast<unsigned>(lengths_udist(g))}});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (unsigned i = 0; i < NUM_NODES; i++)
|
for (unsigned i = 0; i < NUM_NODES; i++)
|
||||||
@ -128,49 +118,37 @@ BOOST_FIXTURE_TEST_CASE(array_test, TestRandomArrayEntryFixture)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TestStaticGraph GraphFromEdgeList(const std::vector<TestEdge> &edges)
|
|
||||||
{
|
|
||||||
std::vector<TestInputEdge> input_edges;
|
|
||||||
unsigned i = 0;
|
|
||||||
unsigned num_nodes = 0;
|
|
||||||
for (const auto &e : edges)
|
|
||||||
{
|
|
||||||
input_edges.push_back(TestInputEdge{e.source, e.target, TestData{i++, false, e.distance}});
|
|
||||||
|
|
||||||
num_nodes = std::max(num_nodes, std::max(e.source, e.target));
|
|
||||||
}
|
|
||||||
|
|
||||||
return TestStaticGraph(num_nodes, input_edges);
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(find_test)
|
BOOST_AUTO_TEST_CASE(find_test)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* (0) -1-> (1)
|
* (0) -1-> (1)
|
||||||
* ^ ^
|
* ^ ^
|
||||||
* 2 1
|
* 2 5
|
||||||
* | |
|
* | |
|
||||||
* (3) -4-> (4)
|
* (3) -3-> (4)
|
||||||
* <-3-
|
* <-4-
|
||||||
*/
|
*/
|
||||||
TestStaticGraph simple_graph = GraphFromEdgeList({TestEdge{0, 1, 1},
|
std::vector<TestInputEdge> input_edges = {
|
||||||
TestEdge{3, 0, 2},
|
TestInputEdge{0, 1, TestData{1}},
|
||||||
TestEdge{3, 4, 4},
|
TestInputEdge{3, 0, TestData{2}},
|
||||||
TestEdge{4, 3, 3},
|
TestInputEdge{3, 4, TestData{3}},
|
||||||
TestEdge{3, 0, 1}});
|
TestInputEdge{4, 3, TestData{4}},
|
||||||
|
TestInputEdge{3, 0, TestData{5}}
|
||||||
|
};
|
||||||
|
TestStaticGraph simple_graph(5, input_edges);
|
||||||
|
|
||||||
auto eit = simple_graph.FindEdge(0, 1);
|
auto eit = simple_graph.FindEdge(0, 1);
|
||||||
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 0);
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 1);
|
||||||
|
|
||||||
eit = simple_graph.FindEdge(1, 0);
|
eit = simple_graph.FindEdge(1, 0);
|
||||||
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
||||||
|
|
||||||
eit = simple_graph.FindEdgeInEitherDirection(1, 0);
|
eit = simple_graph.FindEdgeInEitherDirection(1, 0);
|
||||||
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 0);
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 1);
|
||||||
|
|
||||||
bool reverse = false;
|
bool reverse = false;
|
||||||
eit = simple_graph.FindEdgeIndicateIfReverse(1, 0, reverse);
|
eit = simple_graph.FindEdgeIndicateIfReverse(1, 0, reverse);
|
||||||
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 0);
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 1);
|
||||||
BOOST_CHECK(reverse);
|
BOOST_CHECK(reverse);
|
||||||
|
|
||||||
eit = simple_graph.FindEdge(3, 1);
|
eit = simple_graph.FindEdge(3, 1);
|
||||||
@ -179,13 +157,12 @@ BOOST_AUTO_TEST_CASE(find_test)
|
|||||||
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
BOOST_CHECK_EQUAL(eit, SPECIAL_EDGEID);
|
||||||
|
|
||||||
eit = simple_graph.FindEdge(3, 4);
|
eit = simple_graph.FindEdge(3, 4);
|
||||||
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 2);
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 3);
|
||||||
eit = simple_graph.FindEdgeInEitherDirection(3, 4);
|
eit = simple_graph.FindEdgeInEitherDirection(3, 4);
|
||||||
// I think this is wrong behaviour! Should be 3.
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 3);
|
||||||
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 2);
|
|
||||||
|
|
||||||
eit = simple_graph.FindEdge(3, 0);
|
eit = simple_graph.FindEdge(3, 0);
|
||||||
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 4);
|
BOOST_CHECK_EQUAL(simple_graph.GetEdgeData(eit).id, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
Loading…
Reference in New Issue
Block a user