Index: media/cast/video_receiver/video_decoder_unittest.cc |
diff --git a/media/cast/video_receiver/video_decoder_unittest.cc b/media/cast/video_receiver/video_decoder_unittest.cc |
index cb40e12752a1a88511e6cdbf99406d70d93d83c4..3212c0edf9662342a09d381e64afa346639f926e 100644 |
--- a/media/cast/video_receiver/video_decoder_unittest.cc |
+++ b/media/cast/video_receiver/video_decoder_unittest.cc |
@@ -2,8 +2,15 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
+#include "base/bind.h" |
#include "base/memory/scoped_ptr.h" |
+#include "base/test/simple_test_tick_clock.h" |
+#include "base/time/tick_clock.h" |
+#include "media/cast/cast_config.h" |
#include "media/cast/cast_defines.h" |
+#include "media/cast/cast_environment.h" |
+#include "media/cast/cast_receiver.h" |
+#include "media/cast/test/fake_task_runner.h" |
#include "media/cast/video_receiver/video_decoder.h" |
#include "testing/gmock/include/gmock/gmock.h" |
@@ -14,44 +21,69 @@ using testing::_; |
// Random frame size for testing. |
const int kFrameSize = 2345; |
+static const int64 kStartMillisecond = GG_INT64_C(1245); |
Alpha Left Google
2013/11/06 02:22:06
nit: This doesn't need to be static right?
mikhal
2013/11/06 18:29:16
Keeping for consistency - Static through out the c
|
+ |
+class DecodeTestFrameCallback : |
Alpha Left Google
2013/11/06 02:22:06
Put this in an anonymous namespace otherwise it mi
mikhal
2013/11/06 18:29:16
Done.
|
+ public base::RefCountedThreadSafe<DecodeTestFrameCallback> { |
+ public: |
+ DecodeTestFrameCallback() {} |
+ |
+ void DecodeComplete(scoped_ptr<I420VideoFrame> decoded_frame, |
+ const base::TimeTicks& render_time) {} |
+ protected: |
+ virtual ~DecodeTestFrameCallback() {} |
+ private: |
+ friend class base::RefCountedThreadSafe<DecodeTestFrameCallback>; |
+}; |
class VideoDecoderTest : public ::testing::Test { |
protected: |
- VideoDecoderTest() { |
+ VideoDecoderTest() |
+ : task_runner_(new test::FakeTaskRunner(&testing_clock_)), |
+ cast_environment_(new CastEnvironment(&testing_clock_, task_runner_, |
+ task_runner_, task_runner_, task_runner_, task_runner_)), |
+ test_callback_(new DecodeTestFrameCallback()) { |
Alpha Left Google
2013/11/06 02:22:06
nit: indentation is incorrect.
mikhal
2013/11/06 18:29:16
Done.
|
// Configure to vp8. |
config_.codec = kVp8; |
config_.use_external_decoder = false; |
- decoder_.reset(new VideoDecoder(config_)); |
+ decoder_.reset(new VideoDecoder(config_, cast_environment_)); |
+ testing_clock_.Advance( |
+ base::TimeDelta::FromMilliseconds(kStartMillisecond)); |
} |
virtual ~VideoDecoderTest() {} |
scoped_ptr<VideoDecoder> decoder_; |
VideoReceiverConfig config_; |
+ base::SimpleTestTickClock testing_clock_; |
+ scoped_refptr<test::FakeTaskRunner> task_runner_; |
+ scoped_refptr<CastEnvironment> cast_environment_; |
+ scoped_refptr<DecodeTestFrameCallback> test_callback_; |
}; |
// TODO(pwestin): EXPECT_DEATH tests can not pass valgrind. |
TEST_F(VideoDecoderTest, DISABLED_SizeZero) { |
EncodedVideoFrame encoded_frame; |
- I420VideoFrame video_frame; |
base::TimeTicks render_time; |
encoded_frame.codec = kVp8; |
- |
+ VideoFrameDecodedCallback frame_decoded_callback = |
+ base::Bind(&DecodeTestFrameCallback::DecodeComplete, test_callback_); |
EXPECT_DEATH( |
- decoder_->DecodeVideoFrame(&encoded_frame, render_time, &video_frame), |
- "Empty video frame"); |
+ decoder_->DecodeVideoFrame(&encoded_frame, render_time, |
+ frame_decoded_callback), "Empty video frame"); |
Alpha Left Google
2013/11/06 02:22:06
nit: indentation is incorrect, this should align w
|
} |
// TODO(pwestin): EXPECT_DEATH tests can not pass valgrind. |
TEST_F(VideoDecoderTest, DISABLED_InvalidCodec) { |
EncodedVideoFrame encoded_frame; |
- I420VideoFrame video_frame; |
base::TimeTicks render_time; |
encoded_frame.data.assign(kFrameSize, 0); |
encoded_frame.codec = kExternalVideo; |
+ VideoFrameDecodedCallback frame_decoded_callback = |
+ base::Bind(&DecodeTestFrameCallback::DecodeComplete, test_callback_); |
EXPECT_DEATH( |
- decoder_->DecodeVideoFrame(&encoded_frame, render_time, &video_frame), |
- "Invalid codec"); |
+ decoder_->DecodeVideoFrame(&encoded_frame, render_time, |
+ frame_decoded_callback), "Invalid codec"); |
Alpha Left Google
2013/11/06 02:22:06
nit: indentation is incorrect, it should align wit
mikhal
2013/11/06 18:29:16
Done.
|
} |
// TODO(pwestin): Test decoding a real frame. |