mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 13:50:40 +01:00
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:
parent
89aad9e168
commit
cd7da92012
4 changed files with 50 additions and 3 deletions
|
@ -635,6 +635,16 @@ if (rtc_include_tests) {
|
||||||
}
|
}
|
||||||
|
|
||||||
video_coding_modules_tests_resources = []
|
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)) {
|
if (!(is_ios || is_android)) {
|
||||||
video_coding_modules_tests_resources += [
|
video_coding_modules_tests_resources += [
|
||||||
"../../resources/FourPeople_1280x720_30.yuv",
|
"../../resources/FourPeople_1280x720_30.yuv",
|
||||||
|
|
|
@ -10,6 +10,8 @@
|
||||||
|
|
||||||
#include "modules/video_coding/codecs/test/videoprocessor_integrationtest.h"
|
#include "modules/video_coding/codecs/test/videoprocessor_integrationtest.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <tuple>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "common_types.h" // NOLINT(build/include)
|
#include "common_types.h" // NOLINT(build/include)
|
||||||
|
@ -22,6 +24,7 @@ namespace test {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
const int kForemanNumFrames = 300;
|
const int kForemanNumFrames = 300;
|
||||||
|
const int kForemanFramerateFps = 30;
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
class VideoProcessorIntegrationTestMediaCodec
|
class VideoProcessorIntegrationTestMediaCodec
|
||||||
|
@ -40,7 +43,8 @@ TEST_F(VideoProcessorIntegrationTestMediaCodec, ForemanCif500kbpsVp8) {
|
||||||
config_.SetCodecSettings(cricket::kVp8CodecName, 1, 1, 1, false, false, false,
|
config_.SetCodecSettings(cricket::kVp8CodecName, 1, 1, 1, false, false, false,
|
||||||
false, 352, 288);
|
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
|
// 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
|
// 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,
|
config_.SetCodecSettings(cricket::kH264CodecName, 1, 1, 1, false, false,
|
||||||
false, false, 352, 288);
|
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
|
// 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
|
// 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,
|
config_.SetCodecSettings(cricket::kH264CodecName, 1, 1, 1, false, false,
|
||||||
false, false, 352, 288);
|
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
|
// 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
|
// implementations pass. If this test fails on the bots, disable it and
|
||||||
|
@ -98,5 +104,34 @@ TEST_F(VideoProcessorIntegrationTestMediaCodec,
|
||||||
&quality_thresholds, nullptr, nullptr);
|
&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 test
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
|
1
resources/foreman_240x136.yuv.sha1
Normal file
1
resources/foreman_240x136.yuv.sha1
Normal file
|
@ -0,0 +1 @@
|
||||||
|
117c0301ed19d83f0e112ea3e831dd389db68570
|
1
resources/foreman_480x272.yuv.sha1
Normal file
1
resources/foreman_480x272.yuv.sha1
Normal file
|
@ -0,0 +1 @@
|
||||||
|
65717a7be6dc7ce5d88afedc73e46838aa0a3abc
|
Loading…
Reference in a new issue