// 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. #ifndef MEDIA_BASE_TEST_HELPERS_H_ #define MEDIA_BASE_TEST_HELPERS_H_ #include "base/basictypes.h" #include "base/callback.h" #include "media/base/pipeline_status.h" #include "media/base/sample_format.h" #include "media/base/video_decoder_config.h" #include "testing/gmock/include/gmock/gmock.h" #include "ui/gfx/size.h" namespace base { class MessageLoop; class TimeDelta; } namespace media { class AudioBuffer; class DecoderBuffer; // Return a callback that expects to be run once. base::Closure NewExpectedClosure(); PipelineStatusCB NewExpectedStatusCB(PipelineStatus status); // Helper class for running a message loop until a callback has run. Useful for // testing classes that run on more than a single thread. // // Events are intended for single use and cannot be reset. class WaitableMessageLoopEvent { public: WaitableMessageLoopEvent(); ~WaitableMessageLoopEvent(); // Returns a thread-safe closure that will signal |this| when executed. base::Closure GetClosure(); PipelineStatusCB GetPipelineStatusCB(); // Runs the current message loop until |this| has been signaled. // // Fails the test if the timeout is reached. void RunAndWait(); // Runs the current message loop until |this| has been signaled and asserts // that the |expected| status was received. // // Fails the test if the timeout is reached. void RunAndWaitForStatus(PipelineStatus expected); private: void OnCallback(PipelineStatus status); void OnTimeout(); base::MessageLoop* message_loop_; bool signaled_; PipelineStatus status_; DISALLOW_COPY_AND_ASSIGN(WaitableMessageLoopEvent); }; // Provides pre-canned VideoDecoderConfig. These types are used for tests that // don't care about detailed parameters of the config. class TestVideoConfig { public: // Returns a configuration that is invalid. static VideoDecoderConfig Invalid(); static VideoDecoderConfig Normal(); static VideoDecoderConfig NormalEncrypted(); // Returns a configuration that is larger in dimensions than Normal(). static VideoDecoderConfig Large(); static VideoDecoderConfig LargeEncrypted(); // Returns coded size for Normal and Large config. static gfx::Size NormalCodedSize(); static gfx::Size LargeCodedSize(); private: DISALLOW_IMPLICIT_CONSTRUCTORS(TestVideoConfig); }; // Create an AudioBuffer containing |frames| frames of data, where each sample // is of type T. Each frame will have the data from |channels| channels // interleaved. |start| and |increment| are used to specify the values for the // samples. Since this is interleaved data, channel 0 data will be: // |start| // |start| + |channels| * |increment| // |start| + 2 * |channels| * |increment|, and so on. // Data for subsequent channels is similar. No check is done that |format| // requires data to be of type T, but it is verified that |format| is an // interleaved format. // // |start_time| will be used as the start time for the samples. |duration| is // the duration. template <class T> scoped_refptr<AudioBuffer> MakeInterleavedAudioBuffer( SampleFormat format, int channels, T start, T increment, int frames, base::TimeDelta start_time, base::TimeDelta duration); // Create an AudioBuffer containing |frames| frames of data, where each sample // is of type T. Since this is planar data, there will be a block for each of // |channel| channels. |start| and |increment| are used to specify the values // for the samples, which are created in channel order. Since this is planar // data, channel 0 data will be: // |start| // |start| + |increment| // |start| + 2 * |increment|, and so on. // Data for channel 1 will follow where channel 0 ends. Subsequent channels are // similar. No check is done that |format| requires data to be of type T, but it // is verified that |format| is a planar format. // // |start_time| will be used as the start time for the samples. |duration| is // the duration. template <class T> scoped_refptr<AudioBuffer> MakePlanarAudioBuffer( SampleFormat format, int channels, T start, T increment, int frames, base::TimeDelta start_time, base::TimeDelta duration); // Create a fake video DecoderBuffer for testing purpose. The buffer contains // part of video decoder config info embedded so that the testing code can do // some sanity check. scoped_refptr<DecoderBuffer> CreateFakeVideoBufferForTest( const VideoDecoderConfig& config, base::TimeDelta timestamp, base::TimeDelta duration); // Verify if a fake video DecoderBuffer is valid. bool VerifyFakeVideoBufferForTest(const scoped_refptr<DecoderBuffer>& buffer, const VideoDecoderConfig& config); } // namespace media #endif // MEDIA_BASE_TEST_HELPERS_H_