diff options
author | xiaomings@google.com <xiaomings@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-07-06 21:59:25 +0000 |
---|---|---|
committer | xiaomings@google.com <xiaomings@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-07-06 21:59:25 +0000 |
commit | 0b27daac396b790fcc5f7366465e27dd2b9f91f3 (patch) | |
tree | ca510596e4c40c316bcb63e9396990eee7d28f12 /media/base/bit_reader_unittest.cc | |
parent | 2c1e6e5a9eeb002ec26b23e7d9d86ca795f240b1 (diff) | |
download | chromium_src-0b27daac396b790fcc5f7366465e27dd2b9f91f3.zip chromium_src-0b27daac396b790fcc5f7366465e27dd2b9f91f3.tar.gz chromium_src-0b27daac396b790fcc5f7366465e27dd2b9f91f3.tar.bz2 |
Add HE AAC support to ISO BMFF.
1. Parse esds box to get HE AAC config.
2. Send audio config from AAC header to decoder instead of the one embedded in SampleDescription.
3. Convert raw audio data into ADTS before sending to decoder.
4. Abstract general bit stream code from H264BitReader into media::BitReader.
BUG=134445
TEST=BitReaderTest, AACTest
Review URL: https://chromiumcodereview.appspot.com/10710002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@145617 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'media/base/bit_reader_unittest.cc')
-rw-r--r-- | media/base/bit_reader_unittest.cc | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/media/base/bit_reader_unittest.cc b/media/base/bit_reader_unittest.cc new file mode 100644 index 0000000..00d425f --- /dev/null +++ b/media/base/bit_reader_unittest.cc @@ -0,0 +1,110 @@ +// 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) { + BitReader reader(NULL, 0); + uint8 value8 = 0xff; + + ASSERT_FALSE(reader.HasMoreData()); + ASSERT_EQ(reader.Tell(), 0); + ASSERT_TRUE(reader.ReadBits(0, &value8)); + ASSERT_TRUE(reader.SkipBits(0)); + ASSERT_EQ(reader.Tell(), 0); + ASSERT_FALSE(reader.HasMoreData()); + ASSERT_FALSE(reader.ReadBits(1, &value8)); + ASSERT_FALSE(reader.SkipBits(1)); + ASSERT_EQ(value8, 0); +} + +TEST(BitReaderTest, NormalOperationTest) { + // 0101 0101 1001 1001 repeats 4 times + uint8 buffer[] = {0x55, 0x99, 0x55, 0x99, 0x55, 0x99, 0x55, 0x99}; + BitReader reader(buffer, 6); // Initialize with 6 bytes only + uint8 value8; + uint64 value64; + + ASSERT_TRUE(reader.HasMoreData()); + ASSERT_EQ(reader.Tell(), 0); + ASSERT_TRUE(reader.ReadBits(1, &value8)); + ASSERT_EQ(value8, 0); + ASSERT_TRUE(reader.ReadBits(8, &value8)); + ASSERT_EQ(value8, 0xab); // 1010 1011 + ASSERT_EQ(reader.Tell(), 9); + ASSERT_TRUE(reader.HasMoreData()); + ASSERT_TRUE(reader.SkipBits(7)); + ASSERT_EQ(reader.Tell(), 16); + ASSERT_TRUE(reader.ReadBits(32, &value64)); + ASSERT_EQ(value64, 0x55995599u); + ASSERT_EQ(reader.Tell(), 48); + ASSERT_FALSE(reader.HasMoreData()); + ASSERT_FALSE(reader.SkipBits(1)); + ASSERT_FALSE(reader.ReadBits(1, &value8)); + ASSERT_TRUE(reader.SkipBits(0)); + value8 = 0xff; + ASSERT_TRUE(reader.ReadBits(0, &value8)); + ASSERT_EQ(value8, 0); + + reader.Initialize(buffer, 8); + ASSERT_TRUE(reader.ReadBits(64, &value64)); + EXPECT_EQ(value64, 0x5599559955995599ull); + EXPECT_FALSE(reader.HasMoreData()); + EXPECT_EQ(reader.Tell(), 64); + EXPECT_FALSE(reader.ReadBits(1, &value8)); + EXPECT_FALSE(reader.SkipBits(1)); + EXPECT_TRUE(reader.ReadBits(0, &value8)); + EXPECT_TRUE(reader.SkipBits(0)); +} + +TEST(BitReaderTest, LongSkipTest) { + 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)); + uint8 value8; + + EXPECT_TRUE(reader.SkipBits(64 * 8 + 8)); + EXPECT_EQ(reader.Tell(), 64 * 8 + 8); + EXPECT_TRUE(reader.ReadBits(8, &value8)); + EXPECT_EQ(value8, 0x65); + EXPECT_EQ(reader.Tell(), 64 * 8 + 16); + EXPECT_FALSE(reader.HasMoreData()); + EXPECT_EQ(reader.NumBitsLeft(), 0); +} + +TEST(BitReaderTest, ReadBeyondEndTest) { + uint8 buffer[] = {0x12}; + BitReader reader(buffer, sizeof(buffer)); + uint8 value8; + + EXPECT_TRUE(reader.SkipBits(4)); + EXPECT_FALSE(reader.ReadBits(5, &value8)); + EXPECT_FALSE(reader.ReadBits(1, &value8)); + EXPECT_FALSE(reader.SkipBits(1)); + EXPECT_TRUE(reader.ReadBits(0, &value8)); + EXPECT_TRUE(reader.SkipBits(0)); + + reader.Initialize(buffer, sizeof(buffer)); + EXPECT_TRUE(reader.SkipBits(4)); + EXPECT_FALSE(reader.SkipBits(5)); + EXPECT_FALSE(reader.ReadBits(1, &value8)); + EXPECT_FALSE(reader.SkipBits(1)); + EXPECT_TRUE(reader.ReadBits(0, &value8)); + EXPECT_TRUE(reader.SkipBits(0)); +} + +} // namespace media |