// 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 {}; 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