OLD | NEW |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |