| Index: webrtc/modules/video_coding/codecs/test/videoprocessor_integrationtest_openh264.cc
|
| diff --git a/webrtc/modules/video_coding/codecs/test/videoprocessor_integrationtest_openh264.cc b/webrtc/modules/video_coding/codecs/test/videoprocessor_integrationtest_openh264.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..41e42edee192668f064c7ee809361cf480b91685
|
| --- /dev/null
|
| +++ b/webrtc/modules/video_coding/codecs/test/videoprocessor_integrationtest_openh264.cc
|
| @@ -0,0 +1,69 @@
|
| +/*
|
| + * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license
|
| + * that can be found in the LICENSE file in the root of the source
|
| + * tree. An additional intellectual property rights grant can be found
|
| + * in the file PATENTS. All contributing project authors may
|
| + * be found in the AUTHORS file in the root of the source tree.
|
| + */
|
| +
|
| +#include "webrtc/modules/video_coding/codecs/test/videoprocessor_integrationtest.h"
|
| +
|
| +#include <vector>
|
| +
|
| +namespace webrtc {
|
| +namespace test {
|
| +
|
| +#if defined(WEBRTC_USE_H264)
|
| +
|
| +namespace {
|
| +
|
| +// Test settings.
|
| +// Only allow encoder/decoder to use single core, for predictability.
|
| +const bool kUseSingleCore = true;
|
| +const bool kVerboseLogging = false;
|
| +const bool kHwCodec = false;
|
| +
|
| +// Codec settings.
|
| +const bool kResilienceOn = true;
|
| +
|
| +// Default sequence is foreman (CIF): may be better to use VGA for resize test.
|
| +const int kCifWidth = 352;
|
| +const int kCifHeight = 288;
|
| +const char kForemanCif[] = "foreman_cif";
|
| +const int kNumFrames = 100;
|
| +
|
| +const std::nullptr_t kNoVisualizationParams = nullptr;
|
| +
|
| +} // namespace
|
| +
|
| +// H264: Run with no packet loss and fixed bitrate. Quality should be very high.
|
| +// Note(hbos): The PacketManipulatorImpl code used to simulate packet loss in
|
| +// these unittests appears to drop "packets" in a way that is not compatible
|
| +// with H264. Therefore ProcessXPercentPacketLossH264, X != 0, unittests have
|
| +// not been added.
|
| +TEST_F(VideoProcessorIntegrationTest, Process0PercentPacketLossH264) {
|
| + SetTestConfig(&config_, kHwCodec, kUseSingleCore, 0.0f, kForemanCif,
|
| + kVerboseLogging);
|
| + SetCodecSettings(&config_, kVideoCodecH264, 1, false, false, true, false,
|
| + kResilienceOn, kCifWidth, kCifHeight);
|
| +
|
| + RateProfile rate_profile;
|
| + SetRateProfile(&rate_profile, 0, 500, 30, 0);
|
| + rate_profile.frame_index_rate_update[1] = kNumFrames + 1;
|
| + rate_profile.num_frames = kNumFrames;
|
| +
|
| + std::vector<RateControlThresholds> rc_thresholds;
|
| + AddRateControlThresholds(2, 60, 20, 10, 20, 0, 1, &rc_thresholds);
|
| +
|
| + QualityThresholds quality_thresholds(35.0, 25.0, 0.93, 0.70);
|
| +
|
| + ProcessFramesAndMaybeVerify(rate_profile, &rc_thresholds, &quality_thresholds,
|
| + kNoVisualizationParams);
|
| +}
|
| +
|
| +#endif // defined(WEBRTC_USE_H264)
|
| +
|
| +} // namespace test
|
| +} // namespace webrtc
|
|
|