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

Side by Side Diff: webrtc/call/call_unittest.cc

Issue 2981513002: Wire up RTP keep-alive in ortc api. (Closed)
Patch Set: Add workaround for gcc Created 3 years, 4 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 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 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 <list> 11 #include <list>
12 #include <map> 12 #include <map>
13 #include <memory> 13 #include <memory>
14 #include <utility> 14 #include <utility>
15 15
16 #include "webrtc/api/test/mock_audio_mixer.h" 16 #include "webrtc/api/test/mock_audio_mixer.h"
17 #include "webrtc/call/audio_state.h" 17 #include "webrtc/call/audio_state.h"
18 #include "webrtc/call/call.h" 18 #include "webrtc/call/call.h"
19 #include "webrtc/call/fake_rtp_transport_controller_send.h" 19 #include "webrtc/call/fake_rtp_transport_controller_send.h"
20 #include "webrtc/logging/rtc_event_log/rtc_event_log.h" 20 #include "webrtc/logging/rtc_event_log/rtc_event_log.h"
21 #include "webrtc/modules/audio_device/include/mock_audio_device.h" 21 #include "webrtc/modules/audio_device/include/mock_audio_device.h"
22 #include "webrtc/modules/audio_mixer/audio_mixer_impl.h" 22 #include "webrtc/modules/audio_mixer/audio_mixer_impl.h"
23 #include "webrtc/modules/congestion_controller/include/mock/mock_send_side_conge stion_controller.h" 23 #include "webrtc/modules/congestion_controller/include/mock/mock_send_side_conge stion_controller.h"
24 #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp.h" 24 #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp.h"
25 #include "webrtc/rtc_base/ptr_util.h" 25 #include "webrtc/rtc_base/ptr_util.h"
26 #include "webrtc/test/fake_encoder.h"
26 #include "webrtc/test/gtest.h" 27 #include "webrtc/test/gtest.h"
27 #include "webrtc/test/mock_audio_decoder_factory.h" 28 #include "webrtc/test/mock_audio_decoder_factory.h"
28 #include "webrtc/test/mock_transport.h" 29 #include "webrtc/test/mock_transport.h"
29 #include "webrtc/test/mock_voice_engine.h" 30 #include "webrtc/test/mock_voice_engine.h"
30 31
31 namespace { 32 namespace {
32 33
33 struct CallHelper { 34 struct CallHelper {
34 explicit CallHelper( 35 explicit CallHelper(
35 rtc::scoped_refptr<webrtc::AudioDecoderFactory> decoder_factory = nullptr) 36 rtc::scoped_refptr<webrtc::AudioDecoderFactory> decoder_factory = nullptr)
(...skipping 275 matching lines...) Expand 10 before | Expand all | Expand 10 after
311 config.remote_ssrc = 5548; 312 config.remote_ssrc = 5548;
312 stream = call->CreateFlexfecReceiveStream(config); 313 stream = call->CreateFlexfecReceiveStream(config);
313 EXPECT_NE(stream, nullptr); 314 EXPECT_NE(stream, nullptr);
314 streams.push_back(stream); 315 streams.push_back(stream);
315 316
316 for (auto s : streams) { 317 for (auto s : streams) {
317 call->DestroyFlexfecReceiveStream(s); 318 call->DestroyFlexfecReceiveStream(s);
318 } 319 }
319 } 320 }
320 321
322 TEST(CallTest, DontAllowKeepaliveReconfiguration) {
323 CallHelper call;
324 webrtc::RtpKeepAliveConfig keep_alive_config;
325
326 // Set default values, shouldn't be a problem.
327 EXPECT_TRUE(call->SetRtpKeepAliveConfig(keep_alive_config));
328
329 // Active keep-alive by setting a non-zero timeout.
330 keep_alive_config.timeout_interval_ms = 15000;
331 EXPECT_TRUE(call->SetRtpKeepAliveConfig(keep_alive_config));
332
333 // Create a minimal send stream.
334 MockTransport transport;
335 VideoSendStream::Config send_stream_config(&transport);
336 test::FakeEncoder fake_encoder(Clock::GetRealTimeClock());
337 send_stream_config.encoder_settings.payload_name = "VP8";
338 send_stream_config.encoder_settings.payload_type = 100;
339 send_stream_config.encoder_settings.encoder = &fake_encoder;
340 send_stream_config.rtp.ssrcs.push_back(1234);
341 VideoEncoderConfig encoder_config;
342 VideoSendStream* const stream = call->CreateVideoSendStream(
343 std::move(send_stream_config), encoder_config.Copy());
344
345 // Setting the keep-alive with the current values is OK (ignored).
346 EXPECT_TRUE(call->SetRtpKeepAliveConfig(keep_alive_config));
347
348 // Updating to a new interval is disallowed.
349 keep_alive_config.timeout_interval_ms = 1000;
350 EXPECT_FALSE(call->SetRtpKeepAliveConfig(keep_alive_config));
351
352 // Destroyg the video send stream, with active streams it's again OK to set
353 // a new keep-alive config.
354 call->DestroyVideoSendStream(stream);
355 EXPECT_TRUE(call->SetRtpKeepAliveConfig(keep_alive_config));
356 }
357
321 namespace { 358 namespace {
322 struct CallBitrateHelper { 359 struct CallBitrateHelper {
323 CallBitrateHelper() : CallBitrateHelper(Call::Config::BitrateConfig()) {} 360 CallBitrateHelper() : CallBitrateHelper(Call::Config::BitrateConfig()) {}
324 361
325 explicit CallBitrateHelper(const Call::Config::BitrateConfig& bitrate_config) 362 explicit CallBitrateHelper(const Call::Config::BitrateConfig& bitrate_config)
326 : mock_cc_(Clock::GetRealTimeClock(), &event_log_, &packet_router_) { 363 : mock_cc_(Clock::GetRealTimeClock(), &event_log_, &packet_router_) {
327 Call::Config config(&event_log_); 364 Call::Config config(&event_log_);
328 config.bitrate_config = bitrate_config; 365 config.bitrate_config = bitrate_config;
329 call_.reset( 366 call_.reset(
330 Call::Create(config, rtc::MakeUnique<FakeRtpTransportControllerSend>( 367 Call::Create(config, rtc::MakeUnique<FakeRtpTransportControllerSend>(
(...skipping 375 matching lines...) Expand 10 before | Expand all | Expand 10 after
706 mask.min_bitrate_bps = rtc::Optional<int>(2000); 743 mask.min_bitrate_bps = rtc::Optional<int>(2000);
707 EXPECT_CALL(call.mock_cc(), SetBweBitrates(1000, -1, 1000)); 744 EXPECT_CALL(call.mock_cc(), SetBweBitrates(1000, -1, 1000));
708 call->SetBitrateConfigMask(mask); 745 call->SetBitrateConfigMask(mask);
709 746
710 // Set min to 3000; the clamped value stays the same so nothing happens. 747 // Set min to 3000; the clamped value stays the same so nothing happens.
711 mask.min_bitrate_bps = rtc::Optional<int>(3000); 748 mask.min_bitrate_bps = rtc::Optional<int>(3000);
712 call->SetBitrateConfigMask(mask); 749 call->SetBitrateConfigMask(mask);
713 } 750 }
714 751
715 } // namespace webrtc 752 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698