Index: content/common/gpu/media/h264_bit_reader_unittest.cc |
diff --git a/content/common/gpu/media/h264_bit_reader_unittest.cc b/content/common/gpu/media/h264_bit_reader_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..73f36b0cbb8e76c33c6a6a703fbb13eec99d825e |
--- /dev/null |
+++ b/content/common/gpu/media/h264_bit_reader_unittest.cc |
@@ -0,0 +1,148 @@ |
+// 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 "testing/gtest/include/gtest/gtest.h" |
+ |
+#include "content/common/gpu/media/h264_bit_reader.h" |
+ |
+using content::H264BitReader; |
+ |
+TEST(H264BitReaderTest, ReadStreamWithoutEscapeAndTrailingZeroBytes) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xa0}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, sizeof(rbsp))); |
+ |
+ EXPECT_TRUE(reader.ReadBits(1, &dummy)); |
+ EXPECT_EQ(dummy, 0x00); |
+ EXPECT_EQ(reader.NumBitsLeft(), 47); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(8, &dummy)); |
+ EXPECT_EQ(dummy, 0x02); |
+ EXPECT_EQ(reader.NumBitsLeft(), 39); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(31, &dummy)); |
+ EXPECT_EQ(dummy, 0x23456789); |
+ EXPECT_EQ(reader.NumBitsLeft(), 8); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(1, &dummy)); |
+ EXPECT_EQ(dummy, 1); |
+ EXPECT_EQ(reader.NumBitsLeft(), 7); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(1, &dummy)); |
+ EXPECT_EQ(dummy, 0); |
+ EXPECT_EQ(reader.NumBitsLeft(), 6); |
+ EXPECT_FALSE(reader.HasMoreRBSPData()); |
+} |
+ |
+TEST(H264BitReaderTest, EmptyStream) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0x80, 0x00, 0x00}; |
+ |
+ EXPECT_FALSE(reader.Initialize(rbsp, 0)); |
+ EXPECT_FALSE(reader.Initialize(rbsp, 1)); |
Pawel Osciak
2012/08/01 02:04:37
Why should this be false?
Ami GONE FROM CHROMIUM
2012/09/01 13:32:45
How did this test ever pass?? AFAICT from this CL
|
+ EXPECT_FALSE(reader.Initialize(rbsp, sizeof(rbsp))); |
Pawel Osciak
2012/08/01 02:04:37
And this?
|
+} |
+ |
+TEST(H264BitReaderTest, SingleByteStream) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0x18}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, sizeof(rbsp))); |
+ EXPECT_EQ(reader.NumBitsLeft(), 8); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(4, &dummy)); |
+ EXPECT_EQ(dummy, 0x01); |
+ EXPECT_EQ(reader.NumBitsLeft(), 4); |
+ EXPECT_FALSE(reader.HasMoreRBSPData()); |
+} |
+ |
+TEST(H264BitReaderTest, StopBitOccupyFullByte) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0xab, 0x80}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, sizeof(rbsp))); |
+ EXPECT_EQ(reader.NumBitsLeft(), 16); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(8, &dummy)); |
+ EXPECT_EQ(dummy, 0xab); |
+ EXPECT_EQ(reader.NumBitsLeft(), 8); |
+ EXPECT_FALSE(reader.HasMoreRBSPData()); |
+} |
+ |
+TEST(H264BitReaderTest, ReadFailure) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0x18}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, 1)); |
+ EXPECT_FALSE(reader.ReadBits(5, &dummy)); |
+} |
+ |
+TEST(H264BitReaderTest, MalformedStream) { |
+ const unsigned char rbsp[] = {0x00, 0x00, 0x03, 0x00, 0x00}; |
+ H264BitReader reader; |
+ |
+ EXPECT_FALSE(reader.Initialize(rbsp, 1)); |
+ EXPECT_FALSE(reader.Initialize(rbsp, sizeof(rbsp))); |
+} |
+ |
+TEST(H264BitReaderTest, EscapeSequence) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = |
+ {0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x03, 0x03, 0x00, 0x00, 0x03}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, sizeof(rbsp))); |
+ |
+ EXPECT_TRUE(reader.ReadBits(8, &dummy)); |
+ EXPECT_EQ(dummy, 0x00); |
+ EXPECT_EQ(reader.NumBitsLeft(), 80); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(24, &dummy)); |
+ EXPECT_EQ(dummy, 0x00); |
+ EXPECT_EQ(reader.NumBitsLeft(), 48); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ |
+ EXPECT_TRUE(reader.ReadBits(15, &dummy)); |
+ EXPECT_EQ(dummy, 0x01); |
+ EXPECT_EQ(reader.NumBitsLeft(), 25); |
+ EXPECT_FALSE(reader.HasMoreRBSPData()); |
Pawel Osciak
2012/08/01 02:04:37
This I'm assuming is where the current parser woul
|
+} |
+ |
+TEST(H264BitReaderTest, NonEscapeFollowedByStopBit) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x00}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, sizeof(rbsp))); |
+ EXPECT_TRUE(reader.ReadBits(23, &dummy)); |
+ EXPECT_EQ(dummy, 0x03); |
+ EXPECT_EQ(reader.NumBitsLeft(), 33); |
+ EXPECT_FALSE(reader.HasMoreRBSPData()); |
Pawel Osciak
2012/08/01 02:04:37
And here.
|
+} |
+ |
+TEST(H264BitReaderTest, TrailingZero) { |
+ H264BitReader reader; |
+ const unsigned char rbsp[] = {0x01, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00}; |
+ int dummy = 0; |
+ |
+ EXPECT_TRUE(reader.Initialize(rbsp, sizeof(rbsp))); |
+ EXPECT_TRUE(reader.ReadBits(8, &dummy)); |
+ EXPECT_EQ(dummy, 0x01); |
+ EXPECT_TRUE(reader.HasMoreRBSPData()); |
+ EXPECT_TRUE(reader.ReadBits(15, &dummy)); |
+ EXPECT_EQ(dummy, 0x01); |
+ EXPECT_FALSE(reader.HasMoreRBSPData()); |
Pawel Osciak
2012/08/01 02:04:37
Here as well.
|
+} |