Index: media/base/bit_reader_unittest.cc |
diff --git a/media/base/bit_reader_unittest.cc b/media/base/bit_reader_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..61a5e7caea95d2566e246e34ec4ecf3f0b0b660d |
--- /dev/null |
+++ b/media/base/bit_reader_unittest.cc |
@@ -0,0 +1,101 @@ |
+// Copyright (c) 2012 The Chromium 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 "media/base/bit_reader.h" |
+ |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace media { |
+ |
+TEST(BitReaderTest, EmptyStreamTest) { |
+ uint8 value8 = 0xff; |
+ BitReader reader(NULL, 0); |
+ |
+ EXPECT_EQ(reader.NumBitsLeft(), 0); |
+ EXPECT_TRUE(reader.ReadBits(0, &value8)); |
+ EXPECT_TRUE(reader.SkipBits(0)); |
+ EXPECT_EQ(reader.NumBitsLeft(), 0); |
+ EXPECT_FALSE(reader.ReadBits(1, &value8)); |
+ EXPECT_FALSE(reader.SkipBits(1)); |
+ EXPECT_EQ(value8, 0); |
+} |
+ |
+TEST(BitReaderTest, NormalOperationTest) { |
+ uint8 value8; |
+ uint64 value64; |
+ // 0101 0101 1001 1001 repeats 4 times |
+ uint8 buffer[] = {0x55, 0x99, 0x55, 0x99, 0x55, 0x99, 0x55, 0x99}; |
+ BitReader reader1(buffer, 6); // Initialize with 6 bytes only |
+ |
+ EXPECT_EQ(reader1.NumBitsLeft(), 48); |
+ EXPECT_TRUE(reader1.ReadBits(1, &value8)); |
+ EXPECT_EQ(value8, 0); |
+ EXPECT_TRUE(reader1.ReadBits(8, &value8)); |
+ EXPECT_EQ(value8, 0xab); // 1010 1011 |
+ EXPECT_EQ(reader1.NumBitsLeft(), 39); |
+ EXPECT_TRUE(reader1.SkipBits(7)); |
+ EXPECT_TRUE(reader1.ReadBits(32, &value64)); |
+ EXPECT_EQ(value64, 0x55995599u); |
+ EXPECT_EQ(reader1.NumBitsLeft(), 0); |
+ EXPECT_FALSE(reader1.SkipBits(1)); |
+ EXPECT_FALSE(reader1.ReadBits(1, &value8)); |
+ EXPECT_TRUE(reader1.SkipBits(0)); |
+ value8 = 0xff; |
+ EXPECT_TRUE(reader1.ReadBits(0, &value8)); |
+ EXPECT_EQ(value8, 0); |
+ |
+ BitReader reader2(buffer, 8); |
+ EXPECT_TRUE(reader2.ReadBits(64, &value64)); |
+ EXPECT_EQ(value64, 0x5599559955995599ull); |
+ EXPECT_EQ(reader2.NumBitsLeft(), 0); |
+ EXPECT_FALSE(reader2.ReadBits(1, &value8)); |
+ EXPECT_FALSE(reader2.SkipBits(1)); |
+ EXPECT_TRUE(reader2.ReadBits(0, &value8)); |
+ EXPECT_TRUE(reader2.SkipBits(0)); |
+} |
+ |
+TEST(BitReaderTest, LongSkipTest) { |
+ uint8 value8; |
+ uint8 buffer[] = { |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 1 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 2 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 3 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 4 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 5 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 6 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 7 |
+ 0x12, 0x34, 0x56, 0x78, 0x12, 0x34, 0x56, 0x78, // 64 * 8 |
+ 0x87, 0x65 |
+ }; |
+ BitReader reader(buffer, sizeof(buffer)); |
+ |
+ EXPECT_TRUE(reader.SkipBits(64 * 8 + 8)); |
+ EXPECT_TRUE(reader.ReadBits(8, &value8)); |
+ EXPECT_EQ(value8, 0x65); |
+ EXPECT_EQ(reader.NumBitsLeft(), 0); |
+} |
+ |
+TEST(BitReaderTest, ReadBeyondEndTest) { |
+ uint8 value8; |
+ uint8 buffer[] = {0x12}; |
+ BitReader reader1(buffer, sizeof(buffer)); |
+ |
+ EXPECT_TRUE(reader1.SkipBits(4)); |
+ EXPECT_FALSE(reader1.ReadBits(5, &value8)); |
+ EXPECT_FALSE(reader1.ReadBits(1, &value8)); |
+ EXPECT_FALSE(reader1.SkipBits(1)); |
+ EXPECT_TRUE(reader1.ReadBits(0, &value8)); |
+ EXPECT_TRUE(reader1.SkipBits(0)); |
+ |
+ BitReader reader2(buffer, sizeof(buffer)); |
+ |
+ EXPECT_TRUE(reader2.SkipBits(4)); |
+ EXPECT_FALSE(reader2.SkipBits(5)); |
+ EXPECT_FALSE(reader2.ReadBits(1, &value8)); |
+ EXPECT_FALSE(reader2.SkipBits(1)); |
+ EXPECT_TRUE(reader2.ReadBits(0, &value8)); |
+ EXPECT_TRUE(reader2.SkipBits(0)); |
+} |
+ |
+} // namespace media |