blob: 00652c508a8a89ad26692065eabcccb6abfae044 [file] [log] [blame] [edit]
// Copyright 2018 PDFium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <limits>
#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<const TestCase> 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<int32_t>::min(), number.GetSigned());
}
{
FX_Number number("+2147483647");
EXPECT_TRUE(number.IsInteger());
EXPECT_TRUE(number.IsSigned());
EXPECT_EQ(std::numeric_limits<int32_t>::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());
}