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}
diff --git a/modules/video_coding/BUILD.gn b/modules/video_coding/BUILD.gn
index b2fd91d..555a3b4 100644
--- a/modules/video_coding/BUILD.gn
+++ b/modules/video_coding/BUILD.gn
@@ -635,6 +635,16 @@
   }
 
   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",
diff --git a/modules/video_coding/codecs/test/videoprocessor_integrationtest_mediacodec.cc b/modules/video_coding/codecs/test/videoprocessor_integrationtest_mediacodec.cc
index 938b451..8b758ae 100644
--- a/modules/video_coding/codecs/test/videoprocessor_integrationtest_mediacodec.cc
+++ b/modules/video_coding/codecs/test/videoprocessor_integrationtest_mediacodec.cc
@@ -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 {
 const int kForemanNumFrames = 300;
+const int kForemanFramerateFps = 30;
 }  // namespace
 
 class VideoProcessorIntegrationTestMediaCodec
@@ -40,7 +43,8 @@
   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 @@
   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 @@
   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 @@
                               &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
diff --git a/resources/foreman_240x136.yuv.sha1 b/resources/foreman_240x136.yuv.sha1
new file mode 100644
index 0000000..bc162e1
--- /dev/null
+++ b/resources/foreman_240x136.yuv.sha1
@@ -0,0 +1 @@
+117c0301ed19d83f0e112ea3e831dd389db68570
\ No newline at end of file
diff --git a/resources/foreman_480x272.yuv.sha1 b/resources/foreman_480x272.yuv.sha1
new file mode 100644
index 0000000..a5fded8
--- /dev/null
+++ b/resources/foreman_480x272.yuv.sha1
@@ -0,0 +1 @@
+65717a7be6dc7ce5d88afedc73e46838aa0a3abc
\ No newline at end of file