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

Side by Side Diff: webrtc/ortc/ortcrtpreceiver_unittest.cc

Issue 2675173003: Adding "adapter" ORTC objects on top of ChannelManager/BaseChannel/etc. (Closed)
Patch Set: More sender/receiver tests. Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 /*
2 * Copyright 2017 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
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.
9 */
10
11 #include <memory>
12
13 #include "webrtc/base/gunit.h"
14 #include "webrtc/media/base/fakemediaengine.h"
15 #include "webrtc/p2p/base/fakepackettransport.h"
16 #include "webrtc/ortc/ortcfactory.h"
17 #include "webrtc/ortc/testrtpparameters.h"
18 #include "webrtc/pc/test/fakevideotracksource.h"
19
20 namespace webrtc {
21
22 // This test uses an individual RtpReceiver using only the public interface, and
23 // verify that its APIs behave as intended. Also tests that parameters are
24 // applied to the audio/video engines as expected. Network and media interfaces
25 // are faked to isolate what's being tested.
26 //
27 // This test shouldn't result any any actual media being sent. That sort of
28 // test should go in ortcfactory_integrationtest.cc.
29 class OrtcRtpReceiverTest : public testing::Test {
30 public:
31 OrtcRtpReceiverTest() : fake_packet_transport_("fake") {
32 fake_media_engine_ = new cricket::FakeMediaEngine();
33 // Note: This doesn't need to use fake network classes, since we already
34 // use FakePacketTransport.
35 auto ortc_factory_result = OrtcFactory::Create(
36 nullptr, nullptr, nullptr, nullptr, nullptr,
37 std::unique_ptr<cricket::MediaEngineInterface>(fake_media_engine_));
38 ortc_factory_ = ortc_factory_result.MoveValue();
39 RtcpParameters rtcp_parameters;
40 rtcp_parameters.mux = true;
41 auto rtp_transport_result = ortc_factory_->CreateRtpTransport(
42 rtcp_parameters, &fake_packet_transport_, nullptr, nullptr);
43 rtp_transport_ = rtp_transport_result.MoveValue();
44 }
45
46 protected:
47 // Owned by |ortc_factory_|.
48 cricket::FakeMediaEngine* fake_media_engine_;
49 rtc::FakePacketTransport fake_packet_transport_;
50 std::unique_ptr<OrtcFactoryInterface> ortc_factory_;
51 std::unique_ptr<RtpTransportInterface> rtp_transport_;
52 };
53
54 // See ortcrtpreceiverinterface.h for the current expectations of what GetTrack
55 // will return after calls to Receive.
56 // TODO(deadbeef): Replace this test when this behavior is fixed.
57 TEST_F(OrtcRtpReceiverTest, GetTrack) {
58 auto receiver_result = ortc_factory_->CreateRtpReceiver(
59 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
60 ASSERT_TRUE(receiver_result.ok());
61 auto receiver = receiver_result.MoveValue();
62
63 // Track initially expected to be null.
64 EXPECT_EQ(nullptr, receiver_result.value().get());
65
66 EXPECT_TRUE(receiver->Receive(MakeMinimalVp8ParametersWithNoSsrc()).ok());
67 auto initial_track = receiver->GetTrack();
68 EXPECT_NE(nullptr, initial_track);
69
70 // Codec changing but SSRC (or lack thereof) isn't; shouldn't create new track
71 EXPECT_TRUE(receiver->Receive(MakeMinimalVp9ParametersWithNoSsrc()).ok());
72 EXPECT_EQ(initial_track, receiver->GetTrack());
73
74 // Explicitly set SSRC and expect a different track.
75 EXPECT_TRUE(
76 receiver->Receive(MakeMinimalVp9ParametersWithSsrc(0xdeadbeef)).ok());
77 auto next_track = receiver->GetTrack();
78 EXPECT_NE(next_track, initial_track);
79
80 // Deactivating the encoding shouldn't change the track.
81 RtpParameters inactive_encoding =
82 MakeMinimalVp9ParametersWithSsrc(0xdeadbeef);
83 inactive_encoding.encodings[0].active = false;
84 EXPECT_TRUE(receiver->Receive(inactive_encoding).ok());
85 EXPECT_EQ(next_track, receiver->GetTrack());
86
87 // Removing all encodings *is* expected to clear the track.
88 RtpParameters no_encodings = MakeMinimalVp9ParametersWithSsrc(0xdeadbeef);
89 no_encodings.encodings.clear();
90 EXPECT_TRUE(receiver->Receive(no_encodings).ok());
91 EXPECT_EQ(nullptr, receiver->GetTrack());
92 }
93
94 // Currently SetTransport isn't supported. When it is, replace this test with a
95 // test/tests for it.
96 TEST_F(OrtcRtpReceiverTest, SetTransportFails) {
97 rtc::FakePacketTransport fake_packet_transport("another_transport");
98 RtcpParameters rtcp_parameters;
99 rtcp_parameters.mux = true;
100 auto rtp_transport_result = ortc_factory_->CreateRtpTransport(
101 rtcp_parameters, &fake_packet_transport, nullptr, nullptr);
102 auto rtp_transport = rtp_transport_result.MoveValue();
103
104 auto receiver_result = ortc_factory_->CreateRtpReceiver(
105 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
106 auto receiver = receiver_result.MoveValue();
107 EXPECT_EQ(RTCErrorType::UNSUPPORTED_PARAMETER,
108 receiver->SetTransport(rtp_transport.get()).type());
109 }
110
111 TEST_F(OrtcRtpReceiverTest, GetTransport) {
112 auto result = ortc_factory_->CreateRtpReceiver(cricket::MEDIA_TYPE_AUDIO,
113 rtp_transport_.get());
114 EXPECT_EQ(rtp_transport_.get(), result.value()->GetTransport());
115 }
116
117 // Test that "Receive" causes the expected parameters to be applied to the media
118 // engine level, for an audio receiver.
119 TEST_F(OrtcRtpReceiverTest, ReceiveAppliesAudioParametersToMediaEngine) {
120 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
121 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
122 auto audio_receiver = audio_receiver_result.MoveValue();
123
124 // First, create parameters with all the bells and whistles.
125 RtpParameters parameters;
126
127 RtpCodecParameters opus_codec;
128 opus_codec.name = "opus";
129 opus_codec.kind = cricket::MEDIA_TYPE_AUDIO;
130 opus_codec.payload_type = 120;
131 opus_codec.clock_rate.emplace(48000);
132 opus_codec.num_channels.emplace(2);
133 opus_codec.parameters["minptime"] = "10";
134 opus_codec.rtcp_feedback.emplace_back(RtcpFeedbackType::TRANSPORT_CC);
135 parameters.codecs.push_back(std::move(opus_codec));
136
137 // Add two codecs, expecting the first to be used.
138 // TODO(deadbeef): Once "codec_payload_type" is supported, use it to select a
139 // codec that's not at the top of the list.
140 RtpCodecParameters isac_codec;
141 isac_codec.name = "ISAC";
142 isac_codec.kind = cricket::MEDIA_TYPE_AUDIO;
143 isac_codec.payload_type = 110;
144 isac_codec.clock_rate.emplace(16000);
145 parameters.codecs.push_back(std::move(isac_codec));
146
147 RtpEncodingParameters encoding;
148 encoding.ssrc.emplace(0xdeadbeef);
149 parameters.encodings.push_back(std::move(encoding));
150
151 parameters.header_extensions.emplace_back(
152 "urn:ietf:params:rtp-hdrext:ssrc-audio-level", 3);
153
154 EXPECT_TRUE(audio_receiver->Receive(parameters).ok());
155
156 // Now verify that the parameters were applied to the fake media engine layer
157 // that exists below BaseChannel.
158 cricket::FakeVoiceMediaChannel* fake_voice_channel =
159 fake_media_engine_->GetVoiceChannel(0);
160 ASSERT_NE(nullptr, fake_voice_channel);
161 EXPECT_TRUE(fake_voice_channel->playout());
162
163 // Verify codec parameters.
164 ASSERT_GT(fake_voice_channel->recv_codecs().size(), 0u);
165 const cricket::AudioCodec& top_codec = fake_voice_channel->recv_codecs()[0];
166 EXPECT_EQ("opus", top_codec.name);
167 EXPECT_EQ(120, top_codec.id);
168 EXPECT_EQ(48000, top_codec.clockrate);
169 EXPECT_EQ(2u, top_codec.channels);
170 ASSERT_NE(top_codec.params.end(), top_codec.params.find("minptime"));
171 EXPECT_EQ("10", top_codec.params.at("minptime"));
172
173 // Verify encoding parameters.
174 EXPECT_EQ(1u, fake_voice_channel->recv_streams().size());
175 const cricket::StreamParams& recv_stream =
176 fake_voice_channel->recv_streams()[0];
177 EXPECT_EQ(1u, recv_stream.ssrcs.size());
178 EXPECT_EQ(0xdeadbeef, recv_stream.first_ssrc());
179
180 // Verify header extensions.
181 ASSERT_EQ(1u, fake_voice_channel->recv_extensions().size());
182 const RtpExtension& extension = fake_voice_channel->recv_extensions()[0];
183 EXPECT_EQ("urn:ietf:params:rtp-hdrext:ssrc-audio-level", extension.uri);
184 EXPECT_EQ(3, extension.id);
185 }
186
187 // Test that "Receive" causes the expected parameters to be applied to the media
188 // engine level, for a video receiver.
189 TEST_F(OrtcRtpReceiverTest, ReceiveAppliesVideoParametersToMediaEngine) {
190 auto video_receiver_result = ortc_factory_->CreateRtpReceiver(
191 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
192 auto video_receiver = video_receiver_result.MoveValue();
193
194 // First, create parameters with all the bells and whistles.
195 RtpParameters parameters;
196
197 RtpCodecParameters vp8_codec;
198 vp8_codec.name = "VP8";
199 vp8_codec.kind = cricket::MEDIA_TYPE_VIDEO;
200 vp8_codec.payload_type = 99;
201 // Try a couple types of feedback params. "Generic NACK" is a bit of a
202 // special case, so test it here.
203 vp8_codec.rtcp_feedback.emplace_back(RtcpFeedbackType::CCM,
204 RtcpFeedbackMessageType::FIR);
205 vp8_codec.rtcp_feedback.emplace_back(RtcpFeedbackType::NACK,
206 RtcpFeedbackMessageType::GENERIC_NACK);
207 parameters.codecs.push_back(std::move(vp8_codec));
208
209 RtpCodecParameters vp8_rtx_codec;
210 vp8_rtx_codec.name = "rtx";
211 vp8_rtx_codec.kind = cricket::MEDIA_TYPE_VIDEO;
212 vp8_rtx_codec.payload_type = 100;
213 vp8_rtx_codec.parameters["apt"] = "99";
214 parameters.codecs.push_back(std::move(vp8_rtx_codec));
215
216 // Add two codecs, expecting the first to be used.
217 // TODO(deadbeef): Once "codec_payload_type" is supported, use it to select a
218 // codec that's not at the top of the list.
219 RtpCodecParameters vp9_codec;
220 vp9_codec.name = "VP9";
221 vp9_codec.kind = cricket::MEDIA_TYPE_VIDEO;
222 vp9_codec.payload_type = 102;
223 parameters.codecs.push_back(std::move(vp9_codec));
224
225 RtpCodecParameters vp9_rtx_codec;
226 vp9_rtx_codec.name = "rtx";
227 vp9_rtx_codec.kind = cricket::MEDIA_TYPE_VIDEO;
228 vp9_rtx_codec.payload_type = 103;
229 vp9_rtx_codec.parameters["apt"] = "102";
230 parameters.codecs.push_back(std::move(vp9_rtx_codec));
231
232 RtpEncodingParameters encoding;
233 encoding.ssrc.emplace(0xdeadbeef);
234 encoding.rtx.emplace(0xbaadfeed);
235 parameters.encodings.push_back(std::move(encoding));
236
237 parameters.header_extensions.emplace_back("urn:3gpp:video-orientation", 4);
238 parameters.header_extensions.emplace_back(
239 "http://www.webrtc.org/experiments/rtp-hdrext/playout-delay", 6);
240
241 EXPECT_TRUE(video_receiver->Receive(parameters).ok());
242
243 // Now verify that the parameters were applied to the fake media engine layer
244 // that exists below BaseChannel.
245 cricket::FakeVideoMediaChannel* fake_video_channel =
246 fake_media_engine_->GetVideoChannel(0);
247 ASSERT_NE(nullptr, fake_video_channel);
248
249 // Verify codec parameters.
250 ASSERT_GE(fake_video_channel->recv_codecs().size(), 2u);
251 const cricket::VideoCodec& top_codec = fake_video_channel->recv_codecs()[0];
252 EXPECT_EQ("VP8", top_codec.name);
253 EXPECT_EQ(99, top_codec.id);
254 EXPECT_TRUE(
255 top_codec.feedback_params.Has(cricket::FeedbackParam("ccm", "fir")));
256 EXPECT_TRUE(top_codec.feedback_params.Has(cricket::FeedbackParam("nack")));
257
258 const cricket::VideoCodec& rtx_codec = fake_video_channel->recv_codecs()[1];
259 EXPECT_EQ("rtx", rtx_codec.name);
260 EXPECT_EQ(100, rtx_codec.id);
261 ASSERT_NE(rtx_codec.params.end(), rtx_codec.params.find("apt"));
262 EXPECT_EQ("99", rtx_codec.params.at("apt"));
263
264 // Verify encoding parameters.
265 EXPECT_EQ(1u, fake_video_channel->recv_streams().size());
266 const cricket::StreamParams& recv_stream =
267 fake_video_channel->recv_streams()[0];
268 EXPECT_EQ(2u, recv_stream.ssrcs.size());
269 EXPECT_EQ(0xdeadbeef, recv_stream.first_ssrc());
270 uint32_t rtx_ssrc = 0u;
271 EXPECT_TRUE(recv_stream.GetFidSsrc(recv_stream.first_ssrc(), &rtx_ssrc));
272 EXPECT_EQ(0xbaadfeed, rtx_ssrc);
273
274 // Verify header extensions.
275 ASSERT_EQ(2u, fake_video_channel->recv_extensions().size());
276 const RtpExtension& extension1 = fake_video_channel->recv_extensions()[0];
277 EXPECT_EQ("urn:3gpp:video-orientation", extension1.uri);
278 EXPECT_EQ(4, extension1.id);
279 const RtpExtension& extension2 = fake_video_channel->recv_extensions()[1];
280 EXPECT_EQ("http://www.webrtc.org/experiments/rtp-hdrext/playout-delay",
281 extension2.uri);
282 EXPECT_EQ(6, extension2.id);
283 }
284
285 // Test changing both the receive codec and SSRC at the same time, and verify
286 // that the new parameters are applied to the media engine level.
287 TEST_F(OrtcRtpReceiverTest, CallingReceiveTwiceChangesParameters) {
288 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
289 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
290 auto audio_receiver = audio_receiver_result.MoveValue();
291 RTCError error =
292 audio_receiver->Receive(MakeMinimalOpusParametersWithSsrc(0x11111111));
293 EXPECT_TRUE(error.ok());
294 error =
295 audio_receiver->Receive(MakeMinimalIsacParametersWithSsrc(0x22222222));
296 EXPECT_TRUE(error.ok());
297
298 cricket::FakeVoiceMediaChannel* fake_voice_channel =
299 fake_media_engine_->GetVoiceChannel(0);
300 ASSERT_NE(nullptr, fake_voice_channel);
301 ASSERT_GT(fake_voice_channel->recv_codecs().size(), 0u);
302 EXPECT_EQ("ISAC", fake_voice_channel->recv_codecs()[0].name);
303 ASSERT_EQ(1u, fake_voice_channel->recv_streams().size());
304 EXPECT_EQ(0x22222222u, fake_voice_channel->recv_streams()[0].first_ssrc());
305
306 auto video_receiver_result = ortc_factory_->CreateRtpReceiver(
307 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
308 auto video_receiver = video_receiver_result.MoveValue();
309 error = video_receiver->Receive(MakeMinimalVp8ParametersWithSsrc(0x33333333));
310 EXPECT_TRUE(error.ok());
311 error = video_receiver->Receive(MakeMinimalVp9ParametersWithSsrc(0x44444444));
312 EXPECT_TRUE(error.ok());
313
314 cricket::FakeVideoMediaChannel* fake_video_channel =
315 fake_media_engine_->GetVideoChannel(0);
316 ASSERT_NE(nullptr, fake_video_channel);
317 ASSERT_GT(fake_video_channel->recv_codecs().size(), 0u);
318 EXPECT_EQ("VP9", fake_video_channel->recv_codecs()[0].name);
319 ASSERT_EQ(1u, fake_video_channel->recv_streams().size());
320 EXPECT_EQ(0x44444444u, fake_video_channel->recv_streams()[0].first_ssrc());
321 }
322
323 // Ensure that if the |active| flag of RtpEncodingParameters is set to false,
324 // playout stops at the media engine level. Note that this is only applicable
325 // to audio (at least currently).
326 TEST_F(OrtcRtpReceiverTest, DeactivatingEncodingStopsPlayout) {
327 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
328 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
329 auto audio_receiver = audio_receiver_result.MoveValue();
330 RtpParameters parameters = MakeMinimalOpusParameters();
331 EXPECT_TRUE(audio_receiver->Receive(parameters).ok());
332 parameters.encodings[0].active = false;
333 EXPECT_TRUE(audio_receiver->Receive(parameters).ok());
334
335 cricket::FakeVoiceMediaChannel* fake_voice_channel =
336 fake_media_engine_->GetVoiceChannel(0);
337 ASSERT_NE(nullptr, fake_voice_channel);
338 EXPECT_FALSE(fake_voice_channel->playout());
339 }
340
341 // Ensure that calling Receive with an empty list of encodings causes receive
342 // streams at the media engine level to be cleared.
343 TEST_F(OrtcRtpReceiverTest,
344 CallingReceiveWithEmptyEncodingsClearsReceiveStreams) {
345 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
346 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
347 auto audio_receiver = audio_receiver_result.MoveValue();
348 auto parameters = MakeMinimalOpusParameters();
349 EXPECT_TRUE(audio_receiver->Receive(parameters).ok());
350 parameters.encodings.clear();
351 EXPECT_TRUE(audio_receiver->Receive(parameters).ok());
352
353 cricket::FakeVoiceMediaChannel* fake_voice_channel =
354 fake_media_engine_->GetVoiceChannel(0);
355 ASSERT_NE(nullptr, fake_voice_channel);
356 EXPECT_TRUE(fake_voice_channel->recv_streams().empty());
357
358 auto video_receiver_result = ortc_factory_->CreateRtpReceiver(
359 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
360 auto video_receiver = video_receiver_result.MoveValue();
361 parameters = MakeMinimalVp8Parameters();
362 EXPECT_TRUE(video_receiver->Receive(parameters).ok());
363 parameters.encodings.clear();
364 EXPECT_TRUE(video_receiver->Receive(parameters).ok());
365
366 cricket::FakeVideoMediaChannel* fake_video_channel =
367 fake_media_engine_->GetVideoChannel(0);
368 ASSERT_NE(nullptr, fake_video_channel);
369 EXPECT_TRUE(fake_video_channel->recv_streams().empty());
370 }
371
372 // Ensure that deleting a receiver causes receive streams at the media engine
373 // level to be cleared.
374 TEST_F(OrtcRtpReceiverTest, DeletingReceiverClearsReceiveStreams) {
375 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
376 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
377 auto audio_receiver = audio_receiver_result.MoveValue();
378 EXPECT_TRUE(audio_receiver->Receive(MakeMinimalOpusParameters()).ok());
379
380 // Also create an audio sender, to prevent the voice channel from being
381 // completely deleted.
382 auto audio_sender_result = ortc_factory_->CreateRtpSender(
383 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
384 auto audio_sender = audio_sender_result.MoveValue();
385 EXPECT_TRUE(audio_sender->Send(MakeMinimalOpusParameters()).ok());
386
387 audio_receiver.reset(nullptr);
388 cricket::FakeVoiceMediaChannel* fake_voice_channel =
389 fake_media_engine_->GetVoiceChannel(0);
390 ASSERT_NE(nullptr, fake_voice_channel);
391 EXPECT_TRUE(fake_voice_channel->recv_streams().empty());
392
393 auto video_receiver_result = ortc_factory_->CreateRtpReceiver(
394 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
395 auto video_receiver = video_receiver_result.MoveValue();
396 EXPECT_TRUE(video_receiver->Receive(MakeMinimalVp8Parameters()).ok());
397
398 // Also create an video sender, to prevent the video channel from being
399 // completely deleted.
400 auto video_sender_result = ortc_factory_->CreateRtpSender(
401 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
402 auto video_sender = video_sender_result.MoveValue();
403 EXPECT_TRUE(video_sender->Send(MakeMinimalVp8Parameters()).ok());
404
405 video_receiver.reset(nullptr);
406 cricket::FakeVideoMediaChannel* fake_video_channel =
407 fake_media_engine_->GetVideoChannel(0);
408 ASSERT_NE(nullptr, fake_video_channel);
409 EXPECT_TRUE(fake_video_channel->recv_streams().empty());
410 }
411
412 // If Receive hasn't been called, GetParameters should return empty parameters.
413 TEST_F(OrtcRtpReceiverTest, GetDefaultParameters) {
414 auto result = ortc_factory_->CreateRtpReceiver(cricket::MEDIA_TYPE_AUDIO,
415 rtp_transport_.get());
416 EXPECT_EQ(RtpParameters(), result.value()->GetParameters());
417 result = ortc_factory_->CreateRtpReceiver(cricket::MEDIA_TYPE_VIDEO,
418 rtp_transport_.get());
419 EXPECT_EQ(RtpParameters(), result.value()->GetParameters());
420 }
421
422 // Test that GetParameters returns the last parameters passed into Receive,
423 // along with the implementation-default values filled in where they were left
424 // unset.
425 TEST_F(OrtcRtpReceiverTest,
426 GetParametersReturnsLastSetParametersWithDefaultsFilled) {
427 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
428 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
429 auto audio_receiver = audio_receiver_result.MoveValue();
430
431 RtpParameters opus_parameters = MakeMinimalOpusParameters();
432 EXPECT_TRUE(audio_receiver->Receive(opus_parameters).ok());
433 EXPECT_EQ(opus_parameters, audio_receiver->GetParameters());
434
435 RtpParameters isac_parameters = MakeMinimalIsacParameters();
436 // Sanity check that num_channels actually is left unset.
437 ASSERT_FALSE(isac_parameters.codecs[0].num_channels);
438 EXPECT_TRUE(audio_receiver->Receive(isac_parameters).ok());
439 // Should be filled with a default "num channels" of 1.
440 isac_parameters.codecs[0].num_channels.emplace(1);
441 EXPECT_EQ(isac_parameters, audio_receiver->GetParameters());
442
443 auto video_receiver_result = ortc_factory_->CreateRtpReceiver(
444 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
445 auto video_receiver = video_receiver_result.MoveValue();
446
447 RtpParameters vp8_parameters = MakeMinimalVp8Parameters();
448 // Sanity check that clock_rate actually is left unset.
449 EXPECT_TRUE(video_receiver->Receive(vp8_parameters).ok());
450 // Should be filled with a default clock rate of 90000.
451 vp8_parameters.codecs[0].clock_rate.emplace(90000);
452 EXPECT_EQ(vp8_parameters, video_receiver->GetParameters());
453
454 RtpParameters vp9_parameters = MakeMinimalVp9Parameters();
455 // Sanity check that clock_rate actually is left unset.
456 EXPECT_TRUE(video_receiver->Receive(vp9_parameters).ok());
457 // Should be filled with a default clock rate of 90000.
458 vp9_parameters.codecs[0].clock_rate.emplace(90000);
459 EXPECT_EQ(vp9_parameters, video_receiver->GetParameters());
460 }
461
462 TEST_F(OrtcRtpReceiverTest, GetKind) {
463 // Construct one receiver from the "kind" enum and another from a track.
464 auto audio_receiver_result = ortc_factory_->CreateRtpReceiver(
465 cricket::MEDIA_TYPE_AUDIO, rtp_transport_.get());
466 auto audio_receiver = audio_receiver_result.MoveValue();
467 auto video_receiver_result = ortc_factory_->CreateRtpReceiver(
468 cricket::MEDIA_TYPE_VIDEO, rtp_transport_.get());
469 auto video_receiver = video_receiver_result.MoveValue();
470 EXPECT_EQ(cricket::MEDIA_TYPE_AUDIO, audio_receiver->GetKind());
471 EXPECT_EQ(cricket::MEDIA_TYPE_VIDEO, video_receiver->GetKind());
472 }
473
474 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698