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

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

Issue 2943693003: Create RtcpDemuxer (Closed)
Patch Set: CR response Created 3 years, 6 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 (c) 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/call/rtcp_demuxer.h"
14
15 #include "webrtc/base/arraysize.h"
16 #include "webrtc/base/checks.h"
17 #include "webrtc/base/ptr_util.h"
18 #include "webrtc/call/rtcp_packet_sink_interface.h"
19 #include "webrtc/common_types.h"
20 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet/bye.h"
21 #include "webrtc/test/gmock.h"
22 #include "webrtc/test/gtest.h"
23
24 namespace webrtc {
25
26 namespace {
27
28 using ::testing::_;
29 using ::testing::AtLeast;
30 using ::testing::InSequence;
31 using ::testing::NiceMock;
32 using ::webrtc::rtcp::RtcpPacket;
33
34 class MockRtcpPacketSink : public RtcpPacketSinkInterface {
35 public:
36 MOCK_METHOD1(OnRtcpPacket, void(rtc::ArrayView<const uint8_t>));
37 };
38
39 MATCHER_P(SameAs, other, "") {
danilchap 2017/06/16 16:46:19 there is a matcher that checks same (but with a de
eladalon 2017/06/19 11:28:46 Done.
40 if (arg.size() != other.size()) {
41 return false;
42 }
43
44 for (size_t i = 0; i < arg.size(); i++) {
45 if (arg.data()[i] != other.data()[i]) {
46 return false;
47 }
48 }
49
50 return true;
51 }
52
53 // Produces a packet buffer representing an RTCP packet with a given SSRC,
54 // as it would look when sent over the wire.
55 // |distinguishing_string| allows different RTCP packets with the same SSRC
56 // to be distinguished. How this is set into the actual packet is
57 // unimportant, and depends on which RTCP message we choose to use.
58 rtc::Buffer CreateRtcpPacket(uint32_t ssrc,
59 const std::string& distinguishing_string = "") {
60 auto packet = rtc::MakeUnique<rtcp::Bye>();
danilchap 2017/06/16 16:46:19 why create packet on the heap instead of in the st
eladalon 2017/06/19 11:28:47 Right you are. An earlier version of this function
61 packet->SetSenderSsrc(ssrc);
62 if (distinguishing_string != "") {
63 // Actual way we use |distinguishing_string| is unimportant, so long
64 // as it ends up in the packet.
65 packet->SetReason(distinguishing_string);
66 }
67 return packet->Build();
68 }
69
70 // Converts a buffer to an ArrayView<const uint8_t>, which is the format
71 // expected by the demuxer and the sinks. Note that an ArrayView does not own
72 // the array it peeks into, which is why we could not have returned an ArrayView
73 // directly from CreateRtcpPacket().
74 rtc::ArrayView<const uint8_t> GetArrayView(const rtc::Buffer& buffer) {
danilchap 2017/06/16 16:46:19 one of the the key features of ArrayView - it has
eladalon 2017/06/19 11:28:47 Acknowledged (and used).
75 return rtc::ArrayView<const uint8_t>(buffer.data(), buffer.size());
76 }
77
78 } // namespace
79
80 TEST(RtcpDemuxerTest, OnRtcpPacketCalledOnCorrectSinkBySsrc) {
81 RtcpDemuxer demuxer;
82
83 constexpr uint32_t ssrcs[] = {101, 202, 303};
84 MockRtcpPacketSink sinks[arraysize(ssrcs)];
85 for (size_t i = 0; i < arraysize(ssrcs); i++) {
86 demuxer.AddSink(ssrcs[i], &sinks[i]);
87 }
88
89 for (size_t i = 0; i < arraysize(ssrcs); i++) {
90 auto packet = CreateRtcpPacket(ssrcs[i]);
91 auto array_view = GetArrayView(packet);
92 EXPECT_CALL(sinks[i], OnRtcpPacket(SameAs(array_view))).Times(1);
93 demuxer.OnRtcpPacket(array_view); // Triggers call to OnRtcpPacket().
94 }
95
96 // Test tear-down
97 for (const auto& sink : sinks) {
98 demuxer.RemoveSink(&sink);
99 }
100 }
101
102 TEST(RtcpDemuxerTest, OnRtcpPacketCalledOnResolvedRsidSink) {
103 RtcpDemuxer demuxer;
104
105 // Set up some RSID sinks.
106 const std::string rsids[] = {"a", "b", "c"};
107 MockRtcpPacketSink sinks[arraysize(rsids)];
108 for (size_t i = 0; i < arraysize(rsids); i++) {
109 demuxer.AddSink(rsids[i], &sinks[i]);
110 }
111
112 // Only resolve one of the sinks.
113 constexpr size_t resolved_sink_index = 0;
114 constexpr uint32_t ssrc = 345;
115 demuxer.OnRsidResolved(rsids[resolved_sink_index], ssrc);
116
117 // The resolved sink gets notifications of RTCP messages with its SSRC.
118 auto packet = CreateRtcpPacket(ssrc);
119 auto array_view = GetArrayView(packet);
120 EXPECT_CALL(sinks[resolved_sink_index], OnRtcpPacket(SameAs(array_view)))
121 .Times(1);
122
123 // RTCP received; expected calls triggered.
124 demuxer.OnRtcpPacket(array_view);
125
126 // Test tear-down
127 for (const auto& sink : sinks) {
128 demuxer.RemoveSink(&sink);
129 }
130 }
131
132 TEST(RtcpDemuxerTest,
133 SingleCallbackAfterResolutionOfAnRsidToAlreadyRegisteredSsrc) {
134 RtcpDemuxer demuxer;
135
136 // Associate a sink with an SSRC.
137 MockRtcpPacketSink sink;
138 constexpr uint32_t ssrc = 999;
139 demuxer.AddSink(ssrc, &sink);
140
141 // Associate the same sink with an RSID.
142 const std::string rsid = "r";
143 demuxer.AddSink(rsid, &sink);
144
145 // Resolve the RSID to the aforementioned SSRC.
146 demuxer.OnRsidResolved(rsid, ssrc);
147
148 // OnRtcpPacket still called only a single time for messages with this SSRC.
149 auto packet = CreateRtcpPacket(ssrc);
150 auto array_view = GetArrayView(packet);
151 EXPECT_CALL(sink, OnRtcpPacket(array_view)).Times(1);
152 demuxer.OnRtcpPacket(array_view);
153
154 // Test tear-down
155 demuxer.RemoveSink(&sink);
156 }
157
158 TEST(RtcpDemuxerTest, OnRtcpPacketCalledOnAllBroadcastSinksForAllRtcpPackets) {
159 RtcpDemuxer demuxer;
160
161 MockRtcpPacketSink sinks[3];
162 for (MockRtcpPacketSink& sink : sinks) {
163 demuxer.AddBroadcastSink(&sink);
164 }
165
166 constexpr uint32_t ssrc = 747;
167 auto packet = CreateRtcpPacket(ssrc);
168 auto array_view = GetArrayView(packet);
169
170 for (MockRtcpPacketSink& sink : sinks) {
171 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_view))).Times(1);
172 }
173
174 // RTCP received; expected calls triggered.
175 demuxer.OnRtcpPacket(array_view);
176
177 // Test tear-down
178 for (const auto& sink : sinks) {
179 demuxer.RemoveBroadcastSink(&sink);
180 }
181 }
182
183 TEST(RtcpDemuxerTest, PacketsDeliveredInRightOrderToNonBroadcastSink) {
184 RtcpDemuxer demuxer;
185
186 constexpr uint32_t ssrc = 101;
187 MockRtcpPacketSink sink;
188 demuxer.AddSink(ssrc, &sink);
189
190 std::vector<rtc::Buffer> packets;
191 std::vector<rtc::ArrayView<const uint8_t>> array_views;
192 for (size_t i = 0; i < 5; i++) {
193 packets.emplace_back(CreateRtcpPacket(ssrc, std::to_string(i)));
194 array_views.emplace_back(GetArrayView(packets[i]));
195 }
196
197 InSequence sequence;
198 for (size_t i = 0; i < 5; i++) {
199 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_views[i]))).Times(1);
200 }
201
202 for (const auto array_view : array_views) {
203 demuxer.OnRtcpPacket(array_view);
204 }
205
206 // Test tear-down
207 demuxer.RemoveSink(&sink);
208 }
209
210 TEST(RtcpDemuxerTest, PacketsDeliveredInRightOrderToBroadcastSink) {
211 RtcpDemuxer demuxer;
212
213 MockRtcpPacketSink sink;
214 demuxer.AddBroadcastSink(&sink);
215
216 std::vector<rtc::Buffer> packets;
217 std::vector<rtc::ArrayView<const uint8_t>> array_views;
218 for (size_t i = 0; i < 5; i++) {
219 constexpr uint32_t ssrc = 101;
220 packets.emplace_back(CreateRtcpPacket(ssrc, std::to_string(i)));
221 array_views.emplace_back(GetArrayView(packets[i]));
222 }
223
224 InSequence sequence;
225 for (size_t i = 0; i < 5; i++) {
226 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_views[i]))).Times(1);
227 }
228
229 for (const auto array_view : array_views) {
230 demuxer.OnRtcpPacket(array_view);
231 }
232
233 // Test tear-down
234 demuxer.RemoveBroadcastSink(&sink);
235 }
236
237 TEST(RtcpDemuxerTest, MultipleSinksMappedToSameSsrc) {
238 RtcpDemuxer demuxer;
239
240 MockRtcpPacketSink sinks[3];
241 constexpr uint32_t ssrc = 404;
242 for (auto& sink : sinks) {
243 demuxer.AddSink(ssrc, &sink);
244 }
245
246 // Reception of an RTCP packet associated with the shared SSRC triggers the
247 // callback on all of the sinks associated with it.
248 auto packet = CreateRtcpPacket(ssrc);
249 auto array_view = GetArrayView(packet);
250 for (auto& sink : sinks) {
251 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_view)));
252 }
253 demuxer.OnRtcpPacket(array_view);
254
255 // Test tear-down
256 for (const auto& sink : sinks) {
257 demuxer.RemoveSink(&sink);
258 }
259 }
260
261 TEST(RtcpDemuxerTest, SinkMappedToMultipleSsrcs) {
262 RtcpDemuxer demuxer;
263
264 constexpr uint32_t ssrcs[] = {404, 505, 606};
265 MockRtcpPacketSink sink;
266 for (uint32_t ssrc : ssrcs) {
267 demuxer.AddSink(ssrc, &sink);
268 }
269
270 // The sink which is associated with multiple SSRCs gets the callback
271 // triggered for each of those SSRCs.
272 for (uint32_t ssrc : ssrcs) {
273 auto packet = CreateRtcpPacket(ssrc);
274 auto array_view = GetArrayView(packet);
275 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_view)));
276 demuxer.OnRtcpPacket(array_view);
277 }
278
279 // Test tear-down
280 demuxer.RemoveSink(&sink);
281 }
282
283 TEST(RtcpDemuxerTest, MultipleRsidsOnSameSink) {
284 RtcpDemuxer demuxer;
285
286 // Sink associated with multiple sinks.
287 MockRtcpPacketSink sink;
288 const std::string rsids[] = {"a", "b", "c"};
289 for (const auto& rsid : rsids) {
290 demuxer.AddSink(rsid, &sink);
291 }
292
293 // RSIDs resolved to SSRCs.
294 uint32_t ssrcs[arraysize(rsids)];
295 for (size_t i = 0; i < arraysize(rsids); i++) {
296 ssrcs[i] = 1000 + static_cast<uint32_t>(i);
297 demuxer.OnRsidResolved(rsids[i], ssrcs[i]);
298 }
299
300 // Set up packets to match those RSIDs/SSRCs.
301 std::vector<rtc::Buffer> packets;
302 std::vector<rtc::ArrayView<const uint8_t>> array_views;
303 for (size_t i = 0; i < arraysize(rsids); i++) {
304 packets.emplace_back(CreateRtcpPacket(ssrcs[i]));
305 array_views.emplace_back(GetArrayView(packets[i]));
306 }
307
308 // The sink expects to receive all of the packets.
309 for (size_t i = 0; i < arraysize(rsids); i++) {
310 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_views[i]))).Times(1);
311 }
312
313 // Packet demuxed correctly; OnRtcpPacket() triggered on sink.
314 for (auto array_view : array_views) {
315 demuxer.OnRtcpPacket(array_view);
316 }
317
318 // Test tear-down
319 demuxer.RemoveSink(&sink);
320 }
321
322 TEST(RtcpDemuxerTest, RsidUsedByMultipleSinks) {
323 RtcpDemuxer demuxer;
324
325 MockRtcpPacketSink sinks[3];
326 const std::string shared_rsid = "a";
327
328 for (MockRtcpPacketSink& sink : sinks) {
329 demuxer.AddSink(shared_rsid, &sink);
330 }
331
332 constexpr uint32_t shared_ssrc = 888;
333 demuxer.OnRsidResolved(shared_rsid, shared_ssrc);
334
335 auto packet = CreateRtcpPacket(shared_ssrc);
336 auto array_view = GetArrayView(packet);
337
338 for (MockRtcpPacketSink& sink : sinks) {
339 EXPECT_CALL(sink, OnRtcpPacket(SameAs(array_view))).Times(1);
340 }
341
342 demuxer.OnRtcpPacket(array_view);
343
344 // Test tear-down
345 for (MockRtcpPacketSink& sink : sinks) {
346 demuxer.RemoveSink(&sink);
347 }
348 }
349
350 TEST(RtcpDemuxerTest, NoCallbackOnSsrcSinkRemovedBeforeFirstPacket) {
351 RtcpDemuxer demuxer;
352
353 constexpr uint32_t ssrc = 404;
354 MockRtcpPacketSink sink;
355 demuxer.AddSink(ssrc, &sink);
356
357 demuxer.RemoveSink(&sink);
358
359 // The removed sink does not get callbacks.
360 auto packet = CreateRtcpPacket(ssrc);
361 auto array_view = GetArrayView(packet);
362 EXPECT_CALL(sink, OnRtcpPacket(_)).Times(0); // Not called.
363 demuxer.OnRtcpPacket(array_view);
364 }
365
366 TEST(RtcpDemuxerTest, NoCallbackOnSsrcSinkRemovedAfterFirstPacket) {
367 RtcpDemuxer demuxer;
368
369 constexpr uint32_t ssrc = 404;
370 NiceMock<MockRtcpPacketSink> sink;
371 demuxer.AddSink(ssrc, &sink);
372
373 auto before_packet = CreateRtcpPacket(ssrc);
374 auto before_array_view = GetArrayView(before_packet);
375 demuxer.OnRtcpPacket(before_array_view);
376
377 demuxer.RemoveSink(&sink);
378
379 // The removed sink does not get callbacks.
380 auto after_packet = CreateRtcpPacket(ssrc);
381 auto after_array_view = GetArrayView(after_packet);
382 EXPECT_CALL(sink, OnRtcpPacket(_)).Times(0); // Not called.
383 demuxer.OnRtcpPacket(after_array_view);
384 }
385
386 TEST(RtcpDemuxerTest, NoCallbackOnRsidSinkRemovedBeforeRsidResolution) {
387 RtcpDemuxer demuxer;
388
389 const std::string rsid = "a";
390 constexpr uint32_t ssrc = 404;
391 MockRtcpPacketSink sink;
392 demuxer.AddSink(rsid, &sink);
393
394 // Removal before resolution.
395 demuxer.RemoveSink(&sink);
396 demuxer.OnRsidResolved(rsid, ssrc);
397
398 // The removed sink does not get callbacks.
399 auto packet = CreateRtcpPacket(ssrc);
400 auto array_view = GetArrayView(packet);
401 EXPECT_CALL(sink, OnRtcpPacket(_)).Times(0); // Not called.
402 demuxer.OnRtcpPacket(array_view);
403 }
404
405 TEST(RtcpDemuxerTest, NoCallbackOnRsidSinkRemovedAfterRsidResolution) {
406 RtcpDemuxer demuxer;
407
408 const std::string rsid = "a";
409 constexpr uint32_t ssrc = 404;
410 MockRtcpPacketSink sink;
411 demuxer.AddSink(rsid, &sink);
412
413 // Removal after resolution.
414 demuxer.OnRsidResolved(rsid, ssrc);
415 demuxer.RemoveSink(&sink);
416
417 // The removed sink does not get callbacks.
418 auto packet = CreateRtcpPacket(ssrc);
419 auto array_view = GetArrayView(packet);
420 EXPECT_CALL(sink, OnRtcpPacket(_)).Times(0); // Not called.
421 demuxer.OnRtcpPacket(array_view);
422 }
423
424 TEST(RtcpDemuxerTest, NoCallbackOnBroadcastSinkRemovedBeforeFirstPacket) {
425 RtcpDemuxer demuxer;
426
427 MockRtcpPacketSink sink;
428 demuxer.AddBroadcastSink(&sink);
429
430 demuxer.RemoveBroadcastSink(&sink);
431
432 // The removed sink does not get callbacks.
433 constexpr uint32_t ssrc = 404;
434 auto packet = CreateRtcpPacket(ssrc);
435 auto array_view = GetArrayView(packet);
436 EXPECT_CALL(sink, OnRtcpPacket(_)).Times(0); // Not called.
437 demuxer.OnRtcpPacket(array_view);
438 }
439
440 TEST(RtcpDemuxerTest, NoCallbackOnBroadcastSinkRemovedAfterFirstPacket) {
441 RtcpDemuxer demuxer;
442
443 NiceMock<MockRtcpPacketSink> sink;
444 demuxer.AddBroadcastSink(&sink);
445
446 constexpr uint32_t ssrc = 404;
447 auto before_packet = CreateRtcpPacket(ssrc);
448 auto before_array_view = GetArrayView(before_packet);
449 demuxer.OnRtcpPacket(before_array_view);
450
451 demuxer.RemoveBroadcastSink(&sink);
452
453 // The removed sink does not get callbacks.
454 auto after_packet = CreateRtcpPacket(ssrc);
455 auto after_array_view = GetArrayView(after_packet);
456 EXPECT_CALL(sink, OnRtcpPacket(_)).Times(0); // Not called.
457 demuxer.OnRtcpPacket(after_array_view);
458 }
459
460 // The RSID to SSRC mapping should be one-to-one. If we end up receiving
461 // two (or more) packets with the same SSRC, but different RSIDs, we guarantee
462 // remembering the first one; no guarantees are made about further associations.
463 TEST(RtcpDemuxerTest, FirstRsolutionOfRsidNotForgotten) {
464 RtcpDemuxer demuxer;
465 MockRtcpPacketSink sink;
466
467 const std::string rsid = "a";
468 demuxer.AddSink(rsid, &sink);
469
470 constexpr uint32_t ssrc_a = 111; // First resolution - guaranteed effective.
471 demuxer.OnRsidResolved(rsid, ssrc_a);
472
473 constexpr uint32_t ssrc_b = 222; // Second resolution - no guarantees.
474 demuxer.OnRsidResolved(rsid, ssrc_b);
475
476 auto packet_a = CreateRtcpPacket(ssrc_a);
477 auto array_view_a = GetArrayView(packet_a);
478 EXPECT_CALL(sink, OnRtcpPacket(array_view_a)).Times(1);
479 demuxer.OnRtcpPacket(array_view_a);
480
481 auto packet_b = CreateRtcpPacket(ssrc_b);
482 auto array_view_b = GetArrayView(packet_b);
483 EXPECT_CALL(sink, OnRtcpPacket(array_view_b)).Times(AtLeast(0));
484 demuxer.OnRtcpPacket(array_view_b);
485
486 // Test tear-down
487 demuxer.RemoveSink(&sink);
488 }
489
490 #if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
491 TEST(RtcpDemuxerTest, RepeatedSsrcToSinkAssociationsDisallowed) {
492 RtcpDemuxer demuxer;
493 MockRtcpPacketSink sink;
494
495 constexpr uint32_t ssrc = 101;
496 demuxer.AddSink(ssrc, &sink);
497 EXPECT_DEATH(demuxer.AddSink(ssrc, &sink), "");
498
499 // Test tear-down
500 demuxer.RemoveSink(&sink);
501 }
502
503 TEST(RtcpDemuxerTest, RepeatedRsidToSinkAssociationsDisallowed) {
504 RtcpDemuxer demuxer;
505 MockRtcpPacketSink sink;
506
507 const std::string rsid = "z";
508 demuxer.AddSink(rsid, &sink);
509 EXPECT_DEATH(demuxer.AddSink(rsid, &sink), "");
510
511 // Test tear-down
512 demuxer.RemoveSink(&sink);
513 }
514
515 TEST(RtcpDemuxerTest, RepeatedBroadcastSinkRegistrationDisallowed) {
516 RtcpDemuxer demuxer;
517 MockRtcpPacketSink sink;
518
519 demuxer.AddBroadcastSink(&sink);
520 EXPECT_DEATH(demuxer.AddBroadcastSink(&sink), "");
521
522 // Test tear-down
523 demuxer.RemoveBroadcastSink(&sink);
524 }
525
526 TEST(RtcpDemuxerTest, SsrcSinkCannotAlsoBeRegisteredAsBroadcast) {
527 RtcpDemuxer demuxer;
528 MockRtcpPacketSink sink;
529
530 constexpr uint32_t ssrc = 101;
531 demuxer.AddSink(ssrc, &sink);
532 EXPECT_DEATH(demuxer.AddBroadcastSink(&sink), "");
533
534 // Test tear-down
535 demuxer.RemoveSink(&sink);
536 }
537
538 TEST(RtcpDemuxerTest, RsidSinkCannotAlsoBeRegisteredAsBroadcast) {
539 RtcpDemuxer demuxer;
540 MockRtcpPacketSink sink;
541
542 const std::string rsid = "z";
543 demuxer.AddSink(rsid, &sink);
544 EXPECT_DEATH(demuxer.AddBroadcastSink(&sink), "");
545
546 // Test tear-down
547 demuxer.RemoveSink(&sink);
548 }
549
550 TEST(RtcpDemuxerTest, BroadcastSinkCannotAlsoBeRegisteredAsSsrcSink) {
551 RtcpDemuxer demuxer;
552 MockRtcpPacketSink sink;
553
554 demuxer.AddBroadcastSink(&sink);
555 constexpr uint32_t ssrc = 101;
556 EXPECT_DEATH(demuxer.AddSink(ssrc, &sink), "");
557
558 // Test tear-down
559 demuxer.RemoveBroadcastSink(&sink);
560 }
561
562 TEST(RtcpDemuxerTest, BroadcastSinkCannotAlsoBeRegisteredAsRsidSink) {
563 RtcpDemuxer demuxer;
564 MockRtcpPacketSink sink;
565
566 demuxer.AddBroadcastSink(&sink);
567 const std::string rsid = "j";
568 EXPECT_DEATH(demuxer.AddSink(rsid, &sink), "");
569
570 // Test tear-down
571 demuxer.RemoveBroadcastSink(&sink);
572 }
573
574 TEST(RtcpDemuxerTest, MayNotCallRemoveSinkOnNeverAddedSink) {
575 RtcpDemuxer demuxer;
576 MockRtcpPacketSink sink;
577
578 EXPECT_DEATH(demuxer.RemoveSink(&sink), "");
579 }
580
581 TEST(RtcpDemuxerTest, MayNotCallRemoveBroadcastSinkOnNeverAddedSink) {
582 RtcpDemuxer demuxer;
583 MockRtcpPacketSink sink;
584
585 EXPECT_DEATH(demuxer.RemoveBroadcastSink(&sink), "");
586 }
587
588 TEST(RtcpDemuxerTest, RsidMustBeNonEmpty) {
589 RtcpDemuxer demuxer;
590 MockRtcpPacketSink sink;
591 EXPECT_DEATH(demuxer.AddSink("", &sink), "");
592 }
593
594 TEST(RtcpDemuxerTest, RsidMustBeAlphaNumeric) {
595 RtcpDemuxer demuxer;
596 MockRtcpPacketSink sink;
597 EXPECT_DEATH(demuxer.AddSink("a_3", &sink), "");
598 }
599
600 TEST(RtcpDemuxerTest, RsidMustNotExceedMaximumLength) {
601 RtcpDemuxer demuxer;
602 MockRtcpPacketSink sink;
603 std::string rsid(StreamId::kMaxSize + 1, 'a');
604 EXPECT_DEATH(demuxer.AddSink(rsid, &sink), "");
605 }
606 #endif
607 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698