Chromium Code Reviews| Index: chromecast/media/cma/ipc_streamer/av_streamer_unittest.cc |
| diff --git a/chromecast/media/cma/base/buffering_frame_provider_unittest.cc b/chromecast/media/cma/ipc_streamer/av_streamer_unittest.cc |
| similarity index 53% |
| copy from chromecast/media/cma/base/buffering_frame_provider_unittest.cc |
| copy to chromecast/media/cma/ipc_streamer/av_streamer_unittest.cc |
| index 6f7902a70b86e480bc0d43dbbbc00708b247737c..2971fb7ba671e3943bb9d424403f8b42a0813c8f 100644 |
| --- a/chromecast/media/cma/base/buffering_frame_provider_unittest.cc |
| +++ b/chromecast/media/cma/ipc_streamer/av_streamer_unittest.cc |
| @@ -11,11 +11,14 @@ |
| #include "base/memory/scoped_ptr.h" |
| #include "base/threading/thread.h" |
| #include "base/time/time.h" |
| -#include "chromecast/media/cma/base/buffering_frame_provider.h" |
| #include "chromecast/media/cma/base/decoder_buffer_base.h" |
| #include "chromecast/media/cma/base/frame_generator_for_test.h" |
| #include "chromecast/media/cma/base/mock_frame_consumer.h" |
| #include "chromecast/media/cma/base/mock_frame_provider.h" |
| +#include "chromecast/media/cma/ipc/media_memory_chunk.h" |
| +#include "chromecast/media/cma/ipc/media_message_fifo.h" |
| +#include "chromecast/media/cma/ipc_streamer/av_streamer_proxy.h" |
| +#include "chromecast/media/cma/ipc_streamer/coded_frame_provider_host.h" |
| #include "media/base/audio_decoder_config.h" |
| #include "media/base/decoder_buffer.h" |
| #include "media/base/video_decoder_config.h" |
| @@ -24,45 +27,71 @@ |
| namespace chromecast { |
| namespace media { |
| -class BufferingFrameProviderTest : public testing::Test { |
| +namespace { |
| + |
| +class FifoMemoryChunk : public MediaMemoryChunk { |
| public: |
| - BufferingFrameProviderTest(); |
| - virtual ~BufferingFrameProviderTest(); |
| + FifoMemoryChunk(void* mem, size_t size) |
| + : mem_(mem), size_(size) {} |
| + virtual ~FifoMemoryChunk() {} |
| + |
| + virtual void* data() const OVERRIDE { return mem_; } |
| + virtual size_t size() const OVERRIDE { return size_; } |
| + virtual bool valid() const OVERRIDE { return true; } |
| + |
| + private: |
| + void* mem_; |
| + size_t size_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(FifoMemoryChunk); |
| +}; |
| - // Setup the test. |
| +} // namespace |
| + |
| +class AvStreamerTest : public testing::Test { |
| + public: |
| + AvStreamerTest(); |
| + virtual ~AvStreamerTest(); |
| + |
| + // Setups the test. |
| void Configure( |
| size_t frame_count, |
| const std::vector<bool>& provider_delayed_pattern, |
| const std::vector<bool>& consumer_delayed_pattern); |
| - // Start the test. |
| + // Starts the test. |
| void Start(); |
| protected: |
| - scoped_ptr<BufferingFrameProvider> buffering_frame_provider_; |
| + scoped_ptr<uint64[]> fifo_mem_; |
| + |
| + scoped_ptr<AvStreamerProxy> av_buffer_proxy_; |
| + scoped_ptr<CodedFrameProviderHost> coded_frame_provider_host_; |
| scoped_ptr<MockFrameConsumer> frame_consumer_; |
| private: |
| void OnTestTimeout(); |
| void OnTestCompleted(); |
| - DISALLOW_COPY_AND_ASSIGN(BufferingFrameProviderTest); |
| + void OnFifoRead(); |
| + void OnFifoWrite(); |
| + |
| + DISALLOW_COPY_AND_ASSIGN(AvStreamerTest); |
| }; |
| -BufferingFrameProviderTest::BufferingFrameProviderTest() { |
| +AvStreamerTest::AvStreamerTest() { |
| } |
| -BufferingFrameProviderTest::~BufferingFrameProviderTest() { |
| +AvStreamerTest::~AvStreamerTest() { |
| } |
| -void BufferingFrameProviderTest::Configure( |
| +void AvStreamerTest::Configure( |
| size_t frame_count, |
| const std::vector<bool>& provider_delayed_pattern, |
| const std::vector<bool>& consumer_delayed_pattern) { |
| - DCHECK_GE(frame_count, 1u); |
| - |
| // Frame generation on the producer and consumer side. |
| - std::vector<FrameGeneratorForTest::FrameSpec> frame_specs(frame_count); |
| + std::vector<FrameGeneratorForTest::FrameSpec> frame_specs; |
| + frame_specs.resize(frame_count); |
| for (size_t k = 0; k < frame_specs.size() - 1; k++) { |
| frame_specs[k].has_config = (k == 0); |
| frame_specs[k].timestamp = base::TimeDelta::FromMilliseconds(40) * k; |
| @@ -80,44 +109,80 @@ void BufferingFrameProviderTest::Configure( |
| frame_provider->Configure(provider_delayed_pattern, |
| frame_generator_provider.Pass()); |
| - size_t max_frame_size = 10 * 1024; |
| - size_t buffer_size = 10 * max_frame_size; |
| - buffering_frame_provider_.reset( |
| - new BufferingFrameProvider( |
| - scoped_ptr<CodedFrameProvider>(frame_provider.release()), |
| - buffer_size, |
| - max_frame_size, |
| - BufferingFrameProvider::FrameBufferedCB())); |
| + size_t fifo_size_div_8 = 512; |
| + fifo_mem_.reset(new uint64[fifo_size_div_8]); |
| + scoped_ptr<MediaMessageFifo> producer_fifo( |
| + new MediaMessageFifo( |
| + scoped_ptr<MediaMemoryChunk>( |
| + new FifoMemoryChunk(&fifo_mem_[0], fifo_size_div_8 * 8)), |
| + true)); |
| + scoped_ptr<MediaMessageFifo> consumer_fifo( |
| + new MediaMessageFifo( |
| + scoped_ptr<MediaMemoryChunk>( |
| + new FifoMemoryChunk(&fifo_mem_[0], fifo_size_div_8 * 8)), |
| + false)); |
| + producer_fifo->ObserveWriteActivity( |
| + base::Bind(&AvStreamerTest::OnFifoWrite, base::Unretained(this))); |
| + consumer_fifo->ObserveReadActivity( |
| + base::Bind(&AvStreamerTest::OnFifoRead, base::Unretained(this))); |
| + |
| + av_buffer_proxy_.reset( |
| + new AvStreamerProxy()); |
| + av_buffer_proxy_->SetCodedFrameProvider( |
| + scoped_ptr<CodedFrameProvider>(frame_provider.release())); |
| + av_buffer_proxy_->SetMediaMessageFifo(producer_fifo.Pass()); |
| + |
| + coded_frame_provider_host_.reset( |
| + new CodedFrameProviderHost(consumer_fifo.Pass())); |
| frame_consumer_.reset( |
| - new MockFrameConsumer(buffering_frame_provider_.get())); |
| + new MockFrameConsumer(coded_frame_provider_host_.get())); |
| frame_consumer_->Configure( |
| consumer_delayed_pattern, |
| false, |
| frame_generator_consumer.Pass()); |
| } |
| -void BufferingFrameProviderTest::Start() { |
| +void AvStreamerTest::Start() { |
| + base::MessageLoopProxy::current()->PostTask( |
| + FROM_HERE, |
| + base::Bind(&AvStreamerProxy::Start, |
| + base::Unretained(av_buffer_proxy_.get()))); |
| + |
| frame_consumer_->Start( |
| - base::Bind(&BufferingFrameProviderTest::OnTestCompleted, |
| + base::Bind(&AvStreamerTest::OnTestCompleted, |
| base::Unretained(this))); |
| } |
| -void BufferingFrameProviderTest::OnTestTimeout() { |
| +void AvStreamerTest::OnTestTimeout() { |
| ADD_FAILURE() << "Test timed out"; |
| if (base::MessageLoop::current()) |
| base::MessageLoop::current()->QuitWhenIdle(); |
| } |
| -void BufferingFrameProviderTest::OnTestCompleted() { |
| +void AvStreamerTest::OnTestCompleted() { |
| base::MessageLoop::current()->QuitWhenIdle(); |
| } |
| -TEST_F(BufferingFrameProviderTest, FastProviderSlowConsumer) { |
| +void AvStreamerTest::OnFifoWrite() { |
| + base::MessageLoopProxy::current()->PostTask( |
| + FROM_HERE, |
| + base::Bind(&CodedFrameProviderHost::OnFifoWriteEvent, |
| + base::Unretained(coded_frame_provider_host_.get()))); |
| +} |
| + |
| +void AvStreamerTest::OnFifoRead() { |
| + base::MessageLoopProxy::current()->PostTask( |
| + FROM_HERE, |
| + base::Bind(&AvStreamerProxy::OnFifoReadEvent, |
| + base::Unretained(av_buffer_proxy_.get()))); |
| +} |
| + |
| +TEST_F(AvStreamerTest, FastProviderSlowConsumer) { |
| + size_t frame_count = 100; |
| bool provider_delayed_pattern[] = { false }; |
| bool consumer_delayed_pattern[] = { true }; |
| - const size_t frame_count = 100u; |
| Configure( |
| frame_count, |
| std::vector<bool>( |
| @@ -130,15 +195,15 @@ TEST_F(BufferingFrameProviderTest, FastProviderSlowConsumer) { |
| scoped_ptr<base::MessageLoop> message_loop(new base::MessageLoop()); |
| message_loop->PostTask( |
| FROM_HERE, |
| - base::Bind(&BufferingFrameProviderTest::Start, base::Unretained(this))); |
| + base::Bind(&AvStreamerTest::Start, base::Unretained(this))); |
| message_loop->Run(); |
| }; |
| -TEST_F(BufferingFrameProviderTest, SlowProviderFastConsumer) { |
| +TEST_F(AvStreamerTest, SlowProviderFastConsumer) { |
| + size_t frame_count = 100; |
|
gunsch
2014/09/10 18:51:37
Chromium review picked up the diff between this an
damienv1
2014/09/10 21:24:54
Done.
|
| bool provider_delayed_pattern[] = { true }; |
| bool consumer_delayed_pattern[] = { false }; |
| - const size_t frame_count = 100u; |
| Configure( |
| frame_count, |
| std::vector<bool>( |
| @@ -151,12 +216,15 @@ TEST_F(BufferingFrameProviderTest, SlowProviderFastConsumer) { |
| scoped_ptr<base::MessageLoop> message_loop(new base::MessageLoop()); |
| message_loop->PostTask( |
| FROM_HERE, |
| - base::Bind(&BufferingFrameProviderTest::Start, base::Unretained(this))); |
| + base::Bind(&AvStreamerTest::Start, base::Unretained(this))); |
| message_loop->Run(); |
| }; |
| -TEST_F(BufferingFrameProviderTest, SlowFastProducerConsumer) { |
| - // Lengths are prime between each other so we can test a lot of combinations. |
| +TEST_F(AvStreamerTest, SlowFastProducerConsumer) { |
| + size_t frame_count = 100; |
| + |
| + // Pattern lengths are prime between each other |
| + // so that a lot of combinations can be tested. |
| bool provider_delayed_pattern[] = { |
| true, true, true, true, true, |
| false, false, false, false |
| @@ -166,7 +234,6 @@ TEST_F(BufferingFrameProviderTest, SlowFastProducerConsumer) { |
| false, false, false, false, false, false, false |
| }; |
| - const size_t frame_count = 100u; |
| Configure( |
| frame_count, |
| std::vector<bool>( |
| @@ -179,7 +246,7 @@ TEST_F(BufferingFrameProviderTest, SlowFastProducerConsumer) { |
| scoped_ptr<base::MessageLoop> message_loop(new base::MessageLoop()); |
| message_loop->PostTask( |
| FROM_HERE, |
| - base::Bind(&BufferingFrameProviderTest::Start, base::Unretained(this))); |
| + base::Bind(&AvStreamerTest::Start, base::Unretained(this))); |
| message_loop->Run(); |
| }; |