summaryrefslogtreecommitdiff
path: root/vendor/bandit/specs/matchers/be_close_to.cpp
blob: 6430967388ccf5836b943002b4f9465183e67894 (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
#include <specs/specs.h>

using namespace bandit::Matchers;

SPEC_BEGIN(Matchers::BeCloseTo)

describe("be_close_to matcher", []{
    describe("when the actual value is declared as a float", [&]{
        float actualValue = 2.0 / 3.0;

        describe("and the expected value is also a float", [&]{
            float expectedValue;

            describe("with an explicit threshold", [&]{
                float threshold = 0.1;

                describe("and the values are within the given threshold", [&]{
                    before_each([&]{
                        expectedValue = 2.0 / 3.0 + 0.01;
                    });

		    it("must accept a positive match", [&]{
			actualValue must be_close_to(expectedValue).within(threshold);
		    });

		    it("must reject a negative match", [&]{
			AssertThrows(std::exception, [&]{ actualValue must_not be_close_to(expectedValue).within(threshold); }());
		    });
                });

                describe("and the values are not within the given threshold", [&]{
                    before_each([&]{
                        expectedValue = 2.0 / 3.0 + 0.2;
                    });

		    it("must accept a negative match", [&]{
			actualValue must_not be_close_to(expectedValue).within(threshold);
		    });

		    it("must reject a positive match", [&]{
			AssertThrows(std::exception, [&]{ actualValue must be_close_to(expectedValue).within(threshold); }());
		    });
                });
            });

            describe("without an explicit threshold", [&]{
                describe("and the values are within the default threshold", [&]{
                    before_each([&]{
                        expectedValue = 2.0 / 3.0 + 0.000001;
                    });

		    it("must accept a positive match", [&]{
			actualValue must be_close_to(expectedValue);
		    });

		    it("must reject a negative match", [&]{
			AssertThrows(std::exception, [&]{ actualValue must_not be_close_to(expectedValue); }());
		    });
                });

                describe("and the values are not within the default threshold", [&]{
                    before_each([&]{
                        expectedValue = 2.0 / 3.0 + 0.1;
                    });

		    it("must accept a negative match", [&]{
			actualValue must_not be_close_to(expectedValue);
		    });

		    it("must reject a positive match", [&]{
			AssertThrows(std::exception, [&]{ actualValue must be_close_to(expectedValue); }());
		    });
                });
            });
        });

        describe("and the expected value is a compatible non-float type", [&]{
            int expectedValue;
            float threshold = 1;

            describe("and the values are within the given threshold", [&]{
                before_each([&]{
                    expectedValue = 1;
                });

		it("must accept a positive match", [&]{
		    actualValue must be_close_to(expectedValue).within(threshold);
		});

		it("must reject a negative match", [&]{
		    AssertThrows(std::exception, [&]{ actualValue must_not be_close_to(expectedValue).within(threshold); }());
		});
            });

            describe("and the values are not within the given threshold", [&]{
                before_each([&]{
                    expectedValue = 5;
                });

		it("must accept a negative match", [&]{
		    actualValue must_not be_close_to(expectedValue).within(threshold);
		});

		it("must reject a positive match", [&]{
		    AssertThrows(std::exception, [&]{ actualValue must be_close_to(expectedValue).within(threshold); }());
		});
            });
        });
    });
});

SPEC_END