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

Side by Side Diff: webrtc/modules/video_coding/codecs/vp8/test/vp8_impl_unittest.cc

Issue 2372483002: Reland of Move MutableDataY{,U,V} methods to I420Buffer only. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: 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) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 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 129 matching lines...) Expand 10 before | Expand all | Expand 10 after
140 codec_inst_.height = kHeight; 140 codec_inst_.height = kHeight;
141 const int kFramerate = 30; 141 const int kFramerate = 30;
142 codec_inst_.maxFramerate = kFramerate; 142 codec_inst_.maxFramerate = kFramerate;
143 // Setting aligned stride values. 143 // Setting aligned stride values.
144 int stride_uv; 144 int stride_uv;
145 int stride_y; 145 int stride_y;
146 Calc16ByteAlignedStride(codec_inst_.width, &stride_y, &stride_uv); 146 Calc16ByteAlignedStride(codec_inst_.width, &stride_y, &stride_uv);
147 EXPECT_EQ(stride_y, 176); 147 EXPECT_EQ(stride_y, 176);
148 EXPECT_EQ(stride_uv, 96); 148 EXPECT_EQ(stride_uv, 96);
149 149
150 input_frame_.CreateEmptyFrame(codec_inst_.width, codec_inst_.height, 150 rtc::scoped_refptr<I420Buffer> buffer = I420Buffer::Create(
151 stride_y, stride_uv, stride_uv); 151 codec_inst_.width, codec_inst_.height, stride_y, stride_uv, stride_uv);
152 input_frame_.set_timestamp(kTestTimestamp);
153 // Using ConvertToI420 to add stride to the image. 152 // Using ConvertToI420 to add stride to the image.
154 EXPECT_EQ(0, ConvertToI420(kI420, source_buffer_.get(), 0, 0, 153 EXPECT_EQ(
155 codec_inst_.width, codec_inst_.height, 0, 154 0, ConvertToI420(kI420, source_buffer_.get(), 0, 0, codec_inst_.width,
156 kVideoRotation_0, &input_frame_)); 155 codec_inst_.height, 0, kVideoRotation_0,
156 buffer.get()));
157 input_frame_.reset(
158 new VideoFrame(buffer, kTestTimestamp, 0, webrtc::kVideoRotation_0));
157 } 159 }
158 160
159 void SetUpEncodeDecode() { 161 void SetUpEncodeDecode() {
160 codec_inst_.startBitrate = 300; 162 codec_inst_.startBitrate = 300;
161 codec_inst_.maxBitrate = 4000; 163 codec_inst_.maxBitrate = 4000;
162 codec_inst_.qpMax = 56; 164 codec_inst_.qpMax = 56;
163 codec_inst_.codecSpecific.VP8.denoisingOn = true; 165 codec_inst_.codecSpecific.VP8.denoisingOn = true;
164 166
165 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK, 167 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK,
166 encoder_->InitEncode(&codec_inst_, 1, 1440)); 168 encoder_->InitEncode(&codec_inst_, 1, 1440));
(...skipping 21 matching lines...) Expand all
188 return 0; 190 return 0;
189 } 191 }
190 192
191 const int kWidth = 172; 193 const int kWidth = 172;
192 const int kHeight = 144; 194 const int kHeight = 144;
193 195
194 std::unique_ptr<Vp8UnitTestEncodeCompleteCallback> encode_complete_callback_; 196 std::unique_ptr<Vp8UnitTestEncodeCompleteCallback> encode_complete_callback_;
195 std::unique_ptr<Vp8UnitTestDecodeCompleteCallback> decode_complete_callback_; 197 std::unique_ptr<Vp8UnitTestDecodeCompleteCallback> decode_complete_callback_;
196 std::unique_ptr<uint8_t[]> source_buffer_; 198 std::unique_ptr<uint8_t[]> source_buffer_;
197 FILE* source_file_; 199 FILE* source_file_;
198 VideoFrame input_frame_; 200 std::unique_ptr<VideoFrame> input_frame_;
199 std::unique_ptr<VideoEncoder> encoder_; 201 std::unique_ptr<VideoEncoder> encoder_;
200 std::unique_ptr<VideoDecoder> decoder_; 202 std::unique_ptr<VideoDecoder> decoder_;
201 EncodedImage encoded_frame_; 203 EncodedImage encoded_frame_;
202 VideoFrame decoded_frame_; 204 VideoFrame decoded_frame_;
203 size_t length_source_frame_; 205 size_t length_source_frame_;
204 VideoCodec codec_inst_; 206 VideoCodec codec_inst_;
205 }; 207 };
206 208
207 TEST_F(TestVp8Impl, EncoderParameterTest) { 209 TEST_F(TestVp8Impl, EncoderParameterTest) {
208 strncpy(codec_inst_.plName, "VP8", 31); 210 strncpy(codec_inst_.plName, "VP8", 31);
(...skipping 21 matching lines...) Expand all
230 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK, decoder_->InitDecode(&codec_inst_, 1)); 232 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK, decoder_->InitDecode(&codec_inst_, 1));
231 } 233 }
232 234
233 #if defined(WEBRTC_ANDROID) 235 #if defined(WEBRTC_ANDROID)
234 #define MAYBE_AlignedStrideEncodeDecode DISABLED_AlignedStrideEncodeDecode 236 #define MAYBE_AlignedStrideEncodeDecode DISABLED_AlignedStrideEncodeDecode
235 #else 237 #else
236 #define MAYBE_AlignedStrideEncodeDecode AlignedStrideEncodeDecode 238 #define MAYBE_AlignedStrideEncodeDecode AlignedStrideEncodeDecode
237 #endif 239 #endif
238 TEST_F(TestVp8Impl, MAYBE_AlignedStrideEncodeDecode) { 240 TEST_F(TestVp8Impl, MAYBE_AlignedStrideEncodeDecode) {
239 SetUpEncodeDecode(); 241 SetUpEncodeDecode();
240 encoder_->Encode(input_frame_, NULL, NULL); 242 encoder_->Encode(*input_frame_, NULL, NULL);
241 EXPECT_GT(WaitForEncodedFrame(), 0u); 243 EXPECT_GT(WaitForEncodedFrame(), 0u);
242 // First frame should be a key frame. 244 // First frame should be a key frame.
243 encoded_frame_._frameType = kVideoFrameKey; 245 encoded_frame_._frameType = kVideoFrameKey;
244 encoded_frame_.ntp_time_ms_ = kTestNtpTimeMs; 246 encoded_frame_.ntp_time_ms_ = kTestNtpTimeMs;
245 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK, 247 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK,
246 decoder_->Decode(encoded_frame_, false, NULL)); 248 decoder_->Decode(encoded_frame_, false, NULL));
247 EXPECT_GT(WaitForDecodedFrame(), 0u); 249 EXPECT_GT(WaitForDecodedFrame(), 0u);
248 // Compute PSNR on all planes (faster than SSIM). 250 // Compute PSNR on all planes (faster than SSIM).
249 EXPECT_GT(I420PSNR(&input_frame_, &decoded_frame_), 36); 251 EXPECT_GT(I420PSNR(input_frame_.get(), &decoded_frame_), 36);
250 EXPECT_EQ(kTestTimestamp, decoded_frame_.timestamp()); 252 EXPECT_EQ(kTestTimestamp, decoded_frame_.timestamp());
251 EXPECT_EQ(kTestNtpTimeMs, decoded_frame_.ntp_time_ms()); 253 EXPECT_EQ(kTestNtpTimeMs, decoded_frame_.ntp_time_ms());
252 } 254 }
253 255
254 #if defined(WEBRTC_ANDROID) 256 #if defined(WEBRTC_ANDROID)
255 #define MAYBE_DecodeWithACompleteKeyFrame DISABLED_DecodeWithACompleteKeyFrame 257 #define MAYBE_DecodeWithACompleteKeyFrame DISABLED_DecodeWithACompleteKeyFrame
256 #else 258 #else
257 #define MAYBE_DecodeWithACompleteKeyFrame DecodeWithACompleteKeyFrame 259 #define MAYBE_DecodeWithACompleteKeyFrame DecodeWithACompleteKeyFrame
258 #endif 260 #endif
259 TEST_F(TestVp8Impl, MAYBE_DecodeWithACompleteKeyFrame) { 261 TEST_F(TestVp8Impl, MAYBE_DecodeWithACompleteKeyFrame) {
260 SetUpEncodeDecode(); 262 SetUpEncodeDecode();
261 encoder_->Encode(input_frame_, NULL, NULL); 263 encoder_->Encode(*input_frame_, NULL, NULL);
262 EXPECT_GT(WaitForEncodedFrame(), 0u); 264 EXPECT_GT(WaitForEncodedFrame(), 0u);
263 // Setting complete to false -> should return an error. 265 // Setting complete to false -> should return an error.
264 encoded_frame_._completeFrame = false; 266 encoded_frame_._completeFrame = false;
265 EXPECT_EQ(WEBRTC_VIDEO_CODEC_ERROR, 267 EXPECT_EQ(WEBRTC_VIDEO_CODEC_ERROR,
266 decoder_->Decode(encoded_frame_, false, NULL)); 268 decoder_->Decode(encoded_frame_, false, NULL));
267 // Setting complete back to true. Forcing a delta frame. 269 // Setting complete back to true. Forcing a delta frame.
268 encoded_frame_._frameType = kVideoFrameDelta; 270 encoded_frame_._frameType = kVideoFrameDelta;
269 encoded_frame_._completeFrame = true; 271 encoded_frame_._completeFrame = true;
270 EXPECT_EQ(WEBRTC_VIDEO_CODEC_ERROR, 272 EXPECT_EQ(WEBRTC_VIDEO_CODEC_ERROR,
271 decoder_->Decode(encoded_frame_, false, NULL)); 273 decoder_->Decode(encoded_frame_, false, NULL));
272 // Now setting a key frame. 274 // Now setting a key frame.
273 encoded_frame_._frameType = kVideoFrameKey; 275 encoded_frame_._frameType = kVideoFrameKey;
274 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK, 276 EXPECT_EQ(WEBRTC_VIDEO_CODEC_OK,
275 decoder_->Decode(encoded_frame_, false, NULL)); 277 decoder_->Decode(encoded_frame_, false, NULL));
276 EXPECT_GT(I420PSNR(&input_frame_, &decoded_frame_), 36); 278 EXPECT_GT(I420PSNR(input_frame_.get(), &decoded_frame_), 36);
277 } 279 }
278 280
279 } // namespace webrtc 281 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/video_coding/codecs/vp8/simulcast_unittest.h ('k') | webrtc/modules/video_coding/codecs/vp8/vp8_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698