Add MediaCodec VP tests for uncommon resolutions.

Bug: None
Change-Id: Ibfc35af3635c3b3a50027c4cd828f78e7a438dcd
Reviewed-on: https://webrtc-review.googlesource.com/72342
Commit-Queue: Rasmus Brandt <brandtr@webrtc.org>
Reviewed-by: Åsa Persson <asapersson@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#23020}
This commit is contained in:
Rasmus Brandt 2018-04-25 12:45:16 +02:00 committed by Commit Bot
parent 89aad9e168
commit cd7da92012
4 changed files with 50 additions and 3 deletions

View file

@ -635,6 +635,16 @@ if (rtc_include_tests) {
}
video_coding_modules_tests_resources = []
if (is_android) {
video_coding_modules_tests_resources += [
"../../resources/foreman_128x96.yuv",
"../../resources/foreman_160x120.yuv",
"../../resources/foreman_176x144.yuv",
"../../resources/foreman_240x136.yuv",
"../../resources/foreman_320x240.yuv",
"../../resources/foreman_480x272.yuv",
]
}
if (!(is_ios || is_android)) {
video_coding_modules_tests_resources += [
"../../resources/FourPeople_1280x720_30.yuv",

View file

@ -10,6 +10,8 @@
#include "modules/video_coding/codecs/test/videoprocessor_integrationtest.h"
#include <string>
#include <tuple>
#include <vector>
#include "common_types.h" // NOLINT(build/include)
@ -22,6 +24,7 @@ namespace test {
namespace {
const int kForemanNumFrames = 300;
const int kForemanFramerateFps = 30;
} // namespace
class VideoProcessorIntegrationTestMediaCodec
@ -40,7 +43,8 @@ TEST_F(VideoProcessorIntegrationTestMediaCodec, ForemanCif500kbpsVp8) {
config_.SetCodecSettings(cricket::kVp8CodecName, 1, 1, 1, false, false, false,
false, 352, 288);
std::vector<RateProfile> rate_profiles = {{500, 30, kForemanNumFrames}};
std::vector<RateProfile> rate_profiles = {
{500, kForemanFramerateFps, kForemanNumFrames}};
// The thresholds below may have to be tweaked to let even poor MediaCodec
// implementations pass. If this test fails on the bots, disable it and
@ -59,7 +63,8 @@ TEST_F(VideoProcessorIntegrationTestMediaCodec, ForemanCif500kbpsH264CBP) {
config_.SetCodecSettings(cricket::kH264CodecName, 1, 1, 1, false, false,
false, false, 352, 288);
std::vector<RateProfile> rate_profiles = {{500, 30, kForemanNumFrames}};
std::vector<RateProfile> rate_profiles = {
{500, kForemanFramerateFps, kForemanNumFrames}};
// The thresholds below may have to be tweaked to let even poor MediaCodec
// implementations pass. If this test fails on the bots, disable it and
@ -84,7 +89,8 @@ TEST_F(VideoProcessorIntegrationTestMediaCodec,
config_.SetCodecSettings(cricket::kH264CodecName, 1, 1, 1, false, false,
false, false, 352, 288);
std::vector<RateProfile> rate_profiles = {{500, 30, kForemanNumFrames}};
std::vector<RateProfile> rate_profiles = {
{500, kForemanFramerateFps, kForemanNumFrames}};
// The thresholds below may have to be tweaked to let even poor MediaCodec
// implementations pass. If this test fails on the bots, disable it and
@ -98,5 +104,34 @@ TEST_F(VideoProcessorIntegrationTestMediaCodec,
&quality_thresholds, nullptr, nullptr);
}
TEST_F(VideoProcessorIntegrationTestMediaCodec, ForemanMixedRes100kbpsVp8H264) {
const int kNumFrames = 30;
// TODO(brandtr): Add H.264 when we have fixed the encoder.
const std::vector<std::string> codecs = {cricket::kVp8CodecName};
const std::vector<std::tuple<int, int>> resolutions = {
{128, 96}, {160, 120}, {176, 144}, {240, 136}, {320, 240}, {480, 272}};
const std::vector<RateProfile> rate_profiles = {
{100, kForemanFramerateFps, kNumFrames}};
const std::vector<QualityThresholds> quality_thresholds = {
{29, 26, 0.8, 0.75}};
for (const auto& codec : codecs) {
for (const auto& resolution : resolutions) {
const int width = std::get<0>(resolution);
const int height = std::get<1>(resolution);
config_.filename = std::string("foreman_") + std::to_string(width) + "x" +
std::to_string(height);
config_.filepath = ResourcePath(config_.filename, "yuv");
config_.num_frames = kNumFrames;
config_.SetCodecSettings(codec, 1, 1, 1, false, false, false, false,
width, height);
ProcessFramesAndMaybeVerify(
rate_profiles, nullptr /* rc_thresholds */, &quality_thresholds,
nullptr /* bs_thresholds */, nullptr /* visualization_params */);
}
}
}
} // namespace test
} // namespace webrtc

View file

@ -0,0 +1 @@
117c0301ed19d83f0e112ea3e831dd389db68570

View file

@ -0,0 +1 @@
65717a7be6dc7ce5d88afedc73e46838aa0a3abc