summaryrefslogtreecommitdiffstats
path: root/media/base/pipeline_impl_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'media/base/pipeline_impl_unittest.cc')
-rw-r--r--media/base/pipeline_impl_unittest.cc82
1 files changed, 54 insertions, 28 deletions
diff --git a/media/base/pipeline_impl_unittest.cc b/media/base/pipeline_impl_unittest.cc
index dbaedcc..6685896 100644
--- a/media/base/pipeline_impl_unittest.cc
+++ b/media/base/pipeline_impl_unittest.cc
@@ -46,36 +46,32 @@ void AddAllMockFilters(FilterFactoryCollection* factories,
// TODO(ralphl): Get rid of single character variable names in these tests.
TEST(PipelineImplTest, Initialization) {
std::string u("");
+
+ // This test hangs during initialization of the data source (it never
+ // calls InitializationComplete). Make sure we tear down the pipeline
+ // propertly.
PipelineImpl p;
InitializationHelper h;
MockFilterConfig config;
config.data_source_behavior = media::MOCK_DATA_SOURCE_NEVER_INIT;
- h.Start(&p, MockDataSource::CreateFactory(&config), u);
- h.TimedWait(base::TimeDelta::FromMilliseconds(300));
- EXPECT_TRUE(h.waiting_for_callback());
- EXPECT_FALSE(p.IsInitialized());
- EXPECT_TRUE(media::PIPELINE_OK == p.GetError());
+ h.Start(&p, MockDataSource::CreateFactory(&config), u,
+ media::PIPELINE_OK, true);
p.Stop();
EXPECT_FALSE(h.waiting_for_callback());
EXPECT_FALSE(h.callback_success_status());
EXPECT_TRUE(media::PIPELINE_OK == p.GetError());
+ // This test should not hang. Should return an error indicating that we are
+ // missing a requried filter.
config.data_source_behavior = media::MOCK_DATA_SOURCE_TASK_INIT;
- h.Start(&p, MockDataSource::CreateFactory(&config), u);
- h.TimedWait(base::TimeDelta::FromSeconds(5));
- EXPECT_FALSE(h.waiting_for_callback());
- EXPECT_FALSE(h.callback_success_status());
- EXPECT_FALSE(p.IsInitialized());
- EXPECT_FALSE(media::PIPELINE_OK == p.GetError());
+ h.Start(&p, MockDataSource::CreateFactory(&config), u,
+ media::PIPELINE_ERROR_REQUIRED_FILTER_MISSING);
p.Stop();
- config.data_source_behavior = media::MOCK_DATA_SOURCE_ERROR_IN_INIT;
- h.Start(&p, MockDataSource::CreateFactory(&config), u);
- h.TimedWait(base::TimeDelta::FromSeconds(5));
- EXPECT_FALSE(h.waiting_for_callback());
- EXPECT_FALSE(h.callback_success_status());
- EXPECT_FALSE(p.IsInitialized());
- EXPECT_FALSE(media::PIPELINE_OK == p.GetError());
+ // This test should return a specific error from the mock data source.
+ config.data_source_behavior = media::MOCK_DATA_SOURCE_URL_ERROR_IN_INIT;
+ h.Start(&p, MockDataSource::CreateFactory(&config), u,
+ media::PIPELINE_ERROR_URL_NOT_FOUND);
p.Stop();
}
@@ -88,13 +84,10 @@ TEST(PipelineImplTest, MockAudioPipeline) {
AddAllMockFilters(c, &config);
InitializationHelper h;
h.Start(&p, c, url);
- h.TimedWait(base::TimeDelta::FromSeconds(5));
- EXPECT_FALSE(h.waiting_for_callback());
- EXPECT_TRUE(h.callback_success_status());
- EXPECT_TRUE(p.IsInitialized());
- EXPECT_TRUE(media::PIPELINE_OK == p.GetError());
size_t width, height;
p.GetVideoSize(&width, &height);
+ EXPECT_TRUE(p.IsRendered(media::mime_type::kMajorTypeAudio));
+ EXPECT_FALSE(p.IsRendered(media::mime_type::kMajorTypeVideo));
EXPECT_EQ(0u, width);
EXPECT_EQ(0u, height);
p.SetPlaybackRate(1.0f);
@@ -111,18 +104,51 @@ TEST(PipelineImplTest, MockVideoPipeline) {
AddAllMockFilters(c, &config);
InitializationHelper h;
h.Start(&p, c, url);
- h.TimedWait(base::TimeDelta::FromSeconds(5));
- EXPECT_FALSE(h.waiting_for_callback());
- EXPECT_TRUE(h.callback_success_status());
- EXPECT_TRUE(p.IsInitialized());
- EXPECT_TRUE(media::PIPELINE_OK == p.GetError());
size_t width, height;
p.GetVideoSize(&width, &height);
EXPECT_EQ(config.video_width, width);
EXPECT_EQ(config.video_height, height);
+ EXPECT_TRUE(p.IsRendered(media::mime_type::kMajorTypeAudio));
+ EXPECT_TRUE(p.IsRendered(media::mime_type::kMajorTypeVideo));
p.SetPlaybackRate(1.0f);
p.SetVolume(0.5f);
p.Stop();
EXPECT_FALSE(p.IsInitialized());
}
+TEST(PipelineImplTest, MockVideoOnlyPipeline) {
+ std::string url("");
+ PipelineImpl p;
+ scoped_refptr<FilterFactoryCollection> c = new FilterFactoryCollection();
+ MockFilterConfig config;
+ config.has_audio = false;
+ AddAllMockFilters(c, &config);
+ InitializationHelper h;
+ h.Start(&p, c, url);
+ size_t width, height;
+ p.GetVideoSize(&width, &height);
+ EXPECT_EQ(config.video_width, width);
+ EXPECT_EQ(config.video_height, height);
+ EXPECT_FALSE(p.IsRendered(media::mime_type::kMajorTypeAudio));
+ EXPECT_TRUE(p.IsRendered(media::mime_type::kMajorTypeVideo));
+ p.SetPlaybackRate(1.0f);
+ p.Stop();
+ EXPECT_FALSE(p.IsInitialized());
+}
+
+TEST(PipelineImplTest, MockNothingToRenderPipeline) {
+ std::string url("");
+ PipelineImpl p;
+ scoped_refptr<FilterFactoryCollection> c = new FilterFactoryCollection();
+ MockFilterConfig config;
+ config.has_audio = false;
+ config.has_video = false;
+ AddAllMockFilters(c, &config);
+ InitializationHelper h;
+ h.Start(&p, c, url, media::PIPELINE_ERROR_COULD_NOT_RENDER);
+ p.Stop();
+}
+
+// TODO(ralphl): Add a unit test that makes sure that the mock audio filter
+// is actually called on a SetVolume() call to the pipeline. I almost checked
+// in code that broke this, but all unit tests were passing.