blob: f8548264c01a5625cdefd947b54b2256dc89cada [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>
Mirko Bonadeic61ce0d2017-11-21 17:04:20 +010012#include <utility>
kwiberg31022942016-03-11 14:18:21 -080013
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020014#include "api/array_view.h"
15#include "media/base/fakemediaengine.h"
16#include "media/base/fakertp.h"
17#include "media/base/mediachannel.h"
18#include "media/base/testutils.h"
19#include "p2p/base/fakecandidatepair.h"
20#include "p2p/base/fakedtlstransport.h"
21#include "p2p/base/fakepackettransport.h"
22#include "pc/channel.h"
23#include "rtc_base/buffer.h"
24#include "rtc_base/checks.h"
25#include "rtc_base/fakeclock.h"
26#include "rtc_base/gunit.h"
27#include "rtc_base/logging.h"
28#include "rtc_base/sslstreamadapter.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000029
zhihuangb2cdd932017-01-19 16:54:25 -080030using cricket::DtlsTransportInternal;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000031using cricket::FakeVoiceMediaChannel;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000032using cricket::StreamParams;
Steve Anton4e70a722017-11-28 14:57:10 -080033using webrtc::RtpTransceiverDirection;
Steve Anton3828c062017-12-06 10:34:51 -080034using webrtc::SdpType;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000035
Danil Chapovalov33b01f22016-05-11 19:55:27 +020036namespace {
37const cricket::AudioCodec kPcmuCodec(0, "PCMU", 64000, 8000, 1);
38const cricket::AudioCodec kPcmaCodec(8, "PCMA", 64000, 8000, 1);
39const cricket::AudioCodec kIsacCodec(103, "ISAC", 40000, 16000, 1);
perkj26752742016-10-24 01:21:16 -070040const cricket::VideoCodec kH264Codec(97, "H264");
41const cricket::VideoCodec kH264SvcCodec(99, "H264-SVC");
Danil Chapovalov33b01f22016-05-11 19:55:27 +020042const cricket::DataCodec kGoogleDataCodec(101, "google-data");
43const uint32_t kSsrc1 = 0x1111;
44const uint32_t kSsrc2 = 0x2222;
Zhi Huang365381f2018-04-13 16:44:34 -070045const uint32_t kSsrc3 = 0x3333;
46const uint32_t kSsrc4 = 0x4444;
Danil Chapovalov33b01f22016-05-11 19:55:27 +020047const int kAudioPts[] = {0, 8};
48const int kVideoPts[] = {97, 99};
49enum class NetworkIsWorker { Yes, No };
Niels Möller02284852018-01-17 10:22:47 +010050
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
Yves Gerey665174f2018-06-19 15:03:05 +020091template <class T>
henrike@webrtc.org28e20752013-07-10 00:45:36 +000092class ChannelTest : public testing::Test, public sigslot::has_slots<> {
93 public:
deadbeefac22f702017-01-12 21:59:29 -080094 enum Flags {
95 RTCP_MUX = 0x1,
deadbeefac22f702017-01-12 21:59:29 -080096 SSRC_MUX = 0x8,
97 DTLS = 0x10,
deadbeef5bd5ca32017-02-10 11:31:50 -080098 // Use BaseChannel with PacketTransportInternal rather than
deadbeeff5346592017-01-24 21:51:21 -080099 // DtlsTransportInternal.
deadbeef7914b8c2017-04-21 03:23:33 -0700100 RAW_PACKET_TRANSPORT = 0x20,
deadbeefac22f702017-01-12 21:59:29 -0800101 };
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000102
Peter Boström34fbfff2015-09-24 19:20:30 +0200103 ChannelTest(bool verify_playout,
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200104 rtc::ArrayView<const uint8_t> rtp_data,
105 rtc::ArrayView<const uint8_t> rtcp_data,
106 NetworkIsWorker network_is_worker)
Peter Boström34fbfff2015-09-24 19:20:30 +0200107 : verify_playout_(verify_playout),
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200108 rtp_packet_(rtp_data.data(), rtp_data.size()),
deadbeeff5346592017-01-24 21:51:21 -0800109 rtcp_packet_(rtcp_data.data(), rtcp_data.size()) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200110 if (network_is_worker == NetworkIsWorker::Yes) {
111 network_thread_ = rtc::Thread::Current();
112 } else {
113 network_thread_keeper_ = rtc::Thread::Create();
114 network_thread_keeper_->SetName("Network", nullptr);
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200115 network_thread_ = network_thread_keeper_.get();
116 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200117 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000118
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000119 void CreateChannels(int flags1, int flags2) {
Steve Anton8699a322017-11-06 15:53:33 -0800120 CreateChannels(rtc::MakeUnique<typename T::MediaChannel>(
121 nullptr, typename T::Options()),
122 rtc::MakeUnique<typename T::MediaChannel>(
123 nullptr, typename T::Options()),
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200124 flags1, flags2);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000125 }
Steve Anton8699a322017-11-06 15:53:33 -0800126 void CreateChannels(std::unique_ptr<typename T::MediaChannel> ch1,
127 std::unique_ptr<typename T::MediaChannel> ch2,
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200128 int flags1,
129 int flags2) {
deadbeeff5346592017-01-24 21:51:21 -0800130 // Network thread is started in CreateChannels, to allow the test to
131 // configure a fake clock before any threads are spawned and attempt to
132 // access the time.
133 if (network_thread_keeper_) {
134 network_thread_keeper_->Start();
135 }
Zhi Huange830e682018-03-30 10:48:35 -0700136
deadbeeff5346592017-01-24 21:51:21 -0800137 // Make sure if using raw packet transports, they're used for both
138 // channels.
139 RTC_DCHECK_EQ(flags1 & RAW_PACKET_TRANSPORT, flags2 & RAW_PACKET_TRANSPORT);
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200140 rtc::Thread* worker_thread = rtc::Thread::Current();
Steve Anton8699a322017-11-06 15:53:33 -0800141 media_channel1_ = ch1.get();
142 media_channel2_ = ch2.get();
deadbeef5bd5ca32017-02-10 11:31:50 -0800143 rtc::PacketTransportInternal* rtp1 = nullptr;
144 rtc::PacketTransportInternal* rtcp1 = nullptr;
145 rtc::PacketTransportInternal* rtp2 = nullptr;
146 rtc::PacketTransportInternal* rtcp2 = nullptr;
deadbeeff5346592017-01-24 21:51:21 -0800147 // Based on flags, create fake DTLS or raw packet transports.
148 if (flags1 & RAW_PACKET_TRANSPORT) {
149 fake_rtp_packet_transport1_.reset(
150 new rtc::FakePacketTransport("channel1_rtp"));
151 rtp1 = fake_rtp_packet_transport1_.get();
Zhi Huange830e682018-03-30 10:48:35 -0700152 if (!(flags1 & RTCP_MUX)) {
deadbeeff5346592017-01-24 21:51:21 -0800153 fake_rtcp_packet_transport1_.reset(
154 new rtc::FakePacketTransport("channel1_rtcp"));
155 rtcp1 = fake_rtcp_packet_transport1_.get();
156 }
157 } else {
158 // Confirmed to work with KT_RSA and KT_ECDSA.
159 fake_rtp_dtls_transport1_.reset(new cricket::FakeDtlsTransport(
160 "channel1", cricket::ICE_CANDIDATE_COMPONENT_RTP));
161 rtp1 = fake_rtp_dtls_transport1_.get();
Zhi Huange830e682018-03-30 10:48:35 -0700162 if (!(flags1 & RTCP_MUX)) {
deadbeeff5346592017-01-24 21:51:21 -0800163 fake_rtcp_dtls_transport1_.reset(new cricket::FakeDtlsTransport(
164 "channel1", cricket::ICE_CANDIDATE_COMPONENT_RTCP));
165 rtcp1 = fake_rtcp_dtls_transport1_.get();
166 }
167 if (flags1 & DTLS) {
168 auto cert1 =
169 rtc::RTCCertificate::Create(std::unique_ptr<rtc::SSLIdentity>(
170 rtc::SSLIdentity::Generate("session1", rtc::KT_DEFAULT)));
171 fake_rtp_dtls_transport1_->SetLocalCertificate(cert1);
172 if (fake_rtcp_dtls_transport1_) {
173 fake_rtcp_dtls_transport1_->SetLocalCertificate(cert1);
174 }
175 }
176 }
177 // Based on flags, create fake DTLS or raw packet transports.
178 if (flags2 & RAW_PACKET_TRANSPORT) {
179 fake_rtp_packet_transport2_.reset(
180 new rtc::FakePacketTransport("channel2_rtp"));
181 rtp2 = fake_rtp_packet_transport2_.get();
Zhi Huange830e682018-03-30 10:48:35 -0700182 if (!(flags2 & RTCP_MUX)) {
deadbeeff5346592017-01-24 21:51:21 -0800183 fake_rtcp_packet_transport2_.reset(
184 new rtc::FakePacketTransport("channel2_rtcp"));
185 rtcp2 = fake_rtcp_packet_transport2_.get();
186 }
187 } else {
188 // Confirmed to work with KT_RSA and KT_ECDSA.
189 fake_rtp_dtls_transport2_.reset(new cricket::FakeDtlsTransport(
190 "channel2", cricket::ICE_CANDIDATE_COMPONENT_RTP));
191 rtp2 = fake_rtp_dtls_transport2_.get();
Zhi Huange830e682018-03-30 10:48:35 -0700192 if (!(flags2 & RTCP_MUX)) {
deadbeeff5346592017-01-24 21:51:21 -0800193 fake_rtcp_dtls_transport2_.reset(new cricket::FakeDtlsTransport(
194 "channel2", cricket::ICE_CANDIDATE_COMPONENT_RTCP));
195 rtcp2 = fake_rtcp_dtls_transport2_.get();
196 }
197 if (flags2 & DTLS) {
198 auto cert2 =
199 rtc::RTCCertificate::Create(std::unique_ptr<rtc::SSLIdentity>(
200 rtc::SSLIdentity::Generate("session2", rtc::KT_DEFAULT)));
201 fake_rtp_dtls_transport2_->SetLocalCertificate(cert2);
202 if (fake_rtcp_dtls_transport2_) {
203 fake_rtcp_dtls_transport2_->SetLocalCertificate(cert2);
204 }
205 }
206 }
Zhi Huange830e682018-03-30 10:48:35 -0700207 rtp_transport1_ = CreateRtpTransportBasedOnFlags(
208 fake_rtp_packet_transport1_.get(), fake_rtcp_packet_transport1_.get(),
209 fake_rtp_dtls_transport1_.get(), fake_rtcp_dtls_transport1_.get(),
210 flags1);
211 rtp_transport2_ = CreateRtpTransportBasedOnFlags(
212 fake_rtp_packet_transport2_.get(), fake_rtcp_packet_transport2_.get(),
213 fake_rtp_dtls_transport2_.get(), fake_rtcp_dtls_transport2_.get(),
214 flags2);
215
216 channel1_ = CreateChannel(worker_thread, network_thread_, &media_engine_,
217 std::move(ch1), rtp_transport1_.get(), flags1);
218 channel2_ = CreateChannel(worker_thread, network_thread_, &media_engine_,
219 std::move(ch2), rtp_transport2_.get(), flags2);
deadbeefac22f702017-01-12 21:59:29 -0800220 channel1_->SignalRtcpMuxFullyActive.connect(
deadbeeff5346592017-01-24 21:51:21 -0800221 this, &ChannelTest<T>::OnRtcpMuxFullyActive1);
deadbeefac22f702017-01-12 21:59:29 -0800222 channel2_->SignalRtcpMuxFullyActive.connect(
deadbeeff5346592017-01-24 21:51:21 -0800223 this, &ChannelTest<T>::OnRtcpMuxFullyActive2);
Yves Gerey665174f2018-06-19 15:03:05 +0200224 CreateContent(flags1, kPcmuCodec, kH264Codec, &local_media_content1_);
225 CreateContent(flags2, kPcmuCodec, kH264Codec, &local_media_content2_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000226 CopyContent(local_media_content1_, &remote_media_content1_);
227 CopyContent(local_media_content2_, &remote_media_content2_);
228
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000229 // Add stream information (SSRC) to the local content but not to the remote
230 // content. This means that we per default know the SSRC of what we send but
231 // not what we receive.
232 AddLegacyStreamInContent(kSsrc1, flags1, &local_media_content1_);
233 AddLegacyStreamInContent(kSsrc2, flags2, &local_media_content2_);
234
235 // If SSRC_MUX is used we also need to know the SSRC of the incoming stream.
236 if (flags1 & SSRC_MUX) {
237 AddLegacyStreamInContent(kSsrc1, flags1, &remote_media_content1_);
238 }
239 if (flags2 & SSRC_MUX) {
240 AddLegacyStreamInContent(kSsrc2, flags2, &remote_media_content2_);
241 }
242 }
Steve Anton8699a322017-11-06 15:53:33 -0800243 std::unique_ptr<typename T::Channel> CreateChannel(
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200244 rtc::Thread* worker_thread,
245 rtc::Thread* network_thread,
deadbeefcbecd352015-09-23 11:50:27 -0700246 cricket::MediaEngineInterface* engine,
Steve Anton8699a322017-11-06 15:53:33 -0800247 std::unique_ptr<typename T::MediaChannel> ch,
Zhi Huange830e682018-03-30 10:48:35 -0700248 webrtc::RtpTransportInternal* rtp_transport,
jbauchcb560652016-08-04 05:20:32 -0700249 int flags) {
deadbeeff5346592017-01-24 21:51:21 -0800250 rtc::Thread* signaling_thread = rtc::Thread::Current();
Steve Anton8699a322017-11-06 15:53:33 -0800251 auto channel = rtc::MakeUnique<typename T::Channel>(
252 worker_thread, network_thread, signaling_thread, engine, std::move(ch),
Zhi Huange830e682018-03-30 10:48:35 -0700253 cricket::CN_AUDIO, (flags & DTLS) != 0, rtc::CryptoOptions());
254 channel->Init_w(rtp_transport);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000255 return channel;
256 }
257
Zhi Huange830e682018-03-30 10:48:35 -0700258 std::unique_ptr<webrtc::RtpTransportInternal> CreateRtpTransportBasedOnFlags(
259 rtc::PacketTransportInternal* rtp_packet_transport,
260 rtc::PacketTransportInternal* rtcp_packet_transport,
261 DtlsTransportInternal* rtp_dtls_transport,
262 DtlsTransportInternal* rtcp_dtls_transport,
263 int flags) {
264 if (flags & RTCP_MUX) {
265 rtcp_packet_transport = nullptr;
266 rtcp_dtls_transport = nullptr;
267 }
268
269 if (flags & DTLS) {
270 return CreateDtlsSrtpTransport(rtp_dtls_transport, rtcp_dtls_transport);
271 } else {
272 if (flags & RAW_PACKET_TRANSPORT) {
273 return CreateUnencryptedTransport(rtp_packet_transport,
274 rtcp_packet_transport);
275 } else {
276 return CreateUnencryptedTransport(rtp_dtls_transport,
277 rtcp_dtls_transport);
278 }
279 }
280 }
281
282 std::unique_ptr<webrtc::RtpTransport> CreateUnencryptedTransport(
283 rtc::PacketTransportInternal* rtp_packet_transport,
284 rtc::PacketTransportInternal* rtcp_packet_transport) {
Zhi Huange830e682018-03-30 10:48:35 -0700285 auto rtp_transport =
Zhi Huang365381f2018-04-13 16:44:34 -0700286 rtc::MakeUnique<webrtc::RtpTransport>(rtcp_packet_transport == nullptr);
Zhi Huange830e682018-03-30 10:48:35 -0700287
288 rtp_transport->SetRtpPacketTransport(rtp_packet_transport);
289 if (rtcp_packet_transport) {
290 rtp_transport->SetRtcpPacketTransport(rtcp_packet_transport);
291 }
292 return rtp_transport;
293 }
294
295 std::unique_ptr<webrtc::DtlsSrtpTransport> CreateDtlsSrtpTransport(
296 cricket::DtlsTransportInternal* rtp_dtls_transport,
297 cricket::DtlsTransportInternal* rtcp_dtls_transport) {
Zhi Huang365381f2018-04-13 16:44:34 -0700298 auto dtls_srtp_transport = rtc::MakeUnique<webrtc::DtlsSrtpTransport>(
299 rtcp_dtls_transport == nullptr);
Zhi Huange830e682018-03-30 10:48:35 -0700300
301 dtls_srtp_transport->SetDtlsTransports(rtp_dtls_transport,
302 rtcp_dtls_transport);
303 return dtls_srtp_transport;
304 }
305
deadbeeff5346592017-01-24 21:51:21 -0800306 void ConnectFakeTransports() {
307 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
308 bool asymmetric = false;
309 // Depending on test flags, could be using DTLS or raw packet transport.
310 if (fake_rtp_dtls_transport1_ && fake_rtp_dtls_transport2_) {
311 fake_rtp_dtls_transport1_->SetDestination(
312 fake_rtp_dtls_transport2_.get(), asymmetric);
313 }
314 if (fake_rtcp_dtls_transport1_ && fake_rtcp_dtls_transport2_) {
315 fake_rtcp_dtls_transport1_->SetDestination(
316 fake_rtcp_dtls_transport2_.get(), asymmetric);
317 }
318 if (fake_rtp_packet_transport1_ && fake_rtp_packet_transport2_) {
319 fake_rtp_packet_transport1_->SetDestination(
320 fake_rtp_packet_transport2_.get(), asymmetric);
321 }
322 if (fake_rtcp_packet_transport1_ && fake_rtcp_packet_transport2_) {
323 fake_rtcp_packet_transport1_->SetDestination(
324 fake_rtcp_packet_transport2_.get(), asymmetric);
325 }
326 });
327 }
328
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000329 bool SendInitiate() {
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000330 bool result = channel1_->SetLocalContent(&local_media_content1_,
Steve Anton3828c062017-12-06 10:34:51 -0800331 SdpType::kOffer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000332 if (result) {
333 channel1_->Enable(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000334 result = channel2_->SetRemoteContent(&remote_media_content1_,
Steve Anton3828c062017-12-06 10:34:51 -0800335 SdpType::kOffer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000336 if (result) {
deadbeeff5346592017-01-24 21:51:21 -0800337 ConnectFakeTransports();
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000338 result = channel2_->SetLocalContent(&local_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800339 SdpType::kAnswer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000340 }
341 }
342 return result;
343 }
344
345 bool SendAccept() {
346 channel2_->Enable(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000347 return channel1_->SetRemoteContent(&remote_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800348 SdpType::kAnswer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000349 }
350
351 bool SendOffer() {
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000352 bool result = channel1_->SetLocalContent(&local_media_content1_,
Steve Anton3828c062017-12-06 10:34:51 -0800353 SdpType::kOffer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000354 if (result) {
355 channel1_->Enable(true);
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000356 result = channel2_->SetRemoteContent(&remote_media_content1_,
Steve Anton3828c062017-12-06 10:34:51 -0800357 SdpType::kOffer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000358 }
359 return result;
360 }
361
362 bool SendProvisionalAnswer() {
363 bool result = channel2_->SetLocalContent(&local_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800364 SdpType::kPrAnswer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000365 if (result) {
366 channel2_->Enable(true);
367 result = channel1_->SetRemoteContent(&remote_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800368 SdpType::kPrAnswer, NULL);
deadbeeff5346592017-01-24 21:51:21 -0800369 ConnectFakeTransports();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000370 }
371 return result;
372 }
373
374 bool SendFinalAnswer() {
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000375 bool result = channel2_->SetLocalContent(&local_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800376 SdpType::kAnswer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000377 if (result)
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000378 result = channel1_->SetRemoteContent(&remote_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800379 SdpType::kAnswer, NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000380 return result;
381 }
382
deadbeeff5346592017-01-24 21:51:21 -0800383 bool Terminate() {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000384 channel1_.reset();
385 channel2_.reset();
deadbeeff5346592017-01-24 21:51:21 -0800386 fake_rtp_dtls_transport1_.reset();
387 fake_rtcp_dtls_transport1_.reset();
388 fake_rtp_dtls_transport2_.reset();
389 fake_rtcp_dtls_transport2_.reset();
390 fake_rtp_packet_transport1_.reset();
391 fake_rtcp_packet_transport1_.reset();
392 fake_rtp_packet_transport2_.reset();
393 fake_rtcp_packet_transport2_.reset();
394 if (network_thread_keeper_) {
395 network_thread_keeper_.reset();
396 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000397 return true;
398 }
399
400 bool AddStream1(int id) {
401 return channel1_->AddRecvStream(cricket::StreamParams::CreateLegacy(id));
402 }
Yves Gerey665174f2018-06-19 15:03:05 +0200403 bool RemoveStream1(int id) { return channel1_->RemoveRecvStream(id); }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000404
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200405 void SendRtp1() {
406 media_channel1_->SendRtp(rtp_packet_.data(), rtp_packet_.size(),
407 rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000408 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200409 void SendRtp2() {
410 media_channel2_->SendRtp(rtp_packet_.data(), rtp_packet_.size(),
411 rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000412 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200413 void SendRtcp1() {
414 media_channel1_->SendRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000415 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200416 void SendRtcp2() {
417 media_channel2_->SendRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000418 }
419 // Methods to send custom data.
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200420 void SendCustomRtp1(uint32_t ssrc, int sequence_number, int pl_type = -1) {
421 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
422 media_channel1_->SendRtp(data.data(), data.size(), rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000423 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200424 void SendCustomRtp2(uint32_t ssrc, int sequence_number, int pl_type = -1) {
425 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
426 media_channel2_->SendRtp(data.data(), data.size(), rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000427 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200428 void SendCustomRtcp1(uint32_t ssrc) {
429 rtc::Buffer data = CreateRtcpData(ssrc);
430 media_channel1_->SendRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000431 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200432 void SendCustomRtcp2(uint32_t ssrc) {
433 rtc::Buffer data = CreateRtcpData(ssrc);
434 media_channel2_->SendRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000435 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200436
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000437 bool CheckRtp1() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200438 return media_channel1_->CheckRtp(rtp_packet_.data(), rtp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000439 }
440 bool CheckRtp2() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200441 return media_channel2_->CheckRtp(rtp_packet_.data(), rtp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000442 }
443 bool CheckRtcp1() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200444 return media_channel1_->CheckRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000445 }
446 bool CheckRtcp2() {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200447 return media_channel2_->CheckRtcp(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000448 }
449 // Methods to check custom data.
Peter Boström0c4e06b2015-10-07 12:23:21 +0200450 bool CheckCustomRtp1(uint32_t ssrc, int sequence_number, int pl_type = -1) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200451 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
452 return media_channel1_->CheckRtp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000453 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200454 bool CheckCustomRtp2(uint32_t ssrc, int sequence_number, int pl_type = -1) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200455 rtc::Buffer data = CreateRtpData(ssrc, sequence_number, pl_type);
456 return media_channel2_->CheckRtp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000457 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200458 bool CheckCustomRtcp1(uint32_t ssrc) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200459 rtc::Buffer data = CreateRtcpData(ssrc);
460 return media_channel1_->CheckRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000461 }
Peter Boström0c4e06b2015-10-07 12:23:21 +0200462 bool CheckCustomRtcp2(uint32_t ssrc) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200463 rtc::Buffer data = CreateRtcpData(ssrc);
464 return media_channel2_->CheckRtcp(data.data(), data.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000465 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200466 rtc::Buffer CreateRtpData(uint32_t ssrc, int sequence_number, int pl_type) {
467 rtc::Buffer data(rtp_packet_.data(), rtp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000468 // Set SSRC in the rtp packet copy.
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200469 rtc::SetBE32(data.data() + 8, ssrc);
470 rtc::SetBE16(data.data() + 2, sequence_number);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +0000471 if (pl_type >= 0) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200472 rtc::Set8(data.data(), 1, static_cast<uint8_t>(pl_type));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +0000473 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000474 return data;
475 }
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200476 rtc::Buffer CreateRtcpData(uint32_t ssrc) {
477 rtc::Buffer data(rtcp_packet_.data(), rtcp_packet_.size());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000478 // Set SSRC in the rtcp packet copy.
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200479 rtc::SetBE32(data.data() + 4, ssrc);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000480 return data;
481 }
482
Yves Gerey665174f2018-06-19 15:03:05 +0200483 bool CheckNoRtp1() { return media_channel1_->CheckNoRtp(); }
484 bool CheckNoRtp2() { return media_channel2_->CheckNoRtp(); }
485 bool CheckNoRtcp1() { return media_channel1_->CheckNoRtcp(); }
486 bool CheckNoRtcp2() { return media_channel2_->CheckNoRtcp(); }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000487
488 void CreateContent(int flags,
489 const cricket::AudioCodec& audio_codec,
490 const cricket::VideoCodec& video_codec,
491 typename T::Content* content) {
492 // overridden in specialized classes
493 }
494 void CopyContent(const typename T::Content& source,
495 typename T::Content* content) {
496 // overridden in specialized classes
497 }
498
Steve Anton18ee1d52017-09-11 11:32:35 -0700499 // Creates a MediaContent with one stream.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000500 // kPcmuCodec is used as audio codec and kH264Codec is used as video codec.
Steve Anton18ee1d52017-09-11 11:32:35 -0700501 typename T::Content* CreateMediaContentWithStream(uint32_t ssrc) {
502 typename T::Content* content = new typename T::Content();
Zhi Huange830e682018-03-30 10:48:35 -0700503 CreateContent(0, kPcmuCodec, kH264Codec, content);
Steve Anton18ee1d52017-09-11 11:32:35 -0700504 AddLegacyStreamInContent(ssrc, 0, content);
505 return content;
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000506 }
507
ossu292d6582016-03-17 02:31:13 -0700508 // Will manage the lifetime of a CallThread, making sure it's
509 // destroyed before this object goes out of scope.
510 class ScopedCallThread {
511 public:
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200512 template <class FunctorT>
Steve Anton36b29d12017-10-30 09:57:42 -0700513 explicit ScopedCallThread(const FunctorT& functor)
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200514 : thread_(rtc::Thread::Create()),
515 task_(new rtc::FunctorMessageHandler<void, FunctorT>(functor)) {
ossu292d6582016-03-17 02:31:13 -0700516 thread_->Start();
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -0700517 thread_->Post(RTC_FROM_HERE, task_.get());
ossu292d6582016-03-17 02:31:13 -0700518 }
519
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200520 ~ScopedCallThread() { thread_->Stop(); }
ossu292d6582016-03-17 02:31:13 -0700521
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200522 rtc::Thread* thread() { return thread_.get(); }
ossu292d6582016-03-17 02:31:13 -0700523
524 private:
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200525 std::unique_ptr<rtc::Thread> thread_;
526 std::unique_ptr<rtc::MessageHandler> task_;
ossu292d6582016-03-17 02:31:13 -0700527 };
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000528
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000529 bool CodecMatches(const typename T::Codec& c1, const typename T::Codec& c2) {
530 return false; // overridden in specialized classes
531 }
532
deadbeeff5346592017-01-24 21:51:21 -0800533 void OnRtcpMuxFullyActive1(const std::string&) {
534 rtcp_mux_activated_callbacks1_++;
535 }
536 void OnRtcpMuxFullyActive2(const std::string&) {
537 rtcp_mux_activated_callbacks2_++;
538 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000539
Honghai Zhangcc411c02016-03-29 17:27:21 -0700540 cricket::CandidatePairInterface* last_selected_candidate_pair() {
541 return last_selected_candidate_pair_;
542 }
543
Peter Boström0c4e06b2015-10-07 12:23:21 +0200544 void AddLegacyStreamInContent(uint32_t ssrc,
545 int flags,
546 typename T::Content* content) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000547 // Base implementation.
548 }
549
550 // Tests that can be used by derived classes.
551
552 // Basic sanity check.
553 void TestInit() {
554 CreateChannels(0, 0);
Zhi Huangcf990f52017-09-22 12:12:30 -0700555 EXPECT_FALSE(channel1_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000556 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200557 if (verify_playout_) {
558 EXPECT_FALSE(media_channel1_->playout());
559 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000560 EXPECT_TRUE(media_channel1_->codecs().empty());
561 EXPECT_TRUE(media_channel1_->recv_streams().empty());
562 EXPECT_TRUE(media_channel1_->rtp_packets().empty());
563 EXPECT_TRUE(media_channel1_->rtcp_packets().empty());
564 }
565
566 // Test that SetLocalContent and SetRemoteContent properly configure
567 // the codecs.
568 void TestSetContents() {
569 CreateChannels(0, 0);
570 typename T::Content content;
571 CreateContent(0, kPcmuCodec, kH264Codec, &content);
Steve Anton3828c062017-12-06 10:34:51 -0800572 EXPECT_TRUE(channel1_->SetLocalContent(&content, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000573 EXPECT_EQ(0U, media_channel1_->codecs().size());
Steve Anton3828c062017-12-06 10:34:51 -0800574 EXPECT_TRUE(channel1_->SetRemoteContent(&content, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000575 ASSERT_EQ(1U, media_channel1_->codecs().size());
Yves Gerey665174f2018-06-19 15:03:05 +0200576 EXPECT_TRUE(
577 CodecMatches(content.codecs()[0], media_channel1_->codecs()[0]));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000578 }
579
580 // Test that SetLocalContent and SetRemoteContent properly deals
581 // with an empty offer.
582 void TestSetContentsNullOffer() {
583 CreateChannels(0, 0);
584 typename T::Content content;
Steve Anton3828c062017-12-06 10:34:51 -0800585 EXPECT_TRUE(channel1_->SetLocalContent(&content, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000586 CreateContent(0, kPcmuCodec, kH264Codec, &content);
587 EXPECT_EQ(0U, media_channel1_->codecs().size());
Steve Anton3828c062017-12-06 10:34:51 -0800588 EXPECT_TRUE(channel1_->SetRemoteContent(&content, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000589 ASSERT_EQ(1U, media_channel1_->codecs().size());
Yves Gerey665174f2018-06-19 15:03:05 +0200590 EXPECT_TRUE(
591 CodecMatches(content.codecs()[0], media_channel1_->codecs()[0]));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000592 }
593
594 // Test that SetLocalContent and SetRemoteContent properly set RTCP
595 // mux.
596 void TestSetContentsRtcpMux() {
deadbeefac22f702017-01-12 21:59:29 -0800597 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000598 typename T::Content content;
599 CreateContent(0, kPcmuCodec, kH264Codec, &content);
600 // Both sides agree on mux. Should no longer be a separate RTCP channel.
601 content.set_rtcp_mux(true);
Steve Anton3828c062017-12-06 10:34:51 -0800602 EXPECT_TRUE(channel1_->SetLocalContent(&content, SdpType::kOffer, NULL));
603 EXPECT_TRUE(channel1_->SetRemoteContent(&content, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000604 // Only initiator supports mux. Should still have a separate RTCP channel.
Steve Anton3828c062017-12-06 10:34:51 -0800605 EXPECT_TRUE(channel2_->SetLocalContent(&content, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000606 content.set_rtcp_mux(false);
Steve Anton3828c062017-12-06 10:34:51 -0800607 EXPECT_TRUE(channel2_->SetRemoteContent(&content, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000608 }
609
610 // Test that SetLocalContent and SetRemoteContent properly set RTCP
611 // mux when a provisional answer is received.
612 void TestSetContentsRtcpMuxWithPrAnswer() {
deadbeefac22f702017-01-12 21:59:29 -0800613 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000614 typename T::Content content;
615 CreateContent(0, kPcmuCodec, kH264Codec, &content);
616 content.set_rtcp_mux(true);
Steve Anton3828c062017-12-06 10:34:51 -0800617 EXPECT_TRUE(channel1_->SetLocalContent(&content, SdpType::kOffer, NULL));
618 EXPECT_TRUE(
619 channel1_->SetRemoteContent(&content, SdpType::kPrAnswer, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800620 // Both sides agree on mux. Should signal RTCP mux as fully activated.
621 EXPECT_EQ(0, rtcp_mux_activated_callbacks1_);
Steve Anton3828c062017-12-06 10:34:51 -0800622 EXPECT_TRUE(channel1_->SetRemoteContent(&content, SdpType::kAnswer, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800623 EXPECT_EQ(1, rtcp_mux_activated_callbacks1_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000624 // Only initiator supports mux. Should still have a separate RTCP channel.
Steve Anton3828c062017-12-06 10:34:51 -0800625 EXPECT_TRUE(channel2_->SetLocalContent(&content, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000626 content.set_rtcp_mux(false);
Steve Anton3828c062017-12-06 10:34:51 -0800627 EXPECT_TRUE(
628 channel2_->SetRemoteContent(&content, SdpType::kPrAnswer, NULL));
629 EXPECT_TRUE(channel2_->SetRemoteContent(&content, SdpType::kAnswer, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800630 EXPECT_EQ(0, rtcp_mux_activated_callbacks2_);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000631 }
632
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000633 // Test that Add/RemoveStream properly forward to the media channel.
634 void TestStreams() {
635 CreateChannels(0, 0);
636 EXPECT_TRUE(AddStream1(1));
637 EXPECT_TRUE(AddStream1(2));
638 EXPECT_EQ(2U, media_channel1_->recv_streams().size());
639 EXPECT_TRUE(RemoveStream1(2));
640 EXPECT_EQ(1U, media_channel1_->recv_streams().size());
641 EXPECT_TRUE(RemoveStream1(1));
642 EXPECT_EQ(0U, media_channel1_->recv_streams().size());
643 }
644
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000645 // Test that SetLocalContent and SetRemoteContent properly
646 // handles adding and removing StreamParams when the action is a full
Steve Anton3828c062017-12-06 10:34:51 -0800647 // SdpType::kOffer / SdpType::kAnswer.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000648 void TestChangeStreamParamsInContent() {
649 cricket::StreamParams stream1;
650 stream1.groupid = "group1";
651 stream1.id = "stream1";
652 stream1.ssrcs.push_back(kSsrc1);
653 stream1.cname = "stream1_cname";
654
655 cricket::StreamParams stream2;
656 stream2.groupid = "group1";
657 stream2.id = "stream2";
658 stream2.ssrcs.push_back(kSsrc2);
659 stream2.cname = "stream2_cname";
660
661 // Setup a call where channel 1 send |stream1| to channel 2.
662 CreateChannels(0, 0);
663 typename T::Content content1;
664 CreateContent(0, kPcmuCodec, kH264Codec, &content1);
665 content1.AddStream(stream1);
Steve Anton3828c062017-12-06 10:34:51 -0800666 EXPECT_TRUE(channel1_->SetLocalContent(&content1, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000667 EXPECT_TRUE(channel1_->Enable(true));
668 EXPECT_EQ(1u, media_channel1_->send_streams().size());
669
Steve Anton3828c062017-12-06 10:34:51 -0800670 EXPECT_TRUE(channel2_->SetRemoteContent(&content1, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000671 EXPECT_EQ(1u, media_channel2_->recv_streams().size());
deadbeeff5346592017-01-24 21:51:21 -0800672 ConnectFakeTransports();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000673
674 // Channel 2 do not send anything.
675 typename T::Content content2;
676 CreateContent(0, kPcmuCodec, kH264Codec, &content2);
Steve Anton3828c062017-12-06 10:34:51 -0800677 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000678 EXPECT_EQ(0u, media_channel1_->recv_streams().size());
Steve Anton3828c062017-12-06 10:34:51 -0800679 EXPECT_TRUE(channel2_->SetLocalContent(&content2, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000680 EXPECT_TRUE(channel2_->Enable(true));
681 EXPECT_EQ(0u, media_channel2_->send_streams().size());
682
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200683 SendCustomRtp1(kSsrc1, 0);
684 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000685 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, 0));
686
687 // Let channel 2 update the content by sending |stream2| and enable SRTP.
688 typename T::Content content3;
Zhi Huange830e682018-03-30 10:48:35 -0700689 CreateContent(0, kPcmuCodec, kH264Codec, &content3);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000690 content3.AddStream(stream2);
Steve Anton3828c062017-12-06 10:34:51 -0800691 EXPECT_TRUE(channel2_->SetLocalContent(&content3, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000692 ASSERT_EQ(1u, media_channel2_->send_streams().size());
693 EXPECT_EQ(stream2, media_channel2_->send_streams()[0]);
694
Steve Anton3828c062017-12-06 10:34:51 -0800695 EXPECT_TRUE(channel1_->SetRemoteContent(&content3, SdpType::kOffer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000696 ASSERT_EQ(1u, media_channel1_->recv_streams().size());
697 EXPECT_EQ(stream2, media_channel1_->recv_streams()[0]);
698
699 // Channel 1 replies but stop sending stream1.
700 typename T::Content content4;
Zhi Huange830e682018-03-30 10:48:35 -0700701 CreateContent(0, kPcmuCodec, kH264Codec, &content4);
Steve Anton3828c062017-12-06 10:34:51 -0800702 EXPECT_TRUE(channel1_->SetLocalContent(&content4, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000703 EXPECT_EQ(0u, media_channel1_->send_streams().size());
704
Steve Anton3828c062017-12-06 10:34:51 -0800705 EXPECT_TRUE(channel2_->SetRemoteContent(&content4, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000706 EXPECT_EQ(0u, media_channel2_->recv_streams().size());
707
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200708 SendCustomRtp2(kSsrc2, 0);
709 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000710 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, 0));
711 }
712
713 // Test that we only start playout and sending at the right times.
714 void TestPlayoutAndSendingStates() {
715 CreateChannels(0, 0);
Peter Boström34fbfff2015-09-24 19:20:30 +0200716 if (verify_playout_) {
717 EXPECT_FALSE(media_channel1_->playout());
718 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000719 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200720 if (verify_playout_) {
721 EXPECT_FALSE(media_channel2_->playout());
722 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000723 EXPECT_FALSE(media_channel2_->sending());
724 EXPECT_TRUE(channel1_->Enable(true));
Peter Boström34fbfff2015-09-24 19:20:30 +0200725 if (verify_playout_) {
726 EXPECT_FALSE(media_channel1_->playout());
727 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000728 EXPECT_FALSE(media_channel1_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000729 EXPECT_TRUE(channel1_->SetLocalContent(&local_media_content1_,
Steve Anton3828c062017-12-06 10:34:51 -0800730 SdpType::kOffer, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +0200731 if (verify_playout_) {
732 EXPECT_TRUE(media_channel1_->playout());
733 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000734 EXPECT_FALSE(media_channel1_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000735 EXPECT_TRUE(channel2_->SetRemoteContent(&local_media_content1_,
Steve Anton3828c062017-12-06 10:34:51 -0800736 SdpType::kOffer, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +0200737 if (verify_playout_) {
738 EXPECT_FALSE(media_channel2_->playout());
739 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000740 EXPECT_FALSE(media_channel2_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000741 EXPECT_TRUE(channel2_->SetLocalContent(&local_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800742 SdpType::kAnswer, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +0200743 if (verify_playout_) {
744 EXPECT_FALSE(media_channel2_->playout());
745 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000746 EXPECT_FALSE(media_channel2_->sending());
deadbeeff5346592017-01-24 21:51:21 -0800747 ConnectFakeTransports();
Peter Boström34fbfff2015-09-24 19:20:30 +0200748 if (verify_playout_) {
749 EXPECT_TRUE(media_channel1_->playout());
750 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000751 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200752 if (verify_playout_) {
753 EXPECT_FALSE(media_channel2_->playout());
754 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000755 EXPECT_FALSE(media_channel2_->sending());
756 EXPECT_TRUE(channel2_->Enable(true));
Peter Boström34fbfff2015-09-24 19:20:30 +0200757 if (verify_playout_) {
758 EXPECT_TRUE(media_channel2_->playout());
759 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000760 EXPECT_TRUE(media_channel2_->sending());
sergeyu@chromium.org4b26e2e2014-01-15 23:15:54 +0000761 EXPECT_TRUE(channel1_->SetRemoteContent(&local_media_content2_,
Steve Anton3828c062017-12-06 10:34:51 -0800762 SdpType::kAnswer, NULL));
Peter Boström34fbfff2015-09-24 19:20:30 +0200763 if (verify_playout_) {
764 EXPECT_TRUE(media_channel1_->playout());
765 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000766 EXPECT_TRUE(media_channel1_->sending());
767 }
768
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000769 // Test that changing the MediaContentDirection in the local and remote
770 // session description start playout and sending at the right time.
771 void TestMediaContentDirection() {
772 CreateChannels(0, 0);
773 typename T::Content content1;
774 CreateContent(0, kPcmuCodec, kH264Codec, &content1);
775 typename T::Content content2;
776 CreateContent(0, kPcmuCodec, kH264Codec, &content2);
777 // Set |content2| to be InActive.
Steve Anton4e70a722017-11-28 14:57:10 -0800778 content2.set_direction(RtpTransceiverDirection::kInactive);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000779
780 EXPECT_TRUE(channel1_->Enable(true));
781 EXPECT_TRUE(channel2_->Enable(true));
Peter Boström34fbfff2015-09-24 19:20:30 +0200782 if (verify_playout_) {
783 EXPECT_FALSE(media_channel1_->playout());
784 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000785 EXPECT_FALSE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200786 if (verify_playout_) {
787 EXPECT_FALSE(media_channel2_->playout());
788 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000789 EXPECT_FALSE(media_channel2_->sending());
790
Steve Anton3828c062017-12-06 10:34:51 -0800791 EXPECT_TRUE(channel1_->SetLocalContent(&content1, SdpType::kOffer, NULL));
792 EXPECT_TRUE(channel2_->SetRemoteContent(&content1, SdpType::kOffer, NULL));
793 EXPECT_TRUE(
794 channel2_->SetLocalContent(&content2, SdpType::kPrAnswer, NULL));
795 EXPECT_TRUE(
796 channel1_->SetRemoteContent(&content2, SdpType::kPrAnswer, NULL));
deadbeeff5346592017-01-24 21:51:21 -0800797 ConnectFakeTransports();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000798
Peter Boström34fbfff2015-09-24 19:20:30 +0200799 if (verify_playout_) {
800 EXPECT_TRUE(media_channel1_->playout());
801 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000802 EXPECT_FALSE(media_channel1_->sending()); // remote InActive
Peter Boström34fbfff2015-09-24 19:20:30 +0200803 if (verify_playout_) {
804 EXPECT_FALSE(media_channel2_->playout()); // local InActive
805 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000806 EXPECT_FALSE(media_channel2_->sending()); // local InActive
807
808 // Update |content2| to be RecvOnly.
Steve Anton4e70a722017-11-28 14:57:10 -0800809 content2.set_direction(RtpTransceiverDirection::kRecvOnly);
Steve Anton3828c062017-12-06 10:34:51 -0800810 EXPECT_TRUE(
811 channel2_->SetLocalContent(&content2, SdpType::kPrAnswer, NULL));
812 EXPECT_TRUE(
813 channel1_->SetRemoteContent(&content2, SdpType::kPrAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000814
Peter Boström34fbfff2015-09-24 19:20:30 +0200815 if (verify_playout_) {
816 EXPECT_TRUE(media_channel1_->playout());
817 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000818 EXPECT_TRUE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200819 if (verify_playout_) {
820 EXPECT_TRUE(media_channel2_->playout()); // local RecvOnly
821 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000822 EXPECT_FALSE(media_channel2_->sending()); // local RecvOnly
823
824 // Update |content2| to be SendRecv.
Steve Anton4e70a722017-11-28 14:57:10 -0800825 content2.set_direction(RtpTransceiverDirection::kSendRecv);
Steve Anton3828c062017-12-06 10:34:51 -0800826 EXPECT_TRUE(channel2_->SetLocalContent(&content2, SdpType::kAnswer, NULL));
827 EXPECT_TRUE(channel1_->SetRemoteContent(&content2, SdpType::kAnswer, NULL));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000828
Peter Boström34fbfff2015-09-24 19:20:30 +0200829 if (verify_playout_) {
830 EXPECT_TRUE(media_channel1_->playout());
831 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000832 EXPECT_TRUE(media_channel1_->sending());
Peter Boström34fbfff2015-09-24 19:20:30 +0200833 if (verify_playout_) {
834 EXPECT_TRUE(media_channel2_->playout());
835 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000836 EXPECT_TRUE(media_channel2_->sending());
837 }
838
Honghai Zhangcc411c02016-03-29 17:27:21 -0700839 // Tests that when the transport channel signals a candidate pair change
840 // event, the media channel will receive a call on the network route change.
841 void TestNetworkRouteChanges() {
eladalon05b07bb2017-08-24 07:40:16 -0700842 static constexpr uint16_t kLocalNetId = 1;
843 static constexpr uint16_t kRemoteNetId = 2;
844 static constexpr int kLastPacketId = 100;
Zhi Huang942bc2e2017-11-13 13:26:07 -0800845 // Ipv4(20) + UDP(8).
846 static constexpr int kTransportOverheadPerPacket = 28;
Zhi Huangcf6e24a2018-02-21 10:40:07 -0800847 static constexpr int kSrtpOverheadPerPacket = 10;
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200848
Zhi Huangcf6e24a2018-02-21 10:40:07 -0800849 CreateChannels(DTLS, DTLS);
850 SendInitiate();
Honghai Zhangcc411c02016-03-29 17:27:21 -0700851
Honghai Zhangcc411c02016-03-29 17:27:21 -0700852 typename T::MediaChannel* media_channel1 =
853 static_cast<typename T::MediaChannel*>(channel1_->media_channel());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200854 ASSERT_TRUE(media_channel1);
Honghai Zhangcc411c02016-03-29 17:27:21 -0700855
Zhi Huang942bc2e2017-11-13 13:26:07 -0800856 // Need to wait for the threads before calling
857 // |set_num_network_route_changes| because the network route would be set
858 // when creating the channel.
859 WaitForThreads();
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200860 media_channel1->set_num_network_route_changes(0);
deadbeeff5346592017-01-24 21:51:21 -0800861 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
Zhi Huang942bc2e2017-11-13 13:26:07 -0800862 rtc::NetworkRoute network_route;
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200863 // The transport channel becomes disconnected.
Zhi Huang942bc2e2017-11-13 13:26:07 -0800864 fake_rtp_dtls_transport1_->ice_transport()->SignalNetworkRouteChanged(
865
866 rtc::Optional<rtc::NetworkRoute>(network_route));
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200867 });
868 WaitForThreads();
869 EXPECT_EQ(1, media_channel1->num_network_route_changes());
Honghai Zhangcc411c02016-03-29 17:27:21 -0700870 EXPECT_FALSE(media_channel1->last_network_route().connected);
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200871 media_channel1->set_num_network_route_changes(0);
Honghai Zhangcc411c02016-03-29 17:27:21 -0700872
eladalon05b07bb2017-08-24 07:40:16 -0700873 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
Zhi Huang942bc2e2017-11-13 13:26:07 -0800874 rtc::NetworkRoute network_route;
875 network_route.connected = true;
876 network_route.local_network_id = kLocalNetId;
877 network_route.remote_network_id = kRemoteNetId;
878 network_route.last_sent_packet_id = kLastPacketId;
879 network_route.packet_overhead = kTransportOverheadPerPacket;
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200880 // The transport channel becomes connected.
Zhi Huang942bc2e2017-11-13 13:26:07 -0800881 fake_rtp_dtls_transport1_->ice_transport()->SignalNetworkRouteChanged(
882
883 rtc::Optional<rtc::NetworkRoute>(network_route));
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200884 });
885 WaitForThreads();
886 EXPECT_EQ(1, media_channel1->num_network_route_changes());
honghaiz059e1832016-06-24 11:03:55 -0700887 rtc::NetworkRoute expected_network_route(true, kLocalNetId, kRemoteNetId,
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200888 kLastPacketId);
Honghai Zhangcc411c02016-03-29 17:27:21 -0700889 EXPECT_EQ(expected_network_route, media_channel1->last_network_route());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200890 EXPECT_EQ(kLastPacketId,
Honghai Zhang52dce732016-03-31 12:37:31 -0700891 media_channel1->last_network_route().last_sent_packet_id);
Zhi Huangcf6e24a2018-02-21 10:40:07 -0800892 EXPECT_EQ(kTransportOverheadPerPacket + kSrtpOverheadPerPacket,
michaelt79e05882016-11-08 02:50:09 -0800893 media_channel1->transport_overhead_per_packet());
Honghai Zhangcc411c02016-03-29 17:27:21 -0700894 }
895
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000896 // Test setting up a call.
897 void TestCallSetup() {
898 CreateChannels(0, 0);
Zhi Huangcf990f52017-09-22 12:12:30 -0700899 EXPECT_FALSE(channel1_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000900 EXPECT_TRUE(SendInitiate());
Peter Boström34fbfff2015-09-24 19:20:30 +0200901 if (verify_playout_) {
902 EXPECT_TRUE(media_channel1_->playout());
903 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000904 EXPECT_FALSE(media_channel1_->sending());
905 EXPECT_TRUE(SendAccept());
Zhi Huangcf990f52017-09-22 12:12:30 -0700906 EXPECT_FALSE(channel1_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000907 EXPECT_TRUE(media_channel1_->sending());
908 EXPECT_EQ(1U, media_channel1_->codecs().size());
Peter Boström34fbfff2015-09-24 19:20:30 +0200909 if (verify_playout_) {
910 EXPECT_TRUE(media_channel2_->playout());
911 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000912 EXPECT_TRUE(media_channel2_->sending());
913 EXPECT_EQ(1U, media_channel2_->codecs().size());
914 }
915
916 // Test that we don't crash if packets are sent during call teardown
917 // when RTCP mux is enabled. This is a regression test against a specific
918 // race condition that would only occur when a RTCP packet was sent during
919 // teardown of a channel on which RTCP mux was enabled.
920 void TestCallTeardownRtcpMux() {
921 class LastWordMediaChannel : public T::MediaChannel {
922 public:
Fredrik Solenbergb071a192015-09-17 16:42:56 +0200923 LastWordMediaChannel() : T::MediaChannel(NULL, typename T::Options()) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000924 ~LastWordMediaChannel() {
stefanc1aeaf02015-10-15 07:26:07 -0700925 T::MediaChannel::SendRtp(kPcmuFrame, sizeof(kPcmuFrame),
926 rtc::PacketOptions());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000927 T::MediaChannel::SendRtcp(kRtcpReport, sizeof(kRtcpReport));
928 }
929 };
Steve Anton8699a322017-11-06 15:53:33 -0800930 CreateChannels(rtc::MakeUnique<LastWordMediaChannel>(),
931 rtc::MakeUnique<LastWordMediaChannel>(), RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000932 EXPECT_TRUE(SendInitiate());
933 EXPECT_TRUE(SendAccept());
deadbeeff5346592017-01-24 21:51:21 -0800934 EXPECT_TRUE(Terminate());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000935 }
936
937 // Send voice RTP data to the other side and ensure it gets there.
938 void SendRtpToRtp() {
Zhi Huange830e682018-03-30 10:48:35 -0700939 CreateChannels(RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000940 EXPECT_TRUE(SendInitiate());
941 EXPECT_TRUE(SendAccept());
Zhi Huange830e682018-03-30 10:48:35 -0700942 EXPECT_EQ(nullptr, channel1_->rtcp_packet_transport());
943 EXPECT_EQ(nullptr, channel2_->rtcp_packet_transport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200944 SendRtp1();
945 SendRtp2();
946 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000947 EXPECT_TRUE(CheckRtp1());
948 EXPECT_TRUE(CheckRtp2());
949 EXPECT_TRUE(CheckNoRtp1());
950 EXPECT_TRUE(CheckNoRtp2());
951 }
952
Danil Chapovalovdae07ba2016-05-14 01:43:50 +0200953 void TestDeinit() {
deadbeefac22f702017-01-12 21:59:29 -0800954 CreateChannels(0, 0);
Danil Chapovalovdae07ba2016-05-14 01:43:50 +0200955 EXPECT_TRUE(SendInitiate());
956 EXPECT_TRUE(SendAccept());
957 SendRtp1();
958 SendRtp2();
959 SendRtcp1();
960 SendRtcp2();
961 // Do not wait, destroy channels.
962 channel1_.reset(nullptr);
963 channel2_.reset(nullptr);
964 }
965
deadbeefac22f702017-01-12 21:59:29 -0800966 // Check that RTCP can be transmitted between both sides.
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000967 void SendRtcpToRtcp() {
deadbeefac22f702017-01-12 21:59:29 -0800968 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000969 EXPECT_TRUE(SendInitiate());
970 EXPECT_TRUE(SendAccept());
Zhi Huange830e682018-03-30 10:48:35 -0700971 EXPECT_NE(nullptr, channel1_->rtcp_packet_transport());
972 EXPECT_NE(nullptr, channel2_->rtcp_packet_transport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200973 SendRtcp1();
974 SendRtcp2();
975 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000976 EXPECT_TRUE(CheckRtcp1());
977 EXPECT_TRUE(CheckRtcp2());
978 EXPECT_TRUE(CheckNoRtcp1());
979 EXPECT_TRUE(CheckNoRtcp2());
980 }
981
Zhi Huange830e682018-03-30 10:48:35 -0700982 void SendDtlsSrtpToDtlsSrtp(int flags1, int flags2) {
983 CreateChannels(flags1 | DTLS, flags2 | DTLS);
Zhi Huangcf990f52017-09-22 12:12:30 -0700984 EXPECT_FALSE(channel1_->srtp_active());
985 EXPECT_FALSE(channel2_->srtp_active());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000986 EXPECT_TRUE(SendInitiate());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200987 WaitForThreads();
988 EXPECT_TRUE(channel1_->writable());
989 EXPECT_TRUE(channel2_->writable());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000990 EXPECT_TRUE(SendAccept());
Zhi Huangcf990f52017-09-22 12:12:30 -0700991 EXPECT_TRUE(channel1_->srtp_active());
992 EXPECT_TRUE(channel2_->srtp_active());
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200993 SendRtp1();
994 SendRtp2();
995 SendRtcp1();
996 SendRtcp2();
997 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000998 EXPECT_TRUE(CheckRtp1());
999 EXPECT_TRUE(CheckRtp2());
1000 EXPECT_TRUE(CheckNoRtp1());
1001 EXPECT_TRUE(CheckNoRtp2());
1002 EXPECT_TRUE(CheckRtcp1());
1003 EXPECT_TRUE(CheckRtcp2());
1004 EXPECT_TRUE(CheckNoRtcp1());
1005 EXPECT_TRUE(CheckNoRtcp2());
1006 }
1007
1008 // Test that we can send and receive early media when a provisional answer is
1009 // sent and received. The test uses SRTP, RTCP mux and SSRC mux.
1010 void SendEarlyMediaUsingRtcpMuxSrtp() {
Yves Gerey665174f2018-06-19 15:03:05 +02001011 int sequence_number1_1 = 0, sequence_number2_2 = 0;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001012
Yves Gerey665174f2018-06-19 15:03:05 +02001013 CreateChannels(SSRC_MUX | RTCP_MUX | DTLS, SSRC_MUX | RTCP_MUX | DTLS);
1014 EXPECT_TRUE(SendOffer());
1015 EXPECT_TRUE(SendProvisionalAnswer());
1016 EXPECT_TRUE(channel1_->srtp_active());
1017 EXPECT_TRUE(channel2_->srtp_active());
1018 EXPECT_EQ(nullptr, channel1_->rtcp_packet_transport());
1019 EXPECT_EQ(nullptr, channel2_->rtcp_packet_transport());
1020 WaitForThreads(); // Wait for 'sending' flag go through network thread.
1021 SendCustomRtcp1(kSsrc1);
1022 SendCustomRtp1(kSsrc1, ++sequence_number1_1);
1023 WaitForThreads();
1024 EXPECT_TRUE(CheckCustomRtcp2(kSsrc1));
1025 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, sequence_number1_1));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001026
Yves Gerey665174f2018-06-19 15:03:05 +02001027 // Send packets from callee and verify that it is received.
1028 SendCustomRtcp2(kSsrc2);
1029 SendCustomRtp2(kSsrc2, ++sequence_number2_2);
1030 WaitForThreads();
1031 EXPECT_TRUE(CheckCustomRtcp1(kSsrc2));
1032 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, sequence_number2_2));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001033
Yves Gerey665174f2018-06-19 15:03:05 +02001034 // Complete call setup and ensure everything is still OK.
1035 EXPECT_TRUE(SendFinalAnswer());
1036 EXPECT_TRUE(channel1_->srtp_active());
1037 EXPECT_TRUE(channel2_->srtp_active());
1038 SendCustomRtcp1(kSsrc1);
1039 SendCustomRtp1(kSsrc1, ++sequence_number1_1);
1040 SendCustomRtcp2(kSsrc2);
1041 SendCustomRtp2(kSsrc2, ++sequence_number2_2);
1042 WaitForThreads();
1043 EXPECT_TRUE(CheckCustomRtcp2(kSsrc1));
1044 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, sequence_number1_1));
1045 EXPECT_TRUE(CheckCustomRtcp1(kSsrc2));
1046 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, sequence_number2_2));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001047 }
1048
1049 // Test that we properly send RTP without SRTP from a thread.
1050 void SendRtpToRtpOnThread() {
deadbeefac22f702017-01-12 21:59:29 -08001051 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001052 EXPECT_TRUE(SendInitiate());
1053 EXPECT_TRUE(SendAccept());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001054 ScopedCallThread send_rtp1([this] { SendRtp1(); });
1055 ScopedCallThread send_rtp2([this] { SendRtp2(); });
1056 ScopedCallThread send_rtcp1([this] { SendRtcp1(); });
1057 ScopedCallThread send_rtcp2([this] { SendRtcp2(); });
1058 rtc::Thread* involved_threads[] = {send_rtp1.thread(), send_rtp2.thread(),
1059 send_rtcp1.thread(),
1060 send_rtcp2.thread()};
1061 WaitForThreads(involved_threads);
1062 EXPECT_TRUE(CheckRtp1());
1063 EXPECT_TRUE(CheckRtp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001064 EXPECT_TRUE(CheckNoRtp1());
1065 EXPECT_TRUE(CheckNoRtp2());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001066 EXPECT_TRUE(CheckRtcp1());
1067 EXPECT_TRUE(CheckRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001068 EXPECT_TRUE(CheckNoRtcp1());
1069 EXPECT_TRUE(CheckNoRtcp2());
1070 }
1071
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001072 // Test that the mediachannel retains its sending state after the transport
1073 // becomes non-writable.
1074 void SendWithWritabilityLoss() {
Zhi Huange830e682018-03-30 10:48:35 -07001075 CreateChannels(RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001076 EXPECT_TRUE(SendInitiate());
1077 EXPECT_TRUE(SendAccept());
Zhi Huange830e682018-03-30 10:48:35 -07001078 EXPECT_EQ(nullptr, channel1_->rtcp_packet_transport());
1079 EXPECT_EQ(nullptr, channel2_->rtcp_packet_transport());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001080 SendRtp1();
1081 SendRtp2();
1082 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001083 EXPECT_TRUE(CheckRtp1());
1084 EXPECT_TRUE(CheckRtp2());
1085 EXPECT_TRUE(CheckNoRtp1());
1086 EXPECT_TRUE(CheckNoRtp2());
1087
wu@webrtc.org97077a32013-10-25 21:18:33 +00001088 // Lose writability, which should fail.
deadbeeff5346592017-01-24 21:51:21 -08001089 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
1090 fake_rtp_dtls_transport1_->SetWritable(false);
1091 });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001092 SendRtp1();
1093 SendRtp2();
1094 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001095 EXPECT_TRUE(CheckRtp1());
1096 EXPECT_TRUE(CheckNoRtp2());
1097
1098 // Regain writability
deadbeeff5346592017-01-24 21:51:21 -08001099 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
1100 fake_rtp_dtls_transport1_->SetWritable(true);
1101 });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001102 EXPECT_TRUE(media_channel1_->sending());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001103 SendRtp1();
1104 SendRtp2();
1105 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001106 EXPECT_TRUE(CheckRtp1());
1107 EXPECT_TRUE(CheckRtp2());
1108 EXPECT_TRUE(CheckNoRtp1());
1109 EXPECT_TRUE(CheckNoRtp2());
1110
1111 // Lose writability completely
deadbeeff5346592017-01-24 21:51:21 -08001112 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
1113 bool asymmetric = true;
1114 fake_rtp_dtls_transport1_->SetDestination(nullptr, asymmetric);
1115 });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001116 EXPECT_TRUE(media_channel1_->sending());
1117
wu@webrtc.org97077a32013-10-25 21:18:33 +00001118 // Should fail also.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001119 SendRtp1();
1120 SendRtp2();
1121 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001122 EXPECT_TRUE(CheckRtp1());
1123 EXPECT_TRUE(CheckNoRtp2());
zhihuangb2cdd932017-01-19 16:54:25 -08001124 EXPECT_TRUE(CheckNoRtp1());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001125
1126 // Gain writability back
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001127 network_thread_->Invoke<void>(RTC_FROM_HERE, [this] {
deadbeeff5346592017-01-24 21:51:21 -08001128 bool asymmetric = true;
1129 fake_rtp_dtls_transport1_->SetDestination(fake_rtp_dtls_transport2_.get(),
1130 asymmetric);
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001131 });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001132 EXPECT_TRUE(media_channel1_->sending());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001133 SendRtp1();
1134 SendRtp2();
1135 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001136 EXPECT_TRUE(CheckRtp1());
1137 EXPECT_TRUE(CheckRtp2());
1138 EXPECT_TRUE(CheckNoRtp1());
1139 EXPECT_TRUE(CheckNoRtp2());
1140 }
1141
Yves Gerey665174f2018-06-19 15:03:05 +02001142 void SendBundleToBundle(const int* pl_types,
1143 int len,
1144 bool rtcp_mux,
1145 bool secure) {
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001146 ASSERT_EQ(2, len);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001147 int sequence_number1_1 = 0, sequence_number2_2 = 0;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001148 // Only pl_type1 was added to the bundle filter for both |channel1_|
1149 // and |channel2_|.
1150 int pl_type1 = pl_types[0];
1151 int pl_type2 = pl_types[1];
deadbeefac22f702017-01-12 21:59:29 -08001152 int flags = SSRC_MUX;
Zhi Huange830e682018-03-30 10:48:35 -07001153 if (secure)
1154 flags |= DTLS;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001155 if (rtcp_mux) {
1156 flags |= RTCP_MUX;
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001157 }
1158 CreateChannels(flags, flags);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001159 EXPECT_TRUE(SendInitiate());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001160 EXPECT_TRUE(SendAccept());
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001161
1162 // Both channels can receive pl_type1 only.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001163 SendCustomRtp1(kSsrc1, ++sequence_number1_1, pl_type1);
1164 SendCustomRtp2(kSsrc2, ++sequence_number2_2, pl_type1);
1165 WaitForThreads();
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001166 EXPECT_TRUE(CheckCustomRtp2(kSsrc1, sequence_number1_1, pl_type1));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001167 EXPECT_TRUE(CheckCustomRtp1(kSsrc2, sequence_number2_2, pl_type1));
1168 EXPECT_TRUE(CheckNoRtp1());
1169 EXPECT_TRUE(CheckNoRtp2());
1170
Zhi Huang365381f2018-04-13 16:44:34 -07001171 SendCustomRtp1(kSsrc3, ++sequence_number1_1, pl_type2);
1172 SendCustomRtp2(kSsrc4, ++sequence_number2_2, pl_type2);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001173 WaitForThreads();
Zhi Huang365381f2018-04-13 16:44:34 -07001174 EXPECT_FALSE(CheckCustomRtp2(kSsrc3, sequence_number1_1, pl_type2));
1175 EXPECT_FALSE(CheckCustomRtp1(kSsrc4, sequence_number2_2, pl_type2));
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001176
Zhi Huange830e682018-03-30 10:48:35 -07001177 // RTCP test
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001178 SendCustomRtcp1(kSsrc1);
1179 SendCustomRtcp2(kSsrc2);
1180 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001181 EXPECT_TRUE(CheckCustomRtcp1(kSsrc2));
1182 EXPECT_TRUE(CheckNoRtcp1());
1183 EXPECT_TRUE(CheckCustomRtcp2(kSsrc1));
1184 EXPECT_TRUE(CheckNoRtcp2());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001185
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001186 SendCustomRtcp1(kSsrc2);
1187 SendCustomRtcp2(kSsrc1);
1188 WaitForThreads();
pbos482b12e2015-11-16 10:19:58 -08001189 // Bundle filter shouldn't filter out any RTCP.
1190 EXPECT_TRUE(CheckCustomRtcp1(kSsrc1));
1191 EXPECT_TRUE(CheckCustomRtcp2(kSsrc2));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001192 }
1193
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001194 void TestSetContentFailure() {
1195 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001196
Peter Thatchera6d24442015-07-09 21:26:36 -07001197 std::string err;
Steve Anton18ee1d52017-09-11 11:32:35 -07001198 std::unique_ptr<typename T::Content> content(
1199 CreateMediaContentWithStream(1));
1200
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001201 media_channel1_->set_fail_set_recv_codecs(true);
Steve Anton18ee1d52017-09-11 11:32:35 -07001202 EXPECT_FALSE(
Steve Anton3828c062017-12-06 10:34:51 -08001203 channel1_->SetLocalContent(content.get(), SdpType::kOffer, &err));
Steve Anton18ee1d52017-09-11 11:32:35 -07001204 EXPECT_FALSE(
Steve Anton3828c062017-12-06 10:34:51 -08001205 channel1_->SetLocalContent(content.get(), SdpType::kAnswer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001206
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001207 media_channel1_->set_fail_set_send_codecs(true);
Steve Anton18ee1d52017-09-11 11:32:35 -07001208 EXPECT_FALSE(
Steve Anton3828c062017-12-06 10:34:51 -08001209 channel1_->SetRemoteContent(content.get(), SdpType::kOffer, &err));
Steve Anton18ee1d52017-09-11 11:32:35 -07001210
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001211 media_channel1_->set_fail_set_send_codecs(true);
Steve Anton18ee1d52017-09-11 11:32:35 -07001212 EXPECT_FALSE(
Steve Anton3828c062017-12-06 10:34:51 -08001213 channel1_->SetRemoteContent(content.get(), SdpType::kAnswer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001214 }
1215
1216 void TestSendTwoOffers() {
1217 CreateChannels(0, 0);
1218
Peter Thatchera6d24442015-07-09 21:26:36 -07001219 std::string err;
Steve Anton18ee1d52017-09-11 11:32:35 -07001220 std::unique_ptr<typename T::Content> content1(
1221 CreateMediaContentWithStream(1));
1222 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001223 channel1_->SetLocalContent(content1.get(), SdpType::kOffer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001224 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1225
Steve Anton18ee1d52017-09-11 11:32:35 -07001226 std::unique_ptr<typename T::Content> content2(
1227 CreateMediaContentWithStream(2));
1228 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001229 channel1_->SetLocalContent(content2.get(), SdpType::kOffer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001230 EXPECT_FALSE(media_channel1_->HasSendStream(1));
1231 EXPECT_TRUE(media_channel1_->HasSendStream(2));
1232 }
1233
1234 void TestReceiveTwoOffers() {
1235 CreateChannels(0, 0);
1236
Peter Thatchera6d24442015-07-09 21:26:36 -07001237 std::string err;
Steve Anton18ee1d52017-09-11 11:32:35 -07001238 std::unique_ptr<typename T::Content> content1(
1239 CreateMediaContentWithStream(1));
1240 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001241 channel1_->SetRemoteContent(content1.get(), SdpType::kOffer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001242 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1243
Steve Anton18ee1d52017-09-11 11:32:35 -07001244 std::unique_ptr<typename T::Content> content2(
1245 CreateMediaContentWithStream(2));
1246 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001247 channel1_->SetRemoteContent(content2.get(), SdpType::kOffer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001248 EXPECT_FALSE(media_channel1_->HasRecvStream(1));
1249 EXPECT_TRUE(media_channel1_->HasRecvStream(2));
1250 }
1251
1252 void TestSendPrAnswer() {
1253 CreateChannels(0, 0);
1254
Peter Thatchera6d24442015-07-09 21:26:36 -07001255 std::string err;
1256 // Receive offer
Steve Anton18ee1d52017-09-11 11:32:35 -07001257 std::unique_ptr<typename T::Content> content1(
1258 CreateMediaContentWithStream(1));
1259 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001260 channel1_->SetRemoteContent(content1.get(), SdpType::kOffer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001261 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1262
Peter Thatchera6d24442015-07-09 21:26:36 -07001263 // Send PR answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001264 std::unique_ptr<typename T::Content> content2(
1265 CreateMediaContentWithStream(2));
1266 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001267 channel1_->SetLocalContent(content2.get(), SdpType::kPrAnswer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001268 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1269 EXPECT_TRUE(media_channel1_->HasSendStream(2));
1270
Peter Thatchera6d24442015-07-09 21:26:36 -07001271 // Send answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001272 std::unique_ptr<typename T::Content> content3(
1273 CreateMediaContentWithStream(3));
1274 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001275 channel1_->SetLocalContent(content3.get(), SdpType::kAnswer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001276 EXPECT_TRUE(media_channel1_->HasRecvStream(1));
1277 EXPECT_FALSE(media_channel1_->HasSendStream(2));
1278 EXPECT_TRUE(media_channel1_->HasSendStream(3));
1279 }
1280
1281 void TestReceivePrAnswer() {
1282 CreateChannels(0, 0);
1283
Peter Thatchera6d24442015-07-09 21:26:36 -07001284 std::string err;
1285 // Send offer
Steve Anton18ee1d52017-09-11 11:32:35 -07001286 std::unique_ptr<typename T::Content> content1(
1287 CreateMediaContentWithStream(1));
1288 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001289 channel1_->SetLocalContent(content1.get(), SdpType::kOffer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001290 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1291
Peter Thatchera6d24442015-07-09 21:26:36 -07001292 // Receive PR answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001293 std::unique_ptr<typename T::Content> content2(
1294 CreateMediaContentWithStream(2));
Steve Anton3828c062017-12-06 10:34:51 -08001295 EXPECT_TRUE(
1296 channel1_->SetRemoteContent(content2.get(), SdpType::kPrAnswer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001297 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1298 EXPECT_TRUE(media_channel1_->HasRecvStream(2));
1299
Peter Thatchera6d24442015-07-09 21:26:36 -07001300 // Receive answer
Steve Anton18ee1d52017-09-11 11:32:35 -07001301 std::unique_ptr<typename T::Content> content3(
1302 CreateMediaContentWithStream(3));
1303 EXPECT_TRUE(
Steve Anton3828c062017-12-06 10:34:51 -08001304 channel1_->SetRemoteContent(content3.get(), SdpType::kAnswer, &err));
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001305 EXPECT_TRUE(media_channel1_->HasSendStream(1));
1306 EXPECT_FALSE(media_channel1_->HasRecvStream(2));
1307 EXPECT_TRUE(media_channel1_->HasRecvStream(3));
1308 }
1309
1310 void TestFlushRtcp() {
deadbeefac22f702017-01-12 21:59:29 -08001311 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001312 EXPECT_TRUE(SendInitiate());
1313 EXPECT_TRUE(SendAccept());
Zhi Huange830e682018-03-30 10:48:35 -07001314 EXPECT_NE(nullptr, channel1_->rtcp_packet_transport());
1315 EXPECT_NE(nullptr, channel2_->rtcp_packet_transport());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001316
1317 // Send RTCP1 from a different thread.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001318 ScopedCallThread send_rtcp([this] { SendRtcp1(); });
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001319 // The sending message is only posted. channel2_ should be empty.
1320 EXPECT_TRUE(CheckNoRtcp2());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001321 rtc::Thread* wait_for[] = {send_rtcp.thread()};
1322 WaitForThreads(wait_for); // Ensure rtcp was posted
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001323
1324 // When channel1_ is deleted, the RTCP packet should be sent out to
1325 // channel2_.
1326 channel1_.reset();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001327 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001328 EXPECT_TRUE(CheckRtcp2());
1329 }
1330
zstein56162b92017-04-24 16:54:35 -07001331 void TestOnTransportReadyToSend() {
deadbeefac22f702017-01-12 21:59:29 -08001332 CreateChannels(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001333 EXPECT_FALSE(media_channel1_->ready_to_send());
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001334
zstein56162b92017-04-24 16:54:35 -07001335 channel1_->OnTransportReadyToSend(true);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001336 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001337 EXPECT_TRUE(media_channel1_->ready_to_send());
1338
zstein56162b92017-04-24 16:54:35 -07001339 channel1_->OnTransportReadyToSend(false);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001340 WaitForThreads();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001341 EXPECT_FALSE(media_channel1_->ready_to_send());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001342 }
1343
skvladdc1c62c2016-03-16 19:07:43 -07001344 bool SetRemoteContentWithBitrateLimit(int remote_limit) {
1345 typename T::Content content;
1346 CreateContent(0, kPcmuCodec, kH264Codec, &content);
1347 content.set_bandwidth(remote_limit);
Steve Anton3828c062017-12-06 10:34:51 -08001348 return channel1_->SetRemoteContent(&content, SdpType::kOffer, NULL);
skvladdc1c62c2016-03-16 19:07:43 -07001349 }
1350
deadbeefe702b302017-02-04 12:09:01 -08001351 webrtc::RtpParameters BitrateLimitedParameters(rtc::Optional<int> limit) {
skvladdc1c62c2016-03-16 19:07:43 -07001352 webrtc::RtpParameters parameters;
1353 webrtc::RtpEncodingParameters encoding;
Mirko Bonadeic61ce0d2017-11-21 17:04:20 +01001354 encoding.max_bitrate_bps = std::move(limit);
skvladdc1c62c2016-03-16 19:07:43 -07001355 parameters.encodings.push_back(encoding);
1356 return parameters;
1357 }
1358
1359 void VerifyMaxBitrate(const webrtc::RtpParameters& parameters,
deadbeefe702b302017-02-04 12:09:01 -08001360 rtc::Optional<int> expected_bitrate) {
skvladdc1c62c2016-03-16 19:07:43 -07001361 EXPECT_EQ(1UL, parameters.encodings.size());
1362 EXPECT_EQ(expected_bitrate, parameters.encodings[0].max_bitrate_bps);
1363 }
1364
1365 void DefaultMaxBitrateIsUnlimited() {
1366 CreateChannels(0, 0);
Steve Anton3828c062017-12-06 10:34:51 -08001367 EXPECT_TRUE(channel1_->SetLocalContent(&local_media_content1_,
1368 SdpType::kOffer, NULL));
skvladdc1c62c2016-03-16 19:07:43 -07001369 EXPECT_EQ(media_channel1_->max_bps(), -1);
deadbeefe702b302017-02-04 12:09:01 -08001370 VerifyMaxBitrate(media_channel1_->GetRtpSendParameters(kSsrc1),
Oskar Sundbom36f8f3e2017-11-16 10:54:27 +01001371 rtc::nullopt);
skvladdc1c62c2016-03-16 19:07:43 -07001372 }
1373
Zhi Huange830e682018-03-30 10:48:35 -07001374 // Test that when a channel gets new RtpTransport with a call to
1375 // |SetRtpTransport|, the socket options from the old RtpTransport is merged
1376 // with the options on the new one.
1377
Steve Anton8a63f782017-10-23 13:08:53 -07001378 // For example, audio and video may use separate socket options, but initially
1379 // be unbundled, then later become bundled. When this happens, their preferred
1380 // socket options should be merged to the underlying transport they share.
1381 void SocketOptionsMergedOnSetTransport() {
1382 constexpr int kSndBufSize = 4000;
1383 constexpr int kRcvBufSize = 8000;
1384
Zhi Huange830e682018-03-30 10:48:35 -07001385 CreateChannels(DTLS, DTLS);
Steve Anton8a63f782017-10-23 13:08:53 -07001386
1387 channel1_->SetOption(cricket::BaseChannel::ST_RTP,
1388 rtc::Socket::Option::OPT_SNDBUF, kSndBufSize);
1389 channel2_->SetOption(cricket::BaseChannel::ST_RTP,
1390 rtc::Socket::Option::OPT_RCVBUF, kRcvBufSize);
1391
Zhi Huange830e682018-03-30 10:48:35 -07001392 new_rtp_transport_ = CreateDtlsSrtpTransport(
1393 static_cast<DtlsTransportInternal*>(channel2_->rtp_packet_transport()),
1394 static_cast<DtlsTransportInternal*>(
1395 channel2_->rtcp_packet_transport()));
1396 channel1_->SetRtpTransport(new_rtp_transport_.get());
Steve Anton8a63f782017-10-23 13:08:53 -07001397
1398 int option_val;
Zhi Huange830e682018-03-30 10:48:35 -07001399 ASSERT_TRUE(
1400 static_cast<DtlsTransportInternal*>(channel1_->rtp_packet_transport())
1401 ->GetOption(rtc::Socket::Option::OPT_SNDBUF, &option_val));
Steve Anton8a63f782017-10-23 13:08:53 -07001402 EXPECT_EQ(kSndBufSize, option_val);
Zhi Huange830e682018-03-30 10:48:35 -07001403 ASSERT_TRUE(
1404 static_cast<DtlsTransportInternal*>(channel1_->rtp_packet_transport())
1405 ->GetOption(rtc::Socket::Option::OPT_RCVBUF, &option_val));
Steve Anton8a63f782017-10-23 13:08:53 -07001406 EXPECT_EQ(kRcvBufSize, option_val);
1407 }
1408
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001409 protected:
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001410 void WaitForThreads() { WaitForThreads(rtc::ArrayView<rtc::Thread*>()); }
1411 static void ProcessThreadQueue(rtc::Thread* thread) {
1412 RTC_DCHECK(thread->IsCurrent());
1413 while (!thread->empty()) {
1414 thread->ProcessMessages(0);
1415 }
1416 }
1417 void WaitForThreads(rtc::ArrayView<rtc::Thread*> threads) {
1418 // |threads| and current thread post packets to network thread.
1419 for (rtc::Thread* thread : threads) {
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001420 thread->Invoke<void>(RTC_FROM_HERE,
1421 [thread] { ProcessThreadQueue(thread); });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001422 }
1423 ProcessThreadQueue(rtc::Thread::Current());
1424 // Network thread move them around and post back to worker = current thread.
1425 if (!network_thread_->IsCurrent()) {
1426 network_thread_->Invoke<void>(
Taylor Brandstetter5d97a9a2016-06-10 14:17:27 -07001427 RTC_FROM_HERE, [this] { ProcessThreadQueue(network_thread_); });
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001428 }
1429 // Worker thread = current Thread process received messages.
1430 ProcessThreadQueue(rtc::Thread::Current());
1431 }
Peter Boström34fbfff2015-09-24 19:20:30 +02001432 // TODO(pbos): Remove playout from all media channels and let renderers mute
1433 // themselves.
1434 const bool verify_playout_;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001435 std::unique_ptr<rtc::Thread> network_thread_keeper_;
1436 rtc::Thread* network_thread_;
deadbeeff5346592017-01-24 21:51:21 -08001437 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtp_dtls_transport1_;
1438 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtcp_dtls_transport1_;
1439 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtp_dtls_transport2_;
1440 std::unique_ptr<cricket::FakeDtlsTransport> fake_rtcp_dtls_transport2_;
1441 std::unique_ptr<rtc::FakePacketTransport> fake_rtp_packet_transport1_;
1442 std::unique_ptr<rtc::FakePacketTransport> fake_rtcp_packet_transport1_;
1443 std::unique_ptr<rtc::FakePacketTransport> fake_rtp_packet_transport2_;
1444 std::unique_ptr<rtc::FakePacketTransport> fake_rtcp_packet_transport2_;
Zhi Huange830e682018-03-30 10:48:35 -07001445 std::unique_ptr<webrtc::RtpTransportInternal> rtp_transport1_;
1446 std::unique_ptr<webrtc::RtpTransportInternal> rtp_transport2_;
1447 std::unique_ptr<webrtc::RtpTransportInternal> new_rtp_transport_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001448 cricket::FakeMediaEngine media_engine_;
1449 // The media channels are owned by the voice channel objects below.
deadbeeff5346592017-01-24 21:51:21 -08001450 typename T::MediaChannel* media_channel1_ = nullptr;
1451 typename T::MediaChannel* media_channel2_ = nullptr;
kwiberg31022942016-03-11 14:18:21 -08001452 std::unique_ptr<typename T::Channel> channel1_;
1453 std::unique_ptr<typename T::Channel> channel2_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001454 typename T::Content local_media_content1_;
1455 typename T::Content local_media_content2_;
1456 typename T::Content remote_media_content1_;
1457 typename T::Content remote_media_content2_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001458 // The RTP and RTCP packets to send in the tests.
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001459 rtc::Buffer rtp_packet_;
1460 rtc::Buffer rtcp_packet_;
deadbeeff5346592017-01-24 21:51:21 -08001461 int rtcp_mux_activated_callbacks1_ = 0;
1462 int rtcp_mux_activated_callbacks2_ = 0;
Honghai Zhangcc411c02016-03-29 17:27:21 -07001463 cricket::CandidatePairInterface* last_selected_candidate_pair_;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001464};
1465
Yves Gerey665174f2018-06-19 15:03:05 +02001466template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001467void ChannelTest<VoiceTraits>::CreateContent(
1468 int flags,
1469 const cricket::AudioCodec& audio_codec,
1470 const cricket::VideoCodec& video_codec,
1471 cricket::AudioContentDescription* audio) {
1472 audio->AddCodec(audio_codec);
1473 audio->set_rtcp_mux((flags & RTCP_MUX) != 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001474}
1475
Yves Gerey665174f2018-06-19 15:03:05 +02001476template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001477void ChannelTest<VoiceTraits>::CopyContent(
1478 const cricket::AudioContentDescription& source,
1479 cricket::AudioContentDescription* audio) {
1480 *audio = source;
1481}
1482
Yves Gerey665174f2018-06-19 15:03:05 +02001483template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001484bool ChannelTest<VoiceTraits>::CodecMatches(const cricket::AudioCodec& c1,
1485 const cricket::AudioCodec& c2) {
1486 return c1.name == c2.name && c1.clockrate == c2.clockrate &&
Yves Gerey665174f2018-06-19 15:03:05 +02001487 c1.bitrate == c2.bitrate && c1.channels == c2.channels;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001488}
1489
Peter Boström0c4e06b2015-10-07 12:23:21 +02001490template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001491void ChannelTest<VoiceTraits>::AddLegacyStreamInContent(
Peter Boström0c4e06b2015-10-07 12:23:21 +02001492 uint32_t ssrc,
1493 int flags,
1494 cricket::AudioContentDescription* audio) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001495 audio->AddLegacyStream(ssrc);
1496}
1497
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001498class VoiceChannelSingleThreadTest : public ChannelTest<VoiceTraits> {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001499 public:
solenberg1dd98f32015-09-10 01:57:14 -07001500 typedef ChannelTest<VoiceTraits> Base;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001501 VoiceChannelSingleThreadTest()
1502 : Base(true, kPcmuFrame, kRtcpReport, NetworkIsWorker::Yes) {}
1503};
1504
1505class VoiceChannelDoubleThreadTest : public ChannelTest<VoiceTraits> {
1506 public:
1507 typedef ChannelTest<VoiceTraits> Base;
1508 VoiceChannelDoubleThreadTest()
1509 : Base(true, kPcmuFrame, kRtcpReport, NetworkIsWorker::No) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001510};
1511
jbauch5869f502017-06-29 12:31:36 -07001512class VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest
Yves Gerey665174f2018-06-19 15:03:05 +02001513 : public ChannelTest<VoiceTraits> {
jbauch5869f502017-06-29 12:31:36 -07001514 public:
1515 typedef ChannelTest<VoiceTraits> Base;
1516 VoiceChannelWithEncryptedRtpHeaderExtensionsSingleThreadTest()
Yves Gerey665174f2018-06-19 15:03:05 +02001517 : Base(true,
1518 kPcmuFrameWithExtensions,
1519 kRtcpReport,
1520 NetworkIsWorker::Yes) {}
jbauch5869f502017-06-29 12:31:36 -07001521};
1522
1523class VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest
Yves Gerey665174f2018-06-19 15:03:05 +02001524 : public ChannelTest<VoiceTraits> {
jbauch5869f502017-06-29 12:31:36 -07001525 public:
1526 typedef ChannelTest<VoiceTraits> Base;
1527 VoiceChannelWithEncryptedRtpHeaderExtensionsDoubleThreadTest()
Yves Gerey665174f2018-06-19 15:03:05 +02001528 : Base(true, kPcmuFrameWithExtensions, kRtcpReport, NetworkIsWorker::No) {
1529 }
jbauch5869f502017-06-29 12:31:36 -07001530};
1531
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001532// override to add NULL parameter
deadbeefcbecd352015-09-23 11:50:27 -07001533template <>
Steve Anton8699a322017-11-06 15:53:33 -08001534std::unique_ptr<cricket::VideoChannel> ChannelTest<VideoTraits>::CreateChannel(
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001535 rtc::Thread* worker_thread,
1536 rtc::Thread* network_thread,
deadbeefcbecd352015-09-23 11:50:27 -07001537 cricket::MediaEngineInterface* engine,
Steve Anton8699a322017-11-06 15:53:33 -08001538 std::unique_ptr<cricket::FakeVideoMediaChannel> ch,
Zhi Huange830e682018-03-30 10:48:35 -07001539 webrtc::RtpTransportInternal* rtp_transport,
jbauchcb560652016-08-04 05:20:32 -07001540 int flags) {
deadbeeff5346592017-01-24 21:51:21 -08001541 rtc::Thread* signaling_thread = rtc::Thread::Current();
Steve Anton8699a322017-11-06 15:53:33 -08001542 auto channel = rtc::MakeUnique<cricket::VideoChannel>(
1543 worker_thread, network_thread, signaling_thread, std::move(ch),
Zhi Huange830e682018-03-30 10:48:35 -07001544 cricket::CN_VIDEO, (flags & DTLS) != 0, rtc::CryptoOptions());
1545 channel->Init_w(rtp_transport);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001546 return channel;
1547}
1548
1549// override to add 0 parameter
Yves Gerey665174f2018-06-19 15:03:05 +02001550template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001551bool ChannelTest<VideoTraits>::AddStream1(int id) {
1552 return channel1_->AddRecvStream(cricket::StreamParams::CreateLegacy(id));
1553}
1554
Yves Gerey665174f2018-06-19 15:03:05 +02001555template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001556void ChannelTest<VideoTraits>::CreateContent(
1557 int flags,
1558 const cricket::AudioCodec& audio_codec,
1559 const cricket::VideoCodec& video_codec,
1560 cricket::VideoContentDescription* video) {
1561 video->AddCodec(video_codec);
1562 video->set_rtcp_mux((flags & RTCP_MUX) != 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001563}
1564
Yves Gerey665174f2018-06-19 15:03:05 +02001565template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001566void ChannelTest<VideoTraits>::CopyContent(
1567 const cricket::VideoContentDescription& source,
1568 cricket::VideoContentDescription* video) {
1569 *video = source;
1570}
1571
Yves Gerey665174f2018-06-19 15:03:05 +02001572template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001573bool ChannelTest<VideoTraits>::CodecMatches(const cricket::VideoCodec& c1,
1574 const cricket::VideoCodec& c2) {
perkj26752742016-10-24 01:21:16 -07001575 return c1.name == c2.name;
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001576}
1577
Peter Boström0c4e06b2015-10-07 12:23:21 +02001578template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001579void ChannelTest<VideoTraits>::AddLegacyStreamInContent(
Peter Boström0c4e06b2015-10-07 12:23:21 +02001580 uint32_t ssrc,
1581 int flags,
1582 cricket::VideoContentDescription* video) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001583 video->AddLegacyStream(ssrc);
1584}
1585
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001586class VideoChannelSingleThreadTest : public ChannelTest<VideoTraits> {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001587 public:
solenberg1dd98f32015-09-10 01:57:14 -07001588 typedef ChannelTest<VideoTraits> Base;
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001589 VideoChannelSingleThreadTest()
1590 : Base(false, kH264Packet, kRtcpReport, NetworkIsWorker::Yes) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001591};
1592
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001593class VideoChannelDoubleThreadTest : public ChannelTest<VideoTraits> {
1594 public:
1595 typedef ChannelTest<VideoTraits> Base;
1596 VideoChannelDoubleThreadTest()
1597 : Base(false, kH264Packet, kRtcpReport, NetworkIsWorker::No) {}
1598};
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001599
Kári Tristan Helgason8b35df72017-09-25 14:46:43 +02001600TEST_F(VoiceChannelSingleThreadTest, TestInit) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001601 Base::TestInit();
1602 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
1603 EXPECT_TRUE(media_channel1_->dtmf_info_queue().empty());
1604}
1605
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02001606TEST_F(VoiceChannelSingleThreadTest, TestDeinit) {
1607 Base::TestDeinit();
1608}
1609
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001610TEST_F(VoiceChannelSingleThreadTest, TestSetContents) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001611 Base::TestSetContents();
1612}
1613
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001614TEST_F(VoiceChannelSingleThreadTest, TestSetContentsNullOffer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001615 Base::TestSetContentsNullOffer();
1616}
1617
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001618TEST_F(VoiceChannelSingleThreadTest, TestSetContentsRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001619 Base::TestSetContentsRtcpMux();
1620}
1621
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001622TEST_F(VoiceChannelSingleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001623 Base::TestSetContentsRtcpMux();
1624}
1625
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001626TEST_F(VoiceChannelSingleThreadTest, TestStreams) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001627 Base::TestStreams();
1628}
1629
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001630TEST_F(VoiceChannelSingleThreadTest, TestChangeStreamParamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001631 Base::TestChangeStreamParamsInContent();
1632}
1633
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001634TEST_F(VoiceChannelSingleThreadTest, TestPlayoutAndSendingStates) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001635 Base::TestPlayoutAndSendingStates();
1636}
1637
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001638TEST_F(VoiceChannelSingleThreadTest, TestMediaContentDirection) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001639 Base::TestMediaContentDirection();
1640}
1641
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001642TEST_F(VoiceChannelSingleThreadTest, TestNetworkRouteChanges) {
Honghai Zhangcc411c02016-03-29 17:27:21 -07001643 Base::TestNetworkRouteChanges();
1644}
1645
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001646TEST_F(VoiceChannelSingleThreadTest, TestCallSetup) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001647 Base::TestCallSetup();
1648}
1649
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001650TEST_F(VoiceChannelSingleThreadTest, TestCallTeardownRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001651 Base::TestCallTeardownRtcpMux();
1652}
1653
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001654TEST_F(VoiceChannelSingleThreadTest, SendRtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001655 Base::SendRtpToRtp();
1656}
1657
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001658TEST_F(VoiceChannelSingleThreadTest, SendRtcpToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001659 Base::SendRtcpToRtcp();
1660}
1661
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001662TEST_F(VoiceChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtp) {
Zhi Huange830e682018-03-30 10:48:35 -07001663 Base::SendDtlsSrtpToDtlsSrtp(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001664}
1665
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001666TEST_F(VoiceChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
Zhi Huange830e682018-03-30 10:48:35 -07001667 Base::SendDtlsSrtpToDtlsSrtp(RTCP_MUX, RTCP_MUX);
deadbeeff5346592017-01-24 21:51:21 -08001668}
1669
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001670TEST_F(VoiceChannelSingleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001671 Base::SendEarlyMediaUsingRtcpMuxSrtp();
1672}
1673
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001674TEST_F(VoiceChannelSingleThreadTest, SendRtpToRtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001675 Base::SendRtpToRtpOnThread();
1676}
1677
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001678TEST_F(VoiceChannelSingleThreadTest, SendWithWritabilityLoss) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001679 Base::SendWithWritabilityLoss();
1680}
1681
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001682TEST_F(VoiceChannelSingleThreadTest, TestSetContentFailure) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001683 Base::TestSetContentFailure();
1684}
1685
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001686TEST_F(VoiceChannelSingleThreadTest, TestSendTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001687 Base::TestSendTwoOffers();
1688}
1689
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001690TEST_F(VoiceChannelSingleThreadTest, TestReceiveTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001691 Base::TestReceiveTwoOffers();
1692}
1693
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001694TEST_F(VoiceChannelSingleThreadTest, TestSendPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001695 Base::TestSendPrAnswer();
1696}
1697
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001698TEST_F(VoiceChannelSingleThreadTest, TestReceivePrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001699 Base::TestReceivePrAnswer();
1700}
1701
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001702TEST_F(VoiceChannelSingleThreadTest, TestFlushRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001703 Base::TestFlushRtcp();
1704}
1705
zstein56162b92017-04-24 16:54:35 -07001706TEST_F(VoiceChannelSingleThreadTest, TestOnTransportReadyToSend) {
1707 Base::TestOnTransportReadyToSend();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001708}
1709
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001710TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundle) {
tfarina5237aaf2015-11-10 23:44:30 -08001711 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, false);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001712}
1713
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001714TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundleSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08001715 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, true);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001716}
1717
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001718TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundleWithRtcpMux) {
tfarina5237aaf2015-11-10 23:44:30 -08001719 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, false);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001720}
1721
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001722TEST_F(VoiceChannelSingleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08001723 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001724}
1725
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001726TEST_F(VoiceChannelSingleThreadTest, DefaultMaxBitrateIsUnlimited) {
skvlade0d46372016-04-07 22:59:22 -07001727 Base::DefaultMaxBitrateIsUnlimited();
skvladdc1c62c2016-03-16 19:07:43 -07001728}
1729
Steve Anton8a63f782017-10-23 13:08:53 -07001730TEST_F(VoiceChannelSingleThreadTest, SocketOptionsMergedOnSetTransport) {
1731 Base::SocketOptionsMergedOnSetTransport();
1732}
1733
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001734// VoiceChannelDoubleThreadTest
1735TEST_F(VoiceChannelDoubleThreadTest, TestInit) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001736 Base::TestInit();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001737 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
1738 EXPECT_TRUE(media_channel1_->dtmf_info_queue().empty());
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001739}
1740
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02001741TEST_F(VoiceChannelDoubleThreadTest, TestDeinit) {
1742 Base::TestDeinit();
1743}
1744
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001745TEST_F(VoiceChannelDoubleThreadTest, TestSetContents) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001746 Base::TestSetContents();
1747}
1748
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001749TEST_F(VoiceChannelDoubleThreadTest, TestSetContentsNullOffer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001750 Base::TestSetContentsNullOffer();
1751}
1752
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001753TEST_F(VoiceChannelDoubleThreadTest, TestSetContentsRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001754 Base::TestSetContentsRtcpMux();
1755}
1756
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001757TEST_F(VoiceChannelDoubleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001758 Base::TestSetContentsRtcpMux();
1759}
1760
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001761TEST_F(VoiceChannelDoubleThreadTest, TestStreams) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001762 Base::TestStreams();
1763}
1764
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001765TEST_F(VoiceChannelDoubleThreadTest, TestChangeStreamParamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001766 Base::TestChangeStreamParamsInContent();
1767}
1768
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001769TEST_F(VoiceChannelDoubleThreadTest, TestPlayoutAndSendingStates) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001770 Base::TestPlayoutAndSendingStates();
1771}
1772
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001773TEST_F(VoiceChannelDoubleThreadTest, TestMediaContentDirection) {
1774 Base::TestMediaContentDirection();
1775}
1776
1777TEST_F(VoiceChannelDoubleThreadTest, TestNetworkRouteChanges) {
1778 Base::TestNetworkRouteChanges();
1779}
1780
1781TEST_F(VoiceChannelDoubleThreadTest, TestCallSetup) {
1782 Base::TestCallSetup();
1783}
1784
1785TEST_F(VoiceChannelDoubleThreadTest, TestCallTeardownRtcpMux) {
1786 Base::TestCallTeardownRtcpMux();
1787}
1788
1789TEST_F(VoiceChannelDoubleThreadTest, SendRtpToRtp) {
1790 Base::SendRtpToRtp();
1791}
1792
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001793TEST_F(VoiceChannelDoubleThreadTest, SendRtcpToRtcp) {
1794 Base::SendRtcpToRtcp();
1795}
1796
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001797TEST_F(VoiceChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtp) {
Zhi Huange830e682018-03-30 10:48:35 -07001798 Base::SendDtlsSrtpToDtlsSrtp(0, 0);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001799}
1800
1801TEST_F(VoiceChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
Zhi Huange830e682018-03-30 10:48:35 -07001802 Base::SendDtlsSrtpToDtlsSrtp(RTCP_MUX, RTCP_MUX);
deadbeeff5346592017-01-24 21:51:21 -08001803}
1804
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001805TEST_F(VoiceChannelDoubleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
1806 Base::SendEarlyMediaUsingRtcpMuxSrtp();
1807}
1808
1809TEST_F(VoiceChannelDoubleThreadTest, SendRtpToRtpOnThread) {
1810 Base::SendRtpToRtpOnThread();
1811}
1812
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001813TEST_F(VoiceChannelDoubleThreadTest, SendWithWritabilityLoss) {
1814 Base::SendWithWritabilityLoss();
1815}
1816
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001817TEST_F(VoiceChannelDoubleThreadTest, TestSetContentFailure) {
1818 Base::TestSetContentFailure();
1819}
1820
1821TEST_F(VoiceChannelDoubleThreadTest, TestSendTwoOffers) {
1822 Base::TestSendTwoOffers();
1823}
1824
1825TEST_F(VoiceChannelDoubleThreadTest, TestReceiveTwoOffers) {
1826 Base::TestReceiveTwoOffers();
1827}
1828
1829TEST_F(VoiceChannelDoubleThreadTest, TestSendPrAnswer) {
1830 Base::TestSendPrAnswer();
1831}
1832
1833TEST_F(VoiceChannelDoubleThreadTest, TestReceivePrAnswer) {
1834 Base::TestReceivePrAnswer();
1835}
1836
1837TEST_F(VoiceChannelDoubleThreadTest, TestFlushRtcp) {
1838 Base::TestFlushRtcp();
1839}
1840
zstein56162b92017-04-24 16:54:35 -07001841TEST_F(VoiceChannelDoubleThreadTest, TestOnTransportReadyToSend) {
1842 Base::TestOnTransportReadyToSend();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001843}
1844
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001845TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundle) {
1846 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, false);
1847}
1848
1849TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundleSecure) {
1850 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), false, true);
1851}
1852
1853TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundleWithRtcpMux) {
1854 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, false);
1855}
1856
1857TEST_F(VoiceChannelDoubleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
1858 Base::SendBundleToBundle(kAudioPts, arraysize(kAudioPts), true, true);
1859}
1860
1861TEST_F(VoiceChannelDoubleThreadTest, DefaultMaxBitrateIsUnlimited) {
1862 Base::DefaultMaxBitrateIsUnlimited();
1863}
1864
Steve Anton8a63f782017-10-23 13:08:53 -07001865TEST_F(VoiceChannelDoubleThreadTest, SocketOptionsMergedOnSetTransport) {
1866 Base::SocketOptionsMergedOnSetTransport();
1867}
1868
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001869// VideoChannelSingleThreadTest
1870TEST_F(VideoChannelSingleThreadTest, TestInit) {
1871 Base::TestInit();
1872}
1873
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02001874TEST_F(VideoChannelSingleThreadTest, TestDeinit) {
1875 Base::TestDeinit();
1876}
1877
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001878TEST_F(VideoChannelSingleThreadTest, TestSetContents) {
1879 Base::TestSetContents();
1880}
1881
1882TEST_F(VideoChannelSingleThreadTest, TestSetContentsNullOffer) {
1883 Base::TestSetContentsNullOffer();
1884}
1885
1886TEST_F(VideoChannelSingleThreadTest, TestSetContentsRtcpMux) {
1887 Base::TestSetContentsRtcpMux();
1888}
1889
1890TEST_F(VideoChannelSingleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
1891 Base::TestSetContentsRtcpMux();
1892}
1893
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001894TEST_F(VideoChannelSingleThreadTest, TestStreams) {
1895 Base::TestStreams();
1896}
1897
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001898TEST_F(VideoChannelSingleThreadTest, TestChangeStreamParamsInContent) {
1899 Base::TestChangeStreamParamsInContent();
1900}
1901
1902TEST_F(VideoChannelSingleThreadTest, TestPlayoutAndSendingStates) {
1903 Base::TestPlayoutAndSendingStates();
1904}
1905
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001906TEST_F(VideoChannelSingleThreadTest, TestMediaContentDirection) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001907 Base::TestMediaContentDirection();
1908}
1909
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001910TEST_F(VideoChannelSingleThreadTest, TestNetworkRouteChanges) {
Honghai Zhangcc411c02016-03-29 17:27:21 -07001911 Base::TestNetworkRouteChanges();
1912}
1913
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001914TEST_F(VideoChannelSingleThreadTest, TestCallSetup) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001915 Base::TestCallSetup();
1916}
1917
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001918TEST_F(VideoChannelSingleThreadTest, TestCallTeardownRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001919 Base::TestCallTeardownRtcpMux();
1920}
1921
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001922TEST_F(VideoChannelSingleThreadTest, SendRtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001923 Base::SendRtpToRtp();
1924}
1925
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001926TEST_F(VideoChannelSingleThreadTest, SendRtcpToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001927 Base::SendRtcpToRtcp();
1928}
1929
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001930TEST_F(VideoChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtp) {
Zhi Huange830e682018-03-30 10:48:35 -07001931 Base::SendDtlsSrtpToDtlsSrtp(0, 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001932}
1933
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001934TEST_F(VideoChannelSingleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
Zhi Huange830e682018-03-30 10:48:35 -07001935 Base::SendDtlsSrtpToDtlsSrtp(RTCP_MUX, RTCP_MUX);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001936}
1937
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001938TEST_F(VideoChannelSingleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001939 Base::SendEarlyMediaUsingRtcpMuxSrtp();
1940}
1941
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001942TEST_F(VideoChannelSingleThreadTest, SendRtpToRtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001943 Base::SendRtpToRtpOnThread();
1944}
1945
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001946TEST_F(VideoChannelSingleThreadTest, SendWithWritabilityLoss) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001947 Base::SendWithWritabilityLoss();
1948}
1949
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001950TEST_F(VideoChannelSingleThreadTest, TestSetContentFailure) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001951 Base::TestSetContentFailure();
1952}
1953
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001954TEST_F(VideoChannelSingleThreadTest, TestSendTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001955 Base::TestSendTwoOffers();
1956}
1957
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001958TEST_F(VideoChannelSingleThreadTest, TestReceiveTwoOffers) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001959 Base::TestReceiveTwoOffers();
1960}
1961
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001962TEST_F(VideoChannelSingleThreadTest, TestSendPrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001963 Base::TestSendPrAnswer();
1964}
1965
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001966TEST_F(VideoChannelSingleThreadTest, TestReceivePrAnswer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001967 Base::TestReceivePrAnswer();
1968}
1969
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001970TEST_F(VideoChannelSingleThreadTest, TestFlushRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001971 Base::TestFlushRtcp();
1972}
1973
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001974TEST_F(VideoChannelSingleThreadTest, SendBundleToBundle) {
tfarina5237aaf2015-11-10 23:44:30 -08001975 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, false);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001976}
1977
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001978TEST_F(VideoChannelSingleThreadTest, SendBundleToBundleSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08001979 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, true);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001980}
1981
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001982TEST_F(VideoChannelSingleThreadTest, SendBundleToBundleWithRtcpMux) {
tfarina5237aaf2015-11-10 23:44:30 -08001983 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, false);
buildbot@webrtc.org5ee0f052014-05-05 20:18:08 +00001984}
1985
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001986TEST_F(VideoChannelSingleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
tfarina5237aaf2015-11-10 23:44:30 -08001987 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001988}
1989
zstein56162b92017-04-24 16:54:35 -07001990TEST_F(VideoChannelSingleThreadTest, TestOnTransportReadyToSend) {
1991 Base::TestOnTransportReadyToSend();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001992}
1993
Danil Chapovalov33b01f22016-05-11 19:55:27 +02001994TEST_F(VideoChannelSingleThreadTest, DefaultMaxBitrateIsUnlimited) {
skvladdc1c62c2016-03-16 19:07:43 -07001995 Base::DefaultMaxBitrateIsUnlimited();
1996}
1997
Steve Anton8a63f782017-10-23 13:08:53 -07001998TEST_F(VideoChannelSingleThreadTest, SocketOptionsMergedOnSetTransport) {
1999 Base::SocketOptionsMergedOnSetTransport();
2000}
2001
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002002// VideoChannelDoubleThreadTest
2003TEST_F(VideoChannelDoubleThreadTest, TestInit) {
2004 Base::TestInit();
2005}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002006
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02002007TEST_F(VideoChannelDoubleThreadTest, TestDeinit) {
2008 Base::TestDeinit();
2009}
2010
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002011TEST_F(VideoChannelDoubleThreadTest, TestSetContents) {
2012 Base::TestSetContents();
2013}
2014
2015TEST_F(VideoChannelDoubleThreadTest, TestSetContentsNullOffer) {
2016 Base::TestSetContentsNullOffer();
2017}
2018
2019TEST_F(VideoChannelDoubleThreadTest, TestSetContentsRtcpMux) {
2020 Base::TestSetContentsRtcpMux();
2021}
2022
2023TEST_F(VideoChannelDoubleThreadTest, TestSetContentsRtcpMuxWithPrAnswer) {
2024 Base::TestSetContentsRtcpMux();
2025}
2026
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002027TEST_F(VideoChannelDoubleThreadTest, TestStreams) {
2028 Base::TestStreams();
2029}
2030
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002031TEST_F(VideoChannelDoubleThreadTest, TestChangeStreamParamsInContent) {
2032 Base::TestChangeStreamParamsInContent();
2033}
2034
2035TEST_F(VideoChannelDoubleThreadTest, TestPlayoutAndSendingStates) {
2036 Base::TestPlayoutAndSendingStates();
2037}
2038
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002039TEST_F(VideoChannelDoubleThreadTest, TestMediaContentDirection) {
2040 Base::TestMediaContentDirection();
2041}
2042
2043TEST_F(VideoChannelDoubleThreadTest, TestNetworkRouteChanges) {
2044 Base::TestNetworkRouteChanges();
2045}
2046
2047TEST_F(VideoChannelDoubleThreadTest, TestCallSetup) {
2048 Base::TestCallSetup();
2049}
2050
2051TEST_F(VideoChannelDoubleThreadTest, TestCallTeardownRtcpMux) {
2052 Base::TestCallTeardownRtcpMux();
2053}
2054
2055TEST_F(VideoChannelDoubleThreadTest, SendRtpToRtp) {
2056 Base::SendRtpToRtp();
2057}
2058
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002059TEST_F(VideoChannelDoubleThreadTest, SendRtcpToRtcp) {
2060 Base::SendRtcpToRtcp();
2061}
2062
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002063TEST_F(VideoChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtp) {
Zhi Huange830e682018-03-30 10:48:35 -07002064 Base::SendDtlsSrtpToDtlsSrtp(0, 0);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002065}
2066
2067TEST_F(VideoChannelDoubleThreadTest, SendDtlsSrtpToDtlsSrtpRtcpMux) {
Zhi Huange830e682018-03-30 10:48:35 -07002068 Base::SendDtlsSrtpToDtlsSrtp(RTCP_MUX, RTCP_MUX);
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002069}
2070
2071TEST_F(VideoChannelDoubleThreadTest, SendEarlyMediaUsingRtcpMuxSrtp) {
2072 Base::SendEarlyMediaUsingRtcpMuxSrtp();
2073}
2074
2075TEST_F(VideoChannelDoubleThreadTest, SendRtpToRtpOnThread) {
2076 Base::SendRtpToRtpOnThread();
2077}
2078
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002079TEST_F(VideoChannelDoubleThreadTest, SendWithWritabilityLoss) {
2080 Base::SendWithWritabilityLoss();
2081}
2082
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002083TEST_F(VideoChannelDoubleThreadTest, TestSetContentFailure) {
2084 Base::TestSetContentFailure();
2085}
2086
2087TEST_F(VideoChannelDoubleThreadTest, TestSendTwoOffers) {
2088 Base::TestSendTwoOffers();
2089}
2090
2091TEST_F(VideoChannelDoubleThreadTest, TestReceiveTwoOffers) {
2092 Base::TestReceiveTwoOffers();
2093}
2094
2095TEST_F(VideoChannelDoubleThreadTest, TestSendPrAnswer) {
2096 Base::TestSendPrAnswer();
2097}
2098
2099TEST_F(VideoChannelDoubleThreadTest, TestReceivePrAnswer) {
2100 Base::TestReceivePrAnswer();
2101}
2102
2103TEST_F(VideoChannelDoubleThreadTest, TestFlushRtcp) {
2104 Base::TestFlushRtcp();
2105}
2106
2107TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundle) {
2108 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, false);
2109}
2110
2111TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundleSecure) {
2112 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), false, true);
2113}
2114
2115TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundleWithRtcpMux) {
2116 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, false);
2117}
2118
2119TEST_F(VideoChannelDoubleThreadTest, SendBundleToBundleWithRtcpMuxSecure) {
2120 Base::SendBundleToBundle(kVideoPts, arraysize(kVideoPts), true, true);
2121}
2122
zstein56162b92017-04-24 16:54:35 -07002123TEST_F(VideoChannelDoubleThreadTest, TestOnTransportReadyToSend) {
2124 Base::TestOnTransportReadyToSend();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002125}
2126
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002127TEST_F(VideoChannelDoubleThreadTest, DefaultMaxBitrateIsUnlimited) {
2128 Base::DefaultMaxBitrateIsUnlimited();
2129}
2130
Steve Anton8a63f782017-10-23 13:08:53 -07002131TEST_F(VideoChannelDoubleThreadTest, SocketOptionsMergedOnSetTransport) {
2132 Base::SocketOptionsMergedOnSetTransport();
2133}
2134
deadbeef953c2ce2017-01-09 14:53:41 -08002135// RtpDataChannelSingleThreadTest
2136class RtpDataChannelSingleThreadTest : public ChannelTest<DataTraits> {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002137 public:
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002138 typedef ChannelTest<DataTraits> Base;
deadbeef953c2ce2017-01-09 14:53:41 -08002139 RtpDataChannelSingleThreadTest()
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002140 : Base(true, kDataPacket, kRtcpReport, NetworkIsWorker::Yes) {}
2141};
2142
deadbeef953c2ce2017-01-09 14:53:41 -08002143// RtpDataChannelDoubleThreadTest
2144class RtpDataChannelDoubleThreadTest : public ChannelTest<DataTraits> {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002145 public:
2146 typedef ChannelTest<DataTraits> Base;
deadbeef953c2ce2017-01-09 14:53:41 -08002147 RtpDataChannelDoubleThreadTest()
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002148 : Base(true, kDataPacket, kRtcpReport, NetworkIsWorker::No) {}
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002149};
2150
2151// Override to avoid engine channel parameter.
deadbeefcbecd352015-09-23 11:50:27 -07002152template <>
Steve Anton8699a322017-11-06 15:53:33 -08002153std::unique_ptr<cricket::RtpDataChannel> ChannelTest<DataTraits>::CreateChannel(
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002154 rtc::Thread* worker_thread,
2155 rtc::Thread* network_thread,
deadbeefcbecd352015-09-23 11:50:27 -07002156 cricket::MediaEngineInterface* engine,
Steve Anton8699a322017-11-06 15:53:33 -08002157 std::unique_ptr<cricket::FakeDataMediaChannel> ch,
Zhi Huange830e682018-03-30 10:48:35 -07002158 webrtc::RtpTransportInternal* rtp_transport,
jbauchcb560652016-08-04 05:20:32 -07002159 int flags) {
deadbeeff5346592017-01-24 21:51:21 -08002160 rtc::Thread* signaling_thread = rtc::Thread::Current();
Steve Anton8699a322017-11-06 15:53:33 -08002161 auto channel = rtc::MakeUnique<cricket::RtpDataChannel>(
2162 worker_thread, network_thread, signaling_thread, std::move(ch),
Zhi Huange830e682018-03-30 10:48:35 -07002163 cricket::CN_DATA, (flags & DTLS) != 0, rtc::CryptoOptions());
2164 channel->Init_w(rtp_transport);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002165 return channel;
2166}
2167
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002168template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002169void ChannelTest<DataTraits>::CreateContent(
2170 int flags,
2171 const cricket::AudioCodec& audio_codec,
2172 const cricket::VideoCodec& video_codec,
2173 cricket::DataContentDescription* data) {
2174 data->AddCodec(kGoogleDataCodec);
2175 data->set_rtcp_mux((flags & RTCP_MUX) != 0);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002176}
2177
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002178template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002179void ChannelTest<DataTraits>::CopyContent(
2180 const cricket::DataContentDescription& source,
2181 cricket::DataContentDescription* data) {
2182 *data = source;
2183}
2184
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002185template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002186bool ChannelTest<DataTraits>::CodecMatches(const cricket::DataCodec& c1,
2187 const cricket::DataCodec& c2) {
2188 return c1.name == c2.name;
2189}
2190
Peter Boström0c4e06b2015-10-07 12:23:21 +02002191template <>
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002192void ChannelTest<DataTraits>::AddLegacyStreamInContent(
Peter Boström0c4e06b2015-10-07 12:23:21 +02002193 uint32_t ssrc,
2194 int flags,
2195 cricket::DataContentDescription* data) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002196 data->AddLegacyStream(ssrc);
2197}
2198
deadbeef953c2ce2017-01-09 14:53:41 -08002199TEST_F(RtpDataChannelSingleThreadTest, TestInit) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002200 Base::TestInit();
2201 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2202}
2203
deadbeef953c2ce2017-01-09 14:53:41 -08002204TEST_F(RtpDataChannelSingleThreadTest, TestDeinit) {
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02002205 Base::TestDeinit();
2206}
2207
deadbeef953c2ce2017-01-09 14:53:41 -08002208TEST_F(RtpDataChannelSingleThreadTest, TestSetContents) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002209 Base::TestSetContents();
2210}
2211
deadbeef953c2ce2017-01-09 14:53:41 -08002212TEST_F(RtpDataChannelSingleThreadTest, TestSetContentsNullOffer) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002213 Base::TestSetContentsNullOffer();
2214}
2215
deadbeef953c2ce2017-01-09 14:53:41 -08002216TEST_F(RtpDataChannelSingleThreadTest, TestSetContentsRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002217 Base::TestSetContentsRtcpMux();
2218}
2219
deadbeef953c2ce2017-01-09 14:53:41 -08002220TEST_F(RtpDataChannelSingleThreadTest, TestStreams) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002221 Base::TestStreams();
2222}
2223
deadbeef953c2ce2017-01-09 14:53:41 -08002224TEST_F(RtpDataChannelSingleThreadTest, TestChangeStreamParamsInContent) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002225 Base::TestChangeStreamParamsInContent();
2226}
2227
deadbeef953c2ce2017-01-09 14:53:41 -08002228TEST_F(RtpDataChannelSingleThreadTest, TestPlayoutAndSendingStates) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002229 Base::TestPlayoutAndSendingStates();
2230}
2231
deadbeef953c2ce2017-01-09 14:53:41 -08002232TEST_F(RtpDataChannelSingleThreadTest, TestMediaContentDirection) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002233 Base::TestMediaContentDirection();
2234}
2235
deadbeef953c2ce2017-01-09 14:53:41 -08002236TEST_F(RtpDataChannelSingleThreadTest, TestCallSetup) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002237 Base::TestCallSetup();
2238}
2239
deadbeef953c2ce2017-01-09 14:53:41 -08002240TEST_F(RtpDataChannelSingleThreadTest, TestCallTeardownRtcpMux) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002241 Base::TestCallTeardownRtcpMux();
2242}
2243
zstein56162b92017-04-24 16:54:35 -07002244TEST_F(RtpDataChannelSingleThreadTest, TestOnTransportReadyToSend) {
2245 Base::TestOnTransportReadyToSend();
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002246}
2247
deadbeef953c2ce2017-01-09 14:53:41 -08002248TEST_F(RtpDataChannelSingleThreadTest, SendRtpToRtp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002249 Base::SendRtpToRtp();
2250}
2251
deadbeef953c2ce2017-01-09 14:53:41 -08002252TEST_F(RtpDataChannelSingleThreadTest, SendRtcpToRtcp) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002253 Base::SendRtcpToRtcp();
2254}
2255
deadbeef953c2ce2017-01-09 14:53:41 -08002256TEST_F(RtpDataChannelSingleThreadTest, SendRtpToRtpOnThread) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002257 Base::SendRtpToRtpOnThread();
2258}
2259
deadbeef953c2ce2017-01-09 14:53:41 -08002260TEST_F(RtpDataChannelSingleThreadTest, SendWithWritabilityLoss) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002261 Base::SendWithWritabilityLoss();
2262}
2263
Steve Anton8a63f782017-10-23 13:08:53 -07002264TEST_F(RtpDataChannelSingleThreadTest, SocketOptionsMergedOnSetTransport) {
2265 Base::SocketOptionsMergedOnSetTransport();
2266}
2267
deadbeef953c2ce2017-01-09 14:53:41 -08002268TEST_F(RtpDataChannelSingleThreadTest, TestSendData) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002269 CreateChannels(0, 0);
2270 EXPECT_TRUE(SendInitiate());
2271 EXPECT_TRUE(SendAccept());
2272
2273 cricket::SendDataParams params;
2274 params.ssrc = 42;
2275 unsigned char data[] = {'f', 'o', 'o'};
2276 rtc::CopyOnWriteBuffer payload(data, 3);
2277 cricket::SendDataResult result;
2278 ASSERT_TRUE(media_channel1_->SendData(params, payload, &result));
2279 EXPECT_EQ(params.ssrc, media_channel1_->last_sent_data_params().ssrc);
2280 EXPECT_EQ("foo", media_channel1_->last_sent_data());
2281}
2282
deadbeef953c2ce2017-01-09 14:53:41 -08002283TEST_F(RtpDataChannelDoubleThreadTest, TestInit) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002284 Base::TestInit();
2285 EXPECT_FALSE(media_channel1_->IsStreamMuted(0));
2286}
2287
deadbeef953c2ce2017-01-09 14:53:41 -08002288TEST_F(RtpDataChannelDoubleThreadTest, TestDeinit) {
Danil Chapovalovdae07ba2016-05-14 01:43:50 +02002289 Base::TestDeinit();
2290}
2291
deadbeef953c2ce2017-01-09 14:53:41 -08002292TEST_F(RtpDataChannelDoubleThreadTest, TestSetContents) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002293 Base::TestSetContents();
2294}
2295
deadbeef953c2ce2017-01-09 14:53:41 -08002296TEST_F(RtpDataChannelDoubleThreadTest, TestSetContentsNullOffer) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002297 Base::TestSetContentsNullOffer();
2298}
2299
deadbeef953c2ce2017-01-09 14:53:41 -08002300TEST_F(RtpDataChannelDoubleThreadTest, TestSetContentsRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002301 Base::TestSetContentsRtcpMux();
2302}
2303
deadbeef953c2ce2017-01-09 14:53:41 -08002304TEST_F(RtpDataChannelDoubleThreadTest, TestStreams) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002305 Base::TestStreams();
2306}
2307
deadbeef953c2ce2017-01-09 14:53:41 -08002308TEST_F(RtpDataChannelDoubleThreadTest, TestChangeStreamParamsInContent) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002309 Base::TestChangeStreamParamsInContent();
2310}
2311
deadbeef953c2ce2017-01-09 14:53:41 -08002312TEST_F(RtpDataChannelDoubleThreadTest, TestPlayoutAndSendingStates) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002313 Base::TestPlayoutAndSendingStates();
2314}
2315
deadbeef953c2ce2017-01-09 14:53:41 -08002316TEST_F(RtpDataChannelDoubleThreadTest, TestMediaContentDirection) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002317 Base::TestMediaContentDirection();
2318}
2319
deadbeef953c2ce2017-01-09 14:53:41 -08002320TEST_F(RtpDataChannelDoubleThreadTest, TestCallSetup) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002321 Base::TestCallSetup();
2322}
2323
deadbeef953c2ce2017-01-09 14:53:41 -08002324TEST_F(RtpDataChannelDoubleThreadTest, TestCallTeardownRtcpMux) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002325 Base::TestCallTeardownRtcpMux();
2326}
2327
zstein56162b92017-04-24 16:54:35 -07002328TEST_F(RtpDataChannelDoubleThreadTest, TestOnTransportReadyToSend) {
2329 Base::TestOnTransportReadyToSend();
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002330}
2331
deadbeef953c2ce2017-01-09 14:53:41 -08002332TEST_F(RtpDataChannelDoubleThreadTest, SendRtpToRtp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002333 Base::SendRtpToRtp();
2334}
2335
deadbeef953c2ce2017-01-09 14:53:41 -08002336TEST_F(RtpDataChannelDoubleThreadTest, SendRtcpToRtcp) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002337 Base::SendRtcpToRtcp();
2338}
2339
deadbeef953c2ce2017-01-09 14:53:41 -08002340TEST_F(RtpDataChannelDoubleThreadTest, SendRtpToRtpOnThread) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002341 Base::SendRtpToRtpOnThread();
2342}
2343
deadbeef953c2ce2017-01-09 14:53:41 -08002344TEST_F(RtpDataChannelDoubleThreadTest, SendWithWritabilityLoss) {
Danil Chapovalov33b01f22016-05-11 19:55:27 +02002345 Base::SendWithWritabilityLoss();
2346}
2347
Steve Anton8a63f782017-10-23 13:08:53 -07002348TEST_F(RtpDataChannelDoubleThreadTest, SocketOptionsMergedOnSetTransport) {
2349 Base::SocketOptionsMergedOnSetTransport();
2350}
2351
deadbeef953c2ce2017-01-09 14:53:41 -08002352TEST_F(RtpDataChannelDoubleThreadTest, TestSendData) {
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002353 CreateChannels(0, 0);
2354 EXPECT_TRUE(SendInitiate());
2355 EXPECT_TRUE(SendAccept());
2356
2357 cricket::SendDataParams params;
2358 params.ssrc = 42;
Yves Gerey665174f2018-06-19 15:03:05 +02002359 unsigned char data[] = {'f', 'o', 'o'};
jbaucheec21bd2016-03-20 06:15:43 -07002360 rtc::CopyOnWriteBuffer payload(data, 3);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002361 cricket::SendDataResult result;
2362 ASSERT_TRUE(media_channel1_->SendData(params, payload, &result));
Yves Gerey665174f2018-06-19 15:03:05 +02002363 EXPECT_EQ(params.ssrc, media_channel1_->last_sent_data_params().ssrc);
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002364 EXPECT_EQ("foo", media_channel1_->last_sent_data());
2365}
2366
henrike@webrtc.org28e20752013-07-10 00:45:36 +00002367// TODO(pthatcher): TestSetReceiver?