Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1223)

Unified Diff: media/base/bit_reader_unittest.cc

Issue 10780026: Add HE AAC support to ISO BMFF. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Remove WARN_UNUSED_RESULT on template function. Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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..48e8c5eac11fce366c5a2325780688f0c880aaff
--- /dev/null
+++ b/media/base/bit_reader_unittest.cc
@@ -0,0 +1,48 @@
+// 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, 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_TRUE(reader1.ReadBits(1, &value8));
+ EXPECT_EQ(value8, 0);
+ EXPECT_TRUE(reader1.ReadBits(8, &value8));
+ EXPECT_EQ(value8, 0xab); // 1010 1011
+ EXPECT_TRUE(reader1.ReadBits(7, &value64));
+ EXPECT_TRUE(reader1.ReadBits(32, &value64));
+ EXPECT_EQ(value64, 0x55995599u);
+ EXPECT_FALSE(reader1.ReadBits(1, &value8));
+ 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_FALSE(reader2.ReadBits(1, &value8));
+ EXPECT_TRUE(reader2.ReadBits(0, &value8));
+}
+
+TEST(BitReaderTest, ReadBeyondEndTest) {
+ uint8 value8;
+ uint8 buffer[] = {0x12};
+ BitReader reader1(buffer, sizeof(buffer));
+
+ EXPECT_TRUE(reader1.ReadBits(4, &value8));
+ EXPECT_FALSE(reader1.ReadBits(5, &value8));
+ EXPECT_FALSE(reader1.ReadBits(1, &value8));
+ EXPECT_TRUE(reader1.ReadBits(0, &value8));
+}
+
+} // namespace media
« media/base/bit_reader.cc ('K') | « media/base/bit_reader.cc ('k') | media/media.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698