File: interval-test.cpp

package info (click to toggle)
lib2geom 1.4-5
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 6,124 kB
  • sloc: cpp: 64,251; python: 2,889; ansic: 1,963; makefile: 37
file content (108 lines) | stat: -rw-r--r-- 2,621 bytes parent folder | download | duplicates (4)
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
/** @file
 * @brief Unit tests for Interval, OptInterval, IntInterval, OptIntInterval.
 *//*
 * Authors:
 *   Thomas Holder
 *   PBS <pbs3141@gmail.com>
 *
 * Copyright 2021-2023 Authors
 *
 * SPDX-License-Identifier: LGPL-2.1 OR MPL-1.1
 */

#include <cassert>
#include <unordered_map>
#include <gtest/gtest.h>
#include <2geom/interval.h>

#define assert_true(x) assert(x)
#define assert_false(x) assert(!(x))

namespace Geom {

template <typename IntervalType, typename OptIntervalType>
constexpr bool equality_test()
{
    IntervalType a(3, 5), a2(a), a3, b(4, 7);
    OptIntervalType empty, oa = a, oa2;

    assert_true(a[X] == 3);
    assert_true(a[Y] == 5);
    assert_true(a == a);
    assert_false(a != a);
    assert_true(a == a2);
    assert_false(a != a2);
    a3 = a;
    assert_true(a == a3);
    assert_true(empty == empty);
    assert_false(empty != empty);
    assert_false(a == empty);
    assert_true(a != empty);
    assert_false(empty == a);
    assert_true(empty != a);
    assert_false(a == b);
    assert_true(a != b);
    assert_true(a == oa);
    assert_false(a != oa);
    oa2 = oa;
    assert_true(oa2 == oa);

    return true;
}

TEST(IntervalTest, EqualityTest)
{
    constexpr bool results[] = { equality_test<Interval, OptInterval>(),
                                 equality_test<IntInterval, OptIntInterval>() };
}

template <typename IntervalType>
constexpr bool structured_binding_test()
{
    auto a = IntervalType(1, 2);

    // Check unpacking the endpoints works.
    {
        auto [x, y] = a;
        assert_true(a[X] == x);
        assert_true(a[Y] == y);
    }

    // Ensure interval is read-only.
    {
        auto &[x, y] = a;
        assert_true(a[X] == x);
        assert_true(a[Y] == y);
        x = 3;
        y = 4;
        assert_true(a == IntervalType(1, 2));
    }

    return true;
}

TEST(IntervalTest, StructuredBindingTest)
{
    constexpr bool results[] = { structured_binding_test<Interval>(),
                                 structured_binding_test<IntInterval>() };
}

TEST(IntervalTest, Hash)
{
    auto test = [] <typename IntervalType> {
        std::unordered_map<IntervalType, int> map;
        map[IntervalType(1, 1)] = 1;
        map[IntervalType(1, 2)] = 2;
        map[IntervalType(2, 2)] = 3;
        EXPECT_EQ(map[IntervalType(1, 1)], 1);
        EXPECT_EQ(map[IntervalType(1, 2)], 2);
        EXPECT_EQ(map[IntervalType(2, 2)], 3);
    };

    test.template operator()<Interval>();
    test.template operator()<IntInterval>();
}

} // namespace Geom

// vim: filetype=cpp:expandtab:shiftwidth=4:softtabstop=4:fileencoding=utf-8:textwidth=99 :