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

Side by Side Diff: webrtc/modules/rtp_rtcp/source/rtcp_sender_unittest.cc

Issue 2378113002: Allow max 1 block per type in RTCP Extended Reports (Closed)
Patch Set: use operator==(T, Optional<T>) for slightly cleaner tests Created 4 years, 2 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
« no previous file with comments | « webrtc/modules/rtp_rtcp/source/rtcp_sender.cc ('k') | webrtc/test/rtcp_packet_parser.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 588 matching lines...) Expand 10 before | Expand all | Expand 10 after
599 metric.MOSLQ = 11; 599 metric.MOSLQ = 11;
600 metric.MOSCQ = 12; 600 metric.MOSCQ = 12;
601 metric.RXconfig = 13; 601 metric.RXconfig = 13;
602 metric.JBnominal = 0x5555; 602 metric.JBnominal = 0x5555;
603 metric.JBmax = 0x6666; 603 metric.JBmax = 0x6666;
604 metric.JBabsMax = 0x7777; 604 metric.JBabsMax = 0x7777;
605 EXPECT_EQ(0, rtcp_sender_->SetRTCPVoIPMetrics(&metric)); 605 EXPECT_EQ(0, rtcp_sender_->SetRTCPVoIPMetrics(&metric));
606 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpXrVoipMetric)); 606 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpXrVoipMetric));
607 EXPECT_EQ(1, parser()->xr()->num_packets()); 607 EXPECT_EQ(1, parser()->xr()->num_packets());
608 EXPECT_EQ(kSenderSsrc, parser()->xr()->sender_ssrc()); 608 EXPECT_EQ(kSenderSsrc, parser()->xr()->sender_ssrc());
609 EXPECT_EQ(1U, parser()->xr()->voip_metrics().size()); 609 ASSERT_TRUE(parser()->xr()->voip_metric());
610 EXPECT_EQ(kRemoteSsrc, parser()->xr()->voip_metrics()[0].ssrc()); 610 EXPECT_EQ(kRemoteSsrc, parser()->xr()->voip_metric()->ssrc());
611 EXPECT_EQ(metric.lossRate, parser()->voip_metric()->lossRate); 611 const auto& parsed_metric = parser()->xr()->voip_metric()->voip_metric();
612 EXPECT_EQ(metric.discardRate, parser()->voip_metric()->discardRate); 612 EXPECT_EQ(metric.lossRate, parsed_metric.lossRate);
613 EXPECT_EQ(metric.burstDensity, parser()->voip_metric()->burstDensity); 613 EXPECT_EQ(metric.discardRate, parsed_metric.discardRate);
614 EXPECT_EQ(metric.gapDensity, parser()->voip_metric()->gapDensity); 614 EXPECT_EQ(metric.burstDensity, parsed_metric.burstDensity);
615 EXPECT_EQ(metric.burstDuration, parser()->voip_metric()->burstDuration); 615 EXPECT_EQ(metric.gapDensity, parsed_metric.gapDensity);
616 EXPECT_EQ(metric.gapDuration, parser()->voip_metric()->gapDuration); 616 EXPECT_EQ(metric.burstDuration, parsed_metric.burstDuration);
617 EXPECT_EQ(metric.roundTripDelay, parser()->voip_metric()->roundTripDelay); 617 EXPECT_EQ(metric.gapDuration, parsed_metric.gapDuration);
618 EXPECT_EQ(metric.endSystemDelay, parser()->voip_metric()->endSystemDelay); 618 EXPECT_EQ(metric.roundTripDelay, parsed_metric.roundTripDelay);
619 EXPECT_EQ(metric.signalLevel, parser()->voip_metric()->signalLevel); 619 EXPECT_EQ(metric.endSystemDelay, parsed_metric.endSystemDelay);
620 EXPECT_EQ(metric.noiseLevel, parser()->voip_metric()->noiseLevel); 620 EXPECT_EQ(metric.signalLevel, parsed_metric.signalLevel);
621 EXPECT_EQ(metric.RERL, parser()->voip_metric()->RERL); 621 EXPECT_EQ(metric.noiseLevel, parsed_metric.noiseLevel);
622 EXPECT_EQ(metric.Gmin, parser()->voip_metric()->Gmin); 622 EXPECT_EQ(metric.RERL, parsed_metric.RERL);
623 EXPECT_EQ(metric.Rfactor, parser()->voip_metric()->Rfactor); 623 EXPECT_EQ(metric.Gmin, parsed_metric.Gmin);
624 EXPECT_EQ(metric.extRfactor, parser()->voip_metric()->extRfactor); 624 EXPECT_EQ(metric.Rfactor, parsed_metric.Rfactor);
625 EXPECT_EQ(metric.MOSLQ, parser()->voip_metric()->MOSLQ); 625 EXPECT_EQ(metric.extRfactor, parsed_metric.extRfactor);
626 EXPECT_EQ(metric.MOSCQ, parser()->voip_metric()->MOSCQ); 626 EXPECT_EQ(metric.MOSLQ, parsed_metric.MOSLQ);
627 EXPECT_EQ(metric.RXconfig, parser()->voip_metric()->RXconfig); 627 EXPECT_EQ(metric.MOSCQ, parsed_metric.MOSCQ);
628 EXPECT_EQ(metric.JBnominal, parser()->voip_metric()->JBnominal); 628 EXPECT_EQ(metric.RXconfig, parsed_metric.RXconfig);
629 EXPECT_EQ(metric.JBmax, parser()->voip_metric()->JBmax); 629 EXPECT_EQ(metric.JBnominal, parsed_metric.JBnominal);
630 EXPECT_EQ(metric.JBabsMax, parser()->voip_metric()->JBabsMax); 630 EXPECT_EQ(metric.JBmax, parsed_metric.JBmax);
631 EXPECT_EQ(metric.JBabsMax, parsed_metric.JBabsMax);
631 } 632 }
632 633
633 TEST_F(RtcpSenderTest, SendXrWithDlrr) { 634 TEST_F(RtcpSenderTest, SendXrWithDlrr) {
634 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound); 635 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound);
635 RTCPSender::FeedbackState feedback_state = rtp_rtcp_impl_->GetFeedbackState(); 636 RTCPSender::FeedbackState feedback_state = rtp_rtcp_impl_->GetFeedbackState();
636 feedback_state.has_last_xr_rr = true; 637 feedback_state.has_last_xr_rr = true;
637 rtcp::ReceiveTimeInfo last_xr_rr; 638 rtcp::ReceiveTimeInfo last_xr_rr;
638 last_xr_rr.ssrc = 0x11111111; 639 last_xr_rr.ssrc = 0x11111111;
639 last_xr_rr.last_rr = 0x22222222; 640 last_xr_rr.last_rr = 0x22222222;
640 last_xr_rr.delay_since_last_rr = 0x33333333; 641 last_xr_rr.delay_since_last_rr = 0x33333333;
641 feedback_state.last_xr_rr = last_xr_rr; 642 feedback_state.last_xr_rr = last_xr_rr;
642 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state, kRtcpReport)); 643 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state, kRtcpReport));
643 EXPECT_EQ(1, parser()->xr()->num_packets()); 644 EXPECT_EQ(1, parser()->xr()->num_packets());
644 EXPECT_EQ(kSenderSsrc, parser()->xr()->sender_ssrc()); 645 EXPECT_EQ(kSenderSsrc, parser()->xr()->sender_ssrc());
645 EXPECT_EQ(1U, parser()->xr()->dlrrs().size()); 646 EXPECT_EQ(1U, parser()->xr()->dlrr().sub_blocks().size());
646 EXPECT_EQ(1U, parser()->xr()->dlrrs()[0].sub_blocks().size()); 647 EXPECT_EQ(last_xr_rr.ssrc, parser()->xr()->dlrr().sub_blocks()[0].ssrc);
647 EXPECT_EQ(last_xr_rr.ssrc, parser()->xr()->dlrrs()[0].sub_blocks()[0].ssrc); 648 EXPECT_EQ(last_xr_rr.last_rr, parser()->xr()->dlrr().sub_blocks()[0].last_rr);
648 EXPECT_EQ(last_xr_rr.last_rr,
649 parser()->xr()->dlrrs()[0].sub_blocks()[0].last_rr);
650 EXPECT_EQ(last_xr_rr.delay_since_last_rr, 649 EXPECT_EQ(last_xr_rr.delay_since_last_rr,
651 parser()->xr()->dlrrs()[0].sub_blocks()[0].delay_since_last_rr); 650 parser()->xr()->dlrr().sub_blocks()[0].delay_since_last_rr);
652 } 651 }
653 652
654 TEST_F(RtcpSenderTest, SendXrWithRrtr) { 653 TEST_F(RtcpSenderTest, SendXrWithRrtr) {
655 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound); 654 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound);
656 EXPECT_EQ(0, rtcp_sender_->SetSendingStatus(feedback_state(), false)); 655 EXPECT_EQ(0, rtcp_sender_->SetSendingStatus(feedback_state(), false));
657 rtcp_sender_->SendRtcpXrReceiverReferenceTime(true); 656 rtcp_sender_->SendRtcpXrReceiverReferenceTime(true);
658 uint32_t ntp_secs; 657 uint32_t ntp_secs;
659 uint32_t ntp_frac; 658 uint32_t ntp_frac;
660 clock_.CurrentNtp(ntp_secs, ntp_frac); 659 clock_.CurrentNtp(ntp_secs, ntp_frac);
661 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpReport)); 660 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpReport));
662 EXPECT_EQ(1, parser()->xr()->num_packets()); 661 EXPECT_EQ(1, parser()->xr()->num_packets());
663 EXPECT_EQ(kSenderSsrc, parser()->xr()->sender_ssrc()); 662 EXPECT_EQ(kSenderSsrc, parser()->xr()->sender_ssrc());
664 EXPECT_EQ(0U, parser()->xr()->dlrrs().size()); 663 EXPECT_FALSE(parser()->xr()->dlrr());
665 EXPECT_EQ(1U, parser()->xr()->rrtrs().size()); 664 EXPECT_FALSE(parser()->xr()->voip_metric());
666 EXPECT_EQ(ntp_secs, parser()->xr()->rrtrs()[0].ntp().seconds()); 665 ASSERT_TRUE(parser()->xr()->rrtr());
667 EXPECT_EQ(ntp_frac, parser()->xr()->rrtrs()[0].ntp().fractions()); 666 EXPECT_EQ(ntp_secs, parser()->xr()->rrtr()->ntp().seconds());
667 EXPECT_EQ(ntp_frac, parser()->xr()->rrtr()->ntp().fractions());
668 } 668 }
669 669
670 TEST_F(RtcpSenderTest, TestNoXrRrtrSentIfSending) { 670 TEST_F(RtcpSenderTest, TestNoXrRrtrSentIfSending) {
671 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound); 671 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound);
672 EXPECT_EQ(0, rtcp_sender_->SetSendingStatus(feedback_state(), true)); 672 EXPECT_EQ(0, rtcp_sender_->SetSendingStatus(feedback_state(), true));
673 rtcp_sender_->SendRtcpXrReceiverReferenceTime(true); 673 rtcp_sender_->SendRtcpXrReceiverReferenceTime(true);
674 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpReport)); 674 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpReport));
675 EXPECT_EQ(0, parser()->xr()->num_packets()); 675 EXPECT_EQ(0, parser()->xr()->num_packets());
676 } 676 }
677 677
(...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after
815 rtcp_sender_->SetLastRtpTime(kRtpTimestamp, clock_.TimeInMilliseconds()); 815 rtcp_sender_->SetLastRtpTime(kRtpTimestamp, clock_.TimeInMilliseconds());
816 816
817 // Set up XR VoIP metric to be included with BYE 817 // Set up XR VoIP metric to be included with BYE
818 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound); 818 rtcp_sender_->SetRTCPStatus(RtcpMode::kCompound);
819 RTCPVoIPMetric metric; 819 RTCPVoIPMetric metric;
820 EXPECT_EQ(0, rtcp_sender_->SetRTCPVoIPMetrics(&metric)); 820 EXPECT_EQ(0, rtcp_sender_->SetRTCPVoIPMetrics(&metric));
821 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpBye)); 821 EXPECT_EQ(0, rtcp_sender_->SendRTCP(feedback_state(), kRtcpBye));
822 } 822 }
823 823
824 } // namespace webrtc 824 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/rtp_rtcp/source/rtcp_sender.cc ('k') | webrtc/test/rtcp_packet_parser.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698