NativeFormatTests.cpp 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. //===- llvm/unittest/Support/NativeFormatTests.cpp - formatting tests -----===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. #include "llvm/ADT/SmallString.h"
  9. #include "llvm/Support/NativeFormatting.h"
  10. #include "llvm/Support/raw_ostream.h"
  11. #include "gtest/gtest.h"
  12. #include <type_traits>
  13. using namespace llvm;
  14. namespace {
  15. template <typename T> std::string format_number(T N, IntegerStyle Style) {
  16. std::string S;
  17. llvm::raw_string_ostream Str(S);
  18. write_integer(Str, N, 0, Style);
  19. Str.flush();
  20. return S;
  21. }
  22. std::string format_number(uint64_t N, HexPrintStyle Style,
  23. Optional<size_t> Width = None) {
  24. std::string S;
  25. llvm::raw_string_ostream Str(S);
  26. write_hex(Str, N, Style, Width);
  27. Str.flush();
  28. return S;
  29. }
  30. std::string format_number(double D, FloatStyle Style,
  31. Optional<size_t> Precision = None) {
  32. std::string S;
  33. llvm::raw_string_ostream Str(S);
  34. write_double(Str, D, Style, Precision);
  35. Str.flush();
  36. return S;
  37. }
  38. // Test basic number formatting with various styles and default width and
  39. // precision.
  40. TEST(NativeFormatTest, BasicIntegerTests) {
  41. // Simple integers with no decimal.
  42. EXPECT_EQ("0", format_number(0, IntegerStyle::Integer));
  43. EXPECT_EQ("2425", format_number(2425, IntegerStyle::Integer));
  44. EXPECT_EQ("-2425", format_number(-2425, IntegerStyle::Integer));
  45. EXPECT_EQ("0", format_number(0LL, IntegerStyle::Integer));
  46. EXPECT_EQ("257257257235709",
  47. format_number(257257257235709LL, IntegerStyle::Integer));
  48. EXPECT_EQ("-257257257235709",
  49. format_number(-257257257235709LL, IntegerStyle::Integer));
  50. // Number formatting.
  51. EXPECT_EQ("0", format_number(0, IntegerStyle::Number));
  52. EXPECT_EQ("2,425", format_number(2425, IntegerStyle::Number));
  53. EXPECT_EQ("-2,425", format_number(-2425, IntegerStyle::Number));
  54. EXPECT_EQ("257,257,257,235,709",
  55. format_number(257257257235709LL, IntegerStyle::Number));
  56. EXPECT_EQ("-257,257,257,235,709",
  57. format_number(-257257257235709LL, IntegerStyle::Number));
  58. // Hex formatting.
  59. // lower case, prefix.
  60. EXPECT_EQ("0x0", format_number(0, HexPrintStyle::PrefixLower));
  61. EXPECT_EQ("0xbeef", format_number(0xbeefLL, HexPrintStyle::PrefixLower));
  62. EXPECT_EQ("0xdeadbeef",
  63. format_number(0xdeadbeefLL, HexPrintStyle::PrefixLower));
  64. // upper-case, prefix.
  65. EXPECT_EQ("0x0", format_number(0, HexPrintStyle::PrefixUpper));
  66. EXPECT_EQ("0xBEEF", format_number(0xbeefLL, HexPrintStyle::PrefixUpper));
  67. EXPECT_EQ("0xDEADBEEF",
  68. format_number(0xdeadbeefLL, HexPrintStyle::PrefixUpper));
  69. // lower-case, no prefix
  70. EXPECT_EQ("0", format_number(0, HexPrintStyle::Lower));
  71. EXPECT_EQ("beef", format_number(0xbeefLL, HexPrintStyle::Lower));
  72. EXPECT_EQ("deadbeef", format_number(0xdeadbeefLL, HexPrintStyle::Lower));
  73. // upper-case, no prefix.
  74. EXPECT_EQ("0", format_number(0, HexPrintStyle::Upper));
  75. EXPECT_EQ("BEEF", format_number(0xbeef, HexPrintStyle::Upper));
  76. EXPECT_EQ("DEADBEEF", format_number(0xdeadbeef, HexPrintStyle::Upper));
  77. }
  78. // Test basic floating point formatting with various styles and default width
  79. // and precision.
  80. TEST(NativeFormatTest, BasicFloatingPointTests) {
  81. // Double
  82. EXPECT_EQ("0.000000e+00", format_number(0.0, FloatStyle::Exponent));
  83. EXPECT_EQ("-0.000000e+00", format_number(-0.0, FloatStyle::Exponent));
  84. EXPECT_EQ("1.100000e+00", format_number(1.1, FloatStyle::Exponent));
  85. EXPECT_EQ("1.100000E+00", format_number(1.1, FloatStyle::ExponentUpper));
  86. // Default precision is 2 for floating points.
  87. EXPECT_EQ("1.10", format_number(1.1, FloatStyle::Fixed));
  88. EXPECT_EQ("1.34", format_number(1.34, FloatStyle::Fixed));
  89. EXPECT_EQ("1.34", format_number(1.344, FloatStyle::Fixed));
  90. EXPECT_EQ("1.35", format_number(1.346, FloatStyle::Fixed));
  91. }
  92. // Test common boundary cases and min/max conditions.
  93. TEST(NativeFormatTest, BoundaryTests) {
  94. // Min and max.
  95. EXPECT_EQ("18446744073709551615",
  96. format_number(UINT64_MAX, IntegerStyle::Integer));
  97. EXPECT_EQ("9223372036854775807",
  98. format_number(INT64_MAX, IntegerStyle::Integer));
  99. EXPECT_EQ("-9223372036854775808",
  100. format_number(INT64_MIN, IntegerStyle::Integer));
  101. EXPECT_EQ("4294967295", format_number(UINT32_MAX, IntegerStyle::Integer));
  102. EXPECT_EQ("2147483647", format_number(INT32_MAX, IntegerStyle::Integer));
  103. EXPECT_EQ("-2147483648", format_number(INT32_MIN, IntegerStyle::Integer));
  104. EXPECT_EQ("nan", format_number(std::numeric_limits<double>::quiet_NaN(),
  105. FloatStyle::Fixed));
  106. EXPECT_EQ("INF", format_number(std::numeric_limits<double>::infinity(),
  107. FloatStyle::Fixed));
  108. }
  109. TEST(NativeFormatTest, HexTests) {
  110. // Test hex formatting with different widths and precisions.
  111. // Width less than the value should print the full value anyway.
  112. EXPECT_EQ("0x0", format_number(0, HexPrintStyle::PrefixLower, 0));
  113. EXPECT_EQ("0xabcde", format_number(0xABCDE, HexPrintStyle::PrefixLower, 3));
  114. // Precision greater than the value should pad with 0s.
  115. // TODO: The prefix should not be counted in the precision. But unfortunately
  116. // it is and we have to live with it unless we fix all existing users of
  117. // prefixed hex formatting.
  118. EXPECT_EQ("0x000", format_number(0, HexPrintStyle::PrefixLower, 5));
  119. EXPECT_EQ("0x0abcde", format_number(0xABCDE, HexPrintStyle::PrefixLower, 8));
  120. EXPECT_EQ("00000", format_number(0, HexPrintStyle::Lower, 5));
  121. EXPECT_EQ("000abcde", format_number(0xABCDE, HexPrintStyle::Lower, 8));
  122. // Try printing more digits than can fit in a uint64.
  123. EXPECT_EQ("0x00000000000000abcde",
  124. format_number(0xABCDE, HexPrintStyle::PrefixLower, 21));
  125. }
  126. TEST(NativeFormatTest, IntegerTests) {
  127. EXPECT_EQ("-10", format_number(-10, IntegerStyle::Integer));
  128. EXPECT_EQ("-100", format_number(-100, IntegerStyle::Integer));
  129. EXPECT_EQ("-1000", format_number(-1000, IntegerStyle::Integer));
  130. EXPECT_EQ("-1234567890", format_number(-1234567890, IntegerStyle::Integer));
  131. EXPECT_EQ("10", format_number(10, IntegerStyle::Integer));
  132. EXPECT_EQ("100", format_number(100, IntegerStyle::Integer));
  133. EXPECT_EQ("1000", format_number(1000, IntegerStyle::Integer));
  134. EXPECT_EQ("1234567890", format_number(1234567890, IntegerStyle::Integer));
  135. }
  136. TEST(NativeFormatTest, CommaTests) {
  137. EXPECT_EQ("0", format_number(0, IntegerStyle::Number));
  138. EXPECT_EQ("10", format_number(10, IntegerStyle::Number));
  139. EXPECT_EQ("100", format_number(100, IntegerStyle::Number));
  140. EXPECT_EQ("1,000", format_number(1000, IntegerStyle::Number));
  141. EXPECT_EQ("1,234,567,890", format_number(1234567890, IntegerStyle::Number));
  142. EXPECT_EQ("-10", format_number(-10, IntegerStyle::Number));
  143. EXPECT_EQ("-100", format_number(-100, IntegerStyle::Number));
  144. EXPECT_EQ("-1,000", format_number(-1000, IntegerStyle::Number));
  145. EXPECT_EQ("-1,234,567,890", format_number(-1234567890, IntegerStyle::Number));
  146. }
  147. }