 Chromium Code Reviews
 Chromium Code Reviews Issue 2789843002:
  Delete VieRemb class, move functionality to PacketRouter.  (Closed)
    
  
    Issue 2789843002:
  Delete VieRemb class, move functionality to PacketRouter.  (Closed) 
  | OLD | NEW | 
|---|---|
| 1 /* | 1 /* | 
| 2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2016 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 | 
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 #include "webrtc/test/gmock.h" | 21 #include "webrtc/test/gmock.h" | 
| 22 #include "webrtc/test/gtest.h" | 22 #include "webrtc/test/gtest.h" | 
| 23 | 23 | 
| 24 using testing::_; | 24 using testing::_; | 
| 25 using testing::AtLeast; | 25 using testing::AtLeast; | 
| 26 using testing::NiceMock; | 26 using testing::NiceMock; | 
| 27 using testing::Return; | 27 using testing::Return; | 
| 28 using testing::SaveArg; | 28 using testing::SaveArg; | 
| 29 using testing::StrictMock; | 29 using testing::StrictMock; | 
| 30 | 30 | 
| 31 namespace webrtc { | |
| 32 | |
| 31 namespace { | 33 namespace { | 
| 32 const webrtc::PacedPacketInfo kPacingInfo0(0, 5, 2000); | 34 const webrtc::PacedPacketInfo kPacingInfo0(0, 5, 2000); | 
| 33 const webrtc::PacedPacketInfo kPacingInfo1(1, 8, 4000); | 35 const webrtc::PacedPacketInfo kPacingInfo1(1, 8, 4000); | 
| 34 | 36 | 
| 35 // Helper to convert some time format to resolution used in absolute send time | 37 // Helper to convert some time format to resolution used in absolute send time | 
| 36 // header extension, rounded upwards. |t| is the time to convert, in some | 38 // header extension, rounded upwards. |t| is the time to convert, in some | 
| 37 // resolution. |denom| is the value to divide |t| by to get whole seconds, | 39 // resolution. |denom| is the value to divide |t| by to get whole seconds, | 
| 38 // e.g. |denom| = 1000 if |t| is in milliseconds. | 40 // e.g. |denom| = 1000 if |t| is in milliseconds. | 
| 39 uint32_t AbsSendTime(int64_t t, int64_t denom) { | 41 uint32_t AbsSendTime(int64_t t, int64_t denom) { | 
| 40 return (((t << 18) + (denom >> 1)) / denom) & 0x00fffffful; | 42 return (((t << 18) + (denom >> 1)) / denom) & 0x00fffffful; | 
| 41 } | 43 } | 
| 42 | 44 | 
| 45 class MockPacketRouter : public PacketRouter { | |
| 46 public: | |
| 47 MOCK_METHOD2(OnReceiveBitrateChanged, | |
| 48 void(const std::vector<uint32_t>& ssrcs, | |
| 49 uint32_t bitrate)); | |
| 50 }; | |
| 51 | |
| 52 const uint32_t kInitialBitrateBps = 60000; | |
| 53 | |
| 43 } // namespace | 54 } // namespace | 
| 44 | 55 | 
| 45 namespace webrtc { | |
| 46 namespace test { | 56 namespace test { | 
| 47 | 57 | 
| 48 class CongestionControllerTest : public ::testing::Test { | 58 class CongestionControllerTest : public ::testing::Test { | 
| 49 protected: | 59 protected: | 
| 50 CongestionControllerTest() : clock_(123456), target_bitrate_observer_(this) {} | 60 CongestionControllerTest() : clock_(123456), target_bitrate_observer_(this) {} | 
| 51 ~CongestionControllerTest() override {} | 61 ~CongestionControllerTest() override {} | 
| 52 | 62 | 
| 53 void SetUp() override { | 63 void SetUp() override { | 
| 54 pacer_ = new NiceMock<MockPacedSender>(); | 64 pacer_ = new NiceMock<MockPacedSender>(); | 
| 55 std::unique_ptr<PacedSender> pacer(pacer_); // Passes ownership. | 65 std::unique_ptr<PacedSender> pacer(pacer_); // Passes ownership. | 
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 136 | 146 | 
| 137 SimulatedClock clock_; | 147 SimulatedClock clock_; | 
| 138 StrictMock<MockCongestionObserver> observer_; | 148 StrictMock<MockCongestionObserver> observer_; | 
| 139 TargetBitrateObserver target_bitrate_observer_; | 149 TargetBitrateObserver target_bitrate_observer_; | 
| 140 NiceMock<MockPacedSender>* pacer_; | 150 NiceMock<MockPacedSender>* pacer_; | 
| 141 NiceMock<MockRemoteBitrateObserver> remote_bitrate_observer_; | 151 NiceMock<MockRemoteBitrateObserver> remote_bitrate_observer_; | 
| 142 NiceMock<MockRtcEventLog> event_log_; | 152 NiceMock<MockRtcEventLog> event_log_; | 
| 143 std::unique_ptr<RtcpBandwidthObserver> bandwidth_observer_; | 153 std::unique_ptr<RtcpBandwidthObserver> bandwidth_observer_; | 
| 144 PacketRouter packet_router_; | 154 PacketRouter packet_router_; | 
| 145 std::unique_ptr<CongestionController> controller_; | 155 std::unique_ptr<CongestionController> controller_; | 
| 146 const uint32_t kInitialBitrateBps = 60000; | |
| 147 | 156 | 
| 148 rtc::Optional<uint32_t> target_bitrate_bps_; | 157 rtc::Optional<uint32_t> target_bitrate_bps_; | 
| 149 }; | 158 }; | 
| 150 | 159 | 
| 151 TEST_F(CongestionControllerTest, OnNetworkChanged) { | 160 TEST_F(CongestionControllerTest, OnNetworkChanged) { | 
| 152 // Test no change. | 161 // Test no change. | 
| 153 clock_.AdvanceTimeMilliseconds(25); | 162 clock_.AdvanceTimeMilliseconds(25); | 
| 154 controller_->Process(); | 163 controller_->Process(); | 
| 155 | 164 | 
| 156 EXPECT_CALL(observer_, OnNetworkChanged(kInitialBitrateBps * 2, _, _, _)); | 165 EXPECT_CALL(observer_, OnNetworkChanged(kInitialBitrateBps * 2, _, _, _)); | 
| (...skipping 171 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 328 clock_.AdvanceTimeMilliseconds(25); | 337 clock_.AdvanceTimeMilliseconds(25); | 
| 329 controller_->Process(); | 338 controller_->Process(); | 
| 330 | 339 | 
| 331 EXPECT_CALL(observer_, OnNetworkChanged(_, _, _, testing::Ne(0))); | 340 EXPECT_CALL(observer_, OnNetworkChanged(_, _, _, testing::Ne(0))); | 
| 332 EXPECT_CALL(*pacer_, SetEstimatedBitrate(_)); | 341 EXPECT_CALL(*pacer_, SetEstimatedBitrate(_)); | 
| 333 bandwidth_observer_->OnReceivedEstimatedBitrate(kInitialBitrateBps * 2); | 342 bandwidth_observer_->OnReceivedEstimatedBitrate(kInitialBitrateBps * 2); | 
| 334 clock_.AdvanceTimeMilliseconds(25); | 343 clock_.AdvanceTimeMilliseconds(25); | 
| 335 controller_->Process(); | 344 controller_->Process(); | 
| 336 } | 345 } | 
| 337 | 346 | 
| 338 TEST_F(CongestionControllerTest, OnReceivedPacketWithAbsSendTime) { | 347 TEST(ReceiveSideCongestionControllerTest, OnReceivedPacketWithAbsSendTime) { | 
| 
nisse-webrtc
2017/04/03 11:32:35
This test works fine without a test fixture. At so
 | |
| 339 NiceMock<MockCongestionObserver> observer; | 348 StrictMock<MockPacketRouter> packet_router; | 
| 340 StrictMock<MockRemoteBitrateObserver> remote_bitrate_observer; | 349 SimulatedClock clock_(123456); | 
| 341 std::unique_ptr<PacedSender> pacer(new NiceMock<MockPacedSender>()); | 350 | 
| 342 controller_.reset( | 351 ReceiveSideCongestionController controller(&clock_, &packet_router); | 
| 343 new CongestionController(&clock_, &observer, &remote_bitrate_observer, | |
| 344 &event_log_, &packet_router_, std::move(pacer))); | |
| 345 | 352 | 
| 346 size_t payload_size = 1000; | 353 size_t payload_size = 1000; | 
| 347 RTPHeader header; | 354 RTPHeader header; | 
| 348 header.ssrc = 0x11eb21c; | 355 header.ssrc = 0x11eb21c; | 
| 349 header.extension.hasAbsoluteSendTime = true; | 356 header.extension.hasAbsoluteSendTime = true; | 
| 350 | 357 | 
| 351 std::vector<unsigned int> ssrcs; | 358 std::vector<unsigned int> ssrcs; | 
| 352 EXPECT_CALL(remote_bitrate_observer, OnReceiveBitrateChanged(_, _)) | 359 EXPECT_CALL(packet_router, OnReceiveBitrateChanged(_, _)) | 
| 353 .WillRepeatedly(SaveArg<0>(&ssrcs)); | 360 .WillRepeatedly(SaveArg<0>(&ssrcs)); | 
| 354 | 361 | 
| 355 for (int i = 0; i < 10; ++i) { | 362 for (int i = 0; i < 10; ++i) { | 
| 356 clock_.AdvanceTimeMilliseconds((1000 * payload_size) / kInitialBitrateBps); | 363 clock_.AdvanceTimeMilliseconds((1000 * payload_size) / kInitialBitrateBps); | 
| 357 int64_t now_ms = clock_.TimeInMilliseconds(); | 364 int64_t now_ms = clock_.TimeInMilliseconds(); | 
| 358 header.extension.absoluteSendTime = AbsSendTime(now_ms, 1000); | 365 header.extension.absoluteSendTime = AbsSendTime(now_ms, 1000); | 
| 359 controller_->OnReceivedPacket(now_ms, payload_size, header); | 366 controller.OnReceivedPacket(now_ms, payload_size, header); | 
| 360 } | 367 } | 
| 361 | 368 | 
| 362 ASSERT_EQ(1u, ssrcs.size()); | 369 ASSERT_EQ(1u, ssrcs.size()); | 
| 363 EXPECT_EQ(header.ssrc, ssrcs[0]); | 370 EXPECT_EQ(header.ssrc, ssrcs[0]); | 
| 364 } | 371 } | 
| 365 | 372 | 
| 366 TEST_F(CongestionControllerTest, ProbeOnRouteChange) { | 373 TEST_F(CongestionControllerTest, ProbeOnRouteChange) { | 
| 367 testing::Mock::VerifyAndClearExpectations(pacer_); | 374 testing::Mock::VerifyAndClearExpectations(pacer_); | 
| 368 EXPECT_CALL(*pacer_, CreateProbeCluster(kInitialBitrateBps * 6)); | 375 EXPECT_CALL(*pacer_, CreateProbeCluster(kInitialBitrateBps * 6)); | 
| 369 EXPECT_CALL(*pacer_, CreateProbeCluster(kInitialBitrateBps * 12)); | 376 EXPECT_CALL(*pacer_, CreateProbeCluster(kInitialBitrateBps * 12)); | 
| (...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 480 ASSERT_TRUE(target_bitrate_bps_); | 487 ASSERT_TRUE(target_bitrate_bps_); | 
| 481 | 488 | 
| 482 // Repeat, but this time with a building delay, and make sure that the | 489 // Repeat, but this time with a building delay, and make sure that the | 
| 483 // estimation is adjusted downwards. | 490 // estimation is adjusted downwards. | 
| 484 uint32_t bitrate_before_delay = *target_bitrate_bps_; | 491 uint32_t bitrate_before_delay = *target_bitrate_bps_; | 
| 485 PacketTransmissionAndFeedbackBlock(&seq_num, kRunTimeMs, 50); | 492 PacketTransmissionAndFeedbackBlock(&seq_num, kRunTimeMs, 50); | 
| 486 EXPECT_LT(*target_bitrate_bps_, bitrate_before_delay); | 493 EXPECT_LT(*target_bitrate_bps_, bitrate_before_delay); | 
| 487 } | 494 } | 
| 488 } // namespace test | 495 } // namespace test | 
| 489 } // namespace webrtc | 496 } // namespace webrtc | 
| OLD | NEW |