Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2009)

Unified Diff: media/capture/content/capture_resolution_chooser_unittest.cc

Issue 2143903003: [WIP] Move media/capture to device/capture (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: media/capture/content/capture_resolution_chooser_unittest.cc
diff --git a/media/capture/content/capture_resolution_chooser_unittest.cc b/media/capture/content/capture_resolution_chooser_unittest.cc
deleted file mode 100644
index a0346b1020c8f86e03089762683bac3b7afa30ea..0000000000000000000000000000000000000000
--- a/media/capture/content/capture_resolution_chooser_unittest.cc
+++ /dev/null
@@ -1,353 +0,0 @@
-// Copyright 2015 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "media/capture/content/capture_resolution_chooser.h"
-
-#include <stddef.h>
-
-#include "base/location.h"
-#include "base/macros.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-using tracked_objects::Location;
-
-namespace media {
-
-namespace {
-
-// 16:9 maximum and minimum frame sizes.
-const int kMaxFrameWidth = 3840;
-const int kMaxFrameHeight = 2160;
-const int kMinFrameWidth = 320;
-const int kMinFrameHeight = 180;
-
-// Checks whether |size| is strictly between (inclusive) |min_size| and
-// |max_size| and has the same aspect ratio as |max_size|.
-void ExpectIsWithinBoundsAndSameAspectRatio(const Location& location,
- const gfx::Size& min_size,
- const gfx::Size& max_size,
- const gfx::Size& size) {
- SCOPED_TRACE(::testing::Message() << "From here: " << location.ToString());
- EXPECT_LE(min_size.width(), size.width());
- EXPECT_LE(min_size.height(), size.height());
- EXPECT_GE(max_size.width(), size.width());
- EXPECT_GE(max_size.height(), size.height());
- EXPECT_NEAR(static_cast<double>(max_size.width()) / max_size.height(),
- static_cast<double>(size.width()) / size.height(), 0.01);
-}
-
-// Test that the correct snapped frame sizes are computed for a |chooser|
-// configured with either of the variable-resolution change policies, and are
-// correctly found when searched.
-void TestSnappedFrameSizes(CaptureResolutionChooser* chooser,
- const gfx::Size& smallest_size) {
- const int kSizes[17][2] = {
- {kMaxFrameWidth, kMaxFrameHeight},
- {3520, 1980},
- {3200, 1800},
- {2880, 1620},
- {2560, 1440},
- {2240, 1260},
- {1920, 1080},
- {1760, 990},
- {1600, 900},
- {1440, 810},
- {1280, 720},
- {1120, 630},
- {960, 540},
- {800, 450},
- {640, 360},
- {480, 270},
- {320, 180},
- };
-
- const gfx::Size largest_size(kMaxFrameWidth, kMaxFrameHeight);
- chooser->SetSourceSize(largest_size);
-
- // There should be no size larger than the largest size.
- for (int i = 1; i < 4; ++i) {
- EXPECT_EQ(largest_size,
- chooser->FindLargerFrameSize(largest_size.GetArea(), i));
- EXPECT_EQ(largest_size,
- chooser->FindLargerFrameSize(largest_size.GetArea() * 2, +i));
- }
-
- // There should be no size smaller than the smallest size.
- for (int i = 1; i < 4; ++i) {
- EXPECT_EQ(smallest_size,
- chooser->FindSmallerFrameSize(smallest_size.GetArea(), i));
- EXPECT_EQ(smallest_size,
- chooser->FindSmallerFrameSize(smallest_size.GetArea() / 2, i));
- }
-
- // Test the "find Nth lower size" logic.
- for (size_t skips = 1; skips < 4; ++skips) {
- for (size_t i = skips; i < arraysize(kSizes); ++i) {
- EXPECT_EQ(
- gfx::Size(kSizes[i][0], kSizes[i][1]),
- chooser->FindSmallerFrameSize(
- gfx::Size(kSizes[i - skips][0], kSizes[i - skips][1]).GetArea(),
- skips));
- }
- }
-
- // Test the "find Nth higher size" logic.
- for (size_t skips = 1; skips < 4; ++skips) {
- for (size_t i = skips; i < arraysize(kSizes); ++i) {
- EXPECT_EQ(gfx::Size(kSizes[i - skips][0], kSizes[i - skips][1]),
- chooser->FindLargerFrameSize(
- gfx::Size(kSizes[i][0], kSizes[i][1]).GetArea(), skips));
- }
- }
-
- // Test the "find nearest size" logic.
- for (size_t i = 1; i < arraysize(kSizes) - 1; ++i) {
- const gfx::Size size(kSizes[i][0], kSizes[i][1]);
- const int a_somewhat_smaller_area =
- gfx::Size((kSizes[i - 1][0] + 3 * kSizes[i][0]) / 4,
- (kSizes[i - 1][1] + 3 * kSizes[i][1]) / 4).GetArea();
- EXPECT_EQ(size, chooser->FindNearestFrameSize(a_somewhat_smaller_area));
-
- const int a_smidge_smaller_area = size.GetArea() - 1;
- EXPECT_EQ(size, chooser->FindNearestFrameSize(a_smidge_smaller_area));
-
- const int a_smidge_larger_area = size.GetArea() + 1;
- EXPECT_EQ(size, chooser->FindNearestFrameSize(a_smidge_larger_area));
-
- const int a_somewhat_larger_area =
- gfx::Size((kSizes[i + 1][0] + 3 * kSizes[i][0]) / 4,
- (kSizes[i + 1][1] + 3 * kSizes[i][1]) / 4).GetArea();
- EXPECT_EQ(size, chooser->FindNearestFrameSize(a_somewhat_larger_area));
- }
-}
-
-// Test that setting the target frame area results in the correct capture sizes
-// being computed for a |chooser| configured with either of the
-// variable-resolution change policies.
-void TestTargetedFrameAreas(CaptureResolutionChooser* chooser,
- const gfx::Size& smallest_size) {
- chooser->SetSourceSize(gfx::Size(1280, 720));
-
- // The computed capture size cannot be larger than the source size, even
- // though the |chooser| is configured with a larger max frame size.
- chooser->SetTargetFrameArea(kMaxFrameWidth * kMaxFrameHeight);
- EXPECT_EQ(gfx::Size(1280, 720), chooser->capture_size());
-
- chooser->SetTargetFrameArea(1280 * 720 + 1);
- EXPECT_EQ(gfx::Size(1280, 720), chooser->capture_size());
- chooser->SetTargetFrameArea(1280 * 720 - 1);
- EXPECT_EQ(gfx::Size(1280, 720), chooser->capture_size());
-
- chooser->SetTargetFrameArea(1120 * 630 + 1);
- EXPECT_EQ(gfx::Size(1120, 630), chooser->capture_size());
- chooser->SetTargetFrameArea(1120 * 630 - 1);
- EXPECT_EQ(gfx::Size(1120, 630), chooser->capture_size());
-
- chooser->SetTargetFrameArea(800 * 450 + 1);
- EXPECT_EQ(gfx::Size(800, 450), chooser->capture_size());
- chooser->SetTargetFrameArea(800 * 450 - 1);
- EXPECT_EQ(gfx::Size(800, 450), chooser->capture_size());
-
- chooser->SetTargetFrameArea(640 * 360 + 1);
- EXPECT_EQ(gfx::Size(640, 360), chooser->capture_size());
- chooser->SetTargetFrameArea(640 * 360 - 1);
- EXPECT_EQ(gfx::Size(640, 360), chooser->capture_size());
-
- chooser->SetTargetFrameArea(smallest_size.GetArea() + 1);
- EXPECT_EQ(smallest_size, chooser->capture_size());
- chooser->SetTargetFrameArea(smallest_size.GetArea() - 1);
- EXPECT_EQ(smallest_size, chooser->capture_size());
-
- chooser->SetTargetFrameArea(smallest_size.GetArea() / 2);
- EXPECT_EQ(smallest_size, chooser->capture_size());
-
- chooser->SetTargetFrameArea(0);
- EXPECT_EQ(smallest_size, chooser->capture_size());
-
- // If the source size has increased, the |chooser| is now permitted to compute
- // higher capture sizes.
- chooser->SetSourceSize(gfx::Size(kMaxFrameWidth, kMaxFrameHeight));
- chooser->SetTargetFrameArea(kMaxFrameWidth * kMaxFrameHeight);
- EXPECT_EQ(gfx::Size(kMaxFrameWidth, kMaxFrameHeight),
- chooser->capture_size());
-
- chooser->SetTargetFrameArea(3200 * 1800 + 1);
- EXPECT_EQ(gfx::Size(3200, 1800), chooser->capture_size());
- chooser->SetTargetFrameArea(3200 * 1800 - 1);
- EXPECT_EQ(gfx::Size(3200, 1800), chooser->capture_size());
-
- chooser->SetTargetFrameArea(640 * 360 + 1);
- EXPECT_EQ(gfx::Size(640, 360), chooser->capture_size());
- chooser->SetTargetFrameArea(640 * 360 - 1);
- EXPECT_EQ(gfx::Size(640, 360), chooser->capture_size());
-
- chooser->SetTargetFrameArea(0);
- EXPECT_EQ(smallest_size, chooser->capture_size());
-}
-
-} // namespace
-
-TEST(CaptureResolutionChooserTest,
- FixedResolutionPolicy_CaptureSizeAlwaysFixed) {
- const gfx::Size the_one_frame_size(kMaxFrameWidth, kMaxFrameHeight);
- CaptureResolutionChooser chooser(the_one_frame_size,
- RESOLUTION_POLICY_FIXED_RESOLUTION);
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
-
- chooser.SetSourceSize(the_one_frame_size);
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth + 424, kMaxFrameHeight - 101));
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth - 202, kMaxFrameHeight + 56));
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMinFrameWidth, kMinFrameHeight));
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
-
- // Ensure that there is only one snapped frame size.
- chooser.SetSourceSize(the_one_frame_size);
- for (int i = 1; i < 4; ++i) {
- EXPECT_EQ(the_one_frame_size,
- chooser.FindNearestFrameSize(the_one_frame_size.GetArea() * i));
- EXPECT_EQ(the_one_frame_size,
- chooser.FindSmallerFrameSize(the_one_frame_size.GetArea(), i));
- EXPECT_EQ(the_one_frame_size,
- chooser.FindLargerFrameSize(the_one_frame_size.GetArea(), i));
- }
-
- // Ensure that changing the target frame area does not change the computed
- // frame size.
- chooser.SetTargetFrameArea(0);
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
- chooser.SetTargetFrameArea(the_one_frame_size.GetArea() / 2);
- EXPECT_EQ(the_one_frame_size, chooser.capture_size());
-}
-
-TEST(CaptureResolutionChooserTest,
- FixedAspectRatioPolicy_CaptureSizeHasSameAspectRatio) {
- CaptureResolutionChooser chooser(gfx::Size(kMaxFrameWidth, kMaxFrameHeight),
- RESOLUTION_POLICY_FIXED_ASPECT_RATIO);
-
- // Starting condition.
- const gfx::Size min_size(kMinFrameWidth, kMinFrameHeight);
- const gfx::Size max_size(kMaxFrameWidth, kMaxFrameHeight);
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- // Max size in --> max size out.
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth, kMaxFrameHeight));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- // Various source sizes within bounds.
- chooser.SetSourceSize(gfx::Size(640, 480));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(480, 640));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(640, 640));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- // Bad source size results in no update.
- const gfx::Size unchanged_size = chooser.capture_size();
- chooser.SetSourceSize(gfx::Size(0, 0));
- EXPECT_EQ(unchanged_size, chooser.capture_size());
-
- // Downscaling size (preserving aspect ratio) when source size exceeds the
- // upper bounds.
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth * 2, kMaxFrameHeight * 2));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth * 2, kMaxFrameHeight));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth, kMaxFrameHeight * 2));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- // Upscaling size (preserving aspect ratio) when source size is under the
- // lower bounds.
- chooser.SetSourceSize(gfx::Size(kMinFrameWidth / 2, kMinFrameHeight / 2));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMinFrameWidth / 2, kMaxFrameHeight));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMinFrameWidth, kMinFrameHeight / 2));
- ExpectIsWithinBoundsAndSameAspectRatio(FROM_HERE, min_size, max_size,
- chooser.capture_size());
-
- // For a chooser configured with the "fixed aspect ratio" policy, the smallest
- // possible computed size is the one with 180 lines of resolution and the same
- // aspect ratio.
- const gfx::Size smallest_size(180 * kMaxFrameWidth / kMaxFrameHeight, 180);
-
- TestSnappedFrameSizes(&chooser, smallest_size);
- TestTargetedFrameAreas(&chooser, smallest_size);
-}
-
-TEST(CaptureResolutionChooserTest,
- AnyWithinLimitPolicy_CaptureSizeIsAnythingWithinLimits) {
- const gfx::Size max_size(kMaxFrameWidth, kMaxFrameHeight);
- CaptureResolutionChooser chooser(max_size,
- RESOLUTION_POLICY_ANY_WITHIN_LIMIT);
-
- // Starting condition.
- EXPECT_EQ(max_size, chooser.capture_size());
-
- // Max size in --> max size out.
- chooser.SetSourceSize(max_size);
- EXPECT_EQ(max_size, chooser.capture_size());
-
- // Various source sizes within bounds.
- chooser.SetSourceSize(gfx::Size(640, 480));
- EXPECT_EQ(gfx::Size(640, 480), chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(480, 640));
- EXPECT_EQ(gfx::Size(480, 640), chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(640, 640));
- EXPECT_EQ(gfx::Size(640, 640), chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(2, 2));
- EXPECT_EQ(gfx::Size(2, 2), chooser.capture_size());
-
- // Bad source size results in no update.
- const gfx::Size unchanged_size = chooser.capture_size();
- chooser.SetSourceSize(gfx::Size(0, 0));
- EXPECT_EQ(unchanged_size, chooser.capture_size());
-
- // Downscaling size (preserving aspect ratio) when source size exceeds the
- // upper bounds.
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth * 2, kMaxFrameHeight * 2));
- EXPECT_EQ(max_size, chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth * 2, kMaxFrameHeight));
- EXPECT_EQ(gfx::Size(kMaxFrameWidth, kMaxFrameHeight / 2),
- chooser.capture_size());
-
- chooser.SetSourceSize(gfx::Size(kMaxFrameWidth, kMaxFrameHeight * 2));
- EXPECT_EQ(gfx::Size(kMaxFrameWidth / 2, kMaxFrameHeight),
- chooser.capture_size());
-
- // For a chooser configured with the "any within limit" policy, the smallest
- // possible computed size is smallest non-empty snapped size (which is 90
- // lines of resolution) with the same aspect ratio as the maximum size.
- const gfx::Size smallest_size(90 * kMaxFrameWidth / kMaxFrameHeight, 90);
-
- TestSnappedFrameSizes(&chooser, smallest_size);
- TestTargetedFrameAreas(&chooser, smallest_size);
-}
-
-} // namespace media
« no previous file with comments | « media/capture/content/capture_resolution_chooser.cc ('k') | media/capture/content/feedback_signal_accumulator.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698