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

Side by Side Diff: webrtc/modules/rtp_rtcp/source/rtcp_packet/dlrr_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
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 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 16 matching lines...) Expand all
27 } // namespace 27 } // namespace
28 28
29 TEST(RtcpPacketDlrrTest, Empty) { 29 TEST(RtcpPacketDlrrTest, Empty) {
30 Dlrr dlrr; 30 Dlrr dlrr;
31 31
32 EXPECT_EQ(0u, dlrr.BlockLength()); 32 EXPECT_EQ(0u, dlrr.BlockLength());
33 } 33 }
34 34
35 TEST(RtcpPacketDlrrTest, Create) { 35 TEST(RtcpPacketDlrrTest, Create) {
36 Dlrr dlrr; 36 Dlrr dlrr;
37 EXPECT_TRUE(dlrr.AddDlrrItem(kSsrc, kLastRR, kDelay)); 37 dlrr.AddDlrrItem(ReceiveTimeInfo(kSsrc, kLastRR, kDelay));
38 38
39 ASSERT_EQ(kBlockSizeBytes, dlrr.BlockLength()); 39 ASSERT_EQ(kBlockSizeBytes, dlrr.BlockLength());
40 uint8_t buffer[kBlockSizeBytes]; 40 uint8_t buffer[kBlockSizeBytes];
41 41
42 dlrr.Create(buffer); 42 dlrr.Create(buffer);
43 EXPECT_EQ(0, memcmp(buffer, kBlock, kBlockSizeBytes)); 43 EXPECT_EQ(0, memcmp(buffer, kBlock, kBlockSizeBytes));
44 } 44 }
45 45
46 TEST(RtcpPacketDlrrTest, Parse) { 46 TEST(RtcpPacketDlrrTest, Parse) {
47 Dlrr dlrr; 47 Dlrr dlrr;
(...skipping 14 matching lines...) Expand all
62 buffer[1] = 0; // Reserved. 62 buffer[1] = 0; // Reserved.
63 buffer[2] = 0; // Most significant size byte. 63 buffer[2] = 0; // Most significant size byte.
64 for (uint8_t size = 3; size < 6; ++size) { 64 for (uint8_t size = 3; size < 6; ++size) {
65 buffer[3] = size; 65 buffer[3] = size;
66 Dlrr dlrr; 66 Dlrr dlrr;
67 // Parse should be successful only when size is multiple of 3. 67 // Parse should be successful only when size is multiple of 3.
68 EXPECT_EQ(size % 3 == 0, dlrr.Parse(buffer, static_cast<uint16_t>(size))); 68 EXPECT_EQ(size % 3 == 0, dlrr.Parse(buffer, static_cast<uint16_t>(size)));
69 } 69 }
70 } 70 }
71 71
72 TEST(RtcpPacketDlrrTest, FailsOnTooManySubBlocks) { 72 TEST(RtcpPacketDlrrTest, CreateAndParseManySubBlocks) {
73 Dlrr dlrr;
74 for (size_t i = 1; i <= Dlrr::kMaxNumberOfDlrrItems; ++i) {
75 EXPECT_TRUE(dlrr.AddDlrrItem(kSsrc + i, kLastRR + i, kDelay + i));
76 }
77 EXPECT_FALSE(dlrr.AddDlrrItem(kSsrc, kLastRR, kDelay));
78 }
79
80 TEST(RtcpPacketDlrrTest, CreateAndParseMaxSubBlocks) {
81 const size_t kBufferSize = 0x1000; // More than enough. 73 const size_t kBufferSize = 0x1000; // More than enough.
74 const size_t kManyDlrrItems = 50;
82 uint8_t buffer[kBufferSize]; 75 uint8_t buffer[kBufferSize];
83 76
84 // Create. 77 // Create.
85 Dlrr dlrr; 78 Dlrr dlrr;
86 for (size_t i = 1; i <= Dlrr::kMaxNumberOfDlrrItems; ++i) { 79 for (size_t i = 1; i <= kManyDlrrItems; ++i)
87 EXPECT_TRUE(dlrr.AddDlrrItem(kSsrc + i, kLastRR + i, kDelay + i)); 80 dlrr.AddDlrrItem(ReceiveTimeInfo(kSsrc + i, kLastRR + i, kDelay + i));
88 }
89 size_t used_buffer_size = dlrr.BlockLength(); 81 size_t used_buffer_size = dlrr.BlockLength();
90 ASSERT_LE(used_buffer_size, kBufferSize); 82 ASSERT_LE(used_buffer_size, kBufferSize);
91 dlrr.Create(buffer); 83 dlrr.Create(buffer);
92 84
93 // Parse. 85 // Parse.
94 Dlrr parsed; 86 Dlrr parsed;
95 uint16_t block_length = ByteReader<uint16_t>::ReadBigEndian(&buffer[2]); 87 uint16_t block_length = ByteReader<uint16_t>::ReadBigEndian(&buffer[2]);
96 EXPECT_EQ(used_buffer_size, (block_length + 1) * 4u); 88 EXPECT_EQ(used_buffer_size, (block_length + 1) * 4u);
97 EXPECT_TRUE(parsed.Parse(buffer, block_length)); 89 EXPECT_TRUE(parsed.Parse(buffer, block_length));
98 EXPECT_TRUE(parsed.sub_blocks().size() == Dlrr::kMaxNumberOfDlrrItems); 90 EXPECT_EQ(kManyDlrrItems, parsed.sub_blocks().size());
99 } 91 }
100 } // namespace webrtc 92 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/rtp_rtcp/source/rtcp_packet/dlrr.cc ('k') | webrtc/modules/rtp_rtcp/source/rtcp_packet/extended_reports.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698