Chromium Code Reviews| 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); |
|
wolenetz
2014/09/13 00:06:38
nit: candidate for relocation into EsParserTestBas
damienv1
2014/09/13 01:27:47
Done.
|
| 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 |
| - |