blob: ffa392d73f0e00d35238dbf1ac4ac872a84bc705 [file] [log] [blame]
// Copyright (c) 2016 The WebM project authors. All Rights Reserved.
//
// Use of this source code is governed by a BSD-style license
// that can be found in the LICENSE file in the root of the source
// tree. An additional intellectual property rights grant can be found
// in the file PATENTS. All contributing project authors may
// be found in the AUTHORS file in the root of the source tree.
#include "src/float_parser.h"
#include "gtest/gtest.h"
#include "test_utils/element_parser_test.h"
#include "webm/status.h"
using webm::ElementParserTest;
using webm::FloatParser;
using webm::kUnknownElementSize;
using webm::Status;
namespace {
class FloatParserTest : public ElementParserTest<FloatParser> {};
TEST_F(FloatParserTest, InvalidSize) {
TestInit(1, Status::kInvalidElementSize);
TestInit(5, Status::kInvalidElementSize);
TestInit(9, Status::kInvalidElementSize);
TestInit(kUnknownElementSize, Status::kInvalidElementSize);
}
TEST_F(FloatParserTest, CustomDefault) {
const double sqrt2 = 1.4142135623730951454746218587388284504413604736328125;
ResetParser(sqrt2);
ParseAndVerify();
EXPECT_EQ(sqrt2, parser_.value());
}
TEST_F(FloatParserTest, ValidFloat) {
ParseAndVerify();
EXPECT_EQ(0, parser_.value());
SetReaderData({0x40, 0xC9, 0x0F, 0xDB});
ParseAndVerify();
EXPECT_EQ(6.283185482025146484375, parser_.value());
SetReaderData({0x40, 0x05, 0xBF, 0x0A, 0x8B, 0x14, 0x57, 0x69});
ParseAndVerify();
EXPECT_EQ(2.718281828459045090795598298427648842334747314453125,
parser_.value());
}
TEST_F(FloatParserTest, IncrementalParse) {
SetReaderData({0x3F, 0xF9, 0xE3, 0x77, 0x9B, 0x97, 0xF4, 0xA8});
IncrementalParseAndVerify();
EXPECT_EQ(1.6180339887498949025257388711906969547271728515625,
parser_.value());
}
} // namespace