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

Side by Side Diff: webrtc/modules/rtp_rtcp/source/rtcp_packet/sender_report_unittest.cc

Issue 2370313002: Reland of Unify rtcp packet setters (Closed)
Patch Set: Fix breaking mistype 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
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2016 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 21 matching lines...) Expand all
32 0x12, 0x34, 0x56, 0x78, 32 0x12, 0x34, 0x56, 0x78,
33 0x11, 0x12, 0x14, 0x18, 33 0x11, 0x12, 0x14, 0x18,
34 0x22, 0x24, 0x26, 0x28, 34 0x22, 0x24, 0x26, 0x28,
35 0x33, 0x34, 0x35, 0x36, 35 0x33, 0x34, 0x35, 0x36,
36 0x44, 0x45, 0x46, 0x47, 36 0x44, 0x45, 0x46, 0x47,
37 0x55, 0x56, 0x57, 0x58}; 37 0x55, 0x56, 0x57, 0x58};
38 } // namespace 38 } // namespace
39 39
40 TEST(RtcpPacketSenderReportTest, CreateWithoutReportBlocks) { 40 TEST(RtcpPacketSenderReportTest, CreateWithoutReportBlocks) {
41 SenderReport sr; 41 SenderReport sr;
42 sr.From(kSenderSsrc); 42 sr.SetSenderSsrc(kSenderSsrc);
43 sr.WithNtp(kNtp); 43 sr.SetNtp(kNtp);
44 sr.WithRtpTimestamp(kRtpTimestamp); 44 sr.SetRtpTimestamp(kRtpTimestamp);
45 sr.WithPacketCount(kPacketCount); 45 sr.SetPacketCount(kPacketCount);
46 sr.WithOctetCount(kOctetCount); 46 sr.SetOctetCount(kOctetCount);
47 47
48 rtc::Buffer raw = sr.Build(); 48 rtc::Buffer raw = sr.Build();
49 EXPECT_THAT(make_tuple(raw.data(), raw.size()), ElementsAreArray(kPacket)); 49 EXPECT_THAT(make_tuple(raw.data(), raw.size()), ElementsAreArray(kPacket));
50 } 50 }
51 51
52 TEST(RtcpPacketSenderReportTest, ParseWithoutReportBlocks) { 52 TEST(RtcpPacketSenderReportTest, ParseWithoutReportBlocks) {
53 SenderReport parsed; 53 SenderReport parsed;
54 EXPECT_TRUE(test::ParseSinglePacket(kPacket, &parsed)); 54 EXPECT_TRUE(test::ParseSinglePacket(kPacket, &parsed));
55 55
56 EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc()); 56 EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
57 EXPECT_EQ(kNtp, parsed.ntp()); 57 EXPECT_EQ(kNtp, parsed.ntp());
58 EXPECT_EQ(kRtpTimestamp, parsed.rtp_timestamp()); 58 EXPECT_EQ(kRtpTimestamp, parsed.rtp_timestamp());
59 EXPECT_EQ(kPacketCount, parsed.sender_packet_count()); 59 EXPECT_EQ(kPacketCount, parsed.sender_packet_count());
60 EXPECT_EQ(kOctetCount, parsed.sender_octet_count()); 60 EXPECT_EQ(kOctetCount, parsed.sender_octet_count());
61 EXPECT_TRUE(parsed.report_blocks().empty()); 61 EXPECT_TRUE(parsed.report_blocks().empty());
62 } 62 }
63 63
64 TEST(RtcpPacketSenderReportTest, CreateAndParseWithOneReportBlock) { 64 TEST(RtcpPacketSenderReportTest, CreateAndParseWithOneReportBlock) {
65 ReportBlock rb; 65 ReportBlock rb;
66 rb.To(kRemoteSsrc); 66 rb.SetMediaSsrc(kRemoteSsrc);
67 67
68 SenderReport sr; 68 SenderReport sr;
69 sr.From(kSenderSsrc); 69 sr.SetSenderSsrc(kSenderSsrc);
70 EXPECT_TRUE(sr.WithReportBlock(rb)); 70 EXPECT_TRUE(sr.AddReportBlock(rb));
71 71
72 rtc::Buffer raw = sr.Build(); 72 rtc::Buffer raw = sr.Build();
73 SenderReport parsed; 73 SenderReport parsed;
74 EXPECT_TRUE(test::ParseSinglePacket(raw, &parsed)); 74 EXPECT_TRUE(test::ParseSinglePacket(raw, &parsed));
75 75
76 EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc()); 76 EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
77 EXPECT_EQ(1u, parsed.report_blocks().size()); 77 EXPECT_EQ(1u, parsed.report_blocks().size());
78 EXPECT_EQ(kRemoteSsrc, parsed.report_blocks()[0].source_ssrc()); 78 EXPECT_EQ(kRemoteSsrc, parsed.report_blocks()[0].source_ssrc());
79 } 79 }
80 80
81 TEST(RtcpPacketSenderReportTest, CreateAndParseWithTwoReportBlocks) { 81 TEST(RtcpPacketSenderReportTest, CreateAndParseWithTwoReportBlocks) {
82 ReportBlock rb1; 82 ReportBlock rb1;
83 rb1.To(kRemoteSsrc); 83 rb1.SetMediaSsrc(kRemoteSsrc);
84 ReportBlock rb2; 84 ReportBlock rb2;
85 rb2.To(kRemoteSsrc + 1); 85 rb2.SetMediaSsrc(kRemoteSsrc + 1);
86 86
87 SenderReport sr; 87 SenderReport sr;
88 sr.From(kSenderSsrc); 88 sr.SetSenderSsrc(kSenderSsrc);
89 EXPECT_TRUE(sr.WithReportBlock(rb1)); 89 EXPECT_TRUE(sr.AddReportBlock(rb1));
90 EXPECT_TRUE(sr.WithReportBlock(rb2)); 90 EXPECT_TRUE(sr.AddReportBlock(rb2));
91 91
92 rtc::Buffer raw = sr.Build(); 92 rtc::Buffer raw = sr.Build();
93 SenderReport parsed; 93 SenderReport parsed;
94 EXPECT_TRUE(test::ParseSinglePacket(raw, &parsed)); 94 EXPECT_TRUE(test::ParseSinglePacket(raw, &parsed));
95 95
96 EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc()); 96 EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
97 EXPECT_EQ(2u, parsed.report_blocks().size()); 97 EXPECT_EQ(2u, parsed.report_blocks().size());
98 EXPECT_EQ(kRemoteSsrc, parsed.report_blocks()[0].source_ssrc()); 98 EXPECT_EQ(kRemoteSsrc, parsed.report_blocks()[0].source_ssrc());
99 EXPECT_EQ(kRemoteSsrc + 1, parsed.report_blocks()[1].source_ssrc()); 99 EXPECT_EQ(kRemoteSsrc + 1, parsed.report_blocks()[1].source_ssrc());
100 } 100 }
101 101
102 TEST(RtcpPacketSenderReportTest, CreateWithTooManyReportBlocks) { 102 TEST(RtcpPacketSenderReportTest, CreateWithTooManyReportBlocks) {
103 SenderReport sr; 103 SenderReport sr;
104 sr.From(kSenderSsrc); 104 sr.SetSenderSsrc(kSenderSsrc);
105 const size_t kMaxReportBlocks = (1 << 5) - 1; 105 const size_t kMaxReportBlocks = (1 << 5) - 1;
106 ReportBlock rb; 106 ReportBlock rb;
107 for (size_t i = 0; i < kMaxReportBlocks; ++i) { 107 for (size_t i = 0; i < kMaxReportBlocks; ++i) {
108 rb.To(kRemoteSsrc + i); 108 rb.SetMediaSsrc(kRemoteSsrc + i);
109 EXPECT_TRUE(sr.WithReportBlock(rb)); 109 EXPECT_TRUE(sr.AddReportBlock(rb));
110 } 110 }
111 rb.To(kRemoteSsrc + kMaxReportBlocks); 111 rb.SetMediaSsrc(kRemoteSsrc + kMaxReportBlocks);
112 EXPECT_FALSE(sr.WithReportBlock(rb)); 112 EXPECT_FALSE(sr.AddReportBlock(rb));
113 } 113 }
114 114
115 } // namespace webrtc 115 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/rtp_rtcp/source/rtcp_packet/sender_report.cc ('k') | webrtc/modules/rtp_rtcp/source/rtcp_packet/sli.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698