File: test-101.cpp

package info (click to toggle)
libosmium 2.22.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,544 kB
  • sloc: cpp: 52,804; sh: 148; makefile: 19
file content (42 lines) | stat: -rw-r--r-- 1,259 bytes parent folder | download | duplicates (6)
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

#include <stdexcept>

#include "common.hpp"

class TestHandler101 : public osmium::handler::Handler {

public:

    TestHandler101() :
        osmium::handler::Handler() {
    }

    void node(const osmium::Node& node) const {
        constexpr const double epsilon = 0.00000001;
        if (node.id() == 101000) {
            REQUIRE(node.version() == 1);
            REQUIRE(node.location().lon() == Approx(1.12).epsilon(epsilon));
            REQUIRE(node.location().lat() == Approx(1.02).epsilon(epsilon));
        } else if (node.id() == 101001) {
            REQUIRE(node.version() == 1);
            REQUIRE(node.location().lon() == Approx(1.12).epsilon(epsilon));
            REQUIRE(node.location().lat() == Approx(1.03).epsilon(epsilon));
        } else if (node.id() == 101002) {
        } else if (node.id() == 101003) {
        } else {
            throw std::runtime_error{"Unknown ID"};
        }
    }

}; // class TestHandler101

TEST_CASE("101") {
    osmium::io::Reader reader{dirname + "/1/101/data.osm"};

    CheckBasicsHandler check_basics_handler{101, 4, 0, 0};
    CheckWKTHandler check_wkt_handler{dirname, 101};
    TestHandler101 test_handler;

    osmium::apply(reader, check_basics_handler, check_wkt_handler, test_handler);
}