xref: /llvm-project/compiler-rt/lib/nsan/tests/NSanUnitTest.cpp (revision ef83c25b0e56438d1697138915273dc71b8acf82)
1cae6d458SAlexander Shaposhnikov // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
2cae6d458SAlexander Shaposhnikov // See https://llvm.org/LICENSE.txt for license information.
3cae6d458SAlexander Shaposhnikov // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
4cae6d458SAlexander Shaposhnikov 
5cae6d458SAlexander Shaposhnikov // Do not attempt to use LLVM ostream etc from gtest.
6cae6d458SAlexander Shaposhnikov // #define GTEST_NO_LLVM_SUPPORT 1
7cae6d458SAlexander Shaposhnikov 
8cae6d458SAlexander Shaposhnikov #include "../nsan.h"
9cae6d458SAlexander Shaposhnikov #include "gtest/gtest.h"
10cae6d458SAlexander Shaposhnikov 
11cae6d458SAlexander Shaposhnikov #include <cmath>
12cae6d458SAlexander Shaposhnikov 
13cae6d458SAlexander Shaposhnikov namespace __nsan {
14cae6d458SAlexander Shaposhnikov 
TestFT()15cae6d458SAlexander Shaposhnikov template <typename FT, auto next> void TestFT() {
16cae6d458SAlexander Shaposhnikov   // Basic local tests anchored at 0.0.
17*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(0.0, 0.0), 0);
18*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(-0.0, 0.0), 0);
19*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(next(-0.0, -1.0), 0.0), 1);
20*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(next(0.0, 1.0), -0.0), 1);
21*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(next(-0.0, -1.0), next(0.0, 1.0)), 2);
22cae6d458SAlexander Shaposhnikov   // Basic local tests anchored at 2.0.
23*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(next(2.0, 1.0), 2.0), 1);
24*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(next(2.0, 3.0), 2.0), 1);
25*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(next(2.0, 1.0), next(2.0, 3.0)), 2);
26cae6d458SAlexander Shaposhnikov 
27*ef83c25bSFangrui Song   ASSERT_NE(GetULPDiff<FT>(-0.01, 0.01), kMaxULPDiff);
28cae6d458SAlexander Shaposhnikov 
29cae6d458SAlexander Shaposhnikov   // Basic local tests anchored at a random number.
30cae6d458SAlexander Shaposhnikov   const FT X = 4863.5123;
31cae6d458SAlexander Shaposhnikov   const FT To = 2 * X;
32cae6d458SAlexander Shaposhnikov   FT Y = X;
33*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(X, Y), 0);
34*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(-X, -Y), 0);
35cae6d458SAlexander Shaposhnikov   Y = next(Y, To);
36*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(X, Y), 1);
37*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(-X, -Y), 1);
38cae6d458SAlexander Shaposhnikov   Y = next(Y, To);
39*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(X, Y), 2);
40*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(-X, -Y), 2);
41cae6d458SAlexander Shaposhnikov   Y = next(Y, To);
42*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(X, Y), 3);
43*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(-X, -Y), 3);
44cae6d458SAlexander Shaposhnikov 
45cae6d458SAlexander Shaposhnikov   // Values with larger differences.
46cae6d458SAlexander Shaposhnikov   static constexpr const __sanitizer::u64 MantissaSize =
47cae6d458SAlexander Shaposhnikov       __sanitizer::u64{1} << FTInfo<FT>::kMantissaBits;
48*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(1.0, next(2.0, 1.0)), MantissaSize - 1);
49*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(1.0, 2.0), MantissaSize);
50*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(1.0, next(2.0, 3.0)), MantissaSize + 1);
51*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<FT>(1.0, 3.0), (3 * MantissaSize) / 2);
52cae6d458SAlexander Shaposhnikov }
53cae6d458SAlexander Shaposhnikov 
TEST(NSanTest,Float)54cae6d458SAlexander Shaposhnikov TEST(NSanTest, Float) { TestFT<float, nextafterf>(); }
55cae6d458SAlexander Shaposhnikov 
TEST(NSanTest,Double)56cae6d458SAlexander Shaposhnikov TEST(NSanTest, Double) {
57cae6d458SAlexander Shaposhnikov   TestFT<double, static_cast<double (*)(double, double)>(nextafter)>();
58cae6d458SAlexander Shaposhnikov }
59cae6d458SAlexander Shaposhnikov 
TEST(NSanTest,Float128)60cae6d458SAlexander Shaposhnikov TEST(NSanTest, Float128) {
61cae6d458SAlexander Shaposhnikov   // Very basic tests. FIXME: improve when we have nextafter<__float128>.
62*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<__float128>(0.0, 0.0), 0);
63*ef83c25bSFangrui Song   ASSERT_EQ(GetULPDiff<__float128>(-0.0, 0.0), 0);
64*ef83c25bSFangrui Song   ASSERT_NE(GetULPDiff<__float128>(-0.01, 0.01), kMaxULPDiff);
65cae6d458SAlexander Shaposhnikov }
66cae6d458SAlexander Shaposhnikov 
67cae6d458SAlexander Shaposhnikov } // end namespace __nsan
68