Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(162)

Side by Side Diff: media/base/pipeline_unittest.cc

Issue 13813016: Remove reference counting from media::Demuxer and friends. (Closed) Base URL: http://git.chromium.org/chromium/src.git@vd_scoped
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include <vector> 5 #include <vector>
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/message_loop.h" 8 #include "base/message_loop.h"
9 #include "base/stl_util.h" 9 #include "base/stl_util.h"
10 #include "base/test/simple_test_clock.h" 10 #include "base/test/simple_test_clock.h"
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after
78 // InitializationComplete(), which keeps the pipeline humming along. If 78 // InitializationComplete(), which keeps the pipeline humming along. If
79 // either filters don't call InitializationComplete() immediately or filter 79 // either filters don't call InitializationComplete() immediately or filter
80 // initialization is moved to a separate thread this test will become flaky. 80 // initialization is moved to a separate thread this test will become flaky.
81 class PipelineTest : public ::testing::Test { 81 class PipelineTest : public ::testing::Test {
82 public: 82 public:
83 PipelineTest() 83 PipelineTest()
84 : pipeline_(new Pipeline(message_loop_.message_loop_proxy(), 84 : pipeline_(new Pipeline(message_loop_.message_loop_proxy(),
85 new MediaLog())), 85 new MediaLog())),
86 filter_collection_(new FilterCollection()) { 86 filter_collection_(new FilterCollection()) {
87 demuxer_ = new MockDemuxer(); 87 demuxer_ = new MockDemuxer();
88 filter_collection_->SetDemuxer(demuxer_); 88 scoped_ptr<Demuxer> demuxer(demuxer_);
89 filter_collection_->SetDemuxer(demuxer.Pass());
89 90
90 video_renderer_ = new MockVideoRenderer(); 91 video_renderer_ = new MockVideoRenderer();
91 scoped_ptr<VideoRenderer> video_renderer(video_renderer_); 92 scoped_ptr<VideoRenderer> video_renderer(video_renderer_);
92 filter_collection_->SetVideoRenderer(video_renderer.Pass()); 93 filter_collection_->SetVideoRenderer(video_renderer.Pass());
93 94
94 audio_renderer_ = new MockAudioRenderer(); 95 audio_renderer_ = new MockAudioRenderer();
95 scoped_ptr<AudioRenderer> audio_renderer(audio_renderer_); 96 scoped_ptr<AudioRenderer> audio_renderer(audio_renderer_);
96 filter_collection_->SetAudioRenderer(audio_renderer.Pass()); 97 filter_collection_->SetAudioRenderer(audio_renderer.Pass());
97 98
98 // InitializeDemuxer() adds overriding expectations for expected non-NULL 99 // InitializeDemuxer() adds overriding expectations for expected non-NULL
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
135 typedef std::vector<MockDemuxerStream*> MockDemuxerStreamVector; 136 typedef std::vector<MockDemuxerStream*> MockDemuxerStreamVector;
136 void InitializeDemuxer(MockDemuxerStreamVector* streams, 137 void InitializeDemuxer(MockDemuxerStreamVector* streams,
137 const base::TimeDelta& duration) { 138 const base::TimeDelta& duration) {
138 EXPECT_CALL(callbacks_, OnDurationChange()); 139 EXPECT_CALL(callbacks_, OnDurationChange());
139 EXPECT_CALL(*demuxer_, Initialize(_, _)) 140 EXPECT_CALL(*demuxer_, Initialize(_, _))
140 .WillOnce(DoAll(SetDemuxerProperties(duration), 141 .WillOnce(DoAll(SetDemuxerProperties(duration),
141 RunCallback<1>(PIPELINE_OK))); 142 RunCallback<1>(PIPELINE_OK)));
142 143
143 // Configure the demuxer to return the streams. 144 // Configure the demuxer to return the streams.
144 for (size_t i = 0; i < streams->size(); ++i) { 145 for (size_t i = 0; i < streams->size(); ++i) {
145 scoped_refptr<DemuxerStream> stream((*streams)[i]); 146 DemuxerStream* stream = (*streams)[i];
146 EXPECT_CALL(*demuxer_, GetStream(stream->type())) 147 EXPECT_CALL(*demuxer_, GetStream(stream->type()))
147 .WillRepeatedly(Return(stream)); 148 .WillRepeatedly(Return(stream));
148 } 149 }
149 } 150 }
150 151
151 void InitializeDemuxer(MockDemuxerStreamVector* streams) { 152 void InitializeDemuxer(MockDemuxerStreamVector* streams) {
152 // Initialize with a default non-zero duration. 153 // Initialize with a default non-zero duration.
153 InitializeDemuxer(streams, base::TimeDelta::FromSeconds(10)); 154 InitializeDemuxer(streams, base::TimeDelta::FromSeconds(10));
154 } 155 }
155 156
156 StrictMock<MockDemuxerStream>* CreateStream(DemuxerStream::Type type) { 157 scoped_ptr<StrictMock<MockDemuxerStream> > CreateStream(
157 StrictMock<MockDemuxerStream>* stream = 158 DemuxerStream::Type type) {
158 new StrictMock<MockDemuxerStream>(); 159 scoped_ptr<StrictMock<MockDemuxerStream> > stream(
160 new StrictMock<MockDemuxerStream>());
159 EXPECT_CALL(*stream, type()) 161 EXPECT_CALL(*stream, type())
160 .WillRepeatedly(Return(type)); 162 .WillRepeatedly(Return(type));
161 return stream; 163 return stream.Pass();
162 } 164 }
163 165
164 // Sets up expectations to allow the video renderer to initialize. 166 // Sets up expectations to allow the video renderer to initialize.
165 void InitializeVideoRenderer(const scoped_refptr<DemuxerStream>& stream) { 167 void InitializeVideoRenderer(DemuxerStream* stream) {
166 EXPECT_CALL(*video_renderer_, Initialize(stream, _, _, _, _, _, _, _, _)) 168 EXPECT_CALL(*video_renderer_, Initialize(stream, _, _, _, _, _, _, _, _))
167 .WillOnce(RunCallback<1>(PIPELINE_OK)); 169 .WillOnce(RunCallback<1>(PIPELINE_OK));
168 EXPECT_CALL(*video_renderer_, SetPlaybackRate(0.0f)); 170 EXPECT_CALL(*video_renderer_, SetPlaybackRate(0.0f));
169 171
170 // Startup sequence. 172 // Startup sequence.
171 EXPECT_CALL(*video_renderer_, Preroll(demuxer_->GetStartTime(), _)) 173 EXPECT_CALL(*video_renderer_, Preroll(demuxer_->GetStartTime(), _))
172 .WillOnce(RunCallback<1>(PIPELINE_OK)); 174 .WillOnce(RunCallback<1>(PIPELINE_OK));
173 EXPECT_CALL(*video_renderer_, Play(_)) 175 EXPECT_CALL(*video_renderer_, Play(_))
174 .WillOnce(RunClosure<0>()); 176 .WillOnce(RunClosure<0>());
175 } 177 }
176 178
177 // Sets up expectations to allow the audio renderer to initialize. 179 // Sets up expectations to allow the audio renderer to initialize.
178 void InitializeAudioRenderer(const scoped_refptr<DemuxerStream>& stream, 180 void InitializeAudioRenderer(DemuxerStream* stream,
179 bool disable_after_init_cb) { 181 bool disable_after_init_cb) {
180 if (disable_after_init_cb) { 182 if (disable_after_init_cb) {
181 EXPECT_CALL(*audio_renderer_, Initialize(stream, _, _, _, _, _, _, _)) 183 EXPECT_CALL(*audio_renderer_, Initialize(stream, _, _, _, _, _, _, _))
182 .WillOnce(DoAll(RunCallback<1>(PIPELINE_OK), 184 .WillOnce(DoAll(RunCallback<1>(PIPELINE_OK),
183 WithArg<6>(RunClosure<0>()))); // |disabled_cb|. 185 WithArg<6>(RunClosure<0>()))); // |disabled_cb|.
184 } else { 186 } else {
185 EXPECT_CALL(*audio_renderer_, Initialize(stream, _, _, _, _, _, _, _)) 187 EXPECT_CALL(*audio_renderer_, Initialize(stream, _, _, _, _, _, _, _))
186 .WillOnce(DoAll(SaveArg<4>(&audio_time_cb_), 188 .WillOnce(DoAll(SaveArg<4>(&audio_time_cb_),
187 RunCallback<1>(PIPELINE_OK))); 189 RunCallback<1>(PIPELINE_OK)));
188 } 190 }
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
226 audio_stream_ = CreateStream(DemuxerStream::AUDIO); 228 audio_stream_ = CreateStream(DemuxerStream::AUDIO);
227 } 229 }
228 230
229 void CreateVideoStream() { 231 void CreateVideoStream() {
230 video_stream_ = CreateStream(DemuxerStream::VIDEO); 232 video_stream_ = CreateStream(DemuxerStream::VIDEO);
231 EXPECT_CALL(*video_stream_, video_decoder_config()) 233 EXPECT_CALL(*video_stream_, video_decoder_config())
232 .WillRepeatedly(ReturnRef(video_decoder_config_)); 234 .WillRepeatedly(ReturnRef(video_decoder_config_));
233 } 235 }
234 236
235 MockDemuxerStream* audio_stream() { 237 MockDemuxerStream* audio_stream() {
236 return audio_stream_; 238 return audio_stream_.get();
237 } 239 }
238 240
239 MockDemuxerStream* video_stream() { 241 MockDemuxerStream* video_stream() {
240 return video_stream_; 242 return video_stream_.get();
241 } 243 }
242 244
243 void ExpectSeek(const base::TimeDelta& seek_time) { 245 void ExpectSeek(const base::TimeDelta& seek_time) {
244 // Every filter should receive a call to Seek(). 246 // Every filter should receive a call to Seek().
245 EXPECT_CALL(*demuxer_, Seek(seek_time, _)) 247 EXPECT_CALL(*demuxer_, Seek(seek_time, _))
246 .WillOnce(RunCallback<1>(PIPELINE_OK)); 248 .WillOnce(RunCallback<1>(PIPELINE_OK));
247 EXPECT_CALL(*demuxer_, SetPlaybackRate(_)); 249 EXPECT_CALL(*demuxer_, SetPlaybackRate(_));
248 250
249 if (audio_stream_) { 251 if (audio_stream_) {
250 EXPECT_CALL(*audio_renderer_, Pause(_)) 252 EXPECT_CALL(*audio_renderer_, Pause(_))
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
288 EXPECT_EQ(seek_time, pipeline_->GetMediaTime()); 290 EXPECT_EQ(seek_time, pipeline_->GetMediaTime());
289 } 291 }
290 292
291 // Fixture members. 293 // Fixture members.
292 StrictMock<CallbackHelper> callbacks_; 294 StrictMock<CallbackHelper> callbacks_;
293 base::SimpleTestClock test_clock_; 295 base::SimpleTestClock test_clock_;
294 MessageLoop message_loop_; 296 MessageLoop message_loop_;
295 scoped_refptr<Pipeline> pipeline_; 297 scoped_refptr<Pipeline> pipeline_;
296 298
297 scoped_ptr<FilterCollection> filter_collection_; 299 scoped_ptr<FilterCollection> filter_collection_;
298 scoped_refptr<MockDemuxer> demuxer_; 300 MockDemuxer* demuxer_;
299 MockVideoRenderer* video_renderer_; 301 MockVideoRenderer* video_renderer_;
300 MockAudioRenderer* audio_renderer_; 302 MockAudioRenderer* audio_renderer_;
301 scoped_refptr<StrictMock<MockDemuxerStream> > audio_stream_; 303 scoped_ptr<StrictMock<MockDemuxerStream> > audio_stream_;
302 scoped_refptr<StrictMock<MockDemuxerStream> > video_stream_; 304 scoped_ptr<StrictMock<MockDemuxerStream> > video_stream_;
303 AudioRenderer::TimeCB audio_time_cb_; 305 AudioRenderer::TimeCB audio_time_cb_;
304 VideoDecoderConfig video_decoder_config_; 306 VideoDecoderConfig video_decoder_config_;
305 307
306 private: 308 private:
307 DISALLOW_COPY_AND_ASSIGN(PipelineTest); 309 DISALLOW_COPY_AND_ASSIGN(PipelineTest);
308 }; 310 };
309 311
310 // Test that playback controls methods no-op when the pipeline hasn't been 312 // Test that playback controls methods no-op when the pipeline hasn't been
311 // started. 313 // started.
312 TEST_F(PipelineTest, NotStarted) { 314 TEST_F(PipelineTest, NotStarted) {
(...skipping 895 matching lines...) Expand 10 before | Expand all | Expand 10 after
1208 INSTANTIATE_TEARDOWN_TEST(Error, InitAudioRenderer); 1210 INSTANTIATE_TEARDOWN_TEST(Error, InitAudioRenderer);
1209 INSTANTIATE_TEARDOWN_TEST(Error, InitVideoRenderer); 1211 INSTANTIATE_TEARDOWN_TEST(Error, InitVideoRenderer);
1210 INSTANTIATE_TEARDOWN_TEST(Error, Pausing); 1212 INSTANTIATE_TEARDOWN_TEST(Error, Pausing);
1211 INSTANTIATE_TEARDOWN_TEST(Error, Flushing); 1213 INSTANTIATE_TEARDOWN_TEST(Error, Flushing);
1212 INSTANTIATE_TEARDOWN_TEST(Error, Seeking); 1214 INSTANTIATE_TEARDOWN_TEST(Error, Seeking);
1213 INSTANTIATE_TEARDOWN_TEST(Error, Prerolling); 1215 INSTANTIATE_TEARDOWN_TEST(Error, Prerolling);
1214 INSTANTIATE_TEARDOWN_TEST(Error, Starting); 1216 INSTANTIATE_TEARDOWN_TEST(Error, Starting);
1215 INSTANTIATE_TEARDOWN_TEST(Error, Playing); 1217 INSTANTIATE_TEARDOWN_TEST(Error, Playing);
1216 1218
1217 } // namespace media 1219 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698