mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-14 14:20:45 +01:00

BUG=webrtc:8448 Change-Id: I968d6cd78dd4f3c19a7944ae4cc73c5eddb9a949 Reviewed-on: https://webrtc-review.googlesource.com/16160 Commit-Queue: Rasmus Brandt <brandtr@webrtc.org> Reviewed-by: Sergey Silkin <ssilkin@webrtc.org> Cr-Commit-Position: refs/heads/master@{#20466}
100 lines
3.5 KiB
C++
100 lines
3.5 KiB
C++
/*
|
|
* 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 "modules/video_coding/codecs/test/videoprocessor_integrationtest.h"
|
|
|
|
#include <vector>
|
|
|
|
#include "test/testsupport/fileutils.h"
|
|
|
|
namespace webrtc {
|
|
namespace test {
|
|
|
|
#if defined(WEBRTC_USE_H264)
|
|
|
|
namespace {
|
|
|
|
// Codec settings.
|
|
const bool kResilienceOn = true;
|
|
const int kCifWidth = 352;
|
|
const int kCifHeight = 288;
|
|
const int kNumFrames = 100;
|
|
|
|
const std::nullptr_t kNoVisualizationParams = nullptr;
|
|
|
|
} // namespace
|
|
|
|
class VideoProcessorIntegrationTestOpenH264
|
|
: public VideoProcessorIntegrationTest {
|
|
protected:
|
|
VideoProcessorIntegrationTestOpenH264() {
|
|
config_.filename = "foreman_cif";
|
|
config_.input_filename = ResourcePath(config_.filename, "yuv");
|
|
config_.output_filename =
|
|
TempFilename(OutputPath(), "videoprocessor_integrationtest_libvpx");
|
|
config_.num_frames = kNumFrames;
|
|
config_.networking_config.packet_loss_probability = 0.0;
|
|
// Only allow encoder/decoder to use single core, for predictability.
|
|
config_.use_single_core = true;
|
|
config_.hw_encoder = false;
|
|
config_.hw_decoder = false;
|
|
config_.encoded_frame_checker = &h264_keyframe_checker_;
|
|
}
|
|
};
|
|
|
|
// 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(VideoProcessorIntegrationTestOpenH264, Process0PercentPacketLoss) {
|
|
config_.SetCodecSettings(kVideoCodecH264, 1, false, false, true, false,
|
|
kResilienceOn, kCifWidth, kCifHeight);
|
|
|
|
std::vector<RateProfile> rate_profiles = {{500, 30, kNumFrames + 1}};
|
|
|
|
std::vector<RateControlThresholds> rc_thresholds = {
|
|
{2, 60, 20, 10, 20, 0, 1}};
|
|
|
|
QualityThresholds quality_thresholds(35.0, 25.0, 0.93, 0.70);
|
|
|
|
ProcessFramesAndMaybeVerify(rate_profiles, &rc_thresholds,
|
|
&quality_thresholds, nullptr,
|
|
kNoVisualizationParams);
|
|
}
|
|
|
|
// H264: Enable SingleNalUnit packetization mode. Encoder should split
|
|
// large frames into multiple slices and limit length of NAL units.
|
|
TEST_F(VideoProcessorIntegrationTestOpenH264, ProcessNoLossSingleNalUnit) {
|
|
config_.h264_codec_settings.packetization_mode =
|
|
H264PacketizationMode::SingleNalUnit;
|
|
config_.networking_config.max_payload_size_in_bytes = 500;
|
|
config_.SetCodecSettings(kVideoCodecH264, 1, false, false, true, false,
|
|
kResilienceOn, kCifWidth, kCifHeight);
|
|
|
|
std::vector<RateProfile> rate_profiles = {{500, 30, kNumFrames + 1}};
|
|
|
|
std::vector<RateControlThresholds> rc_thresholds = {
|
|
{2, 60, 30, 10, 20, 0, 1}};
|
|
|
|
QualityThresholds quality_thresholds(35.0, 25.0, 0.93, 0.70);
|
|
|
|
BitstreamThresholds bs_thresholds(
|
|
config_.networking_config.max_payload_size_in_bytes);
|
|
|
|
ProcessFramesAndMaybeVerify(rate_profiles, &rc_thresholds,
|
|
&quality_thresholds, &bs_thresholds,
|
|
kNoVisualizationParams);
|
|
}
|
|
|
|
#endif // defined(WEBRTC_USE_H264)
|
|
|
|
} // namespace test
|
|
} // namespace webrtc
|