Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 #include <memory> | 11 #include <memory> |
| 12 #include <vector> | 12 #include <vector> |
| 13 | 13 |
| 14 #include "webrtc/modules/video_coding/include/mock/mock_vcm_callbacks.h" | 14 #include "webrtc/modules/video_coding/include/mock/mock_vcm_callbacks.h" |
| 15 #include "webrtc/modules/video_coding/include/mock/mock_video_codec_interface.h" | 15 #include "webrtc/modules/video_coding/include/mock/mock_video_codec_interface.h" |
| 16 #include "webrtc/modules/video_coding/include/video_coding.h" | 16 #include "webrtc/modules/video_coding/include/video_coding.h" |
| 17 #include "webrtc/modules/video_coding/test/test_util.h" | 17 #include "webrtc/modules/video_coding/test/test_util.h" |
| 18 #include "webrtc/modules/video_coding/timing.h" | |
| 18 #include "webrtc/modules/video_coding/video_coding_impl.h" | 19 #include "webrtc/modules/video_coding/video_coding_impl.h" |
| 19 #include "webrtc/system_wrappers/include/clock.h" | 20 #include "webrtc/system_wrappers/include/clock.h" |
| 20 #include "webrtc/test/gtest.h" | 21 #include "webrtc/test/gtest.h" |
| 21 | 22 |
| 22 using ::testing::_; | 23 using ::testing::_; |
| 23 using ::testing::NiceMock; | 24 using ::testing::NiceMock; |
| 24 | 25 |
| 25 namespace webrtc { | 26 namespace webrtc { |
| 26 namespace vcm { | 27 namespace vcm { |
| 27 namespace { | 28 namespace { |
| 28 | 29 |
| 29 class TestVideoReceiver : public ::testing::Test { | 30 class TestVideoReceiver : public ::testing::Test { |
| 30 protected: | 31 protected: |
| 31 static const int kUnusedPayloadType = 10; | 32 static const int kUnusedPayloadType = 10; |
| 32 | 33 |
| 33 TestVideoReceiver() : clock_(0) {} | 34 TestVideoReceiver() : clock_(0) {} |
| 34 | 35 |
| 35 virtual void SetUp() { | 36 virtual void SetUp() { |
| 36 receiver_.reset(new VideoReceiver(&clock_, &event_factory_, nullptr)); | 37 timing_.reset(new VCMTiming(&clock_)); |
|
stefan-webrtc
2016/12/15 14:06:03
Maybe move this to the ctor initializer list inste
philipel
2016/12/15 14:18:00
I think this is more in style with this piece of c
| |
| 38 receiver_.reset( | |
| 39 new VideoReceiver(&clock_, &event_factory_, nullptr, timing_.get())); | |
| 37 receiver_->RegisterExternalDecoder(&decoder_, kUnusedPayloadType); | 40 receiver_->RegisterExternalDecoder(&decoder_, kUnusedPayloadType); |
| 38 const size_t kMaxNackListSize = 250; | 41 const size_t kMaxNackListSize = 250; |
| 39 const int kMaxPacketAgeToNack = 450; | 42 const int kMaxPacketAgeToNack = 450; |
| 40 receiver_->SetNackSettings(kMaxNackListSize, kMaxPacketAgeToNack, 0); | 43 receiver_->SetNackSettings(kMaxNackListSize, kMaxPacketAgeToNack, 0); |
| 41 | 44 |
| 42 VideoCodingModule::Codec(kVideoCodecVP8, &settings_); | 45 VideoCodingModule::Codec(kVideoCodecVP8, &settings_); |
| 43 settings_.plType = kUnusedPayloadType; // Use the mocked encoder. | 46 settings_.plType = kUnusedPayloadType; // Use the mocked encoder. |
| 44 EXPECT_EQ(0, receiver_->RegisterReceiveCodec(&settings_, 1, true)); | 47 EXPECT_EQ(0, receiver_->RegisterReceiveCodec(&settings_, 1, true)); |
| 45 } | 48 } |
| 46 | 49 |
| (...skipping 21 matching lines...) Expand all Loading... | |
| 68 EXPECT_CALL(decoder_, Decode(_, _, _, _, _)).Times(1); | 71 EXPECT_CALL(decoder_, Decode(_, _, _, _, _)).Times(1); |
| 69 EXPECT_EQ(0, receiver_->Decode(100)); | 72 EXPECT_EQ(0, receiver_->Decode(100)); |
| 70 } | 73 } |
| 71 | 74 |
| 72 SimulatedClock clock_; | 75 SimulatedClock clock_; |
| 73 NullEventFactory event_factory_; | 76 NullEventFactory event_factory_; |
| 74 VideoCodec settings_; | 77 VideoCodec settings_; |
| 75 NiceMock<MockVideoDecoder> decoder_; | 78 NiceMock<MockVideoDecoder> decoder_; |
| 76 NiceMock<MockPacketRequestCallback> packet_request_callback_; | 79 NiceMock<MockPacketRequestCallback> packet_request_callback_; |
| 77 | 80 |
| 81 std::unique_ptr<VCMTiming> timing_; | |
| 78 std::unique_ptr<VideoReceiver> receiver_; | 82 std::unique_ptr<VideoReceiver> receiver_; |
| 79 }; | 83 }; |
| 80 | 84 |
| 81 TEST_F(TestVideoReceiver, PaddingOnlyFrames) { | 85 TEST_F(TestVideoReceiver, PaddingOnlyFrames) { |
| 82 EXPECT_EQ(0, receiver_->SetVideoProtection(kProtectionNack, true)); | 86 EXPECT_EQ(0, receiver_->SetVideoProtection(kProtectionNack, true)); |
| 83 EXPECT_EQ( | 87 EXPECT_EQ( |
| 84 0, receiver_->RegisterPacketRequestCallback(&packet_request_callback_)); | 88 0, receiver_->RegisterPacketRequestCallback(&packet_request_callback_)); |
| 85 const size_t kPaddingSize = 220; | 89 const size_t kPaddingSize = 220; |
| 86 const uint8_t payload[kPaddingSize] = {0}; | 90 const uint8_t payload[kPaddingSize] = {0}; |
| 87 WebRtcRTPHeader header; | 91 WebRtcRTPHeader header; |
| (...skipping 112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 200 TEST_F(TestVideoReceiver, ReceiverDelay) { | 204 TEST_F(TestVideoReceiver, ReceiverDelay) { |
| 201 EXPECT_EQ(0, receiver_->SetMinReceiverDelay(0)); | 205 EXPECT_EQ(0, receiver_->SetMinReceiverDelay(0)); |
| 202 EXPECT_EQ(0, receiver_->SetMinReceiverDelay(5000)); | 206 EXPECT_EQ(0, receiver_->SetMinReceiverDelay(5000)); |
| 203 EXPECT_EQ(-1, receiver_->SetMinReceiverDelay(-100)); | 207 EXPECT_EQ(-1, receiver_->SetMinReceiverDelay(-100)); |
| 204 EXPECT_EQ(-1, receiver_->SetMinReceiverDelay(10010)); | 208 EXPECT_EQ(-1, receiver_->SetMinReceiverDelay(10010)); |
| 205 } | 209 } |
| 206 | 210 |
| 207 } // namespace | 211 } // namespace |
| 208 } // namespace vcm | 212 } // namespace vcm |
| 209 } // namespace webrtc | 213 } // namespace webrtc |
| OLD | NEW |