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

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

Issue 2466993003: H264SpsPpsTracker class which keep tracks of SPS/PPS. (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
OLDNEW
(Empty)
1 /*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11 #include "webrtc/modules/video_coding/h264_sps_pps_tracker.h"
12
13 #include <vector>
14
15 #include "webrtc/modules/video_coding/packet.h"
16 #include "webrtc/test/gtest.h"
17 #include "webrtc/common_video/h264/h264_common.h"
18
19 namespace webrtc {
20 namespace video_coding {
21
22 namespace {
23 // Using an std::initializer_list for easier appending to std::vector.
24 const std::initializer_list<uint8_t> start_code = {0, 0, 0, 1};
25 } // namespace
26
27 class TestH264SpsPpsTracker : public ::testing::Test {
28 public:
29 VCMPacket GetDefaultPacket() {
30 VCMPacket packet;
31 packet.codec = kVideoCodecH264;
32 packet.video_header.codecHeader.H264.nalus_length = 0;
33 packet.video_header.isFirstPacket = false;
34 packet.video_header.codecHeader.H264.packetization_type = kH264SingleNalu;
35
36 return packet;
37 }
38
39 void AddSps(VCMPacket* packet, int sps_id, std::vector<uint8_t>* data) {
40 NaluInfo info;
41 info.type = H264::NaluType::kSps;
42 info.sps_id = sps_id;
43 info.pps_id = -1;
44 info.offset = data->size();
45 info.size = 2;
46 data->push_back(H264::NaluType::kSps);
47 data->push_back(sps_id); // The sps data, just a single byte.
48
49 packet->video_header.codecHeader.H264
50 .nalus[packet->video_header.codecHeader.H264.nalus_length++] = info;
51 }
52
53 void AddPps(VCMPacket* packet,
54 int sps_id,
55 int pps_id,
56 std::vector<uint8_t>* data) {
57 NaluInfo info;
58 info.type = H264::NaluType::kPps;
59 info.sps_id = sps_id;
60 info.pps_id = pps_id;
61 info.offset = data->size();
62 info.size = 2;
63 data->push_back(H264::NaluType::kPps);
64 data->push_back(pps_id); // The pps data, just a single byte.
65
66 packet->video_header.codecHeader.H264
67 .nalus[packet->video_header.codecHeader.H264.nalus_length++] = info;
68 }
69
70 void AddIdr(VCMPacket* packet, int pps_id) {
71 NaluInfo info;
72 info.type = H264::NaluType::kIdr;
73 info.sps_id = -1;
74 info.pps_id = pps_id;
75
76 packet->video_header.codecHeader.H264
77 .nalus[packet->video_header.codecHeader.H264.nalus_length++] = info;
78 }
79
80 protected:
81 H264SpsPpsTracker tracker_;
82 };
83
84 TEST_F(TestH264SpsPpsTracker, NoNalus) {
85 uint8_t data[] = {1, 2, 3};
86 VCMPacket packet = GetDefaultPacket();
87 packet.dataPtr = data;
88 packet.sizeBytes = sizeof(data);
89
90 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet));
91 EXPECT_EQ(memcmp(packet.dataPtr, data, sizeof(data)), 0);
92 }
93
94 TEST_F(TestH264SpsPpsTracker, NoNalusFirstPacket) {
95 uint8_t data[] = {1, 2, 3};
96 VCMPacket packet = GetDefaultPacket();
97 packet.video_header.isFirstPacket = true;
98 packet.dataPtr = data;
99 packet.sizeBytes = sizeof(data);
100
101 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet));
102 std::vector<uint8_t> expected;
103 expected.insert(expected.end(), start_code);
104 expected.insert(expected.end(), {1, 2, 3});
105 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0);
106 }
107
108 TEST_F(TestH264SpsPpsTracker, IdrNoSpsPpsInserted) {
109 std::vector<uint8_t> data = {1, 2, 3};
110 VCMPacket packet = GetDefaultPacket();
111
112 AddIdr(&packet, 0);
113 packet.dataPtr = data.data();
114 packet.sizeBytes = data.size();
115
116 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet));
117 EXPECT_EQ(memcmp(packet.dataPtr, data.data(), data.size()), 0);
118 }
119
120 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoSpsPpsInserted) {
121 std::vector<uint8_t> data = {1, 2, 3};
122 VCMPacket packet = GetDefaultPacket();
123 packet.video_header.isFirstPacket = true;
124
125 AddIdr(&packet, 0);
126 packet.dataPtr = data.data();
127 packet.sizeBytes = data.size();
128
129 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet));
130 }
131
132 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoPpsInserted) {
133 std::vector<uint8_t> data = {1, 2, 3};
134 VCMPacket packet = GetDefaultPacket();
135 packet.video_header.isFirstPacket = true;
136
137 AddSps(&packet, 0, &data);
138 AddIdr(&packet, 0);
139 packet.dataPtr = data.data();
140 packet.sizeBytes = data.size();
141
142 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet));
143 }
144
145 TEST_F(TestH264SpsPpsTracker, IdrFirstPacketNoSpsInserted) {
146 std::vector<uint8_t> data = {1, 2, 3};
147 VCMPacket packet = GetDefaultPacket();
148 packet.video_header.isFirstPacket = true;
149
150 AddPps(&packet, 0, 0, &data);
151 AddIdr(&packet, 0);
152 packet.dataPtr = data.data();
153 packet.sizeBytes = data.size();
154
155 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&packet));
156 }
157
158 TEST_F(TestH264SpsPpsTracker, SpsPpsPacketThenIdrFirstPacket) {
159 std::vector<uint8_t> data;
160 VCMPacket sps_pps_packet = GetDefaultPacket();
161
162 // Insert SPS/PPS
163 AddSps(&sps_pps_packet, 0, &data);
164 AddPps(&sps_pps_packet, 0, 1, &data);
165 sps_pps_packet.dataPtr = data.data();
166 sps_pps_packet.sizeBytes = data.size();
167 EXPECT_FALSE(tracker_.CopyAndFixBitstream(&sps_pps_packet));
168 data.clear();
169
170 // Insert first packet of the IDR
171 VCMPacket idr_packet = GetDefaultPacket();
172 idr_packet.video_header.isFirstPacket = true;
173 AddIdr(&idr_packet, 1);
174 data.insert(data.end(), {1, 2, 3});
175 idr_packet.dataPtr = data.data();
176 idr_packet.sizeBytes = data.size();
177 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&idr_packet));
178
179 std::vector<uint8_t> expected;
180 expected.insert(expected.end(), start_code);
181 expected.insert(expected.end(), {H264::NaluType::kSps, 0});
182 expected.insert(expected.end(), start_code);
183 expected.insert(expected.end(), {H264::NaluType::kPps, 1});
184 expected.insert(expected.end(), start_code);
185 expected.insert(expected.end(), {1, 2, 3});
186 EXPECT_EQ(memcmp(idr_packet.dataPtr, expected.data(), expected.size()), 0);
187 }
188
189 TEST_F(TestH264SpsPpsTracker, SpsPpsIdrInStapA) {
190 std::vector<uint8_t> data;
191 VCMPacket packet = GetDefaultPacket();
192 packet.video_header.codecHeader.H264.packetization_type = kH264StapA;
193 packet.video_header.isFirstPacket = true; // Always true for StapA
194
195 data.insert(data.end(), {0}); // First byte is ignored
196 data.insert(data.end(), {0, 2}); // Length of segment
197 AddSps(&packet, 13, &data);
198 data.insert(data.end(), {0, 2}); // Length of segment
199 AddPps(&packet, 13, 27, &data);
200 data.insert(data.end(), {0, 5}); // Length of segment
201 AddIdr(&packet, 27);
202 data.insert(data.end(), {1, 2, 3, 2, 1});
203
204 packet.dataPtr = data.data();
205 packet.sizeBytes = data.size();
206 EXPECT_TRUE(tracker_.CopyAndFixBitstream(&packet));
207
208 std::vector<uint8_t> expected;
209 // The SPS/PPS is repeated because this packet both contains the SPS/PPS
210 // and it is the first packet of an IDR, which will cause the SPS/PPS to be
211 // prepended to the bitstream.
212 expected.insert(expected.end(), start_code);
213 expected.insert(expected.end(), {H264::NaluType::kSps, 13});
214 expected.insert(expected.end(), start_code);
215 expected.insert(expected.end(), {H264::NaluType::kPps, 27});
216 expected.insert(expected.end(), start_code);
217 expected.insert(expected.end(), {H264::NaluType::kSps, 13});
218 expected.insert(expected.end(), start_code);
219 expected.insert(expected.end(), {H264::NaluType::kPps, 27});
220 expected.insert(expected.end(), start_code);
221 expected.insert(expected.end(), {1, 2, 3, 2, 1});
222
223 EXPECT_EQ(memcmp(packet.dataPtr, expected.data(), expected.size()), 0);
224 }
225
226 } // namespace video_coding
227 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698