File: RangeTest.cpp

package info (click to toggle)
xournalpp 1.3.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 30,036 kB
  • sloc: cpp: 64,137; xml: 939; sh: 752; ansic: 362; python: 338; php: 74; makefile: 15
file content (62 lines) | stat: -rw-r--r-- 2,050 bytes parent folder | download | duplicates (3)
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
#include <array>

#include <gtest/gtest.h>

#include "util/Range.h"

namespace {
struct TestData {
    TestData(const Range& rg, bool isEmpty, bool isValid): rg(rg), isEmpty(isEmpty), isValid(isValid) {}
    Range rg;
    bool isEmpty;
    bool isValid;
};

std::array<TestData, 5> testData = {
        //
        TestData(Range(), true, false),                      //
        TestData(Range(1.0, 0.0), false, true),              //
        TestData(Range(0.0, 0.0, 1.0, 1.0), false, true),    //
        TestData(Range(0.0, 0.0, -1.0, 1.0), false, false),  //
        TestData(Range(0.0, 0.0, 1.0, 0.0), false, true)     //
};

bool equal(const Range& r1, const Range& r2) {
    return r1.minX == r2.minX && r1.minY == r2.minY && r1.maxX == r2.maxX && r1.maxY == r2.maxY;
}
};  // namespace

TEST(UtilRange, testEmptyValid) {
    for (auto& d: testData) {
        EXPECT_EQ(d.rg.empty(), d.isEmpty);
        EXPECT_EQ(d.rg.isValid(), d.isValid);
    }
}

TEST(UtilRange, testUnite) {
    Range emptyRange;
    for (auto& d: testData) {
        EXPECT_TRUE(equal(d.rg.unite(emptyRange), d.rg));
    }

    // intersecting ranges
    EXPECT_TRUE(equal(Range(0.0, -1.0, 1.0, 2.0).unite(Range(0.5, 1.0, 0.6, 3.0)), Range(0.0, -1.0, 1.0, 3.0)));
    // subrange
    EXPECT_TRUE(equal(Range(0.0, -1.0, 1.0, 2.0).unite(Range(0.5, 1.0, 0.6, 1.5)), Range(0.0, -1.0, 1.0, 2.0)));
    // disjoint ranges
    EXPECT_TRUE(equal(Range(0.0, -1.0, 1.0, 2.0).unite(Range(1.5, 3.0, 2.0, 4.0)), Range(0.0, -1.0, 2.0, 4.0)));
}

TEST(UtilRange, testIntersect) {
    Range emptyRange;
    for (auto& d: testData) {
        EXPECT_TRUE(d.rg.intersect(emptyRange).empty());
    }

    // intersecting ranges
    EXPECT_TRUE(equal(Range(0.0, -1.0, 1.0, 2.0).intersect(Range(0.5, 1.0, 0.6, 3.0)), Range(0.5, 1.0, 0.6, 2.0)));
    // subrange
    EXPECT_TRUE(equal(Range(0.0, -1.0, 1.0, 2.0).intersect(Range(0.5, 1.0, 0.6, 1.5)), Range(0.5, 1.0, 0.6, 1.5)));
    // disjoint ranges
    EXPECT_TRUE(Range(0.0, -1.0, 1.0, 2.0).intersect(Range(1.5, 3.0, 2.0, 4.0)).empty());
}