| Index: media/formats/mp2t/es_parser_mpeg1audio_unittest.cc
|
| diff --git a/media/formats/mp2t/es_parser_adts_unittest.cc b/media/formats/mp2t/es_parser_mpeg1audio_unittest.cc
|
| similarity index 51%
|
| copy from media/formats/mp2t/es_parser_adts_unittest.cc
|
| copy to media/formats/mp2t/es_parser_mpeg1audio_unittest.cc
|
| index c9dd47c54b486c014dbd4281472ad24fe0c4a03f..692721ce76fa3d8f8c5775005c2c1cb2871e1c32 100644
|
| --- a/media/formats/mp2t/es_parser_adts_unittest.cc
|
| +++ b/media/formats/mp2t/es_parser_mpeg1audio_unittest.cc
|
| @@ -9,7 +9,7 @@
|
| #include "base/time/time.h"
|
| #include "media/base/buffers.h"
|
| #include "media/base/stream_parser_buffer.h"
|
| -#include "media/formats/mp2t/es_parser_adts.h"
|
| +#include "media/formats/mp2t/es_parser_mpeg1audio.h"
|
| #include "media/formats/mp2t/es_parser_test_base.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
|
|
| @@ -18,11 +18,11 @@ class AudioDecoderConfig;
|
|
|
| namespace mp2t {
|
|
|
| -class EsParserAdtsTest : public EsParserTestBase,
|
| - public testing::Test {
|
| +class EsParserMpeg1AudioTest : public EsParserTestBase,
|
| + public testing::Test {
|
| public:
|
| - EsParserAdtsTest();
|
| - virtual ~EsParserAdtsTest() {}
|
| + EsParserMpeg1AudioTest();
|
| + virtual ~EsParserMpeg1AudioTest() {}
|
|
|
| protected:
|
| bool Process(const std::vector<Packet>& pes_packets, bool force_timing);
|
| @@ -30,24 +30,25 @@ class EsParserAdtsTest : public EsParserTestBase,
|
| std::vector<Packet> GenerateFixedSizePesPacket(size_t pes_size);
|
|
|
| private:
|
| - DISALLOW_COPY_AND_ASSIGN(EsParserAdtsTest);
|
| + DISALLOW_COPY_AND_ASSIGN(EsParserMpeg1AudioTest);
|
| };
|
|
|
| -EsParserAdtsTest::EsParserAdtsTest() {
|
| +EsParserMpeg1AudioTest::EsParserMpeg1AudioTest() {
|
| }
|
|
|
| -bool EsParserAdtsTest::Process(
|
| +bool EsParserMpeg1AudioTest::Process(
|
| const std::vector<Packet>& pes_packets,
|
| bool force_timing) {
|
| - EsParserAdts es_parser(
|
| - base::Bind(&EsParserAdtsTest::NewAudioConfig, base::Unretained(this)),
|
| - base::Bind(&EsParserAdtsTest::EmitBuffer, base::Unretained(this)),
|
| - false);
|
| + EsParserMpeg1Audio es_parser(
|
| + base::Bind(&EsParserMpeg1AudioTest::NewAudioConfig,
|
| + base::Unretained(this)),
|
| + base::Bind(&EsParserMpeg1AudioTest::EmitBuffer,
|
| + base::Unretained(this)));
|
| return ProcessPesPackets(&es_parser, pes_packets, force_timing);
|
| }
|
|
|
| std::vector<EsParserTestBase::Packet>
|
| -EsParserAdtsTest::GenerateFixedSizePesPacket(size_t pes_size) {
|
| +EsParserMpeg1AudioTest::GenerateFixedSizePesPacket(size_t pes_size) {
|
| DCHECK_GT(stream_.size(), 0u);
|
| std::vector<Packet> pes_packets;
|
|
|
| @@ -63,24 +64,26 @@ EsParserAdtsTest::GenerateFixedSizePesPacket(size_t pes_size) {
|
| return pes_packets;
|
| }
|
|
|
| -TEST_F(EsParserAdtsTest, NoInitialPts) {
|
| - LoadStream("bear.adts");
|
| - std::vector<Packet> pes_packets = GenerateFixedSizePesPacket(512);
|
| - EXPECT_FALSE(Process(pes_packets, false));
|
| - EXPECT_EQ(0u, buffer_count_);
|
| -}
|
| -
|
| -TEST_F(EsParserAdtsTest, SinglePts) {
|
| - LoadStream("bear.adts");
|
| +TEST_F(EsParserMpeg1AudioTest, SinglePts) {
|
| + LoadStream("sfx.mp3");
|
|
|
| std::vector<Packet> pes_packets = GenerateFixedSizePesPacket(512);
|
| pes_packets.front().pts = base::TimeDelta::FromSeconds(10);
|
|
|
| + // Note: there is no parsing of metadata as part of Mpeg2 TS,
|
| + // so the tag starting at 0x80d with 0x54 0x41 0x47 (ascii for "TAG")
|
| + // is not a valid Mpeg1 audio frame header. This makes the previous frame
|
| + // invalid since there is no start code following the previous frame.
|
| + // So instead of the 13 Mpeg1 audio frames, only 12 are considered valid.
|
| + // Offset of frames in the file:
|
| + // {0x20, 0x1c1, 0x277, 0x2f9, 0x3fd, 0x47f, 0x501, 0x583,
|
| + // 0x605, 0x687, 0x73d, 0x7a5, 0x80d}
|
| + // TODO(damienv): find a file that would be more relevant for Mpeg1 audio
|
| + // as part of Mpeg2 TS.
|
| EXPECT_TRUE(Process(pes_packets, false));
|
| EXPECT_EQ(1u, config_count_);
|
| - EXPECT_EQ(45u, buffer_count_);
|
| + EXPECT_EQ(12u, buffer_count_);
|
| }
|
|
|
| } // namespace mp2t
|
| } // namespace media
|
| -
|
|
|