blob: e4e185cb99d7ed9d70693c5d8ff12e69a5168daa (
plain)
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
|
#include "turns/domain/participant.hpp"
#include "turns/domain/disposition.hpp"
#include <catch2/catch_test_macros.hpp>
#include <compare>
#include <glibmm/init.h>
namespace turns::domain::tests
{
TEST_CASE("A freshly constructed participant")
{
auto constexpr constructed_name = "Vana Thistletop";
auto constexpr constructed_priority = 17;
auto constexpr constructed_disposition = disposition::friendly;
auto instance = participant{constructed_name, constructed_priority, constructed_disposition};
SECTION("can be created")
{
REQUIRE(participant::create(constructed_name, constructed_priority, constructed_disposition));
}
SECTION("allows access to its disposition")
{
SECTION("allowing to get it")
{
REQUIRE(instance.disposition() == constructed_disposition);
}
SECTION("allowing to get it via a constant object")
{
auto const & cref = instance;
REQUIRE(cref.disposition() == constructed_disposition);
}
SECTION("allowing to set it")
{
instance.disposition() = disposition::hostile;
REQUIRE(instance.disposition() == disposition::hostile);
}
}
SECTION("allows access to its name")
{
SECTION("allowing to get it")
{
REQUIRE(instance.name() == constructed_name);
}
SECTION("allowing to get it via a constant object")
{
auto const & cref = instance;
REQUIRE(cref.name() == constructed_name);
}
SECTION("allowing to set it")
{
instance.name() = "replaced";
REQUIRE(instance.name() == "replaced");
}
}
SECTION("allows access to its priority")
{
SECTION("allowing to get it")
{
REQUIRE(instance.priority() == constructed_priority);
}
SECTION("allowing to get it via a constant object")
{
auto const & cref = instance;
REQUIRE(cref.priority() == constructed_priority);
}
SECTION("allowing to set it")
{
instance.priority() = 4;
REQUIRE(instance.priority() == 4);
}
}
SECTION("can be compared with another participant")
{
auto equivalent_instance = participant{"Equivalent", constructed_priority, constructed_disposition};
auto lesser_instance = participant{"Lesser", constructed_priority - 1, constructed_disposition};
auto greater_instance = participant{"Greater", constructed_priority + 1, constructed_disposition};
SECTION("yielding std::partial_ordering::equivalent for itself")
{
REQUIRE((instance <=> equivalent_instance) == std::partial_ordering::equivalent);
}
SECTION("yielding std::partial_ordering::equivalent for an equivalent participant")
{
REQUIRE((instance <=> equivalent_instance) == std::partial_ordering::equivalent);
}
SECTION("yielding std::partial_ordering::greater for a lesser participant")
{
REQUIRE((instance <=> lesser_instance) == std::partial_ordering::greater);
}
SECTION("yielding std::partial_ordering::less for a greater participant")
{
REQUIRE((instance <=> greater_instance) == std::partial_ordering::less);
}
}
}
} // namespace turns::domain::tests
|