blob: ff5cea5718a6fcc323d16be66ed7573f176f5809 [file] [log] [blame]
jlmiller@webrtc.org5f93d0a2015-01-20 21:36:13 +00001/*
kjellander65c7f672016-02-12 00:05:01 -08002 * Copyright 2009 The WebRTC project authors. All Rights Reserved.
jlmiller@webrtc.org5f93d0a2015-01-20 21:36:13 +00003 *
kjellander65c7f672016-02-12 00:05:01 -08004 * 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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
jlmiller@webrtc.org5f93d0a2015-01-20 21:36:13 +00009 */
henrike@webrtc.org28e20752013-07-10 00:45:36 +000010
kwiberg31022942016-03-11 14:18:21 -080011#include <memory>
12
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020013#include "api/array_view.h"
14#include "media/base/fakemediaengine.h"
15#include "media/base/fakertp.h"
16#include "media/base/mediachannel.h"
17#include "media/base/testutils.h"
18#include "p2p/base/fakecandidatepair.h"
19#include "p2p/base/fakedtlstransport.h"
20#include "p2p/base/fakepackettransport.h"
21#include "pc/channel.h"
22#include "rtc_base/buffer.h"
23#include "rtc_base/checks.h"
24#include "rtc_base/fakeclock.h"
25#include "rtc_base/gunit.h"
26#include "rtc_base/logging.h"
27#include "rtc_base/sslstreamadapter.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000028
henrike@webrtc.org28e20752013-07-10 00:45:36 +000029using cricket::CA_OFFER;
30using cricket::CA_PRANSWER;
31using cricket::CA_ANSWER;
32using cricket::CA_UPDATE;
zhihuangb2cdd932017-01-19 16:54:25 -080033using cricket::DtlsTransportInternal;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000034using cricket::FakeVoiceMediaChannel;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000035using cricket::StreamParams;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000036
Danil Chapovalov33b01f22016-05-11 19:55:27 +020037namespace {
38const cricket::AudioCodec kPcmuCodec(0, "PCMU", 64000, 8000, 1);
39const cricket::AudioCodec kPcmaCodec(8, "PCMA", 64000, 8000, 1);
40const cricket::AudioCodec kIsacCodec(103, "ISAC", 40000, 16000, 1);
perkj26752742016-10-24 01:21:16 -070041const cricket::VideoCodec kH264Codec(97, "H264");
42const cricket::VideoCodec kH264SvcCodec(99, "H264-SVC");
Danil Chapovalov33b01f22016-05-11 19:55:27 +020043const cricket::DataCodec kGoogleDataCodec(101, "google-data");
44const uint32_t kSsrc1 = 0x1111;
45const uint32_t kSsrc2 = 0x2222;
46const uint32_t kSsrc3 = 0x3333;
47const int kAudioPts[] = {0, 8};
48const int kVideoPts[] = {97, 99};
49enum class NetworkIsWorker { Yes, No };
deadbeefc6b6e092016-12-01 12:49:20 -080050const int kDefaultTimeout = 10000; // 10 seconds.
Danil Chapovalov33b01f22016-05-11 19:55:27 +020051} // namespace
henrike@webrtc.org28e20752013-07-10 00:45:36 +000052
deadbeefcbecd352015-09-23 11:50:27 -070053template <class ChannelT,
54 class MediaChannelT,
55 class ContentT,
56 class CodecT,
57 class MediaInfoT,
58 class OptionsT>
henrike@webrtc.org28e20752013-07-10 00:45:36 +000059class Traits {
60 public:
61 typedef ChannelT Channel;
62 typedef MediaChannelT MediaChannel;
63 typedef ContentT Content;
64 typedef CodecT Codec;
65 typedef MediaInfoT MediaInfo;
Fredrik Solenbergb071a192015-09-17 16:42:56 +020066 typedef OptionsT Options;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000067};
68
henrike@webrtc.org28e20752013-07-10 00:45:36 +000069class VoiceTraits : public Traits<cricket::VoiceChannel,
70 cricket::FakeVoiceMediaChannel,
71 cricket::AudioContentDescription,
72 cricket::AudioCodec,
Fredrik Solenbergb071a192015-09-17 16:42:56 +020073 cricket::VoiceMediaInfo,
deadbeefcbecd352015-09-23 11:50:27 -070074 cricket::AudioOptions> {};
henrike@webrtc.org28e20752013-07-10 00:45:36 +000075
76class VideoTraits : public Traits<cricket::VideoChannel,
77 cricket::FakeVideoMediaChannel,
78 cricket::VideoContentDescription,
79 cricket::VideoCodec,
Fredrik Solenbergb071a192015-09-17 16:42:56 +020080 cricket::VideoMediaInfo,
deadbeefcbecd352015-09-23 11:50:27 -070081 cricket::VideoOptions> {};
henrike@webrtc.org28e20752013-07-10 00:45:36 +000082
deadbeef953c2ce2017-01-09 14:53:41 -080083class DataTraits : public Traits<cricket::RtpDataChannel,
henrike@webrtc.org28e20752013-07-10 00:45:36 +000084 cricket::FakeDataMediaChannel,
85 cricket::DataContentDescription,
86 cricket::DataCodec,
Fredrik Solenbergb071a192015-09-17 16:42:56 +020087 cricket::DataMediaInfo,
deadbeefcbecd352015-09-23 11:50:27 -070088 cricket::DataOptions> {};
henrike@webrtc.org28e20752013-07-10 00:45:36 +000089
deadbeef953c2ce2017-01-09 14:53:41 -080090// Base class for Voice/Video/RtpDataChannel tests
henrike@webrtc.org28e20752013-07-10 00:45:36 +000091template<class T>
92class ChannelTest : public testing::Test, public sigslot::has_slots<> {
93 public:
deadbeefac22f702017-01-12 21:59:29 -080094 enum Flags {
95 RTCP_MUX = 0x1,
96 RTCP_MUX_REQUIRED = 0x2,
97 SECURE = 0x4,
98 SSRC_MUX = 0x8,
99 DTLS = 0x10,
deadbeef5bd5ca32017-02-10 11:31:50 -0800100 // Use BaseChannel with PacketTransportInternal rather than
deadbeeff5346592017-01-24 21:51:21 -0800101 // DtlsTransportInternal.
deadbeef7914b8c2017-04-21 03:23:33 -0700102 RAW_PACKET_TRANSPORT = 0x20,
jbauch5869f502017-06-29 12:31:36 -0700103 GCM_CIPHER = 0x40,
104 ENCRYPTED_HEADERS = 0x80,
deadbeefac22f702017-01-12 21:59:29 -0800105 };
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000106
Peter Boström34fbfff2015-09-24 19:20:30 +0200107 ChannelTest(bool verify_playout,
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200108 rtc::ArrayView<const uint8_t> rtp_data,
109 rtc::ArrayView<const uint8_t> rtcp_data,
110 NetworkIsWorker network_is_worker)
Peter Boström34fbfff2015-09-24 19:20:30 +0200111 : verify_playout_(verify_playout),
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200112 rtp_packet_(rtp_data.data(), rtp_data.size()),
deadbeeff5346592017-01-24 21:51:21 -0800113 rtcp_packet_(rtcp_data.data(), rtcp_data.size()) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200114 if (network_is_worker == NetworkIsWorker::Yes) {
115 network_thread_ = rtc::Thread::Current();
116 } else {
117 network_thread_keeper_ = rtc::Thread::Create();
118 network_thread_keeper_->SetName("Network", nullptr);
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200119 network_thread_ = network_thread_keeper_.get();
120 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200121 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000122
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000123 void CreateChannels(int flags1, int flags2) {
Fredrik Solenbergb071a192015-09-17 16:42:56 +0200124 CreateChannels(new typename T::MediaChannel(NULL, typename T::Options()),
125 new typename T::MediaChannel(NULL, typename T::Options()),
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200126 flags1, flags2);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000127 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200128 void CreateChannels(typename T::MediaChannel* ch1,
129 typename T::MediaChannel* ch2,
130 int flags1,
131 int flags2) {
deadbeeff5346592017-01-24 21:51:21 -0800132 // Network thread is started in CreateChannels, to allow the test to
133 // configure a fake clock before any threads are spawned and attempt to
134 // access the time.
135 if (network_thread_keeper_) {
136 network_thread_keeper_->Start();
137 }
deadbeefac22f702017-01-12 21:59:29 -0800138 // Make sure RTCP_MUX_REQUIRED isn't set without RTCP_MUX.
deadbeeff5346592017-01-24 21:51:21 -0800139 RTC_DCHECK_NE(RTCP_MUX_REQUIRED, flags1 & (RTCP_MUX | RTCP_MUX_REQUIRED));
140 RTC_DCHECK_NE(RTCP_MUX_REQUIRED, flags2 & (RTCP_MUX | RTCP_MUX_REQUIRED));
141 // Make sure if using raw packet transports, they're used for both
142 // channels.
143 RTC_DCHECK_EQ(flags1 & RAW_PACKET_TRANSPORT, flags2 & RAW_PACKET_TRANSPORT);
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200144 rtc::Thread* worker_thread = rtc::Thread::Current();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000145 media_channel1_ = ch1;
146 media_channel2_ = ch2;
deadbeef5bd5ca32017-02-10 11:31:50 -0800147 rtc::PacketTransportInternal* rtp1 = nullptr;
148 rtc::PacketTransportInternal* rtcp1 = nullptr;
149 rtc::PacketTransportInternal* rtp2 = nullptr;
150 rtc::PacketTransportInternal* rtcp2 = nullptr;
deadbeeff5346592017-01-24 21:51:21 -0800151 // Based on flags, create fake DTLS or raw packet transports.
152 if (flags1 & RAW_PACKET_TRANSPORT) {
153 fake_rtp_packet_transport1_.reset(
154 new rtc::FakePacketTransport("channel1_rtp"));
155 rtp1 = fake_rtp_packet_transport1_.get();
156 if (!(flags1 & RTCP_MUX_REQUIRED)) {
157 fake_rtcp_packet_transport1_.reset(
158 new rtc::FakePacketTransport("channel1_rtcp"));
159 rtcp1 = fake_rtcp_packet_transport1_.get();
160 }
161 } else {
162 // Confirmed to work with KT_RSA and KT_ECDSA.
163 fake_rtp_dtls_transport1_.reset(new cricket::FakeDtlsTransport(
164 "channel1", cricket::ICE_CANDIDATE_COMPONENT_RTP));
165 rtp1 = fake_rtp_dtls_transport1_.get();
166 if (!(flags1 & RTCP_MUX_REQUIRED)) {
167 fake_rtcp_dtls_transport1_.reset(new cricket::FakeDtlsTransport(
168 "channel1", cricket::ICE_CANDIDATE_COMPONENT_RTCP));
169 rtcp1 = fake_rtcp_dtls_transport1_.get();
170 }
171 if (flags1 & DTLS) {
172 auto cert1 =
173 rtc::RTCCertificate::Create(std::unique_ptr<rtc::SSLIdentity>(
174 rtc::SSLIdentity::Generate("session1", rtc::KT_DEFAULT)));
175 fake_rtp_dtls_transport1_->SetLocalCertificate(cert1);
176 if (fake_rtcp_dtls_transport1_) {
177 fake_rtcp_dtls_transport1_->SetLocalCertificate(cert1);
178 }
179 }
jbauch5869f502017-06-29 12:31:36 -0700180 if (flags1 & ENCRYPTED_HEADERS) {
181 rtc::CryptoOptions crypto_options;
182 crypto_options.enable_encrypted_rtp_header_extensions = true;
183 fake_rtp_dtls_transport1_->SetCryptoOptions(crypto_options);
184 if (fake_rtcp_dtls_transport1_) {
185 fake_rtcp_dtls_transport1_->SetCryptoOptions(crypto_options);
186 }
187 }
188 if (flags1 & GCM_CIPHER) {
189 fake_rtp_dtls_transport1_->SetSrtpCryptoSuite(
190 rtc::SRTP_AEAD_AES_256_GCM);
191 if (fake_rtcp_dtls_transport1_) {
192 fake_rtcp_dtls_transport1_->SetSrtpCryptoSuite(
193 rtc::SRTP_AEAD_AES_256_GCM);
194 }
195 }
deadbeeff5346592017-01-24 21:51:21 -0800196 }
197 // Based on flags, create fake DTLS or raw packet transports.
198 if (flags2 & RAW_PACKET_TRANSPORT) {
199 fake_rtp_packet_transport2_.reset(
200 new rtc::FakePacketTransport("channel2_rtp"));
201 rtp2 = fake_rtp_packet_transport2_.get();
202 if (!(flags2 & RTCP_MUX_REQUIRED)) {
203 fake_rtcp_packet_transport2_.reset(
204 new rtc::FakePacketTransport("channel2_rtcp"));
205 rtcp2 = fake_rtcp_packet_transport2_.get();
206 }
207 } else {
208 // Confirmed to work with KT_RSA and KT_ECDSA.
209 fake_rtp_dtls_transport2_.reset(new cricket::FakeDtlsTransport(
210 "channel2", cricket::ICE_CANDIDATE_COMPONENT_RTP));
211 rtp2 = fake_rtp_dtls_transport2_.get();
212 if (!(flags2 & RTCP_MUX_REQUIRED)) {
213 fake_rtcp_dtls_transport2_.reset(new cricket::FakeDtlsTransport(
214 "channel2", cricket::ICE_CANDIDATE_COMPONENT_RTCP));
215 rtcp2 = fake_rtcp_dtls_transport2_.get();
216 }
217 if (flags2 & DTLS) {
218 auto cert2 =
219 rtc::RTCCertificate::Create(std::unique_ptr<rtc::SSLIdentity>(
220 rtc::SSLIdentity::Generate("session2", rtc::KT_DEFAULT)));
221 fake_rtp_dtls_transport2_->SetLocalCertificate(cert2);
222 if (fake_rtcp_dtls_transport2_) {
223 fake_rtcp_dtls_transport2_->SetLocalCertificate(cert2);
224 }
225 }
jbauch5869f502017-06-29 12:31:36 -0700226 if (flags2 & ENCRYPTED_HEADERS) {
227 rtc::CryptoOptions crypto_options;
228 crypto_options.enable_encrypted_rtp_header_extensions = true;
229 fake_rtp_dtls_transport2_->SetCryptoOptions(crypto_options);
230 if (fake_rtcp_dtls_transport2_) {
231 fake_rtcp_dtls_transport2_->SetCryptoOptions(crypto_options);
232 }
233 }
234 if (flags2 & GCM_CIPHER) {
235 fake_rtp_dtls_transport2_->SetSrtpCryptoSuite(
236 rtc::SRTP_AEAD_AES_256_GCM);
237 if (fake_rtcp_dtls_transport2_) {
238 fake_rtcp_dtls_transport2_->SetSrtpCryptoSuite(
239 rtc::SRTP_AEAD_AES_256_GCM);
240 }
241 }
deadbeeff5346592017-01-24 21:51:21 -0800242 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200243 channel1_.reset(
244 CreateChannel(worker_thread, network_thread_, &media_engine_, ch1,
deadbeeff5346592017-01-24 21:51:21 -0800245 fake_rtp_dtls_transport1_.get(),
246 fake_rtcp_dtls_transport1_.get(), rtp1, rtcp1, flags1));
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200247 channel2_.reset(
248 CreateChannel(worker_thread, network_thread_, &media_engine_, ch2,
deadbeeff5346592017-01-24 21:51:21 -0800249 fake_rtp_dtls_transport2_.get(),
250 fake_rtcp_dtls_transport2_.get(), rtp2, rtcp2, flags2));
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200251 channel1_->SignalMediaMonitor.connect(this,
252 &ChannelTest<T>::OnMediaMonitor1);
253 channel2_->SignalMediaMonitor.connect(this,
254 &ChannelTest<T>::OnMediaMonitor2);
deadbeefac22f702017-01-12 21:59:29 -0800255 channel1_->SignalRtcpMuxFullyActive.connect(
deadbeeff5346592017-01-24 21:51:21 -0800256 this, &ChannelTest<T>::OnRtcpMuxFullyActive1);
deadbeefac22f702017-01-12 21:59:29 -0800257 channel2_->SignalRtcpMuxFullyActive.connect(
deadbeeff5346592017-01-24 21:51:21 -0800258 this, &ChannelTest<T>::OnRtcpMuxFullyActive2);
mallinath@webrtc.org19f27e62013-10-13 17:18:27 +0000259 if ((flags1 & DTLS) && (flags2 & DTLS)) {
260 flags1 = (flags1 & ~SECURE);
261 flags2 = (flags2 & ~SECURE);
262 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000263 CreateContent(flags1, kPcmuCodec, kH264Codec,
264 &local_media_content1_);
265 CreateContent(flags2, kPcmuCodec, kH264Codec,
266 &local_media_content2_);
267 CopyContent(local_media_content1_, &remote_media_content1_);
268 CopyContent(local_media_content2_, &remote_media_content2_);
269
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000270 // Add stream information (SSRC) to the local content but not to the remote
271 // content. This means that we per default know the SSRC of what we send but
272 // not what we receive.
273 AddLegacyStreamInContent(kSsrc1, flags1, &local_media_content1_);
274 AddLegacyStreamInContent(kSsrc2, flags2, &local_media_content2_);
275
276 // If SSRC_MUX is used we also need to know the SSRC of the incoming stream.
277 if (flags1 & SSRC_MUX) {
278 AddLegacyStreamInContent(kSsrc1, flags1, &remote_media_content1_);
279 }
280 if (flags2 & SSRC_MUX) {
281 AddLegacyStreamInContent(kSsrc2, flags2, &remote_media_content2_);
282 }
283 }
deadbeefcbecd352015-09-23 11:50:27 -0700284 typename T::Channel* CreateChannel(
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200285 rtc::Thread* worker_thread,
286 rtc::Thread* network_thread,
deadbeefcbecd352015-09-23 11:50:27 -0700287 cricket::MediaEngineInterface* engine,
288 typename T::MediaChannel* ch,
deadbeeff5346592017-01-24 21:51:21 -0800289 cricket::DtlsTransportInternal* fake_rtp_dtls_transport,
290 cricket::DtlsTransportInternal* fake_rtcp_dtls_transport,
deadbeef5bd5ca32017-02-10 11:31:50 -0800291 rtc::PacketTransportInternal* fake_rtp_packet_transport,
292 rtc::PacketTransportInternal* fake_rtcp_packet_transport,
jbauchcb560652016-08-04 05:20:32 -0700293 int flags) {
deadbeeff5346592017-01-24 21:51:21 -0800294 rtc::Thread* signaling_thread = rtc::Thread::Current();
deadbeef7af91dd2016-12-13 11:29:11 -0800295 typename T::Channel* channel = new typename T::Channel(
zhihuangf5b251b2017-01-12 19:37:48 -0800296 worker_thread, network_thread, signaling_thread, engine, ch,
deadbeefac22f702017-01-12 21:59:29 -0800297 cricket::CN_AUDIO, (flags & RTCP_MUX_REQUIRED) != 0,
298 (flags & SECURE) != 0);
deadbeeff5346592017-01-24 21:51:21 -0800299 if (!channel->NeedsRtcpTransport()) {
300 fake_rtcp_dtls_transport = nullptr;
zhihuangf5b251b2017-01-12 19:37:48 -0800301 }
deadbeeff5346592017-01-24 21:51:21 -0800302 if (!channel->Init_w(fake_rtp_dtls_transport, fake_rtcp_dtls_transport,
303 fake_rtp_packet_transport,
304 fake_rtcp_packet_transport)) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000305 delete channel;
306 channel = NULL;
307 }
308 return channel;
309 }
310
deadbeeff5346592017-01-24 21:51:21 -0800311 void ConnectFakeTransports() {
312 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
313 bool asymmetric = false;
314 // Depending on test flags, could be using DTLS or raw packet transport.
315 if (fake_rtp_dtls_transport1_ && fake_rtp_dtls_transport2_) {
316 fake_rtp_dtls_transport1_->SetDestination(
317 fake_rtp_dtls_transport2_.get(), asymmetric);
318 }
319 if (fake_rtcp_dtls_transport1_ && fake_rtcp_dtls_transport2_) {
320 fake_rtcp_dtls_transport1_->SetDestination(
321 fake_rtcp_dtls_transport2_.get(), asymmetric);
322 }
323 if (fake_rtp_packet_transport1_ && fake_rtp_packet_transport2_) {
324 fake_rtp_packet_transport1_->SetDestination(
325 fake_rtp_packet_transport2_.get(), asymmetric);
326 }
327 if (fake_rtcp_packet_transport1_ && fake_rtcp_packet_transport2_) {
328 fake_rtcp_packet_transport1_->SetDestination(
329 fake_rtcp_packet_transport2_.get(), asymmetric);
330 }
331 });
332 }
333
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000334 bool SendInitiate() {
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000335 bool result = channel1_->SetLocalContent(&local_media_content1_,
336 CA_OFFER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000337 if (result) {
338 channel1_->Enable(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000339 result = channel2_->SetRemoteContent(&remote_media_content1_,
340 CA_OFFER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000341 if (result) {
deadbeeff5346592017-01-24 21:51:21 -0800342 ConnectFakeTransports();
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000343 result = channel2_->SetLocalContent(&local_media_content2_,
344 CA_ANSWER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000345 }
346 }
347 return result;
348 }
349
350 bool SendAccept() {
351 channel2_->Enable(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000352 return channel1_->SetRemoteContent(&remote_media_content2_,
353 CA_ANSWER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000354 }
355
356 bool SendOffer() {
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000357 bool result = channel1_->SetLocalContent(&local_media_content1_,
358 CA_OFFER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000359 if (result) {
360 channel1_->Enable(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000361 result = channel2_->SetRemoteContent(&remote_media_content1_,
362 CA_OFFER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000363 }
364 return result;
365 }
366
367 bool SendProvisionalAnswer() {
368 bool result = channel2_->SetLocalContent(&local_media_content2_,
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000369 CA_PRANSWER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000370 if (result) {
371 channel2_->Enable(true);
372 result = channel1_->SetRemoteContent(&remote_media_content2_,
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000373 CA_PRANSWER, NULL);
deadbeeff5346592017-01-24 21:51:21 -0800374 ConnectFakeTransports();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000375 }
376 return result;
377 }
378
379 bool SendFinalAnswer() {
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000380 bool result = channel2_->SetLocalContent(&local_media_content2_,
381 CA_ANSWER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000382 if (result)
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000383 result = channel1_->SetRemoteContent(&remote_media_content2_,
384 CA_ANSWER, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000385 return result;
386 }
387
deadbeeff5346592017-01-24 21:51:21 -0800388 bool Terminate() {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000389 channel1_.reset();
390 channel2_.reset();
deadbeeff5346592017-01-24 21:51:21 -0800391 fake_rtp_dtls_transport1_.reset();
392 fake_rtcp_dtls_transport1_.reset();
393 fake_rtp_dtls_transport2_.reset();
394 fake_rtcp_dtls_transport2_.reset();
395 fake_rtp_packet_transport1_.reset();
396 fake_rtcp_packet_transport1_.reset();
397 fake_rtp_packet_transport2_.reset();
398 fake_rtcp_packet_transport2_.reset();
399 if (network_thread_keeper_) {
400 network_thread_keeper_.reset();
401 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000402 return true;
403 }
404
405 bool AddStream1(int id) {
406 return channel1_->AddRecvStream(cricket::StreamParams::CreateLegacy(id));
407 }
408 bool RemoveStream1(int id) {
409 return channel1_->RemoveRecvStream(id);
410 }
411
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200412 void SendRtp1() {
413 media_channel1_->SendRtp(rtp_packet_.data(), rtp_packet_.size(),
414 rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000415 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200416 void SendRtp2() {
417 media_channel2_->SendRtp(rtp_packet_.data(), rtp_packet_.size(),
418 rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000419 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200420 void SendRtcp1() {
421 media_channel1_->SendRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000422 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200423 void SendRtcp2() {
424 media_channel2_->SendRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000425 }
426 // Methods to send custom data.
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200427 void SendCustomRtp1(uint32_t ssrc, int sequence_number, int pl_type = -1) {
428 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
429 media_channel1_->SendRtp(data.data(), data.size(), rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000430 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200431 void SendCustomRtp2(uint32_t ssrc, int sequence_number, int pl_type = -1) {
432 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
433 media_channel2_->SendRtp(data.data(), data.size(), rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000434 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200435 void SendCustomRtcp1(uint32_t ssrc) {
436 rtc::Buffer data = CreateRtcpData(ssrc);
437 media_channel1_->SendRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000438 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200439 void SendCustomRtcp2(uint32_t ssrc) {
440 rtc::Buffer data = CreateRtcpData(ssrc);
441 media_channel2_->SendRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000442 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200443
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000444 bool CheckRtp1() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200445 return media_channel1_->CheckRtp(rtp_packet_.data(), rtp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000446 }
447 bool CheckRtp2() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200448 return media_channel2_->CheckRtp(rtp_packet_.data(), rtp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000449 }
450 bool CheckRtcp1() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200451 return media_channel1_->CheckRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000452 }
453 bool CheckRtcp2() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200454 return media_channel2_->CheckRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000455 }
456 // Methods to check custom data.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200457 bool CheckCustomRtp1(uint32_t ssrc, int sequence_number, int pl_type = -1) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200458 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
459 return media_channel1_->CheckRtp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000460 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200461 bool CheckCustomRtp2(uint32_t ssrc, int sequence_number, int pl_type = -1) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200462 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
463 return media_channel2_->CheckRtp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000464 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200465 bool CheckCustomRtcp1(uint32_t ssrc) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200466 rtc::Buffer data = CreateRtcpData(ssrc);
467 return media_channel1_->CheckRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000468 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200469 bool CheckCustomRtcp2(uint32_t ssrc) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200470 rtc::Buffer data = CreateRtcpData(ssrc);
471 return media_channel2_->CheckRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000472 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200473 rtc::Buffer CreateRtpData(uint32_t ssrc, int sequence_number, int pl_type) {
474 rtc::Buffer data(rtp_packet_.data(), rtp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000475 // Set SSRC in the rtp packet copy.
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200476 rtc::SetBE32(data.data() + 8, ssrc);
477 rtc::SetBE16(data.data() + 2, sequence_number);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +0000478 if (pl_type >= 0) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200479 rtc::Set8(data.data(), 1, static_cast<uint8_t>(pl_type));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +0000480 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000481 return data;
482 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200483 rtc::Buffer CreateRtcpData(uint32_t ssrc) {
484 rtc::Buffer data(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000485 // Set SSRC in the rtcp packet copy.
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200486 rtc::SetBE32(data.data() + 4, ssrc);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000487 return data;
488 }
489
490 bool CheckNoRtp1() {
491 return media_channel1_->CheckNoRtp();
492 }
493 bool CheckNoRtp2() {
494 return media_channel2_->CheckNoRtp();
495 }
496 bool CheckNoRtcp1() {
497 return media_channel1_->CheckNoRtcp();
498 }
499 bool CheckNoRtcp2() {
500 return media_channel2_->CheckNoRtcp();
501 }
502
503 void CreateContent(int flags,
504 const cricket::AudioCodec& audio_codec,
505 const cricket::VideoCodec& video_codec,
506 typename T::Content* content) {
507 // overridden in specialized classes
508 }
509 void CopyContent(const typename T::Content& source,
510 typename T::Content* content) {
511 // overridden in specialized classes
512 }
513
Steve Anton18ee1d52017-09-11 11:32:35 -0700514 // Creates a MediaContent with one stream.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000515 // kPcmuCodec is used as audio codec and kH264Codec is used as video codec.
Steve Anton18ee1d52017-09-11 11:32:35 -0700516 typename T::Content* CreateMediaContentWithStream(uint32_t ssrc) {
517 typename T::Content* content = new typename T::Content();
518 CreateContent(SECURE, kPcmuCodec, kH264Codec, content);
519 AddLegacyStreamInContent(ssrc, 0, content);
520 return content;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000521 }
522
ossu292d6582016-03-17 02:31:13 -0700523 // Will manage the lifetime of a CallThread, making sure it's
524 // destroyed before this object goes out of scope.
525 class ScopedCallThread {
526 public:
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200527 template <class FunctorT>
528 ScopedCallThread(const FunctorT& functor)
529 : thread_(rtc::Thread::Create()),
530 task_(new rtc::FunctorMessageHandler<void, FunctorT>(functor)) {
ossu292d6582016-03-17 02:31:13 -0700531 thread_->Start();
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -0700532 thread_->Post(RTC_FROM_HERE, task_.get());
ossu292d6582016-03-17 02:31:13 -0700533 }
534
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200535 ~ScopedCallThread() { thread_->Stop(); }
ossu292d6582016-03-17 02:31:13 -0700536
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200537 rtc::Thread* thread() { return thread_.get(); }
ossu292d6582016-03-17 02:31:13 -0700538
539 private:
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200540 std::unique_ptr<rtc::Thread> thread_;
541 std::unique_ptr<rtc::MessageHandler> task_;
ossu292d6582016-03-17 02:31:13 -0700542 };
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000543
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000544 bool CodecMatches(const typename T::Codec& c1, const typename T::Codec& c2) {
545 return false; // overridden in specialized classes
546 }
547
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200548 void OnMediaMonitor1(typename T::Channel* channel,
549 const typename T::MediaInfo& info) {
550 RTC_DCHECK_EQ(channel, channel1_.get());
551 media_info_callbacks1_++;
552 }
553 void OnMediaMonitor2(typename T::Channel* channel,
554 const typename T::MediaInfo& info) {
555 RTC_DCHECK_EQ(channel, channel2_.get());
556 media_info_callbacks2_++;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000557 }
deadbeeff5346592017-01-24 21:51:21 -0800558 void OnRtcpMuxFullyActive1(const std::string&) {
559 rtcp_mux_activated_callbacks1_++;
560 }
561 void OnRtcpMuxFullyActive2(const std::string&) {
562 rtcp_mux_activated_callbacks2_++;
563 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000564
Honghai Zhangcc411c02016-03-29 17:27:21 -0700565 cricket::CandidatePairInterface* last_selected_candidate_pair() {
566 return last_selected_candidate_pair_;
567 }
568
Peter Boström0c4e06b2015-10-07 12:23:21 +0200569 void AddLegacyStreamInContent(uint32_t ssrc,
570 int flags,
571 typename T::Content* content) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000572 // Base implementation.
573 }
574
575 // Tests that can be used by derived classes.
576
577 // Basic sanity check.
578 void TestInit() {
579 CreateChannels(0, 0);
Zhi Huangcf990f52017-09-22 12:12:30 -0700580 EXPECT_FALSE(channel1_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000581 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200582 if (verify_playout_) {
583 EXPECT_FALSE(media_channel1_->playout());
584 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000585 EXPECT_TRUE(media_channel1_->codecs().empty());
586 EXPECT_TRUE(media_channel1_->recv_streams().empty());
587 EXPECT_TRUE(media_channel1_->rtp_packets().empty());
588 EXPECT_TRUE(media_channel1_->rtcp_packets().empty());
589 }
590
591 // Test that SetLocalContent and SetRemoteContent properly configure
592 // the codecs.
593 void TestSetContents() {
594 CreateChannels(0, 0);
595 typename T::Content content;
596 CreateContent(0, kPcmuCodec, kH264Codec, &content);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000597 EXPECT_TRUE(channel1_->SetLocalContent(&content, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000598 EXPECT_EQ(0U, media_channel1_->codecs().size());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000599 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000600 ASSERT_EQ(1U, media_channel1_->codecs().size());
601 EXPECT_TRUE(CodecMatches(content.codecs()[0],
602 media_channel1_->codecs()[0]));
603 }
604
605 // Test that SetLocalContent and SetRemoteContent properly deals
606 // with an empty offer.
607 void TestSetContentsNullOffer() {
608 CreateChannels(0, 0);
609 typename T::Content content;
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000610 EXPECT_TRUE(channel1_->SetLocalContent(&content, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000611 CreateContent(0, kPcmuCodec, kH264Codec, &content);
612 EXPECT_EQ(0U, media_channel1_->codecs().size());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000613 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000614 ASSERT_EQ(1U, media_channel1_->codecs().size());
615 EXPECT_TRUE(CodecMatches(content.codecs()[0],
616 media_channel1_->codecs()[0]));
617 }
618
619 // Test that SetLocalContent and SetRemoteContent properly set RTCP
620 // mux.
621 void TestSetContentsRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -0800622 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000623 typename T::Content content;
624 CreateContent(0, kPcmuCodec, kH264Codec, &content);
625 // Both sides agree on mux. Should no longer be a separate RTCP channel.
626 content.set_rtcp_mux(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000627 EXPECT_TRUE(channel1_->SetLocalContent(&content, CA_OFFER, NULL));
628 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000629 // Only initiator supports mux. Should still have a separate RTCP channel.
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000630 EXPECT_TRUE(channel2_->SetLocalContent(&content, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000631 content.set_rtcp_mux(false);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000632 EXPECT_TRUE(channel2_->SetRemoteContent(&content, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000633 }
634
635 // Test that SetLocalContent and SetRemoteContent properly set RTCP
636 // mux when a provisional answer is received.
637 void TestSetContentsRtcpMuxWithPrAnswer() {
deadbeefac22f702017-01-12 21:59:29 -0800638 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000639 typename T::Content content;
640 CreateContent(0, kPcmuCodec, kH264Codec, &content);
641 content.set_rtcp_mux(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000642 EXPECT_TRUE(channel1_->SetLocalContent(&content, CA_OFFER, NULL));
643 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_PRANSWER, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800644 // Both sides agree on mux. Should signal RTCP mux as fully activated.
645 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000646 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_ANSWER, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800647 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000648 // Only initiator supports mux. Should still have a separate RTCP channel.
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000649 EXPECT_TRUE(channel2_->SetLocalContent(&content, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000650 content.set_rtcp_mux(false);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000651 EXPECT_TRUE(channel2_->SetRemoteContent(&content, CA_PRANSWER, NULL));
652 EXPECT_TRUE(channel2_->SetRemoteContent(&content, CA_ANSWER, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800653 EXPECT_EQ(0, rtcp_mux_activated_callbacks2_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000654 }
655
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000656 // Test that SetRemoteContent properly deals with a content update.
657 void TestSetRemoteContentUpdate() {
658 CreateChannels(0, 0);
659 typename T::Content content;
deadbeefac22f702017-01-12 21:59:29 -0800660 CreateContent(RTCP_MUX | SECURE, kPcmuCodec, kH264Codec, &content);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000661 EXPECT_EQ(0U, media_channel1_->codecs().size());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000662 EXPECT_TRUE(channel1_->SetLocalContent(&content, CA_OFFER, NULL));
663 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000664 ASSERT_EQ(1U, media_channel1_->codecs().size());
665 EXPECT_TRUE(CodecMatches(content.codecs()[0],
666 media_channel1_->codecs()[0]));
667 // Now update with other codecs.
668 typename T::Content update_content;
669 update_content.set_partial(true);
670 CreateContent(0, kIsacCodec, kH264SvcCodec,
671 &update_content);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000672 EXPECT_TRUE(channel1_->SetRemoteContent(&update_content, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000673 ASSERT_EQ(1U, media_channel1_->codecs().size());
674 EXPECT_TRUE(CodecMatches(update_content.codecs()[0],
675 media_channel1_->codecs()[0]));
676 // Now update without any codecs. This is ignored.
677 typename T::Content empty_content;
678 empty_content.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000679 EXPECT_TRUE(channel1_->SetRemoteContent(&empty_content, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000680 ASSERT_EQ(1U, media_channel1_->codecs().size());
681 EXPECT_TRUE(CodecMatches(update_content.codecs()[0],
682 media_channel1_->codecs()[0]));
683 }
684
685 // Test that Add/RemoveStream properly forward to the media channel.
686 void TestStreams() {
687 CreateChannels(0, 0);
688 EXPECT_TRUE(AddStream1(1));
689 EXPECT_TRUE(AddStream1(2));
690 EXPECT_EQ(2U, media_channel1_->recv_streams().size());
691 EXPECT_TRUE(RemoveStream1(2));
692 EXPECT_EQ(1U, media_channel1_->recv_streams().size());
693 EXPECT_TRUE(RemoveStream1(1));
694 EXPECT_EQ(0U, media_channel1_->recv_streams().size());
695 }
696
697 // Test that SetLocalContent properly handles adding and removing StreamParams
698 // to the local content description.
699 // This test uses the CA_UPDATE action that don't require a full
700 // MediaContentDescription to do an update.
701 void TestUpdateStreamsInLocalContent() {
702 cricket::StreamParams stream1;
703 stream1.groupid = "group1";
704 stream1.id = "stream1";
705 stream1.ssrcs.push_back(kSsrc1);
706 stream1.cname = "stream1_cname";
707
708 cricket::StreamParams stream2;
709 stream2.groupid = "group2";
710 stream2.id = "stream2";
711 stream2.ssrcs.push_back(kSsrc2);
712 stream2.cname = "stream2_cname";
713
714 cricket::StreamParams stream3;
715 stream3.groupid = "group3";
716 stream3.id = "stream3";
717 stream3.ssrcs.push_back(kSsrc3);
718 stream3.cname = "stream3_cname";
719
720 CreateChannels(0, 0);
721 typename T::Content content1;
722 CreateContent(0, kPcmuCodec, kH264Codec, &content1);
723 content1.AddStream(stream1);
724 EXPECT_EQ(0u, media_channel1_->send_streams().size());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000725 EXPECT_TRUE(channel1_->SetLocalContent(&content1, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000726
727 ASSERT_EQ(1u, media_channel1_->send_streams().size());
728 EXPECT_EQ(stream1, media_channel1_->send_streams()[0]);
729
730 // Update the local streams by adding another sending stream.
731 // Use a partial updated session description.
732 typename T::Content content2;
733 content2.AddStream(stream2);
734 content2.AddStream(stream3);
735 content2.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000736 EXPECT_TRUE(channel1_->SetLocalContent(&content2, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000737 ASSERT_EQ(3u, media_channel1_->send_streams().size());
738 EXPECT_EQ(stream1, media_channel1_->send_streams()[0]);
739 EXPECT_EQ(stream2, media_channel1_->send_streams()[1]);
740 EXPECT_EQ(stream3, media_channel1_->send_streams()[2]);
741
742 // Update the local streams by removing the first sending stream.
743 // This is done by removing all SSRCS for this particular stream.
744 typename T::Content content3;
745 stream1.ssrcs.clear();
746 content3.AddStream(stream1);
747 content3.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000748 EXPECT_TRUE(channel1_->SetLocalContent(&content3, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000749 ASSERT_EQ(2u, media_channel1_->send_streams().size());
750 EXPECT_EQ(stream2, media_channel1_->send_streams()[0]);
751 EXPECT_EQ(stream3, media_channel1_->send_streams()[1]);
752
753 // Update the local streams with a stream that does not change.
754 // THe update is ignored.
755 typename T::Content content4;
756 content4.AddStream(stream2);
757 content4.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000758 EXPECT_TRUE(channel1_->SetLocalContent(&content4, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000759 ASSERT_EQ(2u, media_channel1_->send_streams().size());
760 EXPECT_EQ(stream2, media_channel1_->send_streams()[0]);
761 EXPECT_EQ(stream3, media_channel1_->send_streams()[1]);
762 }
763
764 // Test that SetRemoteContent properly handles adding and removing
765 // StreamParams to the remote content description.
766 // This test uses the CA_UPDATE action that don't require a full
767 // MediaContentDescription to do an update.
768 void TestUpdateStreamsInRemoteContent() {
769 cricket::StreamParams stream1;
770 stream1.id = "Stream1";
771 stream1.groupid = "1";
772 stream1.ssrcs.push_back(kSsrc1);
773 stream1.cname = "stream1_cname";
774
775 cricket::StreamParams stream2;
776 stream2.id = "Stream2";
777 stream2.groupid = "2";
778 stream2.ssrcs.push_back(kSsrc2);
779 stream2.cname = "stream2_cname";
780
781 cricket::StreamParams stream3;
782 stream3.id = "Stream3";
783 stream3.groupid = "3";
784 stream3.ssrcs.push_back(kSsrc3);
785 stream3.cname = "stream3_cname";
786
787 CreateChannels(0, 0);
788 typename T::Content content1;
789 CreateContent(0, kPcmuCodec, kH264Codec, &content1);
790 content1.AddStream(stream1);
791 EXPECT_EQ(0u, media_channel1_->recv_streams().size());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000792 EXPECT_TRUE(channel1_->SetRemoteContent(&content1, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000793
794 ASSERT_EQ(1u, media_channel1_->codecs().size());
795 ASSERT_EQ(1u, media_channel1_->recv_streams().size());
796 EXPECT_EQ(stream1, media_channel1_->recv_streams()[0]);
797
798 // Update the remote streams by adding another sending stream.
799 // Use a partial updated session description.
800 typename T::Content content2;
801 content2.AddStream(stream2);
802 content2.AddStream(stream3);
803 content2.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000804 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000805 ASSERT_EQ(3u, media_channel1_->recv_streams().size());
806 EXPECT_EQ(stream1, media_channel1_->recv_streams()[0]);
807 EXPECT_EQ(stream2, media_channel1_->recv_streams()[1]);
808 EXPECT_EQ(stream3, media_channel1_->recv_streams()[2]);
809
810 // Update the remote streams by removing the first stream.
811 // This is done by removing all SSRCS for this particular stream.
812 typename T::Content content3;
813 stream1.ssrcs.clear();
814 content3.AddStream(stream1);
815 content3.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000816 EXPECT_TRUE(channel1_->SetRemoteContent(&content3, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000817 ASSERT_EQ(2u, media_channel1_->recv_streams().size());
818 EXPECT_EQ(stream2, media_channel1_->recv_streams()[0]);
819 EXPECT_EQ(stream3, media_channel1_->recv_streams()[1]);
820
821 // Update the remote streams with a stream that does not change.
822 // The update is ignored.
823 typename T::Content content4;
824 content4.AddStream(stream2);
825 content4.set_partial(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000826 EXPECT_TRUE(channel1_->SetRemoteContent(&content4, CA_UPDATE, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000827 ASSERT_EQ(2u, media_channel1_->recv_streams().size());
828 EXPECT_EQ(stream2, media_channel1_->recv_streams()[0]);
829 EXPECT_EQ(stream3, media_channel1_->recv_streams()[1]);
830 }
831
832 // Test that SetLocalContent and SetRemoteContent properly
833 // handles adding and removing StreamParams when the action is a full
834 // CA_OFFER / CA_ANSWER.
835 void TestChangeStreamParamsInContent() {
836 cricket::StreamParams stream1;
837 stream1.groupid = "group1";
838 stream1.id = "stream1";
839 stream1.ssrcs.push_back(kSsrc1);
840 stream1.cname = "stream1_cname";
841
842 cricket::StreamParams stream2;
843 stream2.groupid = "group1";
844 stream2.id = "stream2";
845 stream2.ssrcs.push_back(kSsrc2);
846 stream2.cname = "stream2_cname";
847
848 // Setup a call where channel 1 send |stream1| to channel 2.
849 CreateChannels(0, 0);
850 typename T::Content content1;
851 CreateContent(0, kPcmuCodec, kH264Codec, &content1);
852 content1.AddStream(stream1);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000853 EXPECT_TRUE(channel1_->SetLocalContent(&content1, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000854 EXPECT_TRUE(channel1_->Enable(true));
855 EXPECT_EQ(1u, media_channel1_->send_streams().size());
856
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000857 EXPECT_TRUE(channel2_->SetRemoteContent(&content1, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000858 EXPECT_EQ(1u, media_channel2_->recv_streams().size());
deadbeeff5346592017-01-24 21:51:21 -0800859 ConnectFakeTransports();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000860
861 // Channel 2 do not send anything.
862 typename T::Content content2;
863 CreateContent(0, kPcmuCodec, kH264Codec, &content2);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000864 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000865 EXPECT_EQ(0u, media_channel1_->recv_streams().size());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000866 EXPECT_TRUE(channel2_->SetLocalContent(&content2, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000867 EXPECT_TRUE(channel2_->Enable(true));
868 EXPECT_EQ(0u, media_channel2_->send_streams().size());
869
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200870 SendCustomRtp1(kSsrc1, 0);
871 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000872 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, 0));
873
874 // Let channel 2 update the content by sending |stream2| and enable SRTP.
875 typename T::Content content3;
876 CreateContent(SECURE, kPcmuCodec, kH264Codec, &content3);
877 content3.AddStream(stream2);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000878 EXPECT_TRUE(channel2_->SetLocalContent(&content3, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000879 ASSERT_EQ(1u, media_channel2_->send_streams().size());
880 EXPECT_EQ(stream2, media_channel2_->send_streams()[0]);
881
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000882 EXPECT_TRUE(channel1_->SetRemoteContent(&content3, CA_OFFER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000883 ASSERT_EQ(1u, media_channel1_->recv_streams().size());
884 EXPECT_EQ(stream2, media_channel1_->recv_streams()[0]);
885
886 // Channel 1 replies but stop sending stream1.
887 typename T::Content content4;
888 CreateContent(SECURE, kPcmuCodec, kH264Codec, &content4);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000889 EXPECT_TRUE(channel1_->SetLocalContent(&content4, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000890 EXPECT_EQ(0u, media_channel1_->send_streams().size());
891
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000892 EXPECT_TRUE(channel2_->SetRemoteContent(&content4, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000893 EXPECT_EQ(0u, media_channel2_->recv_streams().size());
894
Zhi Huangcf990f52017-09-22 12:12:30 -0700895 EXPECT_TRUE(channel1_->srtp_active());
896 EXPECT_TRUE(channel2_->srtp_active());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200897 SendCustomRtp2(kSsrc2, 0);
898 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000899 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, 0));
900 }
901
jbauch5869f502017-06-29 12:31:36 -0700902 enum EncryptedHeaderTestScenario {
903 // Offer/Answer are processed before DTLS completes.
904 DEFAULT,
905 // DTLS completes before any Offer/Answer have been sent.
906 DTLS_BEFORE_OFFER_ANSWER,
907 // DTLS completes after channel 2 has processed (remote) Offer and (local)
908 // Answer.
909 DTLS_AFTER_CHANNEL2_READY,
910 };
911
912 // Test that encrypted header extensions are working and can be changed when
913 // sending a new OFFER/ANSWER.
914 void TestChangeEncryptedHeaderExtensions(int flags,
915 EncryptedHeaderTestScenario scenario = DEFAULT) {
916 RTC_CHECK(scenario == 0 || (flags & DTLS));
917 struct PacketListener : public sigslot::has_slots<> {
918 PacketListener() {}
919 void OnReadPacket(rtc::PacketTransportInternal* transport,
920 const char* data, size_t size, const rtc::PacketTime& time,
921 int flags) {
922 CompareHeaderExtensions(
923 reinterpret_cast<const char*>(kPcmuFrameWithExtensions),
924 sizeof(kPcmuFrameWithExtensions), data, size, encrypted_headers,
925 false);
926 }
927 std::vector<int> encrypted_headers;
928 } packet_listener1, packet_listener2;
929
930 cricket::StreamParams stream1;
931 stream1.groupid = "group1";
932 stream1.id = "stream1";
933 stream1.ssrcs.push_back(kSsrc1);
934 stream1.cname = "stream1_cname";
935
936 cricket::StreamParams stream2;
937 stream2.groupid = "group1";
938 stream2.id = "stream2";
939 stream2.ssrcs.push_back(kSsrc2);
940 stream2.cname = "stream2_cname";
941
942 // Use SRTP when testing encrypted extensions.
943 int channel_flags = flags | SECURE | ENCRYPTED_HEADERS;
944 // Enable SDES if channel is not using DTLS.
945 int content_flags = (channel_flags & DTLS) == 0 ? SECURE : 0;
946
947 // kPcmuFrameWithExtensions contains RTP extension headers with ids 1-4.
948 // Make sure to use URIs that are supported for encryption.
949 cricket::RtpHeaderExtensions extensions1;
950 extensions1.push_back(
951 RtpExtension(RtpExtension::kAudioLevelUri, 10));
952 extensions1.push_back(
953 RtpExtension(RtpExtension::kAudioLevelUri, 1, true));
954
955 cricket::RtpHeaderExtensions extensions2;
956 extensions2.push_back(
957 RtpExtension(RtpExtension::kAudioLevelUri, 10));
958 extensions2.push_back(
959 RtpExtension(RtpExtension::kAudioLevelUri, 2, true));
960 extensions2.push_back(
961 RtpExtension(RtpExtension::kVideoRotationUri, 3));
962 extensions2.push_back(
963 RtpExtension(RtpExtension::kTimestampOffsetUri, 4, true));
964
965 // Setup a call where channel 1 send |stream1| to channel 2.
966 CreateChannels(channel_flags, channel_flags);
967 fake_rtp_dtls_transport1_->fake_ice_transport()->SignalReadPacket.connect(
968 &packet_listener1, &PacketListener::OnReadPacket);
969 fake_rtp_dtls_transport2_->fake_ice_transport()->SignalReadPacket.connect(
970 &packet_listener2, &PacketListener::OnReadPacket);
971
972 if (scenario == DTLS_BEFORE_OFFER_ANSWER) {
973 ConnectFakeTransports();
974 WaitForThreads();
975 }
976
977 typename T::Content content1;
978 CreateContent(content_flags, kPcmuCodec, kH264Codec, &content1);
979 content1.AddStream(stream1);
980 content1.set_rtp_header_extensions(extensions1);
981 EXPECT_TRUE(channel1_->SetLocalContent(&content1, CA_OFFER, NULL));
982 EXPECT_TRUE(channel1_->Enable(true));
983 EXPECT_EQ(1u, media_channel1_->send_streams().size());
984 packet_listener1.encrypted_headers.push_back(1);
985
986 EXPECT_TRUE(channel2_->SetRemoteContent(&content1, CA_OFFER, NULL));
987 EXPECT_EQ(1u, media_channel2_->recv_streams().size());
988
989 // Channel 2 sends back |stream2|.
990 typename T::Content content2;
991 CreateContent(content_flags, kPcmuCodec, kH264Codec, &content2);
992 content2.AddStream(stream2);
993 content2.set_rtp_header_extensions(extensions1);
994 EXPECT_TRUE(channel2_->SetLocalContent(&content2, CA_ANSWER, NULL));
995 EXPECT_TRUE(channel2_->Enable(true));
996 EXPECT_EQ(1u, media_channel2_->send_streams().size());
997 packet_listener2.encrypted_headers.push_back(1);
998
999 if (scenario == DTLS_AFTER_CHANNEL2_READY) {
1000 ConnectFakeTransports();
1001 WaitForThreads();
1002 }
1003
1004 if (scenario == DTLS_BEFORE_OFFER_ANSWER ||
1005 scenario == DTLS_AFTER_CHANNEL2_READY) {
1006 // In both scenarios with partially completed Offer/Answer, sending
1007 // packets from Channel 2 to Channel 1 should work.
1008 SendCustomRtp2(kSsrc2, 0);
1009 WaitForThreads();
1010 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, 0));
1011 }
1012
1013 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, CA_ANSWER, NULL));
1014 EXPECT_EQ(1u, media_channel1_->recv_streams().size());
1015
1016 if (scenario == DEFAULT) {
1017 ConnectFakeTransports();
1018 WaitForThreads();
1019 }
1020
1021 SendCustomRtp1(kSsrc1, 0);
1022 SendCustomRtp2(kSsrc2, 0);
1023 WaitForThreads();
1024 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, 0));
1025 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, 0));
1026
1027 // Let channel 2 update the encrypted header extensions.
1028 typename T::Content content3;
1029 CreateContent(content_flags, kPcmuCodec, kH264Codec, &content3);
1030 content3.AddStream(stream2);
1031 content3.set_rtp_header_extensions(extensions2);
1032 EXPECT_TRUE(channel2_->SetLocalContent(&content3, CA_OFFER, NULL));
1033 ASSERT_EQ(1u, media_channel2_->send_streams().size());
1034 EXPECT_EQ(stream2, media_channel2_->send_streams()[0]);
1035 packet_listener2.encrypted_headers.clear();
1036 packet_listener2.encrypted_headers.push_back(2);
1037 packet_listener2.encrypted_headers.push_back(4);
1038
1039 EXPECT_TRUE(channel1_->SetRemoteContent(&content3, CA_OFFER, NULL));
1040 ASSERT_EQ(1u, media_channel1_->recv_streams().size());
1041 EXPECT_EQ(stream2, media_channel1_->recv_streams()[0]);
1042
1043 // Channel 1 is already sending the new encrypted extensions. These
1044 // can be decrypted by channel 2. Channel 2 is still sending the old
1045 // encrypted extensions (which can be decrypted by channel 1).
1046
1047 if (flags & DTLS) {
1048 // DTLS supports updating the encrypted extensions with only the OFFER
1049 // being processed. For SDES both the OFFER and ANSWER must have been
1050 // processed to update encrypted extensions, so we can't check this case.
1051 SendCustomRtp1(kSsrc1, 0);
1052 SendCustomRtp2(kSsrc2, 0);
1053 WaitForThreads();
1054 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, 0));
1055 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, 0));
1056 }
1057
1058 // Channel 1 replies with the same extensions.
1059 typename T::Content content4;
1060 CreateContent(content_flags, kPcmuCodec, kH264Codec, &content4);
1061 content4.AddStream(stream1);
1062 content4.set_rtp_header_extensions(extensions2);
1063 EXPECT_TRUE(channel1_->SetLocalContent(&content4, CA_ANSWER, NULL));
1064 EXPECT_EQ(1u, media_channel1_->send_streams().size());
1065 packet_listener1.encrypted_headers.clear();
1066 packet_listener1.encrypted_headers.push_back(2);
1067 packet_listener1.encrypted_headers.push_back(4);
1068
1069 EXPECT_TRUE(channel2_->SetRemoteContent(&content4, CA_ANSWER, NULL));
1070 EXPECT_EQ(1u, media_channel2_->recv_streams().size());
1071
1072 SendCustomRtp1(kSsrc1, 0);
1073 SendCustomRtp2(kSsrc2, 0);
1074 WaitForThreads();
1075 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, 0));
1076 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, 0));
1077 }
1078
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001079 // Test that we only start playout and sending at the right times.
1080 void TestPlayoutAndSendingStates() {
1081 CreateChannels(0, 0);
Peter Boström34fbfff2015-09-24 19:20:30 +02001082 if (verify_playout_) {
1083 EXPECT_FALSE(media_channel1_->playout());
1084 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001085 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +02001086 if (verify_playout_) {
1087 EXPECT_FALSE(media_channel2_->playout());
1088 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001089 EXPECT_FALSE(media_channel2_->sending());
1090 EXPECT_TRUE(channel1_->Enable(true));
Peter Boström34fbfff2015-09-24 19:20:30 +02001091 if (verify_playout_) {
1092 EXPECT_FALSE(media_channel1_->playout());
1093 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001094 EXPECT_FALSE(media_channel1_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001095 EXPECT_TRUE(channel1_->SetLocalContent(&local_media_content1_,
1096 CA_OFFER, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +02001097 if (verify_playout_) {
1098 EXPECT_TRUE(media_channel1_->playout());
1099 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001100 EXPECT_FALSE(media_channel1_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001101 EXPECT_TRUE(channel2_->SetRemoteContent(&local_media_content1_,
1102 CA_OFFER, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +02001103 if (verify_playout_) {
1104 EXPECT_FALSE(media_channel2_->playout());
1105 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001106 EXPECT_FALSE(media_channel2_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001107 EXPECT_TRUE(channel2_->SetLocalContent(&local_media_content2_,
1108 CA_ANSWER, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +02001109 if (verify_playout_) {
1110 EXPECT_FALSE(media_channel2_->playout());
1111 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001112 EXPECT_FALSE(media_channel2_->sending());
deadbeeff5346592017-01-24 21:51:21 -08001113 ConnectFakeTransports();
Peter Boström34fbfff2015-09-24 19:20:30 +02001114 if (verify_playout_) {
1115 EXPECT_TRUE(media_channel1_->playout());
1116 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001117 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +02001118 if (verify_playout_) {
1119 EXPECT_FALSE(media_channel2_->playout());
1120 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001121 EXPECT_FALSE(media_channel2_->sending());
1122 EXPECT_TRUE(channel2_->Enable(true));
Peter Boström34fbfff2015-09-24 19:20:30 +02001123 if (verify_playout_) {
1124 EXPECT_TRUE(media_channel2_->playout());
1125 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001126 EXPECT_TRUE(media_channel2_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001127 EXPECT_TRUE(channel1_->SetRemoteContent(&local_media_content2_,
1128 CA_ANSWER, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +02001129 if (verify_playout_) {
1130 EXPECT_TRUE(media_channel1_->playout());
1131 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001132 EXPECT_TRUE(media_channel1_->sending());
1133 }
1134
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001135 // Test that changing the MediaContentDirection in the local and remote
1136 // session description start playout and sending at the right time.
1137 void TestMediaContentDirection() {
1138 CreateChannels(0, 0);
1139 typename T::Content content1;
1140 CreateContent(0, kPcmuCodec, kH264Codec, &content1);
1141 typename T::Content content2;
1142 CreateContent(0, kPcmuCodec, kH264Codec, &content2);
1143 // Set |content2| to be InActive.
1144 content2.set_direction(cricket::MD_INACTIVE);
1145
1146 EXPECT_TRUE(channel1_->Enable(true));
1147 EXPECT_TRUE(channel2_->Enable(true));
Peter Boström34fbfff2015-09-24 19:20:30 +02001148 if (verify_playout_) {
1149 EXPECT_FALSE(media_channel1_->playout());
1150 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001151 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +02001152 if (verify_playout_) {
1153 EXPECT_FALSE(media_channel2_->playout());
1154 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001155 EXPECT_FALSE(media_channel2_->sending());
1156
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001157 EXPECT_TRUE(channel1_->SetLocalContent(&content1, CA_OFFER, NULL));
1158 EXPECT_TRUE(channel2_->SetRemoteContent(&content1, CA_OFFER, NULL));
1159 EXPECT_TRUE(channel2_->SetLocalContent(&content2, CA_PRANSWER, NULL));
1160 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, CA_PRANSWER, NULL));
deadbeeff5346592017-01-24 21:51:21 -08001161 ConnectFakeTransports();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001162
Peter Boström34fbfff2015-09-24 19:20:30 +02001163 if (verify_playout_) {
1164 EXPECT_TRUE(media_channel1_->playout());
1165 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001166 EXPECT_FALSE(media_channel1_->sending()); // remote InActive
Peter Boström34fbfff2015-09-24 19:20:30 +02001167 if (verify_playout_) {
1168 EXPECT_FALSE(media_channel2_->playout()); // local InActive
1169 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001170 EXPECT_FALSE(media_channel2_->sending()); // local InActive
1171
1172 // Update |content2| to be RecvOnly.
1173 content2.set_direction(cricket::MD_RECVONLY);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001174 EXPECT_TRUE(channel2_->SetLocalContent(&content2, CA_PRANSWER, NULL));
1175 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, CA_PRANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001176
Peter Boström34fbfff2015-09-24 19:20:30 +02001177 if (verify_playout_) {
1178 EXPECT_TRUE(media_channel1_->playout());
1179 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001180 EXPECT_TRUE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +02001181 if (verify_playout_) {
1182 EXPECT_TRUE(media_channel2_->playout()); // local RecvOnly
1183 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001184 EXPECT_FALSE(media_channel2_->sending()); // local RecvOnly
1185
1186 // Update |content2| to be SendRecv.
1187 content2.set_direction(cricket::MD_SENDRECV);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001188 EXPECT_TRUE(channel2_->SetLocalContent(&content2, CA_ANSWER, NULL));
1189 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, CA_ANSWER, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001190
Peter Boström34fbfff2015-09-24 19:20:30 +02001191 if (verify_playout_) {
1192 EXPECT_TRUE(media_channel1_->playout());
1193 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001194 EXPECT_TRUE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +02001195 if (verify_playout_) {
1196 EXPECT_TRUE(media_channel2_->playout());
1197 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001198 EXPECT_TRUE(media_channel2_->sending());
1199 }
1200
Honghai Zhangcc411c02016-03-29 17:27:21 -07001201 // Tests that when the transport channel signals a candidate pair change
1202 // event, the media channel will receive a call on the network route change.
1203 void TestNetworkRouteChanges() {
eladalon05b07bb2017-08-24 07:40:16 -07001204 static constexpr uint16_t kLocalNetId = 1;
1205 static constexpr uint16_t kRemoteNetId = 2;
1206 static constexpr int kLastPacketId = 100;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001207
Honghai Zhangcc411c02016-03-29 17:27:21 -07001208 CreateChannels(0, 0);
1209
Honghai Zhangcc411c02016-03-29 17:27:21 -07001210 typename T::MediaChannel* media_channel1 =
1211 static_cast<typename T::MediaChannel*>(channel1_->media_channel());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001212 ASSERT_TRUE(media_channel1);
Honghai Zhangcc411c02016-03-29 17:27:21 -07001213
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001214 media_channel1->set_num_network_route_changes(0);
deadbeeff5346592017-01-24 21:51:21 -08001215 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001216 // The transport channel becomes disconnected.
deadbeeff5346592017-01-24 21:51:21 -08001217 fake_rtp_dtls_transport1_->ice_transport()
1218 ->SignalSelectedCandidatePairChanged(
1219 fake_rtp_dtls_transport1_->ice_transport(), nullptr, -1, false);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001220 });
1221 WaitForThreads();
1222 EXPECT_EQ(1, media_channel1->num_network_route_changes());
Honghai Zhangcc411c02016-03-29 17:27:21 -07001223 EXPECT_FALSE(media_channel1->last_network_route().connected);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001224 media_channel1->set_num_network_route_changes(0);
Honghai Zhangcc411c02016-03-29 17:27:21 -07001225
eladalon05b07bb2017-08-24 07:40:16 -07001226 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001227 // The transport channel becomes connected.
1228 rtc::SocketAddress local_address("192.168.1.1", 1000 /* port number */);
1229 rtc::SocketAddress remote_address("192.168.1.2", 2000 /* port number */);
deadbeeff5346592017-01-24 21:51:21 -08001230 auto candidate_pair = cricket::FakeCandidatePair::Create(
1231 local_address, kLocalNetId, remote_address, kRemoteNetId);
1232 fake_rtp_dtls_transport1_->ice_transport()
1233 ->SignalSelectedCandidatePairChanged(
1234 fake_rtp_dtls_transport1_->ice_transport(), candidate_pair.get(),
1235 kLastPacketId, true);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001236 });
1237 WaitForThreads();
1238 EXPECT_EQ(1, media_channel1->num_network_route_changes());
honghaiz059e1832016-06-24 11:03:55 -07001239 rtc::NetworkRoute expected_network_route(true, kLocalNetId, kRemoteNetId,
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001240 kLastPacketId);
Honghai Zhangcc411c02016-03-29 17:27:21 -07001241 EXPECT_EQ(expected_network_route, media_channel1->last_network_route());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001242 EXPECT_EQ(kLastPacketId,
Honghai Zhang52dce732016-03-31 12:37:31 -07001243 media_channel1->last_network_route().last_sent_packet_id);
michaelt79e05882016-11-08 02:50:09 -08001244 constexpr int kTransportOverheadPerPacket = 28; // Ipv4(20) + UDP(8).
1245 EXPECT_EQ(kTransportOverheadPerPacket,
1246 media_channel1->transport_overhead_per_packet());
Honghai Zhangcc411c02016-03-29 17:27:21 -07001247 }
1248
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001249 // Test setting up a call.
1250 void TestCallSetup() {
1251 CreateChannels(0, 0);
Zhi Huangcf990f52017-09-22 12:12:30 -07001252 EXPECT_FALSE(channel1_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001253 EXPECT_TRUE(SendInitiate());
Peter Boström34fbfff2015-09-24 19:20:30 +02001254 if (verify_playout_) {
1255 EXPECT_TRUE(media_channel1_->playout());
1256 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001257 EXPECT_FALSE(media_channel1_->sending());
1258 EXPECT_TRUE(SendAccept());
Zhi Huangcf990f52017-09-22 12:12:30 -07001259 EXPECT_FALSE(channel1_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001260 EXPECT_TRUE(media_channel1_->sending());
1261 EXPECT_EQ(1U, media_channel1_->codecs().size());
Peter Boström34fbfff2015-09-24 19:20:30 +02001262 if (verify_playout_) {
1263 EXPECT_TRUE(media_channel2_->playout());
1264 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001265 EXPECT_TRUE(media_channel2_->sending());
1266 EXPECT_EQ(1U, media_channel2_->codecs().size());
1267 }
1268
1269 // Test that we don't crash if packets are sent during call teardown
1270 // when RTCP mux is enabled. This is a regression test against a specific
1271 // race condition that would only occur when a RTCP packet was sent during
1272 // teardown of a channel on which RTCP mux was enabled.
1273 void TestCallTeardownRtcpMux() {
1274 class LastWordMediaChannel : public T::MediaChannel {
1275 public:
Fredrik Solenbergb071a192015-09-17 16:42:56 +02001276 LastWordMediaChannel() : T::MediaChannel(NULL, typename T::Options()) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001277 ~LastWordMediaChannel() {
stefanc1aeaf02015-10-15 07:26:07 -07001278 T::MediaChannel::SendRtp(kPcmuFrame, sizeof(kPcmuFrame),
1279 rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001280 T::MediaChannel::SendRtcp(kRtcpReport, sizeof(kRtcpReport));
1281 }
1282 };
1283 CreateChannels(new LastWordMediaChannel(), new LastWordMediaChannel(),
deadbeefac22f702017-01-12 21:59:29 -08001284 RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001285 EXPECT_TRUE(SendInitiate());
1286 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001287 EXPECT_TRUE(Terminate());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001288 }
1289
1290 // Send voice RTP data to the other side and ensure it gets there.
1291 void SendRtpToRtp() {
deadbeefac22f702017-01-12 21:59:29 -08001292 CreateChannels(RTCP_MUX | RTCP_MUX_REQUIRED, RTCP_MUX | RTCP_MUX_REQUIRED);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001293 EXPECT_TRUE(SendInitiate());
1294 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001295 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1296 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001297 SendRtp1();
1298 SendRtp2();
1299 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001300 EXPECT_TRUE(CheckRtp1());
1301 EXPECT_TRUE(CheckRtp2());
1302 EXPECT_TRUE(CheckNoRtp1());
1303 EXPECT_TRUE(CheckNoRtp2());
1304 }
1305
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02001306 void TestDeinit() {
deadbeefac22f702017-01-12 21:59:29 -08001307 CreateChannels(0, 0);
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02001308 EXPECT_TRUE(SendInitiate());
1309 EXPECT_TRUE(SendAccept());
1310 SendRtp1();
1311 SendRtp2();
1312 SendRtcp1();
1313 SendRtcp2();
1314 // Do not wait, destroy channels.
1315 channel1_.reset(nullptr);
1316 channel2_.reset(nullptr);
1317 }
1318
deadbeefac22f702017-01-12 21:59:29 -08001319 // Check that RTCP can be transmitted between both sides.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001320 void SendRtcpToRtcp() {
deadbeefac22f702017-01-12 21:59:29 -08001321 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001322 EXPECT_TRUE(SendInitiate());
1323 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001324 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1325 EXPECT_TRUE(channel2_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001326 SendRtcp1();
1327 SendRtcp2();
1328 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001329 EXPECT_TRUE(CheckRtcp1());
1330 EXPECT_TRUE(CheckRtcp2());
1331 EXPECT_TRUE(CheckNoRtcp1());
1332 EXPECT_TRUE(CheckNoRtcp2());
1333 }
1334
1335 // Check that RTCP is transmitted if only the initiator supports mux.
1336 void SendRtcpMuxToRtcp() {
deadbeefac22f702017-01-12 21:59:29 -08001337 CreateChannels(RTCP_MUX, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001338 EXPECT_TRUE(SendInitiate());
1339 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001340 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1341 EXPECT_TRUE(channel2_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001342 SendRtcp1();
1343 SendRtcp2();
1344 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001345 EXPECT_TRUE(CheckRtcp1());
1346 EXPECT_TRUE(CheckRtcp2());
1347 EXPECT_TRUE(CheckNoRtcp1());
1348 EXPECT_TRUE(CheckNoRtcp2());
1349 }
1350
1351 // Check that RTP and RTCP are transmitted ok when both sides support mux.
1352 void SendRtcpMuxToRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001353 CreateChannels(RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001354 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001355 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1356 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
1357 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001358 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001359 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1360 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001361 SendRtp1();
1362 SendRtp2();
1363 SendRtcp1();
1364 SendRtcp2();
1365 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001366 EXPECT_TRUE(CheckRtp1());
1367 EXPECT_TRUE(CheckRtp2());
1368 EXPECT_TRUE(CheckNoRtp1());
1369 EXPECT_TRUE(CheckNoRtp2());
1370 EXPECT_TRUE(CheckRtcp1());
1371 EXPECT_TRUE(CheckRtcp2());
1372 EXPECT_TRUE(CheckNoRtcp1());
1373 EXPECT_TRUE(CheckNoRtcp2());
1374 }
1375
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001376 // Check that RTP and RTCP are transmitted ok when both sides
1377 // support mux and one the offerer requires mux.
1378 void SendRequireRtcpMuxToRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001379 CreateChannels(RTCP_MUX | RTCP_MUX_REQUIRED, RTCP_MUX);
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001380 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001381 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1382 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001383 EXPECT_TRUE(SendAccept());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001384 SendRtp1();
1385 SendRtp2();
1386 SendRtcp1();
1387 SendRtcp2();
1388 WaitForThreads();
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001389 EXPECT_TRUE(CheckRtp1());
1390 EXPECT_TRUE(CheckRtp2());
1391 EXPECT_TRUE(CheckNoRtp1());
1392 EXPECT_TRUE(CheckNoRtp2());
1393 EXPECT_TRUE(CheckRtcp1());
1394 EXPECT_TRUE(CheckRtcp2());
1395 EXPECT_TRUE(CheckNoRtcp1());
1396 EXPECT_TRUE(CheckNoRtcp2());
1397 }
1398
1399 // Check that RTP and RTCP are transmitted ok when both sides
deadbeefac22f702017-01-12 21:59:29 -08001400 // support mux and only the answerer requires rtcp mux.
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001401 void SendRtcpMuxToRequireRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001402 CreateChannels(RTCP_MUX, RTCP_MUX | RTCP_MUX_REQUIRED);
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001403 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001404 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1405 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
1406 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001407 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001408 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1409 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001410 SendRtp1();
1411 SendRtp2();
1412 SendRtcp1();
1413 SendRtcp2();
1414 WaitForThreads();
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001415 EXPECT_TRUE(CheckRtp1());
1416 EXPECT_TRUE(CheckRtp2());
1417 EXPECT_TRUE(CheckNoRtp1());
1418 EXPECT_TRUE(CheckNoRtp2());
1419 EXPECT_TRUE(CheckRtcp1());
1420 EXPECT_TRUE(CheckRtcp2());
1421 EXPECT_TRUE(CheckNoRtcp1());
1422 EXPECT_TRUE(CheckNoRtcp2());
1423 }
1424
1425 // Check that RTP and RTCP are transmitted ok when both sides
1426 // require mux.
1427 void SendRequireRtcpMuxToRequireRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001428 CreateChannels(RTCP_MUX | RTCP_MUX_REQUIRED, RTCP_MUX | RTCP_MUX_REQUIRED);
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001429 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001430 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1431 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001432 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001433 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001434 SendRtp1();
1435 SendRtp2();
1436 SendRtcp1();
1437 SendRtcp2();
1438 WaitForThreads();
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001439 EXPECT_TRUE(CheckRtp1());
1440 EXPECT_TRUE(CheckRtp2());
1441 EXPECT_TRUE(CheckNoRtp1());
1442 EXPECT_TRUE(CheckNoRtp2());
1443 EXPECT_TRUE(CheckRtcp1());
1444 EXPECT_TRUE(CheckRtcp2());
1445 EXPECT_TRUE(CheckNoRtcp1());
1446 EXPECT_TRUE(CheckNoRtcp2());
1447 }
1448
1449 // Check that SendAccept fails if the answerer doesn't support mux
1450 // and the offerer requires it.
1451 void SendRequireRtcpMuxToNoRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001452 CreateChannels(RTCP_MUX | RTCP_MUX_REQUIRED, 0);
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001453 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001454 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1455 EXPECT_TRUE(channel2_->NeedsRtcpTransport());
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07001456 EXPECT_FALSE(SendAccept());
1457 }
1458
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001459 // Check that RTCP data sent by the initiator before the accept is not muxed.
1460 void SendEarlyRtcpMuxToRtcp() {
deadbeefac22f702017-01-12 21:59:29 -08001461 CreateChannels(RTCP_MUX, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001462 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001463 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1464 EXPECT_TRUE(channel2_->NeedsRtcpTransport());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001465
1466 // RTCP can be sent before the call is accepted, if the transport is ready.
1467 // It should not be muxed though, as the remote side doesn't support mux.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001468 SendRtcp1();
1469 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001470 EXPECT_TRUE(CheckNoRtp2());
1471 EXPECT_TRUE(CheckRtcp2());
1472
1473 // Send RTCP packet from callee and verify that it is received.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001474 SendRtcp2();
1475 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001476 EXPECT_TRUE(CheckNoRtp1());
1477 EXPECT_TRUE(CheckRtcp1());
1478
1479 // Complete call setup and ensure everything is still OK.
1480 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001481 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001482 SendRtcp1();
1483 SendRtcp2();
1484 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001485 EXPECT_TRUE(CheckRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001486 EXPECT_TRUE(CheckRtcp1());
1487 }
1488
1489
1490 // Check that RTCP data is not muxed until both sides have enabled muxing,
1491 // but that we properly demux before we get the accept message, since there
1492 // is a race between RTP data and the jingle accept.
1493 void SendEarlyRtcpMuxToRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001494 CreateChannels(RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001495 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001496 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1497 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001498
1499 // RTCP can't be sent yet, since the RTCP transport isn't writable, and
1500 // we haven't yet received the accept that says we should mux.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001501 SendRtcp1();
1502 WaitForThreads();
1503 EXPECT_TRUE(CheckNoRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001504
1505 // Send muxed RTCP packet from callee and verify that it is received.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001506 SendRtcp2();
1507 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001508 EXPECT_TRUE(CheckNoRtp1());
1509 EXPECT_TRUE(CheckRtcp1());
1510
1511 // Complete call setup and ensure everything is still OK.
deadbeeff5346592017-01-24 21:51:21 -08001512 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001513 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001514 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1515 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001516 SendRtcp1();
1517 SendRtcp2();
1518 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001519 EXPECT_TRUE(CheckRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001520 EXPECT_TRUE(CheckRtcp1());
1521 }
1522
1523 // Test that we properly send SRTP with RTCP in both directions.
deadbeef7914b8c2017-04-21 03:23:33 -07001524 // You can pass in DTLS, RTCP_MUX, and RAW_PACKET_TRANSPORT as flags.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001525 void SendSrtpToSrtp(int flags1_in = 0, int flags2_in = 0) {
deadbeef7914b8c2017-04-21 03:23:33 -07001526 RTC_CHECK((flags1_in & ~(RTCP_MUX | DTLS | RAW_PACKET_TRANSPORT)) == 0);
1527 RTC_CHECK((flags2_in & ~(RTCP_MUX | DTLS | RAW_PACKET_TRANSPORT)) == 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001528
deadbeefac22f702017-01-12 21:59:29 -08001529 int flags1 = SECURE | flags1_in;
1530 int flags2 = SECURE | flags2_in;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001531 bool dtls1 = !!(flags1_in & DTLS);
1532 bool dtls2 = !!(flags2_in & DTLS);
1533 CreateChannels(flags1, flags2);
Zhi Huangcf990f52017-09-22 12:12:30 -07001534 EXPECT_FALSE(channel1_->srtp_active());
1535 EXPECT_FALSE(channel2_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001536 EXPECT_TRUE(SendInitiate());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001537 WaitForThreads();
1538 EXPECT_TRUE(channel1_->writable());
1539 EXPECT_TRUE(channel2_->writable());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001540 EXPECT_TRUE(SendAccept());
Zhi Huangcf990f52017-09-22 12:12:30 -07001541 EXPECT_TRUE(channel1_->srtp_active());
1542 EXPECT_TRUE(channel2_->srtp_active());
1543 EXPECT_EQ(dtls1 && dtls2, channel1_->dtls_active());
1544 EXPECT_EQ(dtls1 && dtls2, channel2_->dtls_active());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001545 SendRtp1();
1546 SendRtp2();
1547 SendRtcp1();
1548 SendRtcp2();
1549 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001550 EXPECT_TRUE(CheckRtp1());
1551 EXPECT_TRUE(CheckRtp2());
1552 EXPECT_TRUE(CheckNoRtp1());
1553 EXPECT_TRUE(CheckNoRtp2());
1554 EXPECT_TRUE(CheckRtcp1());
1555 EXPECT_TRUE(CheckRtcp2());
1556 EXPECT_TRUE(CheckNoRtcp1());
1557 EXPECT_TRUE(CheckNoRtcp2());
1558 }
1559
1560 // Test that we properly handling SRTP negotiating down to RTP.
1561 void SendSrtpToRtp() {
deadbeefac22f702017-01-12 21:59:29 -08001562 CreateChannels(SECURE, 0);
Zhi Huangcf990f52017-09-22 12:12:30 -07001563 EXPECT_FALSE(channel1_->srtp_active());
1564 EXPECT_FALSE(channel2_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001565 EXPECT_TRUE(SendInitiate());
1566 EXPECT_TRUE(SendAccept());
Zhi Huangcf990f52017-09-22 12:12:30 -07001567 EXPECT_FALSE(channel1_->srtp_active());
1568 EXPECT_FALSE(channel2_->srtp_active());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001569 SendRtp1();
1570 SendRtp2();
1571 SendRtcp1();
1572 SendRtcp2();
1573 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001574 EXPECT_TRUE(CheckRtp1());
1575 EXPECT_TRUE(CheckRtp2());
1576 EXPECT_TRUE(CheckNoRtp1());
1577 EXPECT_TRUE(CheckNoRtp2());
1578 EXPECT_TRUE(CheckRtcp1());
1579 EXPECT_TRUE(CheckRtcp2());
1580 EXPECT_TRUE(CheckNoRtcp1());
1581 EXPECT_TRUE(CheckNoRtcp2());
1582 }
1583
1584 // Test that we can send and receive early media when a provisional answer is
1585 // sent and received. The test uses SRTP, RTCP mux and SSRC mux.
1586 void SendEarlyMediaUsingRtcpMuxSrtp() {
1587 int sequence_number1_1 = 0, sequence_number2_2 = 0;
1588
deadbeefac22f702017-01-12 21:59:29 -08001589 CreateChannels(SSRC_MUX | RTCP_MUX | SECURE,
1590 SSRC_MUX | RTCP_MUX | SECURE);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001591 EXPECT_TRUE(SendOffer());
1592 EXPECT_TRUE(SendProvisionalAnswer());
Zhi Huangcf990f52017-09-22 12:12:30 -07001593 EXPECT_TRUE(channel1_->srtp_active());
1594 EXPECT_TRUE(channel2_->srtp_active());
deadbeeff5346592017-01-24 21:51:21 -08001595 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1596 EXPECT_TRUE(channel2_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001597 WaitForThreads(); // Wait for 'sending' flag go through network thread.
1598 SendCustomRtcp1(kSsrc1);
1599 SendCustomRtp1(kSsrc1, ++sequence_number1_1);
1600 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001601 EXPECT_TRUE(CheckCustomRtcp2(kSsrc1));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001602 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, sequence_number1_1));
1603
1604 // Send packets from callee and verify that it is received.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001605 SendCustomRtcp2(kSsrc2);
1606 SendCustomRtp2(kSsrc2, ++sequence_number2_2);
1607 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001608 EXPECT_TRUE(CheckCustomRtcp1(kSsrc2));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001609 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, sequence_number2_2));
1610
1611 // Complete call setup and ensure everything is still OK.
deadbeeff5346592017-01-24 21:51:21 -08001612 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
1613 EXPECT_EQ(0, rtcp_mux_activated_callbacks2_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001614 EXPECT_TRUE(SendFinalAnswer());
deadbeeff5346592017-01-24 21:51:21 -08001615 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1616 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
1617 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
1618 EXPECT_EQ(1, rtcp_mux_activated_callbacks2_);
Zhi Huangcf990f52017-09-22 12:12:30 -07001619 EXPECT_TRUE(channel1_->srtp_active());
1620 EXPECT_TRUE(channel2_->srtp_active());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001621 SendCustomRtcp1(kSsrc1);
1622 SendCustomRtp1(kSsrc1, ++sequence_number1_1);
1623 SendCustomRtcp2(kSsrc2);
1624 SendCustomRtp2(kSsrc2, ++sequence_number2_2);
1625 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001626 EXPECT_TRUE(CheckCustomRtcp2(kSsrc1));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001627 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, sequence_number1_1));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001628 EXPECT_TRUE(CheckCustomRtcp1(kSsrc2));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001629 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, sequence_number2_2));
1630 }
1631
1632 // Test that we properly send RTP without SRTP from a thread.
1633 void SendRtpToRtpOnThread() {
deadbeefac22f702017-01-12 21:59:29 -08001634 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001635 EXPECT_TRUE(SendInitiate());
1636 EXPECT_TRUE(SendAccept());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001637 ScopedCallThread send_rtp1([this] { SendRtp1(); });
1638 ScopedCallThread send_rtp2([this] { SendRtp2(); });
1639 ScopedCallThread send_rtcp1([this] { SendRtcp1(); });
1640 ScopedCallThread send_rtcp2([this] { SendRtcp2(); });
1641 rtc::Thread* involved_threads[] = {send_rtp1.thread(), send_rtp2.thread(),
1642 send_rtcp1.thread(),
1643 send_rtcp2.thread()};
1644 WaitForThreads(involved_threads);
1645 EXPECT_TRUE(CheckRtp1());
1646 EXPECT_TRUE(CheckRtp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001647 EXPECT_TRUE(CheckNoRtp1());
1648 EXPECT_TRUE(CheckNoRtp2());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001649 EXPECT_TRUE(CheckRtcp1());
1650 EXPECT_TRUE(CheckRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001651 EXPECT_TRUE(CheckNoRtcp1());
1652 EXPECT_TRUE(CheckNoRtcp2());
1653 }
1654
1655 // Test that we properly send SRTP with RTCP from a thread.
1656 void SendSrtpToSrtpOnThread() {
deadbeefac22f702017-01-12 21:59:29 -08001657 CreateChannels(SECURE, SECURE);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001658 EXPECT_TRUE(SendInitiate());
1659 EXPECT_TRUE(SendAccept());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001660 ScopedCallThread send_rtp1([this] { SendRtp1(); });
1661 ScopedCallThread send_rtp2([this] { SendRtp2(); });
1662 ScopedCallThread send_rtcp1([this] { SendRtcp1(); });
1663 ScopedCallThread send_rtcp2([this] { SendRtcp2(); });
1664 rtc::Thread* involved_threads[] = {send_rtp1.thread(), send_rtp2.thread(),
1665 send_rtcp1.thread(),
1666 send_rtcp2.thread()};
1667 WaitForThreads(involved_threads);
1668 EXPECT_TRUE(CheckRtp1());
1669 EXPECT_TRUE(CheckRtp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001670 EXPECT_TRUE(CheckNoRtp1());
1671 EXPECT_TRUE(CheckNoRtp2());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001672 EXPECT_TRUE(CheckRtcp1());
1673 EXPECT_TRUE(CheckRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001674 EXPECT_TRUE(CheckNoRtcp1());
1675 EXPECT_TRUE(CheckNoRtcp2());
1676 }
1677
1678 // Test that the mediachannel retains its sending state after the transport
1679 // becomes non-writable.
1680 void SendWithWritabilityLoss() {
deadbeefac22f702017-01-12 21:59:29 -08001681 CreateChannels(RTCP_MUX | RTCP_MUX_REQUIRED, RTCP_MUX | RTCP_MUX_REQUIRED);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001682 EXPECT_TRUE(SendInitiate());
1683 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001684 EXPECT_FALSE(channel1_->NeedsRtcpTransport());
1685 EXPECT_FALSE(channel2_->NeedsRtcpTransport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001686 SendRtp1();
1687 SendRtp2();
1688 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001689 EXPECT_TRUE(CheckRtp1());
1690 EXPECT_TRUE(CheckRtp2());
1691 EXPECT_TRUE(CheckNoRtp1());
1692 EXPECT_TRUE(CheckNoRtp2());
1693
wu@webrtc.org97077a32013-10-25 21:18:33 +00001694 // Lose writability, which should fail.
deadbeeff5346592017-01-24 21:51:21 -08001695 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
1696 fake_rtp_dtls_transport1_->SetWritable(false);
1697 });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001698 SendRtp1();
1699 SendRtp2();
1700 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001701 EXPECT_TRUE(CheckRtp1());
1702 EXPECT_TRUE(CheckNoRtp2());
1703
1704 // Regain writability
deadbeeff5346592017-01-24 21:51:21 -08001705 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
1706 fake_rtp_dtls_transport1_->SetWritable(true);
1707 });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001708 EXPECT_TRUE(media_channel1_->sending());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001709 SendRtp1();
1710 SendRtp2();
1711 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001712 EXPECT_TRUE(CheckRtp1());
1713 EXPECT_TRUE(CheckRtp2());
1714 EXPECT_TRUE(CheckNoRtp1());
1715 EXPECT_TRUE(CheckNoRtp2());
1716
1717 // Lose writability completely
deadbeeff5346592017-01-24 21:51:21 -08001718 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
1719 bool asymmetric = true;
1720 fake_rtp_dtls_transport1_->SetDestination(nullptr, asymmetric);
1721 });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001722 EXPECT_TRUE(media_channel1_->sending());
1723
wu@webrtc.org97077a32013-10-25 21:18:33 +00001724 // Should fail also.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001725 SendRtp1();
1726 SendRtp2();
1727 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001728 EXPECT_TRUE(CheckRtp1());
1729 EXPECT_TRUE(CheckNoRtp2());
zhihuangb2cdd932017-01-19 16:54:25 -08001730 EXPECT_TRUE(CheckNoRtp1());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001731
1732 // Gain writability back
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001733 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
deadbeeff5346592017-01-24 21:51:21 -08001734 bool asymmetric = true;
1735 fake_rtp_dtls_transport1_->SetDestination(fake_rtp_dtls_transport2_.get(),
1736 asymmetric);
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001737 });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001738 EXPECT_TRUE(media_channel1_->sending());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001739 SendRtp1();
1740 SendRtp2();
1741 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001742 EXPECT_TRUE(CheckRtp1());
1743 EXPECT_TRUE(CheckRtp2());
1744 EXPECT_TRUE(CheckNoRtp1());
1745 EXPECT_TRUE(CheckNoRtp2());
1746 }
1747
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001748 void SendBundleToBundle(
1749 const int* pl_types, int len, bool rtcp_mux, bool secure) {
1750 ASSERT_EQ(2, len);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001751 int sequence_number1_1 = 0, sequence_number2_2 = 0;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001752 // Only pl_type1 was added to the bundle filter for both |channel1_|
1753 // and |channel2_|.
1754 int pl_type1 = pl_types[0];
1755 int pl_type2 = pl_types[1];
deadbeefac22f702017-01-12 21:59:29 -08001756 int flags = SSRC_MUX;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001757 if (secure) flags |= SECURE;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001758 if (rtcp_mux) {
1759 flags |= RTCP_MUX;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001760 }
1761 CreateChannels(flags, flags);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001762 EXPECT_TRUE(SendInitiate());
deadbeeff5346592017-01-24 21:51:21 -08001763 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1764 EXPECT_EQ(rtcp_mux, !channel2_->NeedsRtcpTransport());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001765 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001766 EXPECT_EQ(rtcp_mux, !channel1_->NeedsRtcpTransport());
1767 EXPECT_EQ(rtcp_mux, !channel2_->NeedsRtcpTransport());
zstein3dcf0e92017-06-01 13:22:42 -07001768 EXPECT_TRUE(channel1_->HandlesPayloadType(pl_type1));
1769 EXPECT_TRUE(channel2_->HandlesPayloadType(pl_type1));
1770 EXPECT_FALSE(channel1_->HandlesPayloadType(pl_type2));
1771 EXPECT_FALSE(channel2_->HandlesPayloadType(pl_type2));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001772
1773 // Both channels can receive pl_type1 only.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001774 SendCustomRtp1(kSsrc1, ++sequence_number1_1, pl_type1);
1775 SendCustomRtp2(kSsrc2, ++sequence_number2_2, pl_type1);
1776 WaitForThreads();
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001777 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, sequence_number1_1, pl_type1));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001778 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, sequence_number2_2, pl_type1));
1779 EXPECT_TRUE(CheckNoRtp1());
1780 EXPECT_TRUE(CheckNoRtp2());
1781
1782 // RTCP test
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001783 SendCustomRtp1(kSsrc1, ++sequence_number1_1, pl_type2);
1784 SendCustomRtp2(kSsrc2, ++sequence_number2_2, pl_type2);
1785 WaitForThreads();
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001786 EXPECT_FALSE(CheckCustomRtp2(kSsrc1, sequence_number1_1, pl_type2));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001787 EXPECT_FALSE(CheckCustomRtp1(kSsrc2, sequence_number2_2, pl_type2));
1788
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001789 SendCustomRtcp1(kSsrc1);
1790 SendCustomRtcp2(kSsrc2);
1791 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001792 EXPECT_TRUE(CheckCustomRtcp1(kSsrc2));
1793 EXPECT_TRUE(CheckNoRtcp1());
1794 EXPECT_TRUE(CheckCustomRtcp2(kSsrc1));
1795 EXPECT_TRUE(CheckNoRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001796
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001797 SendCustomRtcp1(kSsrc2);
1798 SendCustomRtcp2(kSsrc1);
1799 WaitForThreads();
pbos482b12e2015-11-16 10:19:58 -08001800 // Bundle filter shouldn't filter out any RTCP.
1801 EXPECT_TRUE(CheckCustomRtcp1(kSsrc1));
1802 EXPECT_TRUE(CheckCustomRtcp2(kSsrc2));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001803 }
1804
deadbeefc6b6e092016-12-01 12:49:20 -08001805 // Test that the media monitor can be run and gives callbacks.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001806 void TestMediaMonitor() {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001807 CreateChannels(0, 0);
1808 EXPECT_TRUE(SendInitiate());
1809 EXPECT_TRUE(SendAccept());
1810 channel1_->StartMediaMonitor(100);
1811 channel2_->StartMediaMonitor(100);
1812 // Ensure we get callbacks and stop.
deadbeefc6b6e092016-12-01 12:49:20 -08001813 EXPECT_TRUE_WAIT(media_info_callbacks1_ > 0, kDefaultTimeout);
1814 EXPECT_TRUE_WAIT(media_info_callbacks2_ > 0, kDefaultTimeout);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001815 channel1_->StopMediaMonitor();
1816 channel2_->StopMediaMonitor();
1817 // Ensure a restart of a stopped monitor works.
1818 channel1_->StartMediaMonitor(100);
deadbeefc6b6e092016-12-01 12:49:20 -08001819 EXPECT_TRUE_WAIT(media_info_callbacks1_ > 0, kDefaultTimeout);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001820 channel1_->StopMediaMonitor();
1821 // Ensure stopping a stopped monitor is OK.
1822 channel1_->StopMediaMonitor();
1823 }
1824
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001825 void TestSetContentFailure() {
1826 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001827
Peter Thatchera6d24442015-07-09 21:26:36 -07001828 std::string err;
Steve Anton18ee1d52017-09-11 11:32:35 -07001829 std::unique_ptr<typename T::Content> content(
1830 CreateMediaContentWithStream(1));
1831
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001832 media_channel1_->set_fail_set_recv_codecs(true);
Steve Anton18ee1d52017-09-11 11:32:35 -07001833 EXPECT_FALSE(
1834 channel1_->SetLocalContent(content.get(), cricket::CA_OFFER, &err));
1835 EXPECT_FALSE(
1836 channel1_->SetLocalContent(content.get(), cricket::CA_ANSWER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001837
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001838 media_channel1_->set_fail_set_send_codecs(true);
Steve Anton18ee1d52017-09-11 11:32:35 -07001839 EXPECT_FALSE(
1840 channel1_->SetRemoteContent(content.get(), cricket::CA_OFFER, &err));
1841
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001842 media_channel1_->set_fail_set_send_codecs(true);
Steve Anton18ee1d52017-09-11 11:32:35 -07001843 EXPECT_FALSE(
1844 channel1_->SetRemoteContent(content.get(), cricket::CA_ANSWER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001845 }
1846
1847 void TestSendTwoOffers() {
1848 CreateChannels(0, 0);
1849
Peter Thatchera6d24442015-07-09 21:26:36 -07001850 std::string err;
Steve Anton18ee1d52017-09-11 11:32:35 -07001851 std::unique_ptr<typename T::Content> content1(
1852 CreateMediaContentWithStream(1));
1853 EXPECT_TRUE(
1854 channel1_->SetLocalContent(content1.get(), cricket::CA_OFFER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001855 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1856
Steve Anton18ee1d52017-09-11 11:32:35 -07001857 std::unique_ptr<typename T::Content> content2(
1858 CreateMediaContentWithStream(2));
1859 EXPECT_TRUE(
1860 channel1_->SetLocalContent(content2.get(), cricket::CA_OFFER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001861 EXPECT_FALSE(media_channel1_->HasSendStream(1));
1862 EXPECT_TRUE(media_channel1_->HasSendStream(2));
1863 }
1864
1865 void TestReceiveTwoOffers() {
1866 CreateChannels(0, 0);
1867
Peter Thatchera6d24442015-07-09 21:26:36 -07001868 std::string err;
Steve Anton18ee1d52017-09-11 11:32:35 -07001869 std::unique_ptr<typename T::Content> content1(
1870 CreateMediaContentWithStream(1));
1871 EXPECT_TRUE(
1872 channel1_->SetRemoteContent(content1.get(), cricket::CA_OFFER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001873 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1874
Steve Anton18ee1d52017-09-11 11:32:35 -07001875 std::unique_ptr<typename T::Content> content2(
1876 CreateMediaContentWithStream(2));
1877 EXPECT_TRUE(
1878 channel1_->SetRemoteContent(content2.get(), cricket::CA_OFFER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001879 EXPECT_FALSE(media_channel1_->HasRecvStream(1));
1880 EXPECT_TRUE(media_channel1_->HasRecvStream(2));
1881 }
1882
1883 void TestSendPrAnswer() {
1884 CreateChannels(0, 0);
1885
Peter Thatchera6d24442015-07-09 21:26:36 -07001886 std::string err;
1887 // Receive offer
Steve Anton18ee1d52017-09-11 11:32:35 -07001888 std::unique_ptr<typename T::Content> content1(
1889 CreateMediaContentWithStream(1));
1890 EXPECT_TRUE(
1891 channel1_->SetRemoteContent(content1.get(), cricket::CA_OFFER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001892 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1893
Peter Thatchera6d24442015-07-09 21:26:36 -07001894 // Send PR answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001895 std::unique_ptr<typename T::Content> content2(
1896 CreateMediaContentWithStream(2));
1897 EXPECT_TRUE(
1898 channel1_->SetLocalContent(content2.get(), cricket::CA_PRANSWER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001899 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1900 EXPECT_TRUE(media_channel1_->HasSendStream(2));
1901
Peter Thatchera6d24442015-07-09 21:26:36 -07001902 // Send answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001903 std::unique_ptr<typename T::Content> content3(
1904 CreateMediaContentWithStream(3));
1905 EXPECT_TRUE(
1906 channel1_->SetLocalContent(content3.get(), cricket::CA_ANSWER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001907 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1908 EXPECT_FALSE(media_channel1_->HasSendStream(2));
1909 EXPECT_TRUE(media_channel1_->HasSendStream(3));
1910 }
1911
1912 void TestReceivePrAnswer() {
1913 CreateChannels(0, 0);
1914
Peter Thatchera6d24442015-07-09 21:26:36 -07001915 std::string err;
1916 // Send offer
Steve Anton18ee1d52017-09-11 11:32:35 -07001917 std::unique_ptr<typename T::Content> content1(
1918 CreateMediaContentWithStream(1));
1919 EXPECT_TRUE(
1920 channel1_->SetLocalContent(content1.get(), cricket::CA_OFFER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001921 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1922
Peter Thatchera6d24442015-07-09 21:26:36 -07001923 // Receive PR answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001924 std::unique_ptr<typename T::Content> content2(
1925 CreateMediaContentWithStream(2));
1926 EXPECT_TRUE(channel1_->SetRemoteContent(content2.get(),
1927 cricket::CA_PRANSWER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001928 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1929 EXPECT_TRUE(media_channel1_->HasRecvStream(2));
1930
Peter Thatchera6d24442015-07-09 21:26:36 -07001931 // Receive answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001932 std::unique_ptr<typename T::Content> content3(
1933 CreateMediaContentWithStream(3));
1934 EXPECT_TRUE(
1935 channel1_->SetRemoteContent(content3.get(), cricket::CA_ANSWER, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001936 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1937 EXPECT_FALSE(media_channel1_->HasRecvStream(2));
1938 EXPECT_TRUE(media_channel1_->HasRecvStream(3));
1939 }
1940
1941 void TestFlushRtcp() {
deadbeefac22f702017-01-12 21:59:29 -08001942 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001943 EXPECT_TRUE(SendInitiate());
1944 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -08001945 EXPECT_TRUE(channel1_->NeedsRtcpTransport());
1946 EXPECT_TRUE(channel2_->NeedsRtcpTransport());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001947
1948 // Send RTCP1 from a different thread.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001949 ScopedCallThread send_rtcp([this] { SendRtcp1(); });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001950 // The sending message is only posted. channel2_ should be empty.
1951 EXPECT_TRUE(CheckNoRtcp2());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001952 rtc::Thread* wait_for[] = {send_rtcp.thread()};
1953 WaitForThreads(wait_for); // Ensure rtcp was posted
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001954
1955 // When channel1_ is deleted, the RTCP packet should be sent out to
1956 // channel2_.
1957 channel1_.reset();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001958 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001959 EXPECT_TRUE(CheckRtcp2());
1960 }
1961
zstein56162b92017-04-24 16:54:35 -07001962 void TestOnTransportReadyToSend() {
deadbeefac22f702017-01-12 21:59:29 -08001963 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001964 EXPECT_FALSE(media_channel1_->ready_to_send());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001965
zstein56162b92017-04-24 16:54:35 -07001966 channel1_->OnTransportReadyToSend(true);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001967 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001968 EXPECT_TRUE(media_channel1_->ready_to_send());
1969
zstein56162b92017-04-24 16:54:35 -07001970 channel1_->OnTransportReadyToSend(false);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001971 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001972 EXPECT_FALSE(media_channel1_->ready_to_send());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001973 }
1974
zstein56162b92017-04-24 16:54:35 -07001975 void TestOnTransportReadyToSendWithRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -08001976 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001977 typename T::Content content;
1978 CreateContent(0, kPcmuCodec, kH264Codec, &content);
deadbeeff5346592017-01-24 21:51:21 -08001979 // Both sides agree on mux. Should signal that RTCP mux is fully active.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001980 content.set_rtcp_mux(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001981 EXPECT_TRUE(channel1_->SetLocalContent(&content, CA_OFFER, NULL));
deadbeeff5346592017-01-24 21:51:21 -08001982 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +00001983 EXPECT_TRUE(channel1_->SetRemoteContent(&content, CA_ANSWER, NULL));
deadbeeff5346592017-01-24 21:51:21 -08001984 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
1985 cricket::FakeDtlsTransport* rtp = fake_rtp_dtls_transport1_.get();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001986 EXPECT_FALSE(media_channel1_->ready_to_send());
1987 // In the case of rtcp mux, the SignalReadyToSend() from rtp channel
1988 // should trigger the MediaChannel's OnReadyToSend.
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001989 network_thread_->Invoke<void>(RTC_FROM_HERE,
1990 [rtp] { rtp->SignalReadyToSend(rtp); });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001991 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001992 EXPECT_TRUE(media_channel1_->ready_to_send());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001993
zstein56162b92017-04-24 16:54:35 -07001994 // TODO(zstein): Find a way to test this without making
1995 // OnTransportReadyToSend public.
1996 network_thread_->Invoke<void>(
1997 RTC_FROM_HERE, [this] { channel1_->OnTransportReadyToSend(false); });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001998 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001999 EXPECT_FALSE(media_channel1_->ready_to_send());
2000 }
2001
skvladdc1c62c2016-03-16 19:07:43 -07002002 bool SetRemoteContentWithBitrateLimit(int remote_limit) {
2003 typename T::Content content;
2004 CreateContent(0, kPcmuCodec, kH264Codec, &content);
2005 content.set_bandwidth(remote_limit);
2006 return channel1_->SetRemoteContent(&content, CA_OFFER, NULL);
2007 }
2008
deadbeefe702b302017-02-04 12:09:01 -08002009 webrtc::RtpParameters BitrateLimitedParameters(rtc::Optional<int> limit) {
skvladdc1c62c2016-03-16 19:07:43 -07002010 webrtc::RtpParameters parameters;
2011 webrtc::RtpEncodingParameters encoding;
2012 encoding.max_bitrate_bps = limit;
2013 parameters.encodings.push_back(encoding);
2014 return parameters;
2015 }
2016
2017 void VerifyMaxBitrate(const webrtc::RtpParameters& parameters,
deadbeefe702b302017-02-04 12:09:01 -08002018 rtc::Optional<int> expected_bitrate) {
skvladdc1c62c2016-03-16 19:07:43 -07002019 EXPECT_EQ(1UL, parameters.encodings.size());
2020 EXPECT_EQ(expected_bitrate, parameters.encodings[0].max_bitrate_bps);
2021 }
2022
2023 void DefaultMaxBitrateIsUnlimited() {
2024 CreateChannels(0, 0);
2025 EXPECT_TRUE(
2026 channel1_->SetLocalContent(&local_media_content1_, CA_OFFER, NULL));
2027 EXPECT_EQ(media_channel1_->max_bps(), -1);
deadbeefe702b302017-02-04 12:09:01 -08002028 VerifyMaxBitrate(media_channel1_->GetRtpSendParameters(kSsrc1),
2029 rtc::Optional<int>());
skvladdc1c62c2016-03-16 19:07:43 -07002030 }
2031
2032 void CanChangeMaxBitrate() {
2033 CreateChannels(0, 0);
2034 EXPECT_TRUE(
2035 channel1_->SetLocalContent(&local_media_content1_, CA_OFFER, NULL));
2036
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -07002037 EXPECT_TRUE(channel1_->SetRtpSendParameters(
deadbeefe702b302017-02-04 12:09:01 -08002038 kSsrc1, BitrateLimitedParameters(rtc::Optional<int>(1000))));
2039 VerifyMaxBitrate(channel1_->GetRtpSendParameters(kSsrc1),
2040 rtc::Optional<int>(1000));
2041 VerifyMaxBitrate(media_channel1_->GetRtpSendParameters(kSsrc1),
2042 rtc::Optional<int>(1000));
skvladdc1c62c2016-03-16 19:07:43 -07002043 EXPECT_EQ(-1, media_channel1_->max_bps());
2044
deadbeefe702b302017-02-04 12:09:01 -08002045 EXPECT_TRUE(channel1_->SetRtpSendParameters(
2046 kSsrc1, BitrateLimitedParameters(rtc::Optional<int>())));
2047 VerifyMaxBitrate(channel1_->GetRtpSendParameters(kSsrc1),
2048 rtc::Optional<int>());
2049 VerifyMaxBitrate(media_channel1_->GetRtpSendParameters(kSsrc1),
2050 rtc::Optional<int>());
skvladdc1c62c2016-03-16 19:07:43 -07002051 EXPECT_EQ(-1, media_channel1_->max_bps());
2052 }
2053
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002054 protected:
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002055 void WaitForThreads() { WaitForThreads(rtc::ArrayView<rtc::Thread*>()); }
2056 static void ProcessThreadQueue(rtc::Thread* thread) {
2057 RTC_DCHECK(thread->IsCurrent());
2058 while (!thread->empty()) {
2059 thread->ProcessMessages(0);
2060 }
2061 }
2062 void WaitForThreads(rtc::ArrayView<rtc::Thread*> threads) {
2063 // |threads| and current thread post packets to network thread.
2064 for (rtc::Thread* thread : threads) {
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07002065 thread->Invoke<void>(RTC_FROM_HERE,
2066 [thread] { ProcessThreadQueue(thread); });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002067 }
2068 ProcessThreadQueue(rtc::Thread::Current());
2069 // Network thread move them around and post back to worker = current thread.
2070 if (!network_thread_->IsCurrent()) {
2071 network_thread_->Invoke<void>(
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07002072 RTC_FROM_HERE, [this] { ProcessThreadQueue(network_thread_); });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002073 }
2074 // Worker thread = current Thread process received messages.
2075 ProcessThreadQueue(rtc::Thread::Current());
2076 }
Peter Boström34fbfff2015-09-24 19:20:30 +02002077 // TODO(pbos): Remove playout from all media channels and let renderers mute
2078 // themselves.
2079 const bool verify_playout_;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002080 std::unique_ptr<rtc::Thread> network_thread_keeper_;
2081 rtc::Thread* network_thread_;
deadbeeff5346592017-01-24 21:51:21 -08002082 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtp_dtls_transport1_;
2083 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtcp_dtls_transport1_;
2084 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtp_dtls_transport2_;
2085 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtcp_dtls_transport2_;
2086 std::unique_ptr<rtc::FakePacketTransport> fake_rtp_packet_transport1_;
2087 std::unique_ptr<rtc::FakePacketTransport> fake_rtcp_packet_transport1_;
2088 std::unique_ptr<rtc::FakePacketTransport> fake_rtp_packet_transport2_;
2089 std::unique_ptr<rtc::FakePacketTransport> fake_rtcp_packet_transport2_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002090 cricket::FakeMediaEngine media_engine_;
2091 // The media channels are owned by the voice channel objects below.
deadbeeff5346592017-01-24 21:51:21 -08002092 typename T::MediaChannel* media_channel1_ = nullptr;
2093 typename T::MediaChannel* media_channel2_ = nullptr;
kwiberg31022942016-03-11 14:18:21 -08002094 std::unique_ptr<typename T::Channel> channel1_;
2095 std::unique_ptr<typename T::Channel> channel2_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002096 typename T::Content local_media_content1_;
2097 typename T::Content local_media_content2_;
2098 typename T::Content remote_media_content1_;
2099 typename T::Content remote_media_content2_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002100 // The RTP and RTCP packets to send in the tests.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002101 rtc::Buffer rtp_packet_;
2102 rtc::Buffer rtcp_packet_;
deadbeeff5346592017-01-24 21:51:21 -08002103 int media_info_callbacks1_ = 0;
2104 int media_info_callbacks2_ = 0;
2105 int rtcp_mux_activated_callbacks1_ = 0;
2106 int rtcp_mux_activated_callbacks2_ = 0;
Honghai Zhangcc411c02016-03-29 17:27:21 -07002107 cricket::CandidatePairInterface* last_selected_candidate_pair_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002108};
2109
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002110template<>
2111void ChannelTest<VoiceTraits>::CreateContent(
2112 int flags,
2113 const cricket::AudioCodec& audio_codec,
2114 const cricket::VideoCodec& video_codec,
2115 cricket::AudioContentDescription* audio) {
2116 audio->AddCodec(audio_codec);
2117 audio->set_rtcp_mux((flags & RTCP_MUX) != 0);
2118 if (flags & SECURE) {
2119 audio->AddCrypto(cricket::CryptoParams(
Guo-wei Shieh456696a2015-09-30 21:48:54 -07002120 1, rtc::CS_AES_CM_128_HMAC_SHA1_32,
2121 "inline:" + rtc::CreateRandomString(40), std::string()));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002122 }
2123}
2124
2125template<>
2126void ChannelTest<VoiceTraits>::CopyContent(
2127 const cricket::AudioContentDescription& source,
2128 cricket::AudioContentDescription* audio) {
2129 *audio = source;
2130}
2131
2132template<>
2133bool ChannelTest<VoiceTraits>::CodecMatches(const cricket::AudioCodec& c1,
2134 const cricket::AudioCodec& c2) {
2135 return c1.name == c2.name && c1.clockrate == c2.clockrate &&
2136 c1.bitrate == c2.bitrate && c1.channels == c2.channels;
2137}
2138
Peter Boström0c4e06b2015-10-07 12:23:21 +02002139template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002140void ChannelTest<VoiceTraits>::AddLegacyStreamInContent(
Peter Boström0c4e06b2015-10-07 12:23:21 +02002141 uint32_t ssrc,
2142 int flags,
2143 cricket::AudioContentDescription* audio) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002144 audio->AddLegacyStream(ssrc);
2145}
2146
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002147class VoiceChannelSingleThreadTest : public ChannelTest<VoiceTraits> {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002148 public:
solenberg1dd98f32015-09-10 01:57:14 -07002149 typedef ChannelTest<VoiceTraits> Base;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002150 VoiceChannelSingleThreadTest()
2151 : Base(true, kPcmuFrame, kRtcpReport, NetworkIsWorker::Yes) {}
2152};
2153
2154class VoiceChannelDoubleThreadTest : public ChannelTest<VoiceTraits> {
2155 public:
2156 typedef ChannelTest<VoiceTraits> Base;
2157 VoiceChannelDoubleThreadTest()
2158 : Base(true, kPcmuFrame, kRtcpReport, NetworkIsWorker::No) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002159};
2160
jbauch5869f502017-06-29 12:31:36 -07002161class VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest
2162 : public ChannelTest<VoiceTraits> {
2163 public:
2164 typedef ChannelTest<VoiceTraits> Base;
2165 VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest()
2166 : Base(true, kPcmuFrameWithExtensions, kRtcpReport,
2167 NetworkIsWorker::Yes) {}
2168};
2169
2170class VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest
2171 : public ChannelTest<VoiceTraits> {
2172 public:
2173 typedef ChannelTest<VoiceTraits> Base;
2174 VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest()
2175 : Base(true, kPcmuFrameWithExtensions, kRtcpReport,
2176 NetworkIsWorker::No) {}
2177};
2178
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002179// override to add NULL parameter
deadbeefcbecd352015-09-23 11:50:27 -07002180template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002181cricket::VideoChannel* ChannelTest<VideoTraits>::CreateChannel(
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002182 rtc::Thread* worker_thread,
2183 rtc::Thread* network_thread,
deadbeefcbecd352015-09-23 11:50:27 -07002184 cricket::MediaEngineInterface* engine,
2185 cricket::FakeVideoMediaChannel* ch,
deadbeeff5346592017-01-24 21:51:21 -08002186 cricket::DtlsTransportInternal* fake_rtp_dtls_transport,
2187 cricket::DtlsTransportInternal* fake_rtcp_dtls_transport,
deadbeef5bd5ca32017-02-10 11:31:50 -08002188 rtc::PacketTransportInternal* fake_rtp_packet_transport,
2189 rtc::PacketTransportInternal* fake_rtcp_packet_transport,
jbauchcb560652016-08-04 05:20:32 -07002190 int flags) {
deadbeeff5346592017-01-24 21:51:21 -08002191 rtc::Thread* signaling_thread = rtc::Thread::Current();
deadbeef7af91dd2016-12-13 11:29:11 -08002192 cricket::VideoChannel* channel = new cricket::VideoChannel(
zhihuangf5b251b2017-01-12 19:37:48 -08002193 worker_thread, network_thread, signaling_thread, ch, cricket::CN_VIDEO,
deadbeefac22f702017-01-12 21:59:29 -08002194 (flags & RTCP_MUX_REQUIRED) != 0, (flags & SECURE) != 0);
deadbeeff5346592017-01-24 21:51:21 -08002195 if (!channel->NeedsRtcpTransport()) {
2196 fake_rtcp_dtls_transport = nullptr;
zhihuangf5b251b2017-01-12 19:37:48 -08002197 }
deadbeeff5346592017-01-24 21:51:21 -08002198 if (!channel->Init_w(fake_rtp_dtls_transport, fake_rtcp_dtls_transport,
2199 fake_rtp_packet_transport, fake_rtcp_packet_transport)) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002200 delete channel;
2201 channel = NULL;
2202 }
2203 return channel;
2204}
2205
2206// override to add 0 parameter
2207template<>
2208bool ChannelTest<VideoTraits>::AddStream1(int id) {
2209 return channel1_->AddRecvStream(cricket::StreamParams::CreateLegacy(id));
2210}
2211
2212template<>
2213void ChannelTest<VideoTraits>::CreateContent(
2214 int flags,
2215 const cricket::AudioCodec& audio_codec,
2216 const cricket::VideoCodec& video_codec,
2217 cricket::VideoContentDescription* video) {
2218 video->AddCodec(video_codec);
2219 video->set_rtcp_mux((flags & RTCP_MUX) != 0);
2220 if (flags & SECURE) {
2221 video->AddCrypto(cricket::CryptoParams(
Guo-wei Shieh456696a2015-09-30 21:48:54 -07002222 1, rtc::CS_AES_CM_128_HMAC_SHA1_80,
2223 "inline:" + rtc::CreateRandomString(40), std::string()));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002224 }
2225}
2226
2227template<>
2228void ChannelTest<VideoTraits>::CopyContent(
2229 const cricket::VideoContentDescription& source,
2230 cricket::VideoContentDescription* video) {
2231 *video = source;
2232}
2233
2234template<>
2235bool ChannelTest<VideoTraits>::CodecMatches(const cricket::VideoCodec& c1,
2236 const cricket::VideoCodec& c2) {
perkj26752742016-10-24 01:21:16 -07002237 return c1.name == c2.name;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002238}
2239
Peter Boström0c4e06b2015-10-07 12:23:21 +02002240template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002241void ChannelTest<VideoTraits>::AddLegacyStreamInContent(
Peter Boström0c4e06b2015-10-07 12:23:21 +02002242 uint32_t ssrc,
2243 int flags,
2244 cricket::VideoContentDescription* video) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002245 video->AddLegacyStream(ssrc);
2246}
2247
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002248class VideoChannelSingleThreadTest : public ChannelTest<VideoTraits> {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002249 public:
solenberg1dd98f32015-09-10 01:57:14 -07002250 typedef ChannelTest<VideoTraits> Base;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002251 VideoChannelSingleThreadTest()
2252 : Base(false, kH264Packet, kRtcpReport, NetworkIsWorker::Yes) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002253};
2254
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002255class VideoChannelDoubleThreadTest : public ChannelTest<VideoTraits> {
2256 public:
2257 typedef ChannelTest<VideoTraits> Base;
2258 VideoChannelDoubleThreadTest()
2259 : Base(false, kH264Packet, kRtcpReport, NetworkIsWorker::No) {}
2260};
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002261
Kári Tristan Helgason8b35df72017-09-25 14:46:43 +02002262TEST_F(VoiceChannelSingleThreadTest, TestInit) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002263 Base::TestInit();
2264 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2265 EXPECT_TRUE(media_channel1_->dtmf_info_queue().empty());
2266}
2267
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02002268TEST_F(VoiceChannelSingleThreadTest, TestDeinit) {
2269 Base::TestDeinit();
2270}
2271
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002272TEST_F(VoiceChannelSingleThreadTest, TestSetContents) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002273 Base::TestSetContents();
2274}
2275
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002276TEST_F(VoiceChannelSingleThreadTest, TestSetContentsNullOffer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002277 Base::TestSetContentsNullOffer();
2278}
2279
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002280TEST_F(VoiceChannelSingleThreadTest, TestSetContentsRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002281 Base::TestSetContentsRtcpMux();
2282}
2283
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002284TEST_F(VoiceChannelSingleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002285 Base::TestSetContentsRtcpMux();
2286}
2287
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002288TEST_F(VoiceChannelSingleThreadTest, TestSetRemoteContentUpdate) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002289 Base::TestSetRemoteContentUpdate();
2290}
2291
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002292TEST_F(VoiceChannelSingleThreadTest, TestStreams) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002293 Base::TestStreams();
2294}
2295
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002296TEST_F(VoiceChannelSingleThreadTest, TestUpdateStreamsInLocalContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002297 Base::TestUpdateStreamsInLocalContent();
2298}
2299
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002300TEST_F(VoiceChannelSingleThreadTest, TestUpdateRemoteStreamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002301 Base::TestUpdateStreamsInRemoteContent();
2302}
2303
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002304TEST_F(VoiceChannelSingleThreadTest, TestChangeStreamParamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002305 Base::TestChangeStreamParamsInContent();
2306}
2307
jbauch5869f502017-06-29 12:31:36 -07002308TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2309 TestChangeEncryptedHeaderExtensionsDtls) {
2310 int flags = DTLS;
2311 Base::TestChangeEncryptedHeaderExtensions(flags);
2312}
2313
2314TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2315 TestChangeEncryptedHeaderExtensionsDtlsScenario1) {
2316 int flags = DTLS;
2317 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_BEFORE_OFFER_ANSWER);
2318}
2319
2320TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2321 TestChangeEncryptedHeaderExtensionsDtlsScenario2) {
2322 int flags = DTLS;
2323 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_AFTER_CHANNEL2_READY);
2324}
2325
2326TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2327 TestChangeEncryptedHeaderExtensionsDtlsGcm) {
2328 int flags = DTLS | GCM_CIPHER;
2329 Base::TestChangeEncryptedHeaderExtensions(flags);
2330}
2331
2332TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2333 TestChangeEncryptedHeaderExtensionsDtlsGcmScenario1) {
2334 int flags = DTLS | GCM_CIPHER;
2335 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_BEFORE_OFFER_ANSWER);
2336}
2337
2338TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2339 TestChangeEncryptedHeaderExtensionsDtlsGcmScenario2) {
2340 int flags = DTLS | GCM_CIPHER;
2341 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_AFTER_CHANNEL2_READY);
2342}
2343
2344TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest,
2345 TestChangeEncryptedHeaderExtensionsSDES) {
2346 int flags = 0;
2347 Base::TestChangeEncryptedHeaderExtensions(flags);
2348}
2349
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002350TEST_F(VoiceChannelSingleThreadTest, TestPlayoutAndSendingStates) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002351 Base::TestPlayoutAndSendingStates();
2352}
2353
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002354TEST_F(VoiceChannelSingleThreadTest, TestMuteStream) {
solenberg1dd98f32015-09-10 01:57:14 -07002355 CreateChannels(0, 0);
2356 // Test that we can Mute the default channel even though the sending SSRC
2357 // is unknown.
2358 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
solenberg1dd98f32015-09-10 01:57:14 -07002359 EXPECT_TRUE(channel1_->SetAudioSend(0, false, nullptr, nullptr));
solenbergdfc8f4f2015-10-01 02:31:10 -07002360 EXPECT_TRUE(media_channel1_->IsStreamMuted(0));
2361 EXPECT_TRUE(channel1_->SetAudioSend(0, true, nullptr, nullptr));
solenberg1dd98f32015-09-10 01:57:14 -07002362 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2363
2364 // Test that we can not mute an unknown SSRC.
solenbergdfc8f4f2015-10-01 02:31:10 -07002365 EXPECT_FALSE(channel1_->SetAudioSend(kSsrc1, false, nullptr, nullptr));
solenberg1dd98f32015-09-10 01:57:14 -07002366
2367 SendInitiate();
2368 // After the local session description has been set, we can mute a stream
2369 // with its SSRC.
solenberg1dd98f32015-09-10 01:57:14 -07002370 EXPECT_TRUE(channel1_->SetAudioSend(kSsrc1, false, nullptr, nullptr));
solenbergdfc8f4f2015-10-01 02:31:10 -07002371 EXPECT_TRUE(media_channel1_->IsStreamMuted(kSsrc1));
2372 EXPECT_TRUE(channel1_->SetAudioSend(kSsrc1, true, nullptr, nullptr));
solenberg1dd98f32015-09-10 01:57:14 -07002373 EXPECT_FALSE(media_channel1_->IsStreamMuted(kSsrc1));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002374}
2375
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002376TEST_F(VoiceChannelSingleThreadTest, TestMediaContentDirection) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002377 Base::TestMediaContentDirection();
2378}
2379
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002380TEST_F(VoiceChannelSingleThreadTest, TestNetworkRouteChanges) {
Honghai Zhangcc411c02016-03-29 17:27:21 -07002381 Base::TestNetworkRouteChanges();
2382}
2383
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002384TEST_F(VoiceChannelSingleThreadTest, TestCallSetup) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002385 Base::TestCallSetup();
2386}
2387
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002388TEST_F(VoiceChannelSingleThreadTest, TestCallTeardownRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002389 Base::TestCallTeardownRtcpMux();
2390}
2391
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002392TEST_F(VoiceChannelSingleThreadTest, SendRtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002393 Base::SendRtpToRtp();
2394}
2395
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002396TEST_F(VoiceChannelSingleThreadTest, SendRtcpToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002397 Base::SendRtcpToRtcp();
2398}
2399
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002400TEST_F(VoiceChannelSingleThreadTest, SendRtcpMuxToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002401 Base::SendRtcpMuxToRtcp();
2402}
2403
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002404TEST_F(VoiceChannelSingleThreadTest, SendRtcpMuxToRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002405 Base::SendRtcpMuxToRtcpMux();
2406}
2407
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002408TEST_F(VoiceChannelSingleThreadTest, SendRequireRtcpMuxToRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07002409 Base::SendRequireRtcpMuxToRtcpMux();
2410}
2411
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002412TEST_F(VoiceChannelSingleThreadTest, SendRtcpMuxToRequireRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07002413 Base::SendRtcpMuxToRequireRtcpMux();
2414}
2415
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002416TEST_F(VoiceChannelSingleThreadTest, SendRequireRtcpMuxToRequireRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07002417 Base::SendRequireRtcpMuxToRequireRtcpMux();
2418}
2419
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002420TEST_F(VoiceChannelSingleThreadTest, SendRequireRtcpMuxToNoRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07002421 Base::SendRequireRtcpMuxToNoRtcpMux();
2422}
2423
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002424TEST_F(VoiceChannelSingleThreadTest, SendEarlyRtcpMuxToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002425 Base::SendEarlyRtcpMuxToRtcp();
2426}
2427
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002428TEST_F(VoiceChannelSingleThreadTest, SendEarlyRtcpMuxToRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002429 Base::SendEarlyRtcpMuxToRtcpMux();
2430}
2431
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002432TEST_F(VoiceChannelSingleThreadTest, SendSrtpToSrtpRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002433 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
2434}
2435
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002436TEST_F(VoiceChannelSingleThreadTest, SendSrtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002437 Base::SendSrtpToSrtp();
2438}
2439
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002440TEST_F(VoiceChannelSingleThreadTest, SendSrtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002441 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
2442}
2443
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002444TEST_F(VoiceChannelSingleThreadTest, SendDtlsSrtpToSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002445 Base::SendSrtpToSrtp(DTLS, 0);
2446}
2447
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002448TEST_F(VoiceChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002449 Base::SendSrtpToSrtp(DTLS, DTLS);
2450}
2451
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002452TEST_F(VoiceChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002453 Base::SendSrtpToSrtp(DTLS | RTCP_MUX, DTLS | RTCP_MUX);
2454}
2455
deadbeeff5346592017-01-24 21:51:21 -08002456// Test using the channel with a raw packet interface, as opposed to a DTLS
2457// transport interface.
2458TEST_F(VoiceChannelSingleThreadTest, SendSrtpToSrtpWithRawPacketTransport) {
2459 Base::SendSrtpToSrtp(RAW_PACKET_TRANSPORT, RAW_PACKET_TRANSPORT);
2460}
2461
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002462TEST_F(VoiceChannelSingleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002463 Base::SendEarlyMediaUsingRtcpMuxSrtp();
2464}
2465
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002466TEST_F(VoiceChannelSingleThreadTest, SendRtpToRtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002467 Base::SendRtpToRtpOnThread();
2468}
2469
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002470TEST_F(VoiceChannelSingleThreadTest, SendSrtpToSrtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002471 Base::SendSrtpToSrtpOnThread();
2472}
2473
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002474TEST_F(VoiceChannelSingleThreadTest, SendWithWritabilityLoss) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002475 Base::SendWithWritabilityLoss();
2476}
2477
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002478TEST_F(VoiceChannelSingleThreadTest, TestMediaMonitor) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002479 Base::TestMediaMonitor();
2480}
2481
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002482// Test that InsertDtmf properly forwards to the media channel.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002483TEST_F(VoiceChannelSingleThreadTest, TestInsertDtmf) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002484 CreateChannels(0, 0);
2485 EXPECT_TRUE(SendInitiate());
2486 EXPECT_TRUE(SendAccept());
2487 EXPECT_EQ(0U, media_channel1_->dtmf_info_queue().size());
2488
solenberg1d63dd02015-12-02 12:35:09 -08002489 EXPECT_TRUE(channel1_->InsertDtmf(1, 3, 100));
2490 EXPECT_TRUE(channel1_->InsertDtmf(2, 5, 110));
2491 EXPECT_TRUE(channel1_->InsertDtmf(3, 7, 120));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002492
henrike@webrtc.org9de257d2013-07-17 14:42:53 +00002493 ASSERT_EQ(3U, media_channel1_->dtmf_info_queue().size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002494 EXPECT_TRUE(CompareDtmfInfo(media_channel1_->dtmf_info_queue()[0],
solenberg1d63dd02015-12-02 12:35:09 -08002495 1, 3, 100));
henrike@webrtc.org9de257d2013-07-17 14:42:53 +00002496 EXPECT_TRUE(CompareDtmfInfo(media_channel1_->dtmf_info_queue()[1],
solenberg1d63dd02015-12-02 12:35:09 -08002497 2, 5, 110));
henrike@webrtc.org9de257d2013-07-17 14:42:53 +00002498 EXPECT_TRUE(CompareDtmfInfo(media_channel1_->dtmf_info_queue()[2],
solenberg1d63dd02015-12-02 12:35:09 -08002499 3, 7, 120));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002500}
2501
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002502TEST_F(VoiceChannelSingleThreadTest, TestSetContentFailure) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002503 Base::TestSetContentFailure();
2504}
2505
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002506TEST_F(VoiceChannelSingleThreadTest, TestSendTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002507 Base::TestSendTwoOffers();
2508}
2509
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002510TEST_F(VoiceChannelSingleThreadTest, TestReceiveTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002511 Base::TestReceiveTwoOffers();
2512}
2513
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002514TEST_F(VoiceChannelSingleThreadTest, TestSendPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002515 Base::TestSendPrAnswer();
2516}
2517
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002518TEST_F(VoiceChannelSingleThreadTest, TestReceivePrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002519 Base::TestReceivePrAnswer();
2520}
2521
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002522TEST_F(VoiceChannelSingleThreadTest, TestFlushRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002523 Base::TestFlushRtcp();
2524}
2525
zstein56162b92017-04-24 16:54:35 -07002526TEST_F(VoiceChannelSingleThreadTest, TestOnTransportReadyToSend) {
2527 Base::TestOnTransportReadyToSend();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002528}
2529
zstein56162b92017-04-24 16:54:35 -07002530TEST_F(VoiceChannelSingleThreadTest, TestOnTransportReadyToSendWithRtcpMux) {
2531 Base::TestOnTransportReadyToSendWithRtcpMux();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002532}
2533
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002534// Test that we can scale the output volume properly for 1:1 calls.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002535TEST_F(VoiceChannelSingleThreadTest, TestScaleVolume1to1Call) {
deadbeefac22f702017-01-12 21:59:29 -08002536 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002537 EXPECT_TRUE(SendInitiate());
2538 EXPECT_TRUE(SendAccept());
solenberg4bac9c52015-10-09 02:32:53 -07002539 double volume;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002540
solenberg4bac9c52015-10-09 02:32:53 -07002541 // Default is (1.0).
2542 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2543 EXPECT_DOUBLE_EQ(1.0, volume);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002544 // invalid ssrc.
solenberg4bac9c52015-10-09 02:32:53 -07002545 EXPECT_FALSE(media_channel1_->GetOutputVolume(3, &volume));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002546
solenberg4bac9c52015-10-09 02:32:53 -07002547 // Set scale to (1.5).
2548 EXPECT_TRUE(channel1_->SetOutputVolume(0, 1.5));
2549 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2550 EXPECT_DOUBLE_EQ(1.5, volume);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002551
solenberg4bac9c52015-10-09 02:32:53 -07002552 // Set scale to (0).
2553 EXPECT_TRUE(channel1_->SetOutputVolume(0, 0.0));
2554 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2555 EXPECT_DOUBLE_EQ(0.0, volume);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002556}
2557
2558// Test that we can scale the output volume properly for multiway calls.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002559TEST_F(VoiceChannelSingleThreadTest, TestScaleVolumeMultiwayCall) {
deadbeefac22f702017-01-12 21:59:29 -08002560 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002561 EXPECT_TRUE(SendInitiate());
2562 EXPECT_TRUE(SendAccept());
2563 EXPECT_TRUE(AddStream1(1));
2564 EXPECT_TRUE(AddStream1(2));
2565
solenberg4bac9c52015-10-09 02:32:53 -07002566 double volume;
2567 // Default is (1.0).
2568 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2569 EXPECT_DOUBLE_EQ(1.0, volume);
2570 EXPECT_TRUE(media_channel1_->GetOutputVolume(1, &volume));
2571 EXPECT_DOUBLE_EQ(1.0, volume);
2572 EXPECT_TRUE(media_channel1_->GetOutputVolume(2, &volume));
2573 EXPECT_DOUBLE_EQ(1.0, volume);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002574 // invalid ssrc.
solenberg4bac9c52015-10-09 02:32:53 -07002575 EXPECT_FALSE(media_channel1_->GetOutputVolume(3, &volume));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002576
solenberg4bac9c52015-10-09 02:32:53 -07002577 // Set scale to (1.5) for ssrc = 1.
2578 EXPECT_TRUE(channel1_->SetOutputVolume(1, 1.5));
2579 EXPECT_TRUE(media_channel1_->GetOutputVolume(1, &volume));
2580 EXPECT_DOUBLE_EQ(1.5, volume);
2581 EXPECT_TRUE(media_channel1_->GetOutputVolume(2, &volume));
2582 EXPECT_DOUBLE_EQ(1.0, volume);
2583 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2584 EXPECT_DOUBLE_EQ(1.0, volume);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002585
solenberg4bac9c52015-10-09 02:32:53 -07002586 // Set scale to (0) for all ssrcs.
2587 EXPECT_TRUE(channel1_->SetOutputVolume(0, 0.0));
2588 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2589 EXPECT_DOUBLE_EQ(0.0, volume);
2590 EXPECT_TRUE(media_channel1_->GetOutputVolume(1, &volume));
2591 EXPECT_DOUBLE_EQ(0.0, volume);
2592 EXPECT_TRUE(media_channel1_->GetOutputVolume(2, &volume));
2593 EXPECT_DOUBLE_EQ(0.0, volume);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002594}
2595
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002596TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundle) {
tfarina5237aaf2015-11-10 23:44:30 -08002597 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, false);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002598}
2599
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002600TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundleSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08002601 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, true);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00002602}
2603
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002604TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundleWithRtcpMux) {
tfarina5237aaf2015-11-10 23:44:30 -08002605 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, false);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00002606}
2607
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002608TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08002609 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002610}
2611
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002612TEST_F(VoiceChannelSingleThreadTest, DefaultMaxBitrateIsUnlimited) {
skvlade0d46372016-04-07 22:59:22 -07002613 Base::DefaultMaxBitrateIsUnlimited();
skvladdc1c62c2016-03-16 19:07:43 -07002614}
2615
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002616TEST_F(VoiceChannelSingleThreadTest, CanChangeMaxBitrate) {
skvlade0d46372016-04-07 22:59:22 -07002617 Base::CanChangeMaxBitrate();
skvladdc1c62c2016-03-16 19:07:43 -07002618}
2619
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002620// VoiceChannelDoubleThreadTest
2621TEST_F(VoiceChannelDoubleThreadTest, TestInit) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002622 Base::TestInit();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002623 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2624 EXPECT_TRUE(media_channel1_->dtmf_info_queue().empty());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002625}
2626
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02002627TEST_F(VoiceChannelDoubleThreadTest, TestDeinit) {
2628 Base::TestDeinit();
2629}
2630
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002631TEST_F(VoiceChannelDoubleThreadTest, TestSetContents) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002632 Base::TestSetContents();
2633}
2634
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002635TEST_F(VoiceChannelDoubleThreadTest, TestSetContentsNullOffer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002636 Base::TestSetContentsNullOffer();
2637}
2638
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002639TEST_F(VoiceChannelDoubleThreadTest, TestSetContentsRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002640 Base::TestSetContentsRtcpMux();
2641}
2642
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002643TEST_F(VoiceChannelDoubleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002644 Base::TestSetContentsRtcpMux();
2645}
2646
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002647TEST_F(VoiceChannelDoubleThreadTest, TestSetRemoteContentUpdate) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002648 Base::TestSetRemoteContentUpdate();
2649}
2650
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002651TEST_F(VoiceChannelDoubleThreadTest, TestStreams) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002652 Base::TestStreams();
2653}
2654
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002655TEST_F(VoiceChannelDoubleThreadTest, TestUpdateStreamsInLocalContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002656 Base::TestUpdateStreamsInLocalContent();
2657}
2658
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002659TEST_F(VoiceChannelDoubleThreadTest, TestUpdateRemoteStreamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002660 Base::TestUpdateStreamsInRemoteContent();
2661}
2662
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002663TEST_F(VoiceChannelDoubleThreadTest, TestChangeStreamParamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002664 Base::TestChangeStreamParamsInContent();
2665}
2666
jbauch5869f502017-06-29 12:31:36 -07002667TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2668 TestChangeEncryptedHeaderExtensionsDtls) {
2669 int flags = DTLS;
2670 Base::TestChangeEncryptedHeaderExtensions(flags);
2671}
2672
2673TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2674 TestChangeEncryptedHeaderExtensionsDtlsScenario1) {
2675 int flags = DTLS;
2676 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_BEFORE_OFFER_ANSWER);
2677}
2678
2679TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2680 TestChangeEncryptedHeaderExtensionsDtlsScenario2) {
2681 int flags = DTLS;
2682 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_AFTER_CHANNEL2_READY);
2683}
2684
2685TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2686 TestChangeEncryptedHeaderExtensionsDtlsGcm) {
2687 int flags = DTLS | GCM_CIPHER;
2688 Base::TestChangeEncryptedHeaderExtensions(flags);
2689}
2690
2691TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2692 TestChangeEncryptedHeaderExtensionsDtlsGcmScenario1) {
2693 int flags = DTLS | GCM_CIPHER;
2694 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_BEFORE_OFFER_ANSWER);
2695}
2696
2697TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2698 TestChangeEncryptedHeaderExtensionsDtlsGcmScenario2) {
2699 int flags = DTLS | GCM_CIPHER;
2700 Base::TestChangeEncryptedHeaderExtensions(flags, DTLS_AFTER_CHANNEL2_READY);
2701}
2702
2703TEST_F(VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest,
2704 TestChangeEncryptedHeaderExtensionsSDES) {
2705 int flags = 0;
2706 Base::TestChangeEncryptedHeaderExtensions(flags);
2707}
2708
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002709TEST_F(VoiceChannelDoubleThreadTest, TestPlayoutAndSendingStates) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002710 Base::TestPlayoutAndSendingStates();
2711}
2712
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002713TEST_F(VoiceChannelDoubleThreadTest, TestMuteStream) {
2714 CreateChannels(0, 0);
2715 // Test that we can Mute the default channel even though the sending SSRC
2716 // is unknown.
2717 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2718 EXPECT_TRUE(channel1_->SetAudioSend(0, false, nullptr, nullptr));
2719 EXPECT_TRUE(media_channel1_->IsStreamMuted(0));
2720 EXPECT_TRUE(channel1_->SetAudioSend(0, true, nullptr, nullptr));
2721 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2722
2723 // Test that we can not mute an unknown SSRC.
2724 EXPECT_FALSE(channel1_->SetAudioSend(kSsrc1, false, nullptr, nullptr));
2725
2726 SendInitiate();
2727 // After the local session description has been set, we can mute a stream
2728 // with its SSRC.
2729 EXPECT_TRUE(channel1_->SetAudioSend(kSsrc1, false, nullptr, nullptr));
2730 EXPECT_TRUE(media_channel1_->IsStreamMuted(kSsrc1));
2731 EXPECT_TRUE(channel1_->SetAudioSend(kSsrc1, true, nullptr, nullptr));
2732 EXPECT_FALSE(media_channel1_->IsStreamMuted(kSsrc1));
2733}
2734
2735TEST_F(VoiceChannelDoubleThreadTest, TestMediaContentDirection) {
2736 Base::TestMediaContentDirection();
2737}
2738
2739TEST_F(VoiceChannelDoubleThreadTest, TestNetworkRouteChanges) {
2740 Base::TestNetworkRouteChanges();
2741}
2742
2743TEST_F(VoiceChannelDoubleThreadTest, TestCallSetup) {
2744 Base::TestCallSetup();
2745}
2746
2747TEST_F(VoiceChannelDoubleThreadTest, TestCallTeardownRtcpMux) {
2748 Base::TestCallTeardownRtcpMux();
2749}
2750
2751TEST_F(VoiceChannelDoubleThreadTest, SendRtpToRtp) {
2752 Base::SendRtpToRtp();
2753}
2754
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002755TEST_F(VoiceChannelDoubleThreadTest, SendRtcpToRtcp) {
2756 Base::SendRtcpToRtcp();
2757}
2758
2759TEST_F(VoiceChannelDoubleThreadTest, SendRtcpMuxToRtcp) {
2760 Base::SendRtcpMuxToRtcp();
2761}
2762
2763TEST_F(VoiceChannelDoubleThreadTest, SendRtcpMuxToRtcpMux) {
2764 Base::SendRtcpMuxToRtcpMux();
2765}
2766
2767TEST_F(VoiceChannelDoubleThreadTest, SendRequireRtcpMuxToRtcpMux) {
2768 Base::SendRequireRtcpMuxToRtcpMux();
2769}
2770
2771TEST_F(VoiceChannelDoubleThreadTest, SendRtcpMuxToRequireRtcpMux) {
2772 Base::SendRtcpMuxToRequireRtcpMux();
2773}
2774
2775TEST_F(VoiceChannelDoubleThreadTest, SendRequireRtcpMuxToRequireRtcpMux) {
2776 Base::SendRequireRtcpMuxToRequireRtcpMux();
2777}
2778
2779TEST_F(VoiceChannelDoubleThreadTest, SendRequireRtcpMuxToNoRtcpMux) {
2780 Base::SendRequireRtcpMuxToNoRtcpMux();
2781}
2782
2783TEST_F(VoiceChannelDoubleThreadTest, SendEarlyRtcpMuxToRtcp) {
2784 Base::SendEarlyRtcpMuxToRtcp();
2785}
2786
2787TEST_F(VoiceChannelDoubleThreadTest, SendEarlyRtcpMuxToRtcpMux) {
2788 Base::SendEarlyRtcpMuxToRtcpMux();
2789}
2790
2791TEST_F(VoiceChannelDoubleThreadTest, SendSrtpToSrtpRtcpMux) {
2792 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
2793}
2794
2795TEST_F(VoiceChannelDoubleThreadTest, SendSrtpToRtp) {
2796 Base::SendSrtpToSrtp();
2797}
2798
2799TEST_F(VoiceChannelDoubleThreadTest, SendSrtcpMux) {
2800 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
2801}
2802
2803TEST_F(VoiceChannelDoubleThreadTest, SendDtlsSrtpToSrtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002804 Base::SendSrtpToSrtp(DTLS, 0);
2805}
2806
2807TEST_F(VoiceChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002808 Base::SendSrtpToSrtp(DTLS, DTLS);
2809}
2810
2811TEST_F(VoiceChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002812 Base::SendSrtpToSrtp(DTLS | RTCP_MUX, DTLS | RTCP_MUX);
2813}
2814
deadbeeff5346592017-01-24 21:51:21 -08002815// Test using the channel with a raw packet interface, as opposed to a DTLS
2816// transport interface.
2817TEST_F(VoiceChannelDoubleThreadTest, SendSrtpToSrtpWithRawPacketTransport) {
2818 Base::SendSrtpToSrtp(RAW_PACKET_TRANSPORT, RAW_PACKET_TRANSPORT);
2819}
2820
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002821TEST_F(VoiceChannelDoubleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
2822 Base::SendEarlyMediaUsingRtcpMuxSrtp();
2823}
2824
2825TEST_F(VoiceChannelDoubleThreadTest, SendRtpToRtpOnThread) {
2826 Base::SendRtpToRtpOnThread();
2827}
2828
2829TEST_F(VoiceChannelDoubleThreadTest, SendSrtpToSrtpOnThread) {
2830 Base::SendSrtpToSrtpOnThread();
2831}
2832
2833TEST_F(VoiceChannelDoubleThreadTest, SendWithWritabilityLoss) {
2834 Base::SendWithWritabilityLoss();
2835}
2836
2837TEST_F(VoiceChannelDoubleThreadTest, TestMediaMonitor) {
2838 Base::TestMediaMonitor();
2839}
2840
2841// Test that InsertDtmf properly forwards to the media channel.
2842TEST_F(VoiceChannelDoubleThreadTest, TestInsertDtmf) {
2843 CreateChannels(0, 0);
2844 EXPECT_TRUE(SendInitiate());
2845 EXPECT_TRUE(SendAccept());
2846 EXPECT_EQ(0U, media_channel1_->dtmf_info_queue().size());
2847
2848 EXPECT_TRUE(channel1_->InsertDtmf(1, 3, 100));
2849 EXPECT_TRUE(channel1_->InsertDtmf(2, 5, 110));
2850 EXPECT_TRUE(channel1_->InsertDtmf(3, 7, 120));
2851
2852 ASSERT_EQ(3U, media_channel1_->dtmf_info_queue().size());
2853 EXPECT_TRUE(
2854 CompareDtmfInfo(media_channel1_->dtmf_info_queue()[0], 1, 3, 100));
2855 EXPECT_TRUE(
2856 CompareDtmfInfo(media_channel1_->dtmf_info_queue()[1], 2, 5, 110));
2857 EXPECT_TRUE(
2858 CompareDtmfInfo(media_channel1_->dtmf_info_queue()[2], 3, 7, 120));
2859}
2860
2861TEST_F(VoiceChannelDoubleThreadTest, TestSetContentFailure) {
2862 Base::TestSetContentFailure();
2863}
2864
2865TEST_F(VoiceChannelDoubleThreadTest, TestSendTwoOffers) {
2866 Base::TestSendTwoOffers();
2867}
2868
2869TEST_F(VoiceChannelDoubleThreadTest, TestReceiveTwoOffers) {
2870 Base::TestReceiveTwoOffers();
2871}
2872
2873TEST_F(VoiceChannelDoubleThreadTest, TestSendPrAnswer) {
2874 Base::TestSendPrAnswer();
2875}
2876
2877TEST_F(VoiceChannelDoubleThreadTest, TestReceivePrAnswer) {
2878 Base::TestReceivePrAnswer();
2879}
2880
2881TEST_F(VoiceChannelDoubleThreadTest, TestFlushRtcp) {
2882 Base::TestFlushRtcp();
2883}
2884
zstein56162b92017-04-24 16:54:35 -07002885TEST_F(VoiceChannelDoubleThreadTest, TestOnTransportReadyToSend) {
2886 Base::TestOnTransportReadyToSend();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002887}
2888
zstein56162b92017-04-24 16:54:35 -07002889TEST_F(VoiceChannelDoubleThreadTest, TestOnTransportReadyToSendWithRtcpMux) {
2890 Base::TestOnTransportReadyToSendWithRtcpMux();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002891}
2892
2893// Test that we can scale the output volume properly for 1:1 calls.
2894TEST_F(VoiceChannelDoubleThreadTest, TestScaleVolume1to1Call) {
deadbeefac22f702017-01-12 21:59:29 -08002895 CreateChannels(0, 0);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002896 EXPECT_TRUE(SendInitiate());
2897 EXPECT_TRUE(SendAccept());
2898 double volume;
2899
2900 // Default is (1.0).
2901 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2902 EXPECT_DOUBLE_EQ(1.0, volume);
2903 // invalid ssrc.
2904 EXPECT_FALSE(media_channel1_->GetOutputVolume(3, &volume));
2905
2906 // Set scale to (1.5).
2907 EXPECT_TRUE(channel1_->SetOutputVolume(0, 1.5));
2908 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2909 EXPECT_DOUBLE_EQ(1.5, volume);
2910
2911 // Set scale to (0).
2912 EXPECT_TRUE(channel1_->SetOutputVolume(0, 0.0));
2913 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2914 EXPECT_DOUBLE_EQ(0.0, volume);
2915}
2916
2917// Test that we can scale the output volume properly for multiway calls.
2918TEST_F(VoiceChannelDoubleThreadTest, TestScaleVolumeMultiwayCall) {
deadbeefac22f702017-01-12 21:59:29 -08002919 CreateChannels(0, 0);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002920 EXPECT_TRUE(SendInitiate());
2921 EXPECT_TRUE(SendAccept());
2922 EXPECT_TRUE(AddStream1(1));
2923 EXPECT_TRUE(AddStream1(2));
2924
2925 double volume;
2926 // Default is (1.0).
2927 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2928 EXPECT_DOUBLE_EQ(1.0, volume);
2929 EXPECT_TRUE(media_channel1_->GetOutputVolume(1, &volume));
2930 EXPECT_DOUBLE_EQ(1.0, volume);
2931 EXPECT_TRUE(media_channel1_->GetOutputVolume(2, &volume));
2932 EXPECT_DOUBLE_EQ(1.0, volume);
2933 // invalid ssrc.
2934 EXPECT_FALSE(media_channel1_->GetOutputVolume(3, &volume));
2935
2936 // Set scale to (1.5) for ssrc = 1.
2937 EXPECT_TRUE(channel1_->SetOutputVolume(1, 1.5));
2938 EXPECT_TRUE(media_channel1_->GetOutputVolume(1, &volume));
2939 EXPECT_DOUBLE_EQ(1.5, volume);
2940 EXPECT_TRUE(media_channel1_->GetOutputVolume(2, &volume));
2941 EXPECT_DOUBLE_EQ(1.0, volume);
2942 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2943 EXPECT_DOUBLE_EQ(1.0, volume);
2944
2945 // Set scale to (0) for all ssrcs.
2946 EXPECT_TRUE(channel1_->SetOutputVolume(0, 0.0));
2947 EXPECT_TRUE(media_channel1_->GetOutputVolume(0, &volume));
2948 EXPECT_DOUBLE_EQ(0.0, volume);
2949 EXPECT_TRUE(media_channel1_->GetOutputVolume(1, &volume));
2950 EXPECT_DOUBLE_EQ(0.0, volume);
2951 EXPECT_TRUE(media_channel1_->GetOutputVolume(2, &volume));
2952 EXPECT_DOUBLE_EQ(0.0, volume);
2953}
2954
2955TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundle) {
2956 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, false);
2957}
2958
2959TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundleSecure) {
2960 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, true);
2961}
2962
2963TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundleWithRtcpMux) {
2964 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, false);
2965}
2966
2967TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
2968 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, true);
2969}
2970
2971TEST_F(VoiceChannelDoubleThreadTest, DefaultMaxBitrateIsUnlimited) {
2972 Base::DefaultMaxBitrateIsUnlimited();
2973}
2974
2975TEST_F(VoiceChannelDoubleThreadTest, CanChangeMaxBitrate) {
2976 Base::CanChangeMaxBitrate();
2977}
2978
2979// VideoChannelSingleThreadTest
2980TEST_F(VideoChannelSingleThreadTest, TestInit) {
2981 Base::TestInit();
2982}
2983
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02002984TEST_F(VideoChannelSingleThreadTest, TestDeinit) {
2985 Base::TestDeinit();
2986}
2987
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002988TEST_F(VideoChannelSingleThreadTest, TestSetContents) {
2989 Base::TestSetContents();
2990}
2991
2992TEST_F(VideoChannelSingleThreadTest, TestSetContentsNullOffer) {
2993 Base::TestSetContentsNullOffer();
2994}
2995
2996TEST_F(VideoChannelSingleThreadTest, TestSetContentsRtcpMux) {
2997 Base::TestSetContentsRtcpMux();
2998}
2999
3000TEST_F(VideoChannelSingleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
3001 Base::TestSetContentsRtcpMux();
3002}
3003
3004TEST_F(VideoChannelSingleThreadTest, TestSetRemoteContentUpdate) {
3005 Base::TestSetRemoteContentUpdate();
3006}
3007
3008TEST_F(VideoChannelSingleThreadTest, TestStreams) {
3009 Base::TestStreams();
3010}
3011
3012TEST_F(VideoChannelSingleThreadTest, TestUpdateStreamsInLocalContent) {
3013 Base::TestUpdateStreamsInLocalContent();
3014}
3015
3016TEST_F(VideoChannelSingleThreadTest, TestUpdateRemoteStreamsInContent) {
3017 Base::TestUpdateStreamsInRemoteContent();
3018}
3019
3020TEST_F(VideoChannelSingleThreadTest, TestChangeStreamParamsInContent) {
3021 Base::TestChangeStreamParamsInContent();
3022}
3023
3024TEST_F(VideoChannelSingleThreadTest, TestPlayoutAndSendingStates) {
3025 Base::TestPlayoutAndSendingStates();
3026}
3027
3028TEST_F(VideoChannelSingleThreadTest, TestMuteStream) {
solenberg1dd98f32015-09-10 01:57:14 -07003029 CreateChannels(0, 0);
3030 // Test that we can Mute the default channel even though the sending SSRC
3031 // is unknown.
3032 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
deadbeef5a4a75a2016-06-02 16:23:38 -07003033 EXPECT_TRUE(channel1_->SetVideoSend(0, false, nullptr, nullptr));
solenbergdfc8f4f2015-10-01 02:31:10 -07003034 EXPECT_TRUE(media_channel1_->IsStreamMuted(0));
deadbeef5a4a75a2016-06-02 16:23:38 -07003035 EXPECT_TRUE(channel1_->SetVideoSend(0, true, nullptr, nullptr));
solenberg1dd98f32015-09-10 01:57:14 -07003036 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
3037 // Test that we can not mute an unknown SSRC.
deadbeef5a4a75a2016-06-02 16:23:38 -07003038 EXPECT_FALSE(channel1_->SetVideoSend(kSsrc1, false, nullptr, nullptr));
solenberg1dd98f32015-09-10 01:57:14 -07003039 SendInitiate();
3040 // After the local session description has been set, we can mute a stream
3041 // with its SSRC.
deadbeef5a4a75a2016-06-02 16:23:38 -07003042 EXPECT_TRUE(channel1_->SetVideoSend(kSsrc1, false, nullptr, nullptr));
solenbergdfc8f4f2015-10-01 02:31:10 -07003043 EXPECT_TRUE(media_channel1_->IsStreamMuted(kSsrc1));
deadbeef5a4a75a2016-06-02 16:23:38 -07003044 EXPECT_TRUE(channel1_->SetVideoSend(kSsrc1, true, nullptr, nullptr));
solenberg1dd98f32015-09-10 01:57:14 -07003045 EXPECT_FALSE(media_channel1_->IsStreamMuted(kSsrc1));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003046}
3047
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003048TEST_F(VideoChannelSingleThreadTest, TestMediaContentDirection) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003049 Base::TestMediaContentDirection();
3050}
3051
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003052TEST_F(VideoChannelSingleThreadTest, TestNetworkRouteChanges) {
Honghai Zhangcc411c02016-03-29 17:27:21 -07003053 Base::TestNetworkRouteChanges();
3054}
3055
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003056TEST_F(VideoChannelSingleThreadTest, TestCallSetup) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003057 Base::TestCallSetup();
3058}
3059
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003060TEST_F(VideoChannelSingleThreadTest, TestCallTeardownRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003061 Base::TestCallTeardownRtcpMux();
3062}
3063
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003064TEST_F(VideoChannelSingleThreadTest, SendRtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003065 Base::SendRtpToRtp();
3066}
3067
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003068TEST_F(VideoChannelSingleThreadTest, SendRtcpToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003069 Base::SendRtcpToRtcp();
3070}
3071
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003072TEST_F(VideoChannelSingleThreadTest, SendRtcpMuxToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003073 Base::SendRtcpMuxToRtcp();
3074}
3075
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003076TEST_F(VideoChannelSingleThreadTest, SendRtcpMuxToRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003077 Base::SendRtcpMuxToRtcpMux();
3078}
3079
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003080TEST_F(VideoChannelSingleThreadTest, SendRequireRtcpMuxToRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07003081 Base::SendRequireRtcpMuxToRtcpMux();
3082}
3083
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003084TEST_F(VideoChannelSingleThreadTest, SendRtcpMuxToRequireRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07003085 Base::SendRtcpMuxToRequireRtcpMux();
3086}
3087
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003088TEST_F(VideoChannelSingleThreadTest, SendRequireRtcpMuxToRequireRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07003089 Base::SendRequireRtcpMuxToRequireRtcpMux();
3090}
3091
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003092TEST_F(VideoChannelSingleThreadTest, SendRequireRtcpMuxToNoRtcpMux) {
Peter Thatcheraf55ccc2015-05-21 07:48:41 -07003093 Base::SendRequireRtcpMuxToNoRtcpMux();
3094}
3095
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003096TEST_F(VideoChannelSingleThreadTest, SendEarlyRtcpMuxToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003097 Base::SendEarlyRtcpMuxToRtcp();
3098}
3099
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003100TEST_F(VideoChannelSingleThreadTest, SendEarlyRtcpMuxToRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003101 Base::SendEarlyRtcpMuxToRtcpMux();
3102}
3103
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003104TEST_F(VideoChannelSingleThreadTest, SendSrtpToSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003105 Base::SendSrtpToSrtp();
3106}
3107
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003108TEST_F(VideoChannelSingleThreadTest, SendSrtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003109 Base::SendSrtpToSrtp();
3110}
3111
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003112TEST_F(VideoChannelSingleThreadTest, SendDtlsSrtpToSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003113 Base::SendSrtpToSrtp(DTLS, 0);
3114}
3115
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003116TEST_F(VideoChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003117 Base::SendSrtpToSrtp(DTLS, DTLS);
3118}
3119
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003120TEST_F(VideoChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003121 Base::SendSrtpToSrtp(DTLS | RTCP_MUX, DTLS | RTCP_MUX);
3122}
3123
deadbeeff5346592017-01-24 21:51:21 -08003124// Test using the channel with a raw packet interface, as opposed to a DTLS
3125// transport interface.
3126TEST_F(VideoChannelSingleThreadTest, SendSrtpToSrtpWithRawPacketTransport) {
3127 Base::SendSrtpToSrtp(RAW_PACKET_TRANSPORT, RAW_PACKET_TRANSPORT);
3128}
3129
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003130TEST_F(VideoChannelSingleThreadTest, SendSrtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003131 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
3132}
3133
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003134TEST_F(VideoChannelSingleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003135 Base::SendEarlyMediaUsingRtcpMuxSrtp();
3136}
3137
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003138TEST_F(VideoChannelSingleThreadTest, SendRtpToRtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003139 Base::SendRtpToRtpOnThread();
3140}
3141
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003142TEST_F(VideoChannelSingleThreadTest, SendSrtpToSrtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003143 Base::SendSrtpToSrtpOnThread();
3144}
3145
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003146TEST_F(VideoChannelSingleThreadTest, SendWithWritabilityLoss) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003147 Base::SendWithWritabilityLoss();
3148}
3149
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003150TEST_F(VideoChannelSingleThreadTest, TestMediaMonitor) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003151 Base::TestMediaMonitor();
3152}
3153
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003154TEST_F(VideoChannelSingleThreadTest, TestSetContentFailure) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003155 Base::TestSetContentFailure();
3156}
3157
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003158TEST_F(VideoChannelSingleThreadTest, TestSendTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003159 Base::TestSendTwoOffers();
3160}
3161
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003162TEST_F(VideoChannelSingleThreadTest, TestReceiveTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003163 Base::TestReceiveTwoOffers();
3164}
3165
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003166TEST_F(VideoChannelSingleThreadTest, TestSendPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003167 Base::TestSendPrAnswer();
3168}
3169
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003170TEST_F(VideoChannelSingleThreadTest, TestReceivePrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003171 Base::TestReceivePrAnswer();
3172}
3173
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003174TEST_F(VideoChannelSingleThreadTest, TestFlushRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003175 Base::TestFlushRtcp();
3176}
3177
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003178TEST_F(VideoChannelSingleThreadTest, SendBundleToBundle) {
tfarina5237aaf2015-11-10 23:44:30 -08003179 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, false);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003180}
3181
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003182TEST_F(VideoChannelSingleThreadTest, SendBundleToBundleSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08003183 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, true);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00003184}
3185
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003186TEST_F(VideoChannelSingleThreadTest, SendBundleToBundleWithRtcpMux) {
tfarina5237aaf2015-11-10 23:44:30 -08003187 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, false);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00003188}
3189
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003190TEST_F(VideoChannelSingleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08003191 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003192}
3193
zstein56162b92017-04-24 16:54:35 -07003194TEST_F(VideoChannelSingleThreadTest, TestOnTransportReadyToSend) {
3195 Base::TestOnTransportReadyToSend();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003196}
3197
zstein56162b92017-04-24 16:54:35 -07003198TEST_F(VideoChannelSingleThreadTest, TestOnTransportReadyToSendWithRtcpMux) {
3199 Base::TestOnTransportReadyToSendWithRtcpMux();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003200}
3201
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003202TEST_F(VideoChannelSingleThreadTest, DefaultMaxBitrateIsUnlimited) {
skvladdc1c62c2016-03-16 19:07:43 -07003203 Base::DefaultMaxBitrateIsUnlimited();
3204}
3205
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003206TEST_F(VideoChannelSingleThreadTest, CanChangeMaxBitrate) {
skvladdc1c62c2016-03-16 19:07:43 -07003207 Base::CanChangeMaxBitrate();
3208}
3209
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003210// VideoChannelDoubleThreadTest
3211TEST_F(VideoChannelDoubleThreadTest, TestInit) {
3212 Base::TestInit();
3213}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003214
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02003215TEST_F(VideoChannelDoubleThreadTest, TestDeinit) {
3216 Base::TestDeinit();
3217}
3218
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003219TEST_F(VideoChannelDoubleThreadTest, TestSetContents) {
3220 Base::TestSetContents();
3221}
3222
3223TEST_F(VideoChannelDoubleThreadTest, TestSetContentsNullOffer) {
3224 Base::TestSetContentsNullOffer();
3225}
3226
3227TEST_F(VideoChannelDoubleThreadTest, TestSetContentsRtcpMux) {
3228 Base::TestSetContentsRtcpMux();
3229}
3230
3231TEST_F(VideoChannelDoubleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
3232 Base::TestSetContentsRtcpMux();
3233}
3234
3235TEST_F(VideoChannelDoubleThreadTest, TestSetRemoteContentUpdate) {
3236 Base::TestSetRemoteContentUpdate();
3237}
3238
3239TEST_F(VideoChannelDoubleThreadTest, TestStreams) {
3240 Base::TestStreams();
3241}
3242
3243TEST_F(VideoChannelDoubleThreadTest, TestUpdateStreamsInLocalContent) {
3244 Base::TestUpdateStreamsInLocalContent();
3245}
3246
3247TEST_F(VideoChannelDoubleThreadTest, TestUpdateRemoteStreamsInContent) {
3248 Base::TestUpdateStreamsInRemoteContent();
3249}
3250
3251TEST_F(VideoChannelDoubleThreadTest, TestChangeStreamParamsInContent) {
3252 Base::TestChangeStreamParamsInContent();
3253}
3254
3255TEST_F(VideoChannelDoubleThreadTest, TestPlayoutAndSendingStates) {
3256 Base::TestPlayoutAndSendingStates();
3257}
3258
3259TEST_F(VideoChannelDoubleThreadTest, TestMuteStream) {
3260 CreateChannels(0, 0);
3261 // Test that we can Mute the default channel even though the sending SSRC
3262 // is unknown.
3263 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
deadbeef5a4a75a2016-06-02 16:23:38 -07003264 EXPECT_TRUE(channel1_->SetVideoSend(0, false, nullptr, nullptr));
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003265 EXPECT_TRUE(media_channel1_->IsStreamMuted(0));
deadbeef5a4a75a2016-06-02 16:23:38 -07003266 EXPECT_TRUE(channel1_->SetVideoSend(0, true, nullptr, nullptr));
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003267 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
3268 // Test that we can not mute an unknown SSRC.
deadbeef5a4a75a2016-06-02 16:23:38 -07003269 EXPECT_FALSE(channel1_->SetVideoSend(kSsrc1, false, nullptr, nullptr));
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003270 SendInitiate();
3271 // After the local session description has been set, we can mute a stream
3272 // with its SSRC.
deadbeef5a4a75a2016-06-02 16:23:38 -07003273 EXPECT_TRUE(channel1_->SetVideoSend(kSsrc1, false, nullptr, nullptr));
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003274 EXPECT_TRUE(media_channel1_->IsStreamMuted(kSsrc1));
deadbeef5a4a75a2016-06-02 16:23:38 -07003275 EXPECT_TRUE(channel1_->SetVideoSend(kSsrc1, true, nullptr, nullptr));
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003276 EXPECT_FALSE(media_channel1_->IsStreamMuted(kSsrc1));
3277}
3278
3279TEST_F(VideoChannelDoubleThreadTest, TestMediaContentDirection) {
3280 Base::TestMediaContentDirection();
3281}
3282
3283TEST_F(VideoChannelDoubleThreadTest, TestNetworkRouteChanges) {
3284 Base::TestNetworkRouteChanges();
3285}
3286
3287TEST_F(VideoChannelDoubleThreadTest, TestCallSetup) {
3288 Base::TestCallSetup();
3289}
3290
3291TEST_F(VideoChannelDoubleThreadTest, TestCallTeardownRtcpMux) {
3292 Base::TestCallTeardownRtcpMux();
3293}
3294
3295TEST_F(VideoChannelDoubleThreadTest, SendRtpToRtp) {
3296 Base::SendRtpToRtp();
3297}
3298
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003299TEST_F(VideoChannelDoubleThreadTest, SendRtcpToRtcp) {
3300 Base::SendRtcpToRtcp();
3301}
3302
3303TEST_F(VideoChannelDoubleThreadTest, SendRtcpMuxToRtcp) {
3304 Base::SendRtcpMuxToRtcp();
3305}
3306
3307TEST_F(VideoChannelDoubleThreadTest, SendRtcpMuxToRtcpMux) {
3308 Base::SendRtcpMuxToRtcpMux();
3309}
3310
3311TEST_F(VideoChannelDoubleThreadTest, SendRequireRtcpMuxToRtcpMux) {
3312 Base::SendRequireRtcpMuxToRtcpMux();
3313}
3314
3315TEST_F(VideoChannelDoubleThreadTest, SendRtcpMuxToRequireRtcpMux) {
3316 Base::SendRtcpMuxToRequireRtcpMux();
3317}
3318
3319TEST_F(VideoChannelDoubleThreadTest, SendRequireRtcpMuxToRequireRtcpMux) {
3320 Base::SendRequireRtcpMuxToRequireRtcpMux();
3321}
3322
3323TEST_F(VideoChannelDoubleThreadTest, SendRequireRtcpMuxToNoRtcpMux) {
3324 Base::SendRequireRtcpMuxToNoRtcpMux();
3325}
3326
3327TEST_F(VideoChannelDoubleThreadTest, SendEarlyRtcpMuxToRtcp) {
3328 Base::SendEarlyRtcpMuxToRtcp();
3329}
3330
3331TEST_F(VideoChannelDoubleThreadTest, SendEarlyRtcpMuxToRtcpMux) {
3332 Base::SendEarlyRtcpMuxToRtcpMux();
3333}
3334
3335TEST_F(VideoChannelDoubleThreadTest, SendSrtpToSrtp) {
3336 Base::SendSrtpToSrtp();
3337}
3338
3339TEST_F(VideoChannelDoubleThreadTest, SendSrtpToRtp) {
3340 Base::SendSrtpToSrtp();
3341}
3342
3343TEST_F(VideoChannelDoubleThreadTest, SendDtlsSrtpToSrtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003344 Base::SendSrtpToSrtp(DTLS, 0);
3345}
3346
3347TEST_F(VideoChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003348 Base::SendSrtpToSrtp(DTLS, DTLS);
3349}
3350
3351TEST_F(VideoChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003352 Base::SendSrtpToSrtp(DTLS | RTCP_MUX, DTLS | RTCP_MUX);
3353}
3354
deadbeeff5346592017-01-24 21:51:21 -08003355// Test using the channel with a raw packet interface, as opposed to a DTLS
3356// transport interface.
3357TEST_F(VideoChannelDoubleThreadTest, SendSrtpToSrtpWithRawPacketTransport) {
3358 Base::SendSrtpToSrtp(RAW_PACKET_TRANSPORT, RAW_PACKET_TRANSPORT);
3359}
3360
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003361TEST_F(VideoChannelDoubleThreadTest, SendSrtcpMux) {
3362 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
3363}
3364
3365TEST_F(VideoChannelDoubleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
3366 Base::SendEarlyMediaUsingRtcpMuxSrtp();
3367}
3368
3369TEST_F(VideoChannelDoubleThreadTest, SendRtpToRtpOnThread) {
3370 Base::SendRtpToRtpOnThread();
3371}
3372
3373TEST_F(VideoChannelDoubleThreadTest, SendSrtpToSrtpOnThread) {
3374 Base::SendSrtpToSrtpOnThread();
3375}
3376
3377TEST_F(VideoChannelDoubleThreadTest, SendWithWritabilityLoss) {
3378 Base::SendWithWritabilityLoss();
3379}
3380
3381TEST_F(VideoChannelDoubleThreadTest, TestMediaMonitor) {
3382 Base::TestMediaMonitor();
3383}
3384
3385TEST_F(VideoChannelDoubleThreadTest, TestSetContentFailure) {
3386 Base::TestSetContentFailure();
3387}
3388
3389TEST_F(VideoChannelDoubleThreadTest, TestSendTwoOffers) {
3390 Base::TestSendTwoOffers();
3391}
3392
3393TEST_F(VideoChannelDoubleThreadTest, TestReceiveTwoOffers) {
3394 Base::TestReceiveTwoOffers();
3395}
3396
3397TEST_F(VideoChannelDoubleThreadTest, TestSendPrAnswer) {
3398 Base::TestSendPrAnswer();
3399}
3400
3401TEST_F(VideoChannelDoubleThreadTest, TestReceivePrAnswer) {
3402 Base::TestReceivePrAnswer();
3403}
3404
3405TEST_F(VideoChannelDoubleThreadTest, TestFlushRtcp) {
3406 Base::TestFlushRtcp();
3407}
3408
3409TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundle) {
3410 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, false);
3411}
3412
3413TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundleSecure) {
3414 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, true);
3415}
3416
3417TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundleWithRtcpMux) {
3418 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, false);
3419}
3420
3421TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
3422 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, true);
3423}
3424
zstein56162b92017-04-24 16:54:35 -07003425TEST_F(VideoChannelDoubleThreadTest, TestOnTransportReadyToSend) {
3426 Base::TestOnTransportReadyToSend();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003427}
3428
zstein56162b92017-04-24 16:54:35 -07003429TEST_F(VideoChannelDoubleThreadTest, TestOnTransportReadyToSendWithRtcpMux) {
3430 Base::TestOnTransportReadyToSendWithRtcpMux();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003431}
3432
3433TEST_F(VideoChannelDoubleThreadTest, DefaultMaxBitrateIsUnlimited) {
3434 Base::DefaultMaxBitrateIsUnlimited();
3435}
3436
3437TEST_F(VideoChannelDoubleThreadTest, CanChangeMaxBitrate) {
3438 Base::CanChangeMaxBitrate();
3439}
3440
deadbeef953c2ce2017-01-09 14:53:41 -08003441// RtpDataChannelSingleThreadTest
3442class RtpDataChannelSingleThreadTest : public ChannelTest<DataTraits> {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003443 public:
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003444 typedef ChannelTest<DataTraits> Base;
deadbeef953c2ce2017-01-09 14:53:41 -08003445 RtpDataChannelSingleThreadTest()
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003446 : Base(true, kDataPacket, kRtcpReport, NetworkIsWorker::Yes) {}
3447};
3448
deadbeef953c2ce2017-01-09 14:53:41 -08003449// RtpDataChannelDoubleThreadTest
3450class RtpDataChannelDoubleThreadTest : public ChannelTest<DataTraits> {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003451 public:
3452 typedef ChannelTest<DataTraits> Base;
deadbeef953c2ce2017-01-09 14:53:41 -08003453 RtpDataChannelDoubleThreadTest()
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003454 : Base(true, kDataPacket, kRtcpReport, NetworkIsWorker::No) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003455};
3456
3457// Override to avoid engine channel parameter.
deadbeefcbecd352015-09-23 11:50:27 -07003458template <>
deadbeef953c2ce2017-01-09 14:53:41 -08003459cricket::RtpDataChannel* ChannelTest<DataTraits>::CreateChannel(
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003460 rtc::Thread* worker_thread,
3461 rtc::Thread* network_thread,
deadbeefcbecd352015-09-23 11:50:27 -07003462 cricket::MediaEngineInterface* engine,
3463 cricket::FakeDataMediaChannel* ch,
deadbeeff5346592017-01-24 21:51:21 -08003464 cricket::DtlsTransportInternal* fake_rtp_dtls_transport,
3465 cricket::DtlsTransportInternal* fake_rtcp_dtls_transport,
deadbeef5bd5ca32017-02-10 11:31:50 -08003466 rtc::PacketTransportInternal* fake_rtp_packet_transport,
3467 rtc::PacketTransportInternal* fake_rtcp_packet_transport,
jbauchcb560652016-08-04 05:20:32 -07003468 int flags) {
deadbeeff5346592017-01-24 21:51:21 -08003469 rtc::Thread* signaling_thread = rtc::Thread::Current();
deadbeef953c2ce2017-01-09 14:53:41 -08003470 cricket::RtpDataChannel* channel = new cricket::RtpDataChannel(
zhihuangf5b251b2017-01-12 19:37:48 -08003471 worker_thread, network_thread, signaling_thread, ch, cricket::CN_DATA,
deadbeefac22f702017-01-12 21:59:29 -08003472 (flags & RTCP_MUX_REQUIRED) != 0, (flags & SECURE) != 0);
deadbeeff5346592017-01-24 21:51:21 -08003473 if (!channel->NeedsRtcpTransport()) {
3474 fake_rtcp_dtls_transport = nullptr;
zhihuangf5b251b2017-01-12 19:37:48 -08003475 }
deadbeeff5346592017-01-24 21:51:21 -08003476 if (!channel->Init_w(fake_rtp_dtls_transport, fake_rtcp_dtls_transport,
3477 fake_rtp_packet_transport, fake_rtcp_packet_transport)) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003478 delete channel;
3479 channel = NULL;
3480 }
3481 return channel;
3482}
3483
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003484template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003485void ChannelTest<DataTraits>::CreateContent(
3486 int flags,
3487 const cricket::AudioCodec& audio_codec,
3488 const cricket::VideoCodec& video_codec,
3489 cricket::DataContentDescription* data) {
3490 data->AddCodec(kGoogleDataCodec);
3491 data->set_rtcp_mux((flags & RTCP_MUX) != 0);
3492 if (flags & SECURE) {
3493 data->AddCrypto(cricket::CryptoParams(
Guo-wei Shieh456696a2015-09-30 21:48:54 -07003494 1, rtc::CS_AES_CM_128_HMAC_SHA1_32,
3495 "inline:" + rtc::CreateRandomString(40), std::string()));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003496 }
3497}
3498
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003499template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003500void ChannelTest<DataTraits>::CopyContent(
3501 const cricket::DataContentDescription& source,
3502 cricket::DataContentDescription* data) {
3503 *data = source;
3504}
3505
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003506template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003507bool ChannelTest<DataTraits>::CodecMatches(const cricket::DataCodec& c1,
3508 const cricket::DataCodec& c2) {
3509 return c1.name == c2.name;
3510}
3511
Peter Boström0c4e06b2015-10-07 12:23:21 +02003512template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003513void ChannelTest<DataTraits>::AddLegacyStreamInContent(
Peter Boström0c4e06b2015-10-07 12:23:21 +02003514 uint32_t ssrc,
3515 int flags,
3516 cricket::DataContentDescription* data) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003517 data->AddLegacyStream(ssrc);
3518}
3519
deadbeef953c2ce2017-01-09 14:53:41 -08003520TEST_F(RtpDataChannelSingleThreadTest, TestInit) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003521 Base::TestInit();
3522 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
3523}
3524
deadbeef953c2ce2017-01-09 14:53:41 -08003525TEST_F(RtpDataChannelSingleThreadTest, TestDeinit) {
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02003526 Base::TestDeinit();
3527}
3528
deadbeef953c2ce2017-01-09 14:53:41 -08003529TEST_F(RtpDataChannelSingleThreadTest, TestSetContents) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003530 Base::TestSetContents();
3531}
3532
deadbeef953c2ce2017-01-09 14:53:41 -08003533TEST_F(RtpDataChannelSingleThreadTest, TestSetContentsNullOffer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003534 Base::TestSetContentsNullOffer();
3535}
3536
deadbeef953c2ce2017-01-09 14:53:41 -08003537TEST_F(RtpDataChannelSingleThreadTest, TestSetContentsRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003538 Base::TestSetContentsRtcpMux();
3539}
3540
deadbeef953c2ce2017-01-09 14:53:41 -08003541TEST_F(RtpDataChannelSingleThreadTest, TestSetRemoteContentUpdate) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003542 Base::TestSetRemoteContentUpdate();
3543}
3544
deadbeef953c2ce2017-01-09 14:53:41 -08003545TEST_F(RtpDataChannelSingleThreadTest, TestStreams) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003546 Base::TestStreams();
3547}
3548
deadbeef953c2ce2017-01-09 14:53:41 -08003549TEST_F(RtpDataChannelSingleThreadTest, TestUpdateStreamsInLocalContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003550 Base::TestUpdateStreamsInLocalContent();
3551}
3552
deadbeef953c2ce2017-01-09 14:53:41 -08003553TEST_F(RtpDataChannelSingleThreadTest, TestUpdateRemoteStreamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003554 Base::TestUpdateStreamsInRemoteContent();
3555}
3556
deadbeef953c2ce2017-01-09 14:53:41 -08003557TEST_F(RtpDataChannelSingleThreadTest, TestChangeStreamParamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003558 Base::TestChangeStreamParamsInContent();
3559}
3560
deadbeef953c2ce2017-01-09 14:53:41 -08003561TEST_F(RtpDataChannelSingleThreadTest, TestPlayoutAndSendingStates) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003562 Base::TestPlayoutAndSendingStates();
3563}
3564
deadbeef953c2ce2017-01-09 14:53:41 -08003565TEST_F(RtpDataChannelSingleThreadTest, TestMediaContentDirection) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003566 Base::TestMediaContentDirection();
3567}
3568
deadbeef953c2ce2017-01-09 14:53:41 -08003569TEST_F(RtpDataChannelSingleThreadTest, TestCallSetup) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003570 Base::TestCallSetup();
3571}
3572
deadbeef953c2ce2017-01-09 14:53:41 -08003573TEST_F(RtpDataChannelSingleThreadTest, TestCallTeardownRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003574 Base::TestCallTeardownRtcpMux();
3575}
3576
zstein56162b92017-04-24 16:54:35 -07003577TEST_F(RtpDataChannelSingleThreadTest, TestOnTransportReadyToSend) {
3578 Base::TestOnTransportReadyToSend();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003579}
3580
zstein56162b92017-04-24 16:54:35 -07003581TEST_F(RtpDataChannelSingleThreadTest, TestOnTransportReadyToSendWithRtcpMux) {
3582 Base::TestOnTransportReadyToSendWithRtcpMux();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003583}
3584
deadbeef953c2ce2017-01-09 14:53:41 -08003585TEST_F(RtpDataChannelSingleThreadTest, SendRtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003586 Base::SendRtpToRtp();
3587}
3588
deadbeef953c2ce2017-01-09 14:53:41 -08003589TEST_F(RtpDataChannelSingleThreadTest, SendRtcpToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003590 Base::SendRtcpToRtcp();
3591}
3592
deadbeef953c2ce2017-01-09 14:53:41 -08003593TEST_F(RtpDataChannelSingleThreadTest, SendRtcpMuxToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003594 Base::SendRtcpMuxToRtcp();
3595}
3596
deadbeef953c2ce2017-01-09 14:53:41 -08003597TEST_F(RtpDataChannelSingleThreadTest, SendRtcpMuxToRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003598 Base::SendRtcpMuxToRtcpMux();
3599}
3600
deadbeef953c2ce2017-01-09 14:53:41 -08003601TEST_F(RtpDataChannelSingleThreadTest, SendEarlyRtcpMuxToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003602 Base::SendEarlyRtcpMuxToRtcp();
3603}
3604
deadbeef953c2ce2017-01-09 14:53:41 -08003605TEST_F(RtpDataChannelSingleThreadTest, SendEarlyRtcpMuxToRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003606 Base::SendEarlyRtcpMuxToRtcpMux();
3607}
3608
deadbeef953c2ce2017-01-09 14:53:41 -08003609TEST_F(RtpDataChannelSingleThreadTest, SendSrtpToSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003610 Base::SendSrtpToSrtp();
3611}
3612
deadbeef953c2ce2017-01-09 14:53:41 -08003613TEST_F(RtpDataChannelSingleThreadTest, SendSrtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003614 Base::SendSrtpToSrtp();
3615}
3616
deadbeef953c2ce2017-01-09 14:53:41 -08003617TEST_F(RtpDataChannelSingleThreadTest, SendSrtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003618 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
3619}
3620
deadbeef953c2ce2017-01-09 14:53:41 -08003621TEST_F(RtpDataChannelSingleThreadTest, SendRtpToRtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003622 Base::SendRtpToRtpOnThread();
3623}
3624
deadbeef953c2ce2017-01-09 14:53:41 -08003625TEST_F(RtpDataChannelSingleThreadTest, SendSrtpToSrtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003626 Base::SendSrtpToSrtpOnThread();
3627}
3628
deadbeef953c2ce2017-01-09 14:53:41 -08003629TEST_F(RtpDataChannelSingleThreadTest, SendWithWritabilityLoss) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003630 Base::SendWithWritabilityLoss();
3631}
3632
deadbeef953c2ce2017-01-09 14:53:41 -08003633TEST_F(RtpDataChannelSingleThreadTest, TestMediaMonitor) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003634 Base::TestMediaMonitor();
3635}
3636
deadbeef953c2ce2017-01-09 14:53:41 -08003637TEST_F(RtpDataChannelSingleThreadTest, TestSendData) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003638 CreateChannels(0, 0);
3639 EXPECT_TRUE(SendInitiate());
3640 EXPECT_TRUE(SendAccept());
3641
3642 cricket::SendDataParams params;
3643 params.ssrc = 42;
3644 unsigned char data[] = {'f', 'o', 'o'};
3645 rtc::CopyOnWriteBuffer payload(data, 3);
3646 cricket::SendDataResult result;
3647 ASSERT_TRUE(media_channel1_->SendData(params, payload, &result));
3648 EXPECT_EQ(params.ssrc, media_channel1_->last_sent_data_params().ssrc);
3649 EXPECT_EQ("foo", media_channel1_->last_sent_data());
3650}
3651
deadbeef953c2ce2017-01-09 14:53:41 -08003652TEST_F(RtpDataChannelDoubleThreadTest, TestInit) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003653 Base::TestInit();
3654 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
3655}
3656
deadbeef953c2ce2017-01-09 14:53:41 -08003657TEST_F(RtpDataChannelDoubleThreadTest, TestDeinit) {
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02003658 Base::TestDeinit();
3659}
3660
deadbeef953c2ce2017-01-09 14:53:41 -08003661TEST_F(RtpDataChannelDoubleThreadTest, TestSetContents) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003662 Base::TestSetContents();
3663}
3664
deadbeef953c2ce2017-01-09 14:53:41 -08003665TEST_F(RtpDataChannelDoubleThreadTest, TestSetContentsNullOffer) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003666 Base::TestSetContentsNullOffer();
3667}
3668
deadbeef953c2ce2017-01-09 14:53:41 -08003669TEST_F(RtpDataChannelDoubleThreadTest, TestSetContentsRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003670 Base::TestSetContentsRtcpMux();
3671}
3672
deadbeef953c2ce2017-01-09 14:53:41 -08003673TEST_F(RtpDataChannelDoubleThreadTest, TestSetRemoteContentUpdate) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003674 Base::TestSetRemoteContentUpdate();
3675}
3676
deadbeef953c2ce2017-01-09 14:53:41 -08003677TEST_F(RtpDataChannelDoubleThreadTest, TestStreams) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003678 Base::TestStreams();
3679}
3680
deadbeef953c2ce2017-01-09 14:53:41 -08003681TEST_F(RtpDataChannelDoubleThreadTest, TestUpdateStreamsInLocalContent) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003682 Base::TestUpdateStreamsInLocalContent();
3683}
3684
deadbeef953c2ce2017-01-09 14:53:41 -08003685TEST_F(RtpDataChannelDoubleThreadTest, TestUpdateRemoteStreamsInContent) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003686 Base::TestUpdateStreamsInRemoteContent();
3687}
3688
deadbeef953c2ce2017-01-09 14:53:41 -08003689TEST_F(RtpDataChannelDoubleThreadTest, TestChangeStreamParamsInContent) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003690 Base::TestChangeStreamParamsInContent();
3691}
3692
deadbeef953c2ce2017-01-09 14:53:41 -08003693TEST_F(RtpDataChannelDoubleThreadTest, TestPlayoutAndSendingStates) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003694 Base::TestPlayoutAndSendingStates();
3695}
3696
deadbeef953c2ce2017-01-09 14:53:41 -08003697TEST_F(RtpDataChannelDoubleThreadTest, TestMediaContentDirection) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003698 Base::TestMediaContentDirection();
3699}
3700
deadbeef953c2ce2017-01-09 14:53:41 -08003701TEST_F(RtpDataChannelDoubleThreadTest, TestCallSetup) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003702 Base::TestCallSetup();
3703}
3704
deadbeef953c2ce2017-01-09 14:53:41 -08003705TEST_F(RtpDataChannelDoubleThreadTest, TestCallTeardownRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003706 Base::TestCallTeardownRtcpMux();
3707}
3708
zstein56162b92017-04-24 16:54:35 -07003709TEST_F(RtpDataChannelDoubleThreadTest, TestOnTransportReadyToSend) {
3710 Base::TestOnTransportReadyToSend();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003711}
3712
zstein56162b92017-04-24 16:54:35 -07003713TEST_F(RtpDataChannelDoubleThreadTest, TestOnTransportReadyToSendWithRtcpMux) {
3714 Base::TestOnTransportReadyToSendWithRtcpMux();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003715}
3716
deadbeef953c2ce2017-01-09 14:53:41 -08003717TEST_F(RtpDataChannelDoubleThreadTest, SendRtpToRtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003718 Base::SendRtpToRtp();
3719}
3720
deadbeef953c2ce2017-01-09 14:53:41 -08003721TEST_F(RtpDataChannelDoubleThreadTest, SendRtcpToRtcp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003722 Base::SendRtcpToRtcp();
3723}
3724
deadbeef953c2ce2017-01-09 14:53:41 -08003725TEST_F(RtpDataChannelDoubleThreadTest, SendRtcpMuxToRtcp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003726 Base::SendRtcpMuxToRtcp();
3727}
3728
deadbeef953c2ce2017-01-09 14:53:41 -08003729TEST_F(RtpDataChannelDoubleThreadTest, SendRtcpMuxToRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003730 Base::SendRtcpMuxToRtcpMux();
3731}
3732
deadbeef953c2ce2017-01-09 14:53:41 -08003733TEST_F(RtpDataChannelDoubleThreadTest, SendEarlyRtcpMuxToRtcp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003734 Base::SendEarlyRtcpMuxToRtcp();
3735}
3736
deadbeef953c2ce2017-01-09 14:53:41 -08003737TEST_F(RtpDataChannelDoubleThreadTest, SendEarlyRtcpMuxToRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003738 Base::SendEarlyRtcpMuxToRtcpMux();
3739}
3740
deadbeef953c2ce2017-01-09 14:53:41 -08003741TEST_F(RtpDataChannelDoubleThreadTest, SendSrtpToSrtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003742 Base::SendSrtpToSrtp();
3743}
3744
deadbeef953c2ce2017-01-09 14:53:41 -08003745TEST_F(RtpDataChannelDoubleThreadTest, SendSrtpToRtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003746 Base::SendSrtpToSrtp();
3747}
3748
deadbeef953c2ce2017-01-09 14:53:41 -08003749TEST_F(RtpDataChannelDoubleThreadTest, SendSrtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003750 Base::SendSrtpToSrtp(RTCP_MUX, RTCP_MUX);
3751}
3752
deadbeef953c2ce2017-01-09 14:53:41 -08003753TEST_F(RtpDataChannelDoubleThreadTest, SendRtpToRtpOnThread) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003754 Base::SendRtpToRtpOnThread();
3755}
3756
deadbeef953c2ce2017-01-09 14:53:41 -08003757TEST_F(RtpDataChannelDoubleThreadTest, SendSrtpToSrtpOnThread) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003758 Base::SendSrtpToSrtpOnThread();
3759}
3760
deadbeef953c2ce2017-01-09 14:53:41 -08003761TEST_F(RtpDataChannelDoubleThreadTest, SendWithWritabilityLoss) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003762 Base::SendWithWritabilityLoss();
3763}
3764
deadbeef953c2ce2017-01-09 14:53:41 -08003765TEST_F(RtpDataChannelDoubleThreadTest, TestMediaMonitor) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02003766 Base::TestMediaMonitor();
3767}
3768
deadbeef953c2ce2017-01-09 14:53:41 -08003769TEST_F(RtpDataChannelDoubleThreadTest, TestSendData) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003770 CreateChannels(0, 0);
3771 EXPECT_TRUE(SendInitiate());
3772 EXPECT_TRUE(SendAccept());
3773
3774 cricket::SendDataParams params;
3775 params.ssrc = 42;
3776 unsigned char data[] = {
3777 'f', 'o', 'o'
3778 };
jbaucheec21bd2016-03-20 06:15:43 -07003779 rtc::CopyOnWriteBuffer payload(data, 3);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003780 cricket::SendDataResult result;
3781 ASSERT_TRUE(media_channel1_->SendData(params, payload, &result));
3782 EXPECT_EQ(params.ssrc,
3783 media_channel1_->last_sent_data_params().ssrc);
3784 EXPECT_EQ("foo", media_channel1_->last_sent_data());
3785}
3786
deadbeefbad5dad2017-01-17 18:32:35 -08003787#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
3788
3789// Verifies some DCHECKs are in place.
3790// Uses VoiceChannel, but any BaseChannel subclass would work.
3791class BaseChannelDeathTest : public testing::Test {
3792 public:
3793 BaseChannelDeathTest()
deadbeeff5346592017-01-24 21:51:21 -08003794 : fake_rtp_dtls_transport_("foo", cricket::ICE_CANDIDATE_COMPONENT_RTP),
3795 fake_rtcp_dtls_transport_("foo", cricket::ICE_CANDIDATE_COMPONENT_RTCP),
3796 // RTCP mux not required, SRTP required.
deadbeefbad5dad2017-01-17 18:32:35 -08003797 voice_channel_(
3798 rtc::Thread::Current(),
3799 rtc::Thread::Current(),
3800 rtc::Thread::Current(),
3801 &fake_media_engine_,
3802 new cricket::FakeVoiceMediaChannel(nullptr,
3803 cricket::AudioOptions()),
3804 cricket::CN_AUDIO,
3805 false,
deadbeeff5346592017-01-24 21:51:21 -08003806 true) {}
deadbeefbad5dad2017-01-17 18:32:35 -08003807
3808 protected:
deadbeefbad5dad2017-01-17 18:32:35 -08003809 cricket::FakeMediaEngine fake_media_engine_;
deadbeeff5346592017-01-24 21:51:21 -08003810 cricket::FakeDtlsTransport fake_rtp_dtls_transport_;
3811 cricket::FakeDtlsTransport fake_rtcp_dtls_transport_;
deadbeefbad5dad2017-01-17 18:32:35 -08003812 cricket::VoiceChannel voice_channel_;
deadbeefbad5dad2017-01-17 18:32:35 -08003813};
3814
deadbeeff5346592017-01-24 21:51:21 -08003815TEST_F(BaseChannelDeathTest, SetTransportsWithNullRtpTransport) {
3816 ASSERT_TRUE(voice_channel_.Init_w(
3817 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_,
3818 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_));
3819 cricket::FakeDtlsTransport new_rtcp_transport(
3820 "bar", cricket::ICE_CANDIDATE_COMPONENT_RTCP);
3821 EXPECT_DEATH(voice_channel_.SetTransports(nullptr, &new_rtcp_transport), "");
deadbeefbad5dad2017-01-17 18:32:35 -08003822}
3823
deadbeeff5346592017-01-24 21:51:21 -08003824TEST_F(BaseChannelDeathTest, SetTransportsWithMissingRtcpTransport) {
3825 ASSERT_TRUE(voice_channel_.Init_w(
3826 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_,
3827 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_));
3828 cricket::FakeDtlsTransport new_rtp_transport(
3829 "bar", cricket::ICE_CANDIDATE_COMPONENT_RTP);
3830 EXPECT_DEATH(voice_channel_.SetTransports(&new_rtp_transport, nullptr), "");
deadbeefbad5dad2017-01-17 18:32:35 -08003831}
3832
deadbeeff5346592017-01-24 21:51:21 -08003833TEST_F(BaseChannelDeathTest, SetTransportsWithUnneededRtcpTransport) {
3834 ASSERT_TRUE(voice_channel_.Init_w(
3835 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_,
3836 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_));
deadbeefbad5dad2017-01-17 18:32:35 -08003837 // Activate RTCP muxing, simulating offer/answer negotiation.
3838 cricket::AudioContentDescription content;
3839 content.set_rtcp_mux(true);
3840 ASSERT_TRUE(voice_channel_.SetLocalContent(&content, CA_OFFER, nullptr));
3841 ASSERT_TRUE(voice_channel_.SetRemoteContent(&content, CA_ANSWER, nullptr));
deadbeeff5346592017-01-24 21:51:21 -08003842 cricket::FakeDtlsTransport new_rtp_transport(
3843 "bar", cricket::ICE_CANDIDATE_COMPONENT_RTP);
3844 cricket::FakeDtlsTransport new_rtcp_transport(
3845 "bar", cricket::ICE_CANDIDATE_COMPONENT_RTCP);
deadbeefbad5dad2017-01-17 18:32:35 -08003846 // After muxing is enabled, no RTCP transport should be passed in here.
3847 EXPECT_DEATH(
deadbeeff5346592017-01-24 21:51:21 -08003848 voice_channel_.SetTransports(&new_rtp_transport, &new_rtcp_transport),
3849 "");
deadbeefbad5dad2017-01-17 18:32:35 -08003850}
3851
3852// This test will probably go away if/when we move the transport name out of
3853// the transport classes and into their parent classes.
deadbeeff5346592017-01-24 21:51:21 -08003854TEST_F(BaseChannelDeathTest, SetTransportsWithMismatchingTransportNames) {
3855 ASSERT_TRUE(voice_channel_.Init_w(
3856 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_,
3857 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_));
3858 cricket::FakeDtlsTransport new_rtp_transport(
3859 "bar", cricket::ICE_CANDIDATE_COMPONENT_RTP);
3860 cricket::FakeDtlsTransport new_rtcp_transport(
3861 "baz", cricket::ICE_CANDIDATE_COMPONENT_RTCP);
deadbeefbad5dad2017-01-17 18:32:35 -08003862 EXPECT_DEATH(
deadbeeff5346592017-01-24 21:51:21 -08003863 voice_channel_.SetTransports(&new_rtp_transport, &new_rtcp_transport),
3864 "");
3865}
3866
3867// Not expected to support going from DtlsTransportInternal to
deadbeef5bd5ca32017-02-10 11:31:50 -08003868// PacketTransportInternal.
deadbeeff5346592017-01-24 21:51:21 -08003869TEST_F(BaseChannelDeathTest, SetTransportsDtlsToNonDtls) {
3870 ASSERT_TRUE(voice_channel_.Init_w(
3871 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_,
3872 &fake_rtp_dtls_transport_, &fake_rtcp_dtls_transport_));
3873 EXPECT_DEATH(
deadbeef5bd5ca32017-02-10 11:31:50 -08003874 voice_channel_.SetTransports(
3875 static_cast<rtc::PacketTransportInternal*>(&fake_rtp_dtls_transport_),
3876 static_cast<rtc::PacketTransportInternal*>(
3877 &fake_rtp_dtls_transport_)),
deadbeeff5346592017-01-24 21:51:21 -08003878 "");
3879}
3880
deadbeef5bd5ca32017-02-10 11:31:50 -08003881// Not expected to support going from PacketTransportInternal to
deadbeeff5346592017-01-24 21:51:21 -08003882// DtlsTransportInternal.
3883TEST_F(BaseChannelDeathTest, SetTransportsNonDtlsToDtls) {
3884 ASSERT_TRUE(voice_channel_.Init_w(nullptr, nullptr, &fake_rtp_dtls_transport_,
3885 &fake_rtcp_dtls_transport_));
3886 EXPECT_DEATH(voice_channel_.SetTransports(&fake_rtp_dtls_transport_,
3887 &fake_rtp_dtls_transport_),
3888 "");
deadbeefbad5dad2017-01-17 18:32:35 -08003889}
3890
3891#endif // RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
3892
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003893// TODO(pthatcher): TestSetReceiver?