aboutsummaryrefslogtreecommitdiffstats
path: root/vespalib/src/tests/floatingpointtype/floatingpointtypetest.cpp
blob: 4b9718f119995943983ef61283f68c5f59fd0be4 (plain) (blame)
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
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.

#include <vespa/vespalib/gtest/gtest.h>
#include <vespa/vespalib/objects/floatingpointtype.h>

TEST(FloatingPointTypeTest, test_floating_point)
{
    vespalib::Double d1(1.0);
    vespalib::Double d2(1.000000000000001);
    vespalib::Double d3(-1.00000000000001);
    vespalib::Double d4(4.0);

    EXPECT_TRUE(d1.getValue() != d2.getValue());

    EXPECT_EQ(d1, d2);
    EXPECT_EQ(d2, d1);

    EXPECT_NE(d1, d3);
    EXPECT_NE(d1, d4);

    EXPECT_TRUE(d1 - d2 == 0);
    EXPECT_TRUE(d2 - d1 == 0);

    EXPECT_TRUE(d1 - 1 == 0);
    EXPECT_TRUE(d1 + 1 != 0);

    EXPECT_TRUE(d2 * d4 == 4.0);
    EXPECT_TRUE(d2 / d4 == 0.25);

    EXPECT_TRUE(d1 >= 1);
    EXPECT_TRUE(d1 <= 1);
    EXPECT_TRUE(!(d1 < 1));
    EXPECT_TRUE(!(d1 > 1));

    EXPECT_EQ(d2 * 4, d4);

    EXPECT_EQ(++d4, 5.0);
    EXPECT_EQ(d4++, 5.0);
    EXPECT_EQ(d4, 6.0);

    d4 /= 3;
    EXPECT_EQ(d4, 2.00000000001);
    d4 *= 2;
    EXPECT_EQ(d4, 4.000000000001);

    EXPECT_EQ(--d4, 3.0);
    EXPECT_EQ(d4--, 3.0);
    EXPECT_EQ(d4, 2.0);
    d4 /= 0.50000000001;

    EXPECT_EQ(d4, 4.0);

    EXPECT_TRUE(!(d3 + 1 > 0));
    EXPECT_TRUE(!(d3 + 1 < 0));
}

GTEST_MAIN_RUN_ALL_TESTS()