blob: ff81413d1eb2ef3a7ec23c2a29e6039b066e8b16 [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <vector>
#include "base/functional/bind.h"
#include "base/time/time.h"
#include "media/base/media_util.h"
#include "media/base/stream_parser_buffer.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"
namespace media {
class AudioDecoderConfig;
namespace mp2t {
class EsParserMpeg1AudioTest : public EsParserTestBase,
public testing::Test {
public:
EsParserMpeg1AudioTest();
EsParserMpeg1AudioTest(const EsParserMpeg1AudioTest&) = delete;
EsParserMpeg1AudioTest& operator=(const EsParserMpeg1AudioTest&) = delete;
protected:
bool Process(const std::vector<Packet>& pes_packets, bool force_timing);
private:
NullMediaLog media_log_;
};
EsParserMpeg1AudioTest::EsParserMpeg1AudioTest() {
}
bool EsParserMpeg1AudioTest::Process(
const std::vector<Packet>& pes_packets,
bool force_timing) {
EsParserMpeg1Audio es_parser(
base::BindRepeating(&EsParserMpeg1AudioTest::NewAudioConfig,
base::Unretained(this)),
base::BindRepeating(&EsParserMpeg1AudioTest::EmitBuffer,
base::Unretained(this)),
&media_log_);
return ProcessPesPackets(&es_parser, pes_packets, force_timing);
}
TEST_F(EsParserMpeg1AudioTest, SinglePts) {
LoadStream("sfx.mp3");
std::vector<Packet> pes_packets = GenerateFixedSizePesPacket(512);
pes_packets.front().pts = base::Seconds(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(12u, buffer_count_);
}
TEST_F(EsParserMpeg1AudioTest, NoTimingInfo) {
LoadStream("sfx.mp3");
std::vector<Packet> pes_packets = GenerateFixedSizePesPacket(512);
// Process should succeed even without timing info, we should just skip the
// audio frames without timing info, but still should be able to parse and
// play the stream after that.
EXPECT_TRUE(Process(pes_packets, false));
EXPECT_EQ(1u, config_count_);
EXPECT_EQ(0u, buffer_count_);
}
} // namespace mp2t
} // namespace media