File: test-output-flex-way-add.cpp

package info (click to toggle)
osm2pgsql 1.4.1%2Bds-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 5,124 kB
  • sloc: cpp: 41,466; ansic: 1,366; python: 564; sh: 19; makefile: 15
file content (130 lines) | stat: -rw-r--r-- 4,384 bytes parent folder | download
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/**
 * SPDX-License-Identifier: GPL-2.0-or-later
 *
 * This file is part of osm2pgsql (https://osm2pgsql.org/).
 *
 * Copyright (C) 2006-2021 by the osm2pgsql developer community.
 * For a full list of authors see the git log.
 */

#include <catch.hpp>

#include "common-import.hpp"
#include "common-options.hpp"

static testing::db::import_t db;

static char const *const conf_file = "test_output_flex_way.lua";

static const char *const tdata[] = {
    "n10 v1 dV x10.0 y10.0",
    "n11 v1 dV x10.0 y10.1",
    "n12 v1 dV x10.1 y10.0",
    "n13 v1 dV x10.1 y10.1",
    "n14 v1 dV x10.2 y10.0",
    "n15 v1 dV x10.2 y10.1",
    "n16 v1 dV x10.3 y10.0",
    "n17 v1 dV x10.3 y10.1",
    "n18 v1 dV x10.4 y10.0",
    "n19 v1 dV x10.4 y10.1",
    "w11 v1 dV Tt1=yes Nn12,n13",
    "w12 v1 dV Tt2=yes Nn14,n15",
    "w13 v1 dV Ttboth=yes Nn16,n17",
    "w14 v1 dV Ttboth=yes Nn18,n19",
    "r30 v1 dV Tt=ag Mw11@,w12@mark,w13@,w14@mark"};

TEST_CASE("add way")
{
    options_t options = testing::opt_t().slim().flex(conf_file);

    testing::db::data_t data{tdata};

    REQUIRE_NOTHROW(db.run_import(options, data()));

    auto conn = db.db().connect();

    CHECK(1 == conn.get_count("osm2pgsql_test_t1"));
    CHECK(1 == conn.get_count("osm2pgsql_test_t2"));
    CHECK(2 == conn.get_count("osm2pgsql_test_tboth"));

    options.append = true;

    SECTION("way is not relevant")
    {
        REQUIRE_NOTHROW(db.run_import(
            options, "w10 v1 dV Tt=ag Nn10,n11\n"
                     "r30 v2 dV Tt=ag Mw10@,w11@,w12@mark,w13@,w14@mark\n"));

        CHECK(1 == conn.get_count("osm2pgsql_test_t1"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t2"));
        CHECK(2 == conn.get_count("osm2pgsql_test_tboth"));
    }

    SECTION("add to t1")
    {
        REQUIRE_NOTHROW(db.run_import(
            options, "w10 v1 dV Tt1=yes Nn10,n11\n"
                     "r30 v2 dV Tt=ag Mw10@,w11@,w12@mark,w13@,w14@mark\n"));

        CHECK(2 == conn.get_count("osm2pgsql_test_t1"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t1", "way_id = 10"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t2"));
        CHECK(2 == conn.get_count("osm2pgsql_test_tboth"));
    }

    SECTION("add to t2")
    {
        REQUIRE_NOTHROW(db.run_import(
            options,
            "w10 v1 dV Tt2=yes Nn10,n11\n"
            "r30 v2 dV Tt=ag Mw10@mark,w11@,w12@mark,w13@,w14@mark\n"));

        CHECK(1 == conn.get_count("osm2pgsql_test_t1"));
        CHECK(2 == conn.get_count("osm2pgsql_test_t2"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t2",
                                  "way_id = 10 AND rel_ids = '{30}'"));
        CHECK(2 == conn.get_count("osm2pgsql_test_tboth"));
    }

    SECTION("add to t1 and t2")
    {
        REQUIRE_NOTHROW(db.run_import(
            options,
            "w10 v1 dV Tt1=yes,t2=yes Nn10,n11\n"
            "r30 v2 dV Tt=ag Mw10@mark,w11@,w12@mark,w13@,w14@mark\n"));

        CHECK(2 == conn.get_count("osm2pgsql_test_t1"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t1", "way_id = 10"));
        CHECK(2 == conn.get_count("osm2pgsql_test_t2"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t2",
                                  "way_id = 10 AND rel_ids = '{30}'"));
        CHECK(2 == conn.get_count("osm2pgsql_test_tboth"));
    }

    SECTION("add to tboth (only stage1)")
    {
        REQUIRE_NOTHROW(db.run_import(
            options, "w10 v1 dV Ttboth=yes Nn10,n11\n"
                     "r30 v2 dV Tt=ag Mw10@,w11@,w12@mark,w13@,w14@mark\n"));

        CHECK(1 == conn.get_count("osm2pgsql_test_t1"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t2"));
        CHECK(3 == conn.get_count("osm2pgsql_test_tboth"));
        CHECK(1 == conn.get_count("osm2pgsql_test_tboth",
                                  "way_id = 10 AND rel_ids IS NULL"));
    }

    SECTION("add to tboth (stage1 and stage2)")
    {
        REQUIRE_NOTHROW(db.run_import(
            options,
            "w10 v1 dV Ttboth=yes Nn10,n11\n"
            "r30 v2 dV Tt=ag Mw10@mark,w11@,w12@mark,w13@,w14@mark\n"));

        CHECK(1 == conn.get_count("osm2pgsql_test_t1"));
        CHECK(1 == conn.get_count("osm2pgsql_test_t2"));
        CHECK(3 == conn.get_count("osm2pgsql_test_tboth"));
        CHECK(1 == conn.get_count("osm2pgsql_test_tboth",
                                  "way_id = 10 AND rel_ids = '{30}'"));
    }
}