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

Unified Diff: chrome/browser/android/shortcut_helper_unittest.cc

Issue 880203004: Break out manifest icon logic from ShortcutHelper (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Changing unittest Created 5 years, 11 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
« no previous file with comments | « chrome/browser/android/shortcut_helper.cc ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/android/shortcut_helper_unittest.cc
diff --git a/chrome/browser/android/shortcut_helper_unittest.cc b/chrome/browser/android/shortcut_helper_unittest.cc
deleted file mode 100644
index 76e1a5e239c2f9eed0cb9f3ca01fa1c19f8a4ab2..0000000000000000000000000000000000000000
--- a/chrome/browser/android/shortcut_helper_unittest.cc
+++ /dev/null
@@ -1,494 +0,0 @@
-// Copyright 2014 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 "chrome/browser/android/shortcut_helper.h"
-
-#include "base/strings/utf_string_conversions.h"
-#include "chrome/test/base/chrome_render_view_host_test_harness.h"
-#include "content/public/browser/web_contents.h"
-#include "ui/gfx/screen.h"
-#include "ui/gfx/screen_type_delegate.h"
-
-// A dummy implementation of gfx::Screen, since ShortcutHelper needs access to
-// a gfx::Display's device scale factor.
-// This is inspired by web_contents_video_capture_device_unittest.cc
-// A bug has been opened to merge all those mocks: http://crbug.com/417227
-class FakeScreen : public gfx::Screen {
- public:
- FakeScreen() : display_(0x1337, gfx::Rect(0, 0, 2560, 1440)) {
- }
- virtual ~FakeScreen() {}
-
- void SetDisplayDeviceScaleFactor(float device_scale_factor) {
- display_.set_device_scale_factor(device_scale_factor);
- }
-
- // gfx::Screen implementation (only what's needed for testing).
- virtual gfx::Point GetCursorScreenPoint() override { return gfx::Point(); }
- virtual gfx::NativeWindow GetWindowUnderCursor() override { return NULL; }
- virtual gfx::NativeWindow GetWindowAtScreenPoint(
- const gfx::Point& point) override { return NULL; }
- virtual int GetNumDisplays() const override { return 1; }
- virtual std::vector<gfx::Display> GetAllDisplays() const override {
- return std::vector<gfx::Display>(1, display_);
- }
- virtual gfx::Display GetDisplayNearestWindow(
- gfx::NativeView view) const override {
- return display_;
- }
- virtual gfx::Display GetDisplayNearestPoint(
- const gfx::Point& point) const override {
- return display_;
- }
- virtual gfx::Display GetDisplayMatching(
- const gfx::Rect& match_rect) const override {
- return display_;
- }
- virtual gfx::Display GetPrimaryDisplay() const override {
- return display_;
- }
- virtual void AddObserver(gfx::DisplayObserver* observer) override {}
- virtual void RemoveObserver(gfx::DisplayObserver* observer) override {}
-
- private:
- gfx::Display display_;
-
- DISALLOW_COPY_AND_ASSIGN(FakeScreen);
-};
-
-class ShortcutHelperTest : public ChromeRenderViewHostTestHarness {
- protected:
- ShortcutHelperTest() : shortcut_helper_(NULL) {}
- virtual ~ShortcutHelperTest() {}
-
- static jobject CreateShortcutHelperJava(JNIEnv* env) {
- jclass clazz = env->FindClass("org/chromium/chrome/browser/ShortcutHelper");
- jmethodID constructor =
- env->GetMethodID(clazz, "<init>",
- "(Landroid/content/Context;"
- "Lorg/chromium/chrome/browser/Tab;)V");
- return env->NewObject(clazz, constructor, jobject(), jobject());
- }
-
- void ResetShorcutHelper() {
- if (shortcut_helper_)
- delete shortcut_helper_;
-
- JNIEnv* env = base::android::AttachCurrentThread();
- shortcut_helper_ =
- new ShortcutHelper(env, CreateShortcutHelperJava(env), web_contents());
- }
-
- virtual void SetUp() override {
- gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, &fake_screen_);
- ASSERT_EQ(&fake_screen_, gfx::Screen::GetNativeScreen());
-
- ChromeRenderViewHostTestHarness::SetUp();
-
- ResetShorcutHelper();
- }
-
- virtual void TearDown() override {
- delete shortcut_helper_;
- shortcut_helper_ = NULL;
-
- ChromeRenderViewHostTestHarness::TearDown();
-
- gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, NULL);
- }
-
- GURL FindBestMatchingIcon(const std::vector<content::Manifest::Icon>& icons) {
- return shortcut_helper_->FindBestMatchingIcon(icons);
- }
-
- void SetDisplayDeviceScaleFactor(float device_scale_factor) {
- fake_screen_.SetDisplayDeviceScaleFactor(device_scale_factor);
-
- ResetShorcutHelper();
- }
-
- static int GetPreferredIconSizeInDp() {
- return ShortcutHelper::kPreferredIconSizeInDp;
- }
-
- static content::Manifest::Icon CreateIcon(
- const std::string& url,
- const std::string& type,
- double density,
- const std::vector<gfx::Size> sizes) {
- content::Manifest::Icon icon;
- icon.src = GURL(url);
- if (!type.empty())
- icon.type = base::NullableString16(base::UTF8ToUTF16(type), false);
- icon.density = density;
- icon.sizes = sizes;
-
- return icon;
- }
-
- private:
- ShortcutHelper* shortcut_helper_;
- FakeScreen fake_screen_;
-
- DISALLOW_COPY_AND_ASSIGN(ShortcutHelperTest);
-};
-
-TEST_F(ShortcutHelperTest, NoIcons) {
- // No icons should return the empty URL.
- std::vector<content::Manifest::Icon> icons;
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_TRUE(url.is_empty());
-}
-
-TEST_F(ShortcutHelperTest, NoSizes) {
- // Icon with no sizes are ignored.
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(
- CreateIcon("http://foo.com/icon.png", "", 1.0, std::vector<gfx::Size>()));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_TRUE(url.is_empty());
-}
-
-TEST_F(ShortcutHelperTest, MIMETypeFiltering) {
- // Icons with type specified to a MIME type that isn't a valid image MIME type
- // are ignored.
- std::vector<gfx::Size> sizes;
- sizes.push_back(gfx::Size(10, 10));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(
- CreateIcon("http://foo.com/icon.png", "image/foo_bar", 1.0, sizes));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "image/", 1.0, sizes));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "image/", 1.0, sizes));
- icons.push_back(
- CreateIcon("http://foo.com/icon.png", "video/mp4", 1.0, sizes));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_TRUE(url.is_empty());
-
- icons.clear();
- icons.push_back(
- CreateIcon("http://foo.com/icon.png", "image/png", 1.0, sizes));
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
-
- icons.clear();
- icons.push_back(
- CreateIcon("http://foo.com/icon.png", "image/gif", 1.0, sizes));
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
-
- icons.clear();
- icons.push_back(
- CreateIcon("http://foo.com/icon.png", "image/jpeg", 1.0, sizes));
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
-}
-
-TEST_F(ShortcutHelperTest, PreferredSizeOfCurrentDensityIsUsedFirst) {
- // This test has three icons each are marked with sizes set to the preferred
- // icon size for the associated density.
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(GetPreferredIconSizeInDp(),
- GetPreferredIconSizeInDp()));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(GetPreferredIconSizeInDp() * 2,
- GetPreferredIconSizeInDp() * 2));
-
- std::vector<gfx::Size> sizes_3;
- sizes_3.push_back(gfx::Size(GetPreferredIconSizeInDp() * 3,
- GetPreferredIconSizeInDp() * 3));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_x1.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon_x2.png", "", 2.0, sizes_2));
- icons.push_back(CreateIcon("http://foo.com/icon_x3.png", "", 3.0, sizes_3));
-
- SetDisplayDeviceScaleFactor(1.0f);
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x1.png", url.spec());
-
- SetDisplayDeviceScaleFactor(2.0f);
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x2.png", url.spec());
-
- SetDisplayDeviceScaleFactor(3.0f);
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x3.png", url.spec());
-}
-
-TEST_F(ShortcutHelperTest, PreferredSizeOfDefaultDensityIsUsedSecond) {
- // This test has three icons. The first one is of density zero and is marked
- // with three sizes which are the preferred icon size for density 1, 2 and 3.
- // The icon for density 2 and 3 have a size set to 2x2 and 3x3.
- // Regardless of the device scale factor, the icon of density 1 is going to be
- // used because it matches the preferred size.
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(GetPreferredIconSizeInDp(),
- GetPreferredIconSizeInDp()));
- sizes_1.push_back(gfx::Size(GetPreferredIconSizeInDp() * 2,
- GetPreferredIconSizeInDp() * 2));
- sizes_1.push_back(gfx::Size(GetPreferredIconSizeInDp() * 3,
- GetPreferredIconSizeInDp() * 3));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(2, 2));
-
- std::vector<gfx::Size> sizes_3;
- sizes_3.push_back(gfx::Size(3, 3));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_x1.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon_x2.png", "", 2.0, sizes_2));
- icons.push_back(CreateIcon("http://foo.com/icon_x3.png", "", 3.0, sizes_3));
-
- SetDisplayDeviceScaleFactor(1.0f);
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x1.png", url.spec());
-
- SetDisplayDeviceScaleFactor(2.0f);
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x1.png", url.spec());
-
- SetDisplayDeviceScaleFactor(3.0f);
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x1.png", url.spec());
-}
-
-TEST_F(ShortcutHelperTest, DeviceDensityFirst) {
- // If there is no perfect icon but an icon of the current device density is
- // present, it will be picked.
- // This test has three icons each are marked with sizes set to the preferred
- // icon size for the associated density.
- std::vector<gfx::Size> sizes;
- sizes.push_back(gfx::Size(2, 2));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_x1.png", "", 1.0, sizes));
- icons.push_back(CreateIcon("http://foo.com/icon_x2.png", "", 2.0, sizes));
- icons.push_back(CreateIcon("http://foo.com/icon_x3.png", "", 3.0, sizes));
-
- SetDisplayDeviceScaleFactor(1.0f);
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x1.png", url.spec());
-
- SetDisplayDeviceScaleFactor(2.0f);
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x2.png", url.spec());
-
- SetDisplayDeviceScaleFactor(3.0f);
- url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x3.png", url.spec());
-}
-
-TEST_F(ShortcutHelperTest, DeviceDensityFallback) {
- // If there is no perfect icon but and no icon of the current display density,
- // an icon of density 1.0 will be used.
- std::vector<gfx::Size> sizes;
- sizes.push_back(gfx::Size(2, 2));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_x1.png", "", 1.0, sizes));
- icons.push_back(CreateIcon("http://foo.com/icon_x2.png", "", 2.0, sizes));
-
- SetDisplayDeviceScaleFactor(3.0f);
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon_x1.png", url.spec());
-}
-
-TEST_F(ShortcutHelperTest, DoNotUseOtherDensities) {
- // If there are only icons of densities that are not the current display
- // density or the default density, they are ignored.
- std::vector<gfx::Size> sizes;
- sizes.push_back(gfx::Size(2, 2));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_x2.png", "", 2.0, sizes));
-
- SetDisplayDeviceScaleFactor(3.0f);
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_TRUE(url.is_empty());
-}
-
-TEST_F(ShortcutHelperTest, NotSquareIconsAreIgnored) {
- std::vector<gfx::Size> sizes;
- sizes.push_back(gfx::Size(20, 2));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_TRUE(url.is_empty());
-}
-
-TEST_F(ShortcutHelperTest, ClosestIconToPreferred) {
- // This test verifies ShortcutHelper::FindBestMatchingIcon by passing
- // different icon sizes and checking which one is picked.
- // The Device Scale Factor is 1.0 and the preferred icon size is returned by
- // GetPreferredIconSizeInDp().
- int very_small = GetPreferredIconSizeInDp() / 4;
- int small = GetPreferredIconSizeInDp() / 2;
- int bit_small = GetPreferredIconSizeInDp() - 1;
- int bit_big = GetPreferredIconSizeInDp() + 1;
- int big = GetPreferredIconSizeInDp() * 2;
- int very_big = GetPreferredIconSizeInDp() * 4;
-
- // (very_small, bit_small) => bit_small
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(very_small, very_small));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(bit_small, bit_small));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_2));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // (very_small, bit_small, smaller) => bit_small
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(very_small, very_small));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(bit_small, bit_small));
-
- std::vector<gfx::Size> sizes_3;
- sizes_3.push_back(gfx::Size(small, small));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_2));
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_3));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // (very_big, big) => big
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(very_big, very_big));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(big, big));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_2));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // (very_big, big, bit_big) => bit_big
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(very_big, very_big));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(big, big));
-
- std::vector<gfx::Size> sizes_3;
- sizes_3.push_back(gfx::Size(bit_big, bit_big));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_2));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_3));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // (bit_small, very_big) => very_big
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(bit_small, bit_small));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(very_big, very_big));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_2));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // (bit_small, bit_big) => bit_big
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(bit_small, bit_small));
-
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(bit_big, bit_big));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_2));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-}
-
-TEST_F(ShortcutHelperTest, UseAnyIfNoPreferredSize) {
- // 'any' (ie. gfx::Size(0,0)) should be used if there is no icon of a
- // preferred size. An icon with the current device scale factor is preferred
- // over one with the default density.
-
- // 'any' with preferred size => preferred size
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(GetPreferredIconSizeInDp(),
- GetPreferredIconSizeInDp()));
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(0,0));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_2));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // 'any' with nearly preferred size => any
- {
- std::vector<gfx::Size> sizes_1;
- sizes_1.push_back(gfx::Size(GetPreferredIconSizeInDp() + 1,
- GetPreferredIconSizeInDp() + 1));
- std::vector<gfx::Size> sizes_2;
- sizes_2.push_back(gfx::Size(0,0));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes_1));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 1.0, sizes_2));
-
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-
- // 'any' on default density and current density => current density.
- {
- std::vector<gfx::Size> sizes;
- sizes.push_back(gfx::Size(0,0));
-
- std::vector<content::Manifest::Icon> icons;
- icons.push_back(CreateIcon("http://foo.com/icon_no.png", "", 1.0, sizes));
- icons.push_back(CreateIcon("http://foo.com/icon.png", "", 3.0, sizes));
-
- SetDisplayDeviceScaleFactor(3.0f);
- GURL url = FindBestMatchingIcon(icons);
- EXPECT_EQ("http://foo.com/icon.png", url.spec());
- }
-}
« no previous file with comments | « chrome/browser/android/shortcut_helper.cc ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698