aboutsummaryrefslogtreecommitdiff
path: root/libc/test/include/IsNormalTest.h
blob: 5e74efa139e056a679ec0a49c534fc948c7101e9 (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
//===-- Utility class to test the isnormal macro  ---------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

#ifndef LLVM_LIBC_TEST_INCLUDE_MATH_ISNORMAL_H
#define LLVM_LIBC_TEST_INCLUDE_MATH_ISNORMAL_H

#include "test/UnitTest/FPMatcher.h"
#include "test/UnitTest/Test.h"

#include "include/llvm-libc-macros/math-function-macros.h"

template <typename T>
class IsNormalTest : public LIBC_NAMESPACE::testing::Test {
  DECLARE_SPECIAL_CONSTANTS(T)

public:
  typedef int (*IsNormalFunc)(T);

  void testSpecialNumbers(IsNormalFunc func) {
    EXPECT_EQ(func(aNaN), 0);
    EXPECT_EQ(func(neg_aNaN), 0);
    EXPECT_EQ(func(sNaN), 0);
    EXPECT_EQ(func(neg_sNaN), 0);
    EXPECT_EQ(func(inf), 0);
    EXPECT_EQ(func(neg_inf), 0);
    EXPECT_EQ(func(min_normal), 1);
    EXPECT_EQ(func(max_normal), 1);
    EXPECT_EQ(func(neg_max_normal), 1);
    EXPECT_EQ(func(min_denormal), 0);
    EXPECT_EQ(func(neg_min_denormal), 0);
    EXPECT_EQ(func(max_denormal), 0);
    EXPECT_EQ(func(zero), 0);
    EXPECT_EQ(func(neg_zero), 0);
  }
};

#define LIST_ISNORMAL_TESTS(T, func)                                           \
  using LlvmLibcIsNormalTest = IsNormalTest<T>;                                \
  TEST_F(LlvmLibcIsNormalTest, SpecialNumbers) {                               \
    auto isnormal_func = [](T x) { return func(x); };                          \
    testSpecialNumbers(isnormal_func);                                         \
  }

#endif // LLVM_LIBC_TEST_INCLUDE_MATH_ISNORMAL_H