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

Side by Side Diff: webrtc/modules/video_coding/h264_sps_pps_tracker_unittest.cc

Issue 2477343002: H264SpsPpsTracker now return PacketAction on CopyAndFixBitstream. (Closed)
Patch Set: Created 4 years, 1 month 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/video_coding/h264_sps_pps_tracker.cc ('k') | no next file » | 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) 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 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
80 H264SpsPpsTracker tracker_; 80 H264SpsPpsTracker tracker_;
81 }; 81 };
82 82
83 TEST_F(TestH264SpsPpsTracker, NoNalus) { 83 TEST_F(TestH264SpsPpsTracker, NoNalus) {
84 uint8_t data[] = {1, 2, 3}; 84 uint8_t data[] = {1, 2, 3};
85 VCMPacket packet = GetDefaultPacket(); 85 VCMPacket packet = GetDefaultPacket();
86 packet.video_header.codecHeader.H264.packetization_type = kH264FuA; 86 packet.video_header.codecHeader.H264.packetization_type = kH264FuA;
87 packet.dataPtr = data; 87 packet.dataPtr = data;
88 packet.sizeBytes = sizeof(data); 88 packet.sizeBytes = sizeof(data);
89 89
90 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet)); 90 EXPECT_EQ(H264SpsPpsTracker::kInsert, tracker_.CopyAndFixBitstream(&packet));
91 EXPECT_EQ(memcmp(packet.dataPtr, data, sizeof(data)), 0); 91 EXPECT_EQ(memcmp(packet.dataPtr, data, sizeof(data)), 0);
92 delete[] packet.dataPtr; 92 delete[] packet.dataPtr;
93 } 93 }
94 94
95 TEST_F(TestH264SpsPpsTracker, FuAFirstPacket) { 95 TEST_F(TestH264SpsPpsTracker, FuAFirstPacket) {
96 uint8_t data[] = {1, 2, 3}; 96 uint8_t data[] = {1, 2, 3};
97 VCMPacket packet = GetDefaultPacket(); 97 VCMPacket packet = GetDefaultPacket();
98 packet.video_header.codecHeader.H264.packetization_type = kH264FuA; 98 packet.video_header.codecHeader.H264.packetization_type = kH264FuA;
99 packet.video_header.isFirstPacket = true; 99 packet.video_header.isFirstPacket = true;
100 packet.dataPtr = data; 100 packet.dataPtr = data;
101 packet.sizeBytes = sizeof(data); 101 packet.sizeBytes = sizeof(data);
102 102
103 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet)); 103 EXPECT_EQ(H264SpsPpsTracker::kInsert, tracker_.CopyAndFixBitstream(&packet));
104 std::vector<uint8_t> expected; 104 std::vector<uint8_t> expected;
105 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 105 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
106 expected.insert(expected.end(), {1, 2, 3}); 106 expected.insert(expected.end(), {1, 2, 3});
107 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0); 107 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0);
108 delete[] packet.dataPtr; 108 delete[] packet.dataPtr;
109 } 109 }
110 110
111 TEST_F(TestH264SpsPpsTracker, StapAIncorrectSegmentLength) { 111 TEST_F(TestH264SpsPpsTracker, StapAIncorrectSegmentLength) {
112 uint8_t data[] = {0, 0, 2, 0}; 112 uint8_t data[] = {0, 0, 2, 0};
113 VCMPacket packet = GetDefaultPacket(); 113 VCMPacket packet = GetDefaultPacket();
114 packet.video_header.codecHeader.H264.packetization_type = kH264StapA; 114 packet.video_header.codecHeader.H264.packetization_type = kH264StapA;
115 packet.video_header.isFirstPacket = true; 115 packet.video_header.isFirstPacket = true;
116 packet.dataPtr = data; 116 packet.dataPtr = data;
117 packet.sizeBytes = sizeof(data); 117 packet.sizeBytes = sizeof(data);
118 118
119 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet)); 119 EXPECT_EQ(H264SpsPpsTracker::kDrop, tracker_.CopyAndFixBitstream(&packet));
120 } 120 }
121 121
122 TEST_F(TestH264SpsPpsTracker, NoNalusFirstPacket) { 122 TEST_F(TestH264SpsPpsTracker, NoNalusFirstPacket) {
123 uint8_t data[] = {1, 2, 3}; 123 uint8_t data[] = {1, 2, 3};
124 VCMPacket packet = GetDefaultPacket(); 124 VCMPacket packet = GetDefaultPacket();
125 packet.video_header.isFirstPacket = true; 125 packet.video_header.isFirstPacket = true;
126 packet.dataPtr = data; 126 packet.dataPtr = data;
127 packet.sizeBytes = sizeof(data); 127 packet.sizeBytes = sizeof(data);
128 128
129 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet)); 129 EXPECT_EQ(H264SpsPpsTracker::kInsert, tracker_.CopyAndFixBitstream(&packet));
130 std::vector<uint8_t> expected; 130 std::vector<uint8_t> expected;
131 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 131 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
132 expected.insert(expected.end(), {1, 2, 3}); 132 expected.insert(expected.end(), {1, 2, 3});
133 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0); 133 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0);
134 delete[] packet.dataPtr; 134 delete[] packet.dataPtr;
135 } 135 }
136 136
137 TEST_F(TestH264SpsPpsTracker, IdrNoSpsPpsInserted) { 137 TEST_F(TestH264SpsPpsTracker, IdrNoSpsPpsInserted) {
138 std::vector<uint8_t> data = {1, 2, 3}; 138 std::vector<uint8_t> data = {1, 2, 3};
139 VCMPacket packet = GetDefaultPacket(); 139 VCMPacket packet = GetDefaultPacket();
140 packet.video_header.codecHeader.H264.packetization_type = kH264FuA; 140 packet.video_header.codecHeader.H264.packetization_type = kH264FuA;
141 141
142 AddIdr(&packet, 0); 142 AddIdr(&packet, 0);
143 packet.dataPtr = data.data(); 143 packet.dataPtr = data.data();
144 packet.sizeBytes = data.size(); 144 packet.sizeBytes = data.size();
145 145
146 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet)); 146 EXPECT_EQ(H264SpsPpsTracker::kInsert, tracker_.CopyAndFixBitstream(&packet));
147 EXPECT_EQ(memcmp(packet.dataPtr, data.data(), data.size()), 0); 147 EXPECT_EQ(memcmp(packet.dataPtr, data.data(), data.size()), 0);
148 delete[] packet.dataPtr; 148 delete[] packet.dataPtr;
149 } 149 }
150 150
151 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoSpsPpsInserted) { 151 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoSpsPpsInserted) {
152 std::vector<uint8_t> data = {1, 2, 3}; 152 std::vector<uint8_t> data = {1, 2, 3};
153 VCMPacket packet = GetDefaultPacket(); 153 VCMPacket packet = GetDefaultPacket();
154 packet.video_header.isFirstPacket = true; 154 packet.video_header.isFirstPacket = true;
155 155
156 AddIdr(&packet, 0); 156 AddIdr(&packet, 0);
157 packet.dataPtr = data.data(); 157 packet.dataPtr = data.data();
158 packet.sizeBytes = data.size(); 158 packet.sizeBytes = data.size();
159 159
160 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet)); 160 EXPECT_EQ(H264SpsPpsTracker::kRequestKeyframe,
161 tracker_.CopyAndFixBitstream(&packet));
161 } 162 }
162 163
163 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoPpsInserted) { 164 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoPpsInserted) {
164 std::vector<uint8_t> data = {1, 2, 3}; 165 std::vector<uint8_t> data = {1, 2, 3};
165 VCMPacket packet = GetDefaultPacket(); 166 VCMPacket packet = GetDefaultPacket();
166 packet.video_header.isFirstPacket = true; 167 packet.video_header.isFirstPacket = true;
167 168
168 AddSps(&packet, 0, &data); 169 AddSps(&packet, 0, &data);
169 AddIdr(&packet, 0); 170 AddIdr(&packet, 0);
170 packet.dataPtr = data.data(); 171 packet.dataPtr = data.data();
171 packet.sizeBytes = data.size(); 172 packet.sizeBytes = data.size();
172 173
173 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet)); 174 EXPECT_EQ(H264SpsPpsTracker::kRequestKeyframe,
175 tracker_.CopyAndFixBitstream(&packet));
174 } 176 }
175 177
176 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoSpsInserted) { 178 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoSpsInserted) {
177 std::vector<uint8_t> data = {1, 2, 3}; 179 std::vector<uint8_t> data = {1, 2, 3};
178 VCMPacket packet = GetDefaultPacket(); 180 VCMPacket packet = GetDefaultPacket();
179 packet.video_header.isFirstPacket = true; 181 packet.video_header.isFirstPacket = true;
180 182
181 AddPps(&packet, 0, 0, &data); 183 AddPps(&packet, 0, 0, &data);
182 AddIdr(&packet, 0); 184 AddIdr(&packet, 0);
183 packet.dataPtr = data.data(); 185 packet.dataPtr = data.data();
184 packet.sizeBytes = data.size(); 186 packet.sizeBytes = data.size();
185 187
186 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet)); 188 EXPECT_EQ(H264SpsPpsTracker::kRequestKeyframe,
189 tracker_.CopyAndFixBitstream(&packet));
187 } 190 }
188 191
189 TEST_F(TestH264SpsPpsTracker, SpsPpsPacketThenIdrFirstPacket) { 192 TEST_F(TestH264SpsPpsTracker, SpsPpsPacketThenIdrFirstPacket) {
190 std::vector<uint8_t> data; 193 std::vector<uint8_t> data;
191 VCMPacket sps_pps_packet = GetDefaultPacket(); 194 VCMPacket sps_pps_packet = GetDefaultPacket();
192 195
193 // Insert SPS/PPS 196 // Insert SPS/PPS
194 AddSps(&sps_pps_packet, 0, &data); 197 AddSps(&sps_pps_packet, 0, &data);
195 AddPps(&sps_pps_packet, 0, 1, &data); 198 AddPps(&sps_pps_packet, 0, 1, &data);
196 sps_pps_packet.dataPtr = data.data(); 199 sps_pps_packet.dataPtr = data.data();
197 sps_pps_packet.sizeBytes = data.size(); 200 sps_pps_packet.sizeBytes = data.size();
198 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&sps_pps_packet)); 201 EXPECT_EQ(H264SpsPpsTracker::kDrop,
202 tracker_.CopyAndFixBitstream(&sps_pps_packet));
199 data.clear(); 203 data.clear();
200 204
201 // Insert first packet of the IDR 205 // Insert first packet of the IDR
202 VCMPacket idr_packet = GetDefaultPacket(); 206 VCMPacket idr_packet = GetDefaultPacket();
203 idr_packet.video_header.isFirstPacket = true; 207 idr_packet.video_header.isFirstPacket = true;
204 AddIdr(&idr_packet, 1); 208 AddIdr(&idr_packet, 1);
205 data.insert(data.end(), {1, 2, 3}); 209 data.insert(data.end(), {1, 2, 3});
206 idr_packet.dataPtr = data.data(); 210 idr_packet.dataPtr = data.data();
207 idr_packet.sizeBytes = data.size(); 211 idr_packet.sizeBytes = data.size();
208 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&idr_packet)); 212 EXPECT_EQ(H264SpsPpsTracker::kInsert,
213 tracker_.CopyAndFixBitstream(&idr_packet));
209 214
210 std::vector<uint8_t> expected; 215 std::vector<uint8_t> expected;
211 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 216 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
212 expected.insert(expected.end(), {H264::NaluType::kSps, 0}); 217 expected.insert(expected.end(), {H264::NaluType::kSps, 0});
213 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 218 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
214 expected.insert(expected.end(), {H264::NaluType::kPps, 1}); 219 expected.insert(expected.end(), {H264::NaluType::kPps, 1});
215 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 220 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
216 expected.insert(expected.end(), {1, 2, 3}); 221 expected.insert(expected.end(), {1, 2, 3});
217 EXPECT_EQ(memcmp(idr_packet.dataPtr, expected.data(), expected.size()), 0); 222 EXPECT_EQ(memcmp(idr_packet.dataPtr, expected.data(), expected.size()), 0);
218 delete[] idr_packet.dataPtr; 223 delete[] idr_packet.dataPtr;
219 } 224 }
220 225
221 TEST_F(TestH264SpsPpsTracker, SpsPpsIdrInStapA) { 226 TEST_F(TestH264SpsPpsTracker, SpsPpsIdrInStapA) {
222 std::vector<uint8_t> data; 227 std::vector<uint8_t> data;
223 VCMPacket packet = GetDefaultPacket(); 228 VCMPacket packet = GetDefaultPacket();
224 packet.video_header.codecHeader.H264.packetization_type = kH264StapA; 229 packet.video_header.codecHeader.H264.packetization_type = kH264StapA;
225 packet.video_header.isFirstPacket = true; // Always true for StapA 230 packet.video_header.isFirstPacket = true; // Always true for StapA
226 231
227 data.insert(data.end(), {0}); // First byte is ignored 232 data.insert(data.end(), {0}); // First byte is ignored
228 data.insert(data.end(), {0, 2}); // Length of segment 233 data.insert(data.end(), {0, 2}); // Length of segment
229 AddSps(&packet, 13, &data); 234 AddSps(&packet, 13, &data);
230 data.insert(data.end(), {0, 2}); // Length of segment 235 data.insert(data.end(), {0, 2}); // Length of segment
231 AddPps(&packet, 13, 27, &data); 236 AddPps(&packet, 13, 27, &data);
232 data.insert(data.end(), {0, 5}); // Length of segment 237 data.insert(data.end(), {0, 5}); // Length of segment
233 AddIdr(&packet, 27); 238 AddIdr(&packet, 27);
234 data.insert(data.end(), {1, 2, 3, 2, 1}); 239 data.insert(data.end(), {1, 2, 3, 2, 1});
235 240
236 packet.dataPtr = data.data(); 241 packet.dataPtr = data.data();
237 packet.sizeBytes = data.size(); 242 packet.sizeBytes = data.size();
238 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet)); 243 EXPECT_EQ(H264SpsPpsTracker::kInsert, tracker_.CopyAndFixBitstream(&packet));
239 244
240 std::vector<uint8_t> expected; 245 std::vector<uint8_t> expected;
241 // The SPS/PPS is repeated because this packet both contains the SPS/PPS 246 // The SPS/PPS is repeated because this packet both contains the SPS/PPS
242 // and it is the first packet of an IDR, which will cause the SPS/PPS to be 247 // and it is the first packet of an IDR, which will cause the SPS/PPS to be
243 // prepended to the bitstream. 248 // prepended to the bitstream.
244 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 249 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
245 expected.insert(expected.end(), {H264::NaluType::kSps, 13}); 250 expected.insert(expected.end(), {H264::NaluType::kSps, 13});
246 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 251 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
247 expected.insert(expected.end(), {H264::NaluType::kPps, 27}); 252 expected.insert(expected.end(), {H264::NaluType::kPps, 27});
248 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 253 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
249 expected.insert(expected.end(), {H264::NaluType::kSps, 13}); 254 expected.insert(expected.end(), {H264::NaluType::kSps, 13});
250 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 255 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
251 expected.insert(expected.end(), {H264::NaluType::kPps, 27}); 256 expected.insert(expected.end(), {H264::NaluType::kPps, 27});
252 expected.insert(expected.end(), start_code, start_code + sizeof(start_code)); 257 expected.insert(expected.end(), start_code, start_code + sizeof(start_code));
253 expected.insert(expected.end(), {1, 2, 3, 2, 1}); 258 expected.insert(expected.end(), {1, 2, 3, 2, 1});
254 259
255 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0); 260 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0);
256 delete[] packet.dataPtr; 261 delete[] packet.dataPtr;
257 } 262 }
258 263
259 } // namespace video_coding 264 } // namespace video_coding
260 } // namespace webrtc 265 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/video_coding/h264_sps_pps_tracker.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698