// Copyright 2018 The PDFium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include #include "core/fxcrt/fx_number.h" #include "testing/gtest/include/gtest/gtest.h" TEST(fxnumber, Default) { FX_Number number; EXPECT_TRUE(number.IsInteger()); EXPECT_FALSE(number.IsSigned()); EXPECT_EQ(0, number.GetSigned()); EXPECT_FLOAT_EQ(0.0f, number.GetFloat()); } TEST(fxnumber, FromSigned) { FX_Number number(-128); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(-128, number.GetSigned()); EXPECT_FLOAT_EQ(-128.0f, number.GetFloat()); // Show that assignment works. FX_Number number2 = number; EXPECT_TRUE(number2.IsInteger()); EXPECT_TRUE(number2.IsSigned()); EXPECT_EQ(-128, number2.GetSigned()); EXPECT_FLOAT_EQ(-128.0f, number2.GetFloat()); } TEST(fxnumber, FromFloat) { FX_Number number(-100.001f); EXPECT_FALSE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(-100, number.GetSigned()); EXPECT_FLOAT_EQ(-100.001f, number.GetFloat()); // Show that assignment works. FX_Number number2 = number; EXPECT_FALSE(number2.IsInteger()); EXPECT_TRUE(number2.IsSigned()); EXPECT_EQ(-100, number2.GetSigned()); EXPECT_FLOAT_EQ(-100.001f, number2.GetFloat()); } TEST(fxnumber, FromStringUnsigned) { struct TestCase { const char* input; int expected_output; }; auto test_func = [](pdfium::span test_cases) { for (const auto& test : test_cases) { FX_Number number(test.input); EXPECT_TRUE(number.IsInteger()); EXPECT_FALSE(number.IsSigned()); EXPECT_EQ(test.expected_output, number.GetSigned()); } }; static constexpr TestCase kNormalCases[] = { {"", 0}, {"0", 0}, {"10", 10}, }; test_func(kNormalCases); static constexpr TestCase kOverflowCases[] = { {"4223423494965252", 0}, {"4294967296", 0}, {"4294967297", 0}, {"5000000000", 0}, }; test_func(kOverflowCases); // No explicit sign will allow the number to go negative if retrieved as a // signed value. This is needed for things like the encryption permissions // flag (Table 3.20 PDF 1.7 spec) static constexpr TestCase kNegativeCases[] = { {"4294965252", -2044}, {"4294967247", -49}, {"4294967248", -48}, {"4294967292", -4}, {"4294967295", -1}, }; test_func(kNegativeCases); } TEST(fxnumber, FromStringSigned) { { FX_Number number("-0"); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(0, number.GetSigned()); } { FX_Number number("+0"); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(0, number.GetSigned()); } { FX_Number number("-10"); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(-10, number.GetSigned()); } { FX_Number number("+10"); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(10, number.GetSigned()); } { FX_Number number("-2147483648"); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(std::numeric_limits::min(), number.GetSigned()); } { FX_Number number("+2147483647"); EXPECT_TRUE(number.IsInteger()); EXPECT_TRUE(number.IsSigned()); EXPECT_EQ(std::numeric_limits::max(), number.GetSigned()); } { // Value underflows. FX_Number number("-2147483649"); EXPECT_EQ(0, number.GetSigned()); } { // Value overflows. FX_Number number("+2147483648"); EXPECT_EQ(0, number.GetSigned()); } } TEST(fxnumber, FromStringFloat) { FX_Number number("3.24"); EXPECT_FLOAT_EQ(3.24f, number.GetFloat()); }