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

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

Issue 1439553003: [rtp_rtcp] rtcp::Sdes cleaned and got Parse function (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: rebase Created 4 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
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
11 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet/sdes.h" 11 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet/sdes.h"
12 12
13 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
14 14
15 #include "webrtc/modules/rtp_rtcp/source/byte_io.h"
16 #include "webrtc/test/rtcp_packet_parser.h"
17
18 using webrtc::rtcp::RawPacket; 15 using webrtc::rtcp::RawPacket;
19 using webrtc::rtcp::Sdes; 16 using webrtc::rtcp::Sdes;
20 using webrtc::test::RtcpPacketParser; 17 using webrtc::RTCPUtility::RtcpCommonHeader;
18 using webrtc::RTCPUtility::RtcpParseCommonHeader;
21 19
22 namespace webrtc { 20 namespace webrtc {
21 namespace {
23 const uint32_t kSenderSsrc = 0x12345678; 22 const uint32_t kSenderSsrc = 0x12345678;
23 const uint8_t kPadding = 0;
24 const uint8_t kTerminatorTag = 0;
25 const uint8_t kCnameTag = 1;
26 const uint8_t kNameTag = 2;
27 const uint8_t kEmailTag = 3;
28
29 bool Parse(const uint8_t* buffer, size_t length, Sdes* sdes) {
30 RtcpCommonHeader header;
31 EXPECT_TRUE(RtcpParseCommonHeader(buffer, length, &header));
32 // Check that there is exactly one RTCP packet in the buffer.
33 EXPECT_EQ(length, header.BlockSize());
34 return sdes->Parse(header, buffer + RtcpCommonHeader::kHeaderSizeBytes);
35 }
36 } // namespace
24 37
25 TEST(RtcpPacketSdesTest, WithOneChunk) { 38 TEST(RtcpPacketSdesTest, WithOneChunk) {
39 const std::string kCname = "alice@host";
40
26 Sdes sdes; 41 Sdes sdes;
27 EXPECT_TRUE(sdes.WithCName(kSenderSsrc, "alice@host")); 42 EXPECT_TRUE(sdes.WithCName(kSenderSsrc, kCname));
28 43
29 rtc::scoped_ptr<RawPacket> packet(sdes.Build()); 44 rtc::scoped_ptr<RawPacket> packet = sdes.Build();
30 RtcpPacketParser parser; 45 Sdes sdes_parsed;
31 parser.Parse(packet->Buffer(), packet->Length()); 46 Parse(packet->Buffer(), packet->Length(), &sdes_parsed);
32 EXPECT_EQ(1, parser.sdes()->num_packets()); 47 const Sdes& parsed = sdes_parsed; // Ensure acessors are const.
åsapersson 2016/02/11 10:20:33 acessors->accessors
danilchap 2016/02/11 11:13:37 Done.
33 EXPECT_EQ(1, parser.sdes_chunk()->num_packets()); 48
34 EXPECT_EQ(kSenderSsrc, parser.sdes_chunk()->Ssrc()); 49 EXPECT_EQ(1u, parsed.chunks().size());
35 EXPECT_EQ("alice@host", parser.sdes_chunk()->Cname()); 50 EXPECT_EQ(kSenderSsrc, parsed.chunks()[0].ssrc);
51 EXPECT_EQ(kCname, parsed.chunks()[0].cname);
36 } 52 }
37 53
38 TEST(RtcpPacketSdesTest, WithMultipleChunks) { 54 TEST(RtcpPacketSdesTest, WithMultipleChunks) {
39 Sdes sdes; 55 Sdes sdes;
40 EXPECT_TRUE(sdes.WithCName(kSenderSsrc, "a")); 56 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 0, "a"));
41 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 1, "ab")); 57 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 1, "ab"));
42 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 2, "abc")); 58 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 2, "abc"));
43 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 3, "abcd")); 59 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 3, "abcd"));
44 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 4, "abcde")); 60 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 4, "abcde"));
45 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 5, "abcdef")); 61 EXPECT_TRUE(sdes.WithCName(kSenderSsrc + 5, "abcdef"));
46 62
47 rtc::scoped_ptr<RawPacket> packet(sdes.Build()); 63 rtc::scoped_ptr<RawPacket> packet = sdes.Build();
48 RtcpPacketParser parser; 64 Sdes parsed;
49 parser.Parse(packet->Buffer(), packet->Length()); 65 Parse(packet->Buffer(), packet->Length(), &parsed);
50 EXPECT_EQ(1, parser.sdes()->num_packets()); 66
51 EXPECT_EQ(6, parser.sdes_chunk()->num_packets()); 67 EXPECT_EQ(6u, parsed.chunks().size());
52 EXPECT_EQ(kSenderSsrc + 5, parser.sdes_chunk()->Ssrc()); 68 EXPECT_EQ(kSenderSsrc + 5, parsed.chunks()[5].ssrc);
53 EXPECT_EQ("abcdef", parser.sdes_chunk()->Cname()); 69 EXPECT_EQ("abcdef", parsed.chunks()[5].cname);
54 } 70 }
55 71
56 TEST(RtcpPacketSdesTest, WithTooManyChunks) { 72 TEST(RtcpPacketSdesTest, WithTooManyChunks) {
73 const size_t kMaxChunks = (1 << 5) - 1;
57 Sdes sdes; 74 Sdes sdes;
58 const int kMaxChunks = (1 << 5) - 1; 75 for (size_t i = 0; i < kMaxChunks; ++i) {
59 for (int i = 0; i < kMaxChunks; ++i) {
60 uint32_t ssrc = kSenderSsrc + i; 76 uint32_t ssrc = kSenderSsrc + i;
61 std::ostringstream oss; 77 std::ostringstream oss;
62 oss << "cname" << i; 78 oss << "cname" << i;
63 EXPECT_TRUE(sdes.WithCName(ssrc, oss.str())); 79 EXPECT_TRUE(sdes.WithCName(ssrc, oss.str()));
64 } 80 }
65 EXPECT_FALSE(sdes.WithCName(kSenderSsrc + kMaxChunks, "foo")); 81 EXPECT_FALSE(sdes.WithCName(kSenderSsrc + kMaxChunks, "foo"));
66 } 82 }
67 83
68 TEST(RtcpPacketSdesTest, CnameItemWithEmptyString) { 84 TEST(RtcpPacketSdesTest, CnameItemWithEmptyString) {
69 Sdes sdes; 85 Sdes sdes;
70 EXPECT_TRUE(sdes.WithCName(kSenderSsrc, "")); 86 EXPECT_TRUE(sdes.WithCName(kSenderSsrc, ""));
71 87
72 rtc::scoped_ptr<RawPacket> packet(sdes.Build()); 88 rtc::scoped_ptr<RawPacket> packet = sdes.Build();
73 RtcpPacketParser parser; 89 Sdes parsed;
74 parser.Parse(packet->Buffer(), packet->Length()); 90 Parse(packet->Buffer(), packet->Length(), &parsed);
75 EXPECT_EQ(1, parser.sdes()->num_packets()); 91
76 EXPECT_EQ(1, parser.sdes_chunk()->num_packets()); 92 EXPECT_EQ(1u, parsed.chunks().size());
77 EXPECT_EQ(kSenderSsrc, parser.sdes_chunk()->Ssrc()); 93 EXPECT_EQ(kSenderSsrc, parsed.chunks()[0].ssrc);
78 EXPECT_EQ("", parser.sdes_chunk()->Cname()); 94 EXPECT_EQ("", parsed.chunks()[0].cname);
79 } 95 }
80 96
åsapersson 2016/02/11 10:20:33 maybe add a test for zero chunks
danilchap 2016/02/11 11:13:37 Done.
97 TEST(RtcpPacketSdesTest, ParseSkipsNonCNameField) {
98 const char kName[] = "abc";
99 const std::string kCname = "de";
100 const uint8_t kValidPacket[] = {0x81, 202, 0x00, 0x04,
101 0x12, 0x34, 0x56, 0x78,
102 kNameTag, 3, kName[0], kName[1], kName[2],
103 kCnameTag, 2, kCname[0], kCname[1],
104 kTerminatorTag, kPadding, kPadding};
105 // Sanity checks packet was assembled correctly.
106 ASSERT_EQ(0u, sizeof(kValidPacket) % 4);
107 ASSERT_EQ(kValidPacket[3] + 1u, sizeof(kValidPacket) / 4);
108
109 Sdes parsed;
110 EXPECT_TRUE(Parse(kValidPacket, sizeof(kValidPacket), &parsed));
111
112 EXPECT_EQ(1u, parsed.chunks().size());
113 EXPECT_EQ(kSenderSsrc, parsed.chunks()[0].ssrc);
114 EXPECT_EQ(kCname, parsed.chunks()[0].cname);
115 }
116
117 TEST(RtcpPacketSdesTest, ParseFailsWithoutCName) {
118 const char kName[] = "ab";
119 const char kEmail[] = "de";
120 const uint8_t kInvalidPacket[] = {0x81, 202, 0x00, 0x04,
121 0x12, 0x34, 0x56, 0x78,
122 kNameTag, 3, kName[0], kName[1], kName[2],
123 kEmailTag, 2, kEmail[0], kEmail[1],
124 kTerminatorTag, kPadding, kPadding};
125 // Sanity checks packet was assembled correctly.
126 ASSERT_EQ(0u, sizeof(kInvalidPacket) % 4);
127 ASSERT_EQ(kInvalidPacket[3] + 1u, sizeof(kInvalidPacket) / 4);
128
129 Sdes parsed;
130 EXPECT_FALSE(Parse(kInvalidPacket, sizeof(kInvalidPacket), &parsed));
131 }
132
133 TEST(RtcpPacketSdesTest, ParseFailsWithoutChunkItemTerminator) {
134 const char kName[] = "abc";
135 const char kCname[] = "d";
136 // No place for next chunk item.
137 const uint8_t kInvalidPacket[] = {0x81, 202, 0x00, 0x03,
138 0x12, 0x34, 0x56, 0x78,
139 kNameTag, 3, kName[0], kName[1], kName[2],
140 kCnameTag, 1, kCname[0]};
141 // Sanity checks packet was assembled correctly.
142 ASSERT_EQ(0u, sizeof(kInvalidPacket) % 4);
143 ASSERT_EQ(kInvalidPacket[3] + 1u, sizeof(kInvalidPacket) / 4);
144
145 Sdes parsed;
146 EXPECT_FALSE(Parse(kInvalidPacket, sizeof(kInvalidPacket), &parsed));
147 }
148
149 TEST(RtcpPacketSdesTest, ParseFailsWithDamagedChunkItem) {
150 const char kName[] = "ab";
151 const char kCname[] = "d";
152 // Next chunk item has non-terminator type, but not the size.
153 const uint8_t kInvalidPacket[] = {0x81, 202, 0x00, 0x03,
154 0x12, 0x34, 0x56, 0x78,
155 kNameTag, 2, kName[0], kName[1],
156 kCnameTag, 1, kCname[0],
157 kEmailTag};
158 // Sanity checks packet was assembled correctly.
159 ASSERT_EQ(0u, sizeof(kInvalidPacket) % 4);
160 ASSERT_EQ(kInvalidPacket[3] + 1u, sizeof(kInvalidPacket) / 4);
161
162 Sdes parsed;
163 EXPECT_FALSE(Parse(kInvalidPacket, sizeof(kInvalidPacket), &parsed));
164 }
165
166 TEST(RtcpPacketSdesTest, ParseFailsWithTooLongChunkItem) {
167 const char kName[] = "abc";
168 const char kCname[] = "d";
169 // Last chunk item has length that goes beyond the buffer end.
170 const uint8_t kInvalidPacket[] = {0x81, 202, 0x00, 0x03,
171 0x12, 0x34, 0x56, 0x78,
172 kNameTag, 3, kName[0], kName[1], kName[2],
173 kCnameTag, 2, kCname[0]};
174 // Sanity checks packet was assembled correctly.
175 ASSERT_EQ(0u, sizeof(kInvalidPacket) % 4);
176 ASSERT_EQ(kInvalidPacket[3] + 1u, sizeof(kInvalidPacket) / 4);
177
178 Sdes parsed;
179 EXPECT_FALSE(Parse(kInvalidPacket, sizeof(kInvalidPacket), &parsed));
180 }
181
182 TEST(RtcpPacketSdesTest, ParseFailsWithTwoCNames) {
183 const char kCname1[] = "a";
184 const char kCname2[] = "de";
185 const uint8_t kInvalidPacket[] = {0x81, 202, 0x00, 0x03,
186 0x12, 0x34, 0x56, 0x78,
187 kCnameTag, 1, kCname1[0],
188 kCnameTag, 2, kCname2[0], kCname2[1],
189 kTerminatorTag};
190 // Sanity checks packet was assembled correctly.
191 ASSERT_EQ(0u, sizeof(kInvalidPacket) % 4);
192 ASSERT_EQ(kInvalidPacket[3] + 1u, sizeof(kInvalidPacket) / 4);
193
194 Sdes parsed;
195 EXPECT_FALSE(Parse(kInvalidPacket, sizeof(kInvalidPacket), &parsed));
196 }
197
198 TEST(RtcpPacketSdesTest, ParseFailsWithTooLittleSpaceForNextChunk) {
199 const char kCname[] = "a";
200 const char kEmail[] = "de";
201 // Two chunks are promised in the header, but no place for the second chunk.
202 const uint8_t kInvalidPacket[] = {0x82, 202, 0x00, 0x04,
203 0x12, 0x34, 0x56, 0x78, // 1st chunk.
204 kCnameTag, 1, kCname[0],
205 kEmailTag, 2, kEmail[0], kEmail[1],
206 kTerminatorTag,
207 0x23, 0x45, 0x67, 0x89}; // 2nd chunk.
208 // Sanity checks packet was assembled correctly.
209 ASSERT_EQ(0u, sizeof(kInvalidPacket) % 4);
210 ASSERT_EQ(kInvalidPacket[3] + 1u, sizeof(kInvalidPacket) / 4);
211
212 Sdes parsed;
213 EXPECT_FALSE(Parse(kInvalidPacket, sizeof(kInvalidPacket), &parsed));
214 }
215
216 TEST(RtcpPacketSdesTest, ParsedSdesCanBeReusedForBuilding) {
217 Sdes source;
218 const std::string kAlice = "alice@host";
219 const std::string kBob = "bob@host";
220 source.WithCName(kSenderSsrc, kAlice);
221
222 rtc::scoped_ptr<RawPacket> packet1 = source.Build();
223 Sdes middle;
224 Parse(packet1->Buffer(), packet1->Length(), &middle);
225
226 EXPECT_EQ(source.BlockLength(), middle.BlockLength());
227
228 middle.WithCName(kSenderSsrc + 1, kBob);
229
230 rtc::scoped_ptr<RawPacket> packet2 = middle.Build();
231 Sdes destination;
232 Parse(packet2->Buffer(), packet2->Length(), &destination);
233
234 EXPECT_EQ(middle.BlockLength(), destination.BlockLength());
235
236 EXPECT_EQ(2u, destination.chunks().size());
237 EXPECT_EQ(kSenderSsrc, destination.chunks()[0].ssrc);
238 EXPECT_EQ(kAlice, destination.chunks()[0].cname);
239 EXPECT_EQ(kSenderSsrc + 1, destination.chunks()[1].ssrc);
240 EXPECT_EQ(kBob, destination.chunks()[1].cname);
241 }
81 } // namespace webrtc 242 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698