Index: chrome/browser/window_sizer_unittest.cc |
=================================================================== |
--- chrome/browser/window_sizer_unittest.cc (revision 68008) |
+++ chrome/browser/window_sizer_unittest.cc (working copy) |
@@ -1,1002 +0,0 @@ |
-// Copyright (c) 2006-2008 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 <vector> |
- |
-#include "chrome/browser/window_sizer.h" |
-#include "base/logging.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
- |
-// Some standard monitor sizes (no task bar). |
-static const gfx::Rect tentwentyfour(0, 0, 1024, 768); |
-static const gfx::Rect twelveeighty(0, 0, 1280, 1024); |
-static const gfx::Rect sixteenhundred(0, 0, 1600, 1200); |
-static const gfx::Rect sixteeneighty(0, 0, 1680, 1050); |
-static const gfx::Rect nineteentwenty(0, 0, 1920, 1200); |
- |
-// Represents a 1024x768 monitor that is not the primary monitor, arranged to |
-// the immediate left of the primary 1024x768 monitor. |
-static const gfx::Rect left_nonprimary(-1024, 0, 1024, 768); |
- |
-// Represents a 1024x768 monitor that is not the primary monitor, arranged to |
-// the immediate right of the primary 1024x768 monitor. |
-static const gfx::Rect right_nonprimary(1024, 0, 1024, 768); |
- |
-// Represents a 1024x768 monitor that is not the primary monitor, arranged to |
-// the immediate top of the primary 1024x768 monitor. |
-static const gfx::Rect top_nonprimary(0, -768, 1024, 768); |
- |
-// Represents a 1024x768 monitor that is not the primary monitor, arranged to |
-// the immediate bottom of the primary 1024x768 monitor. |
-static const gfx::Rect bottom_nonprimary(0, 768, 1024, 768); |
- |
-// The work area for 1024x768 monitors with different taskbar orientations. |
-static const gfx::Rect taskbar_bottom_work_area(0, 0, 1024, 734); |
-static const gfx::Rect taskbar_top_work_area(0, 34, 1024, 734); |
-static const gfx::Rect taskbar_left_work_area(107, 0, 917, 768); |
-static const gfx::Rect taskbar_right_work_area(0, 0, 917, 768); |
- |
-static int kWindowTilePixels = WindowSizer::kWindowTilePixels; |
- |
-// Testing implementation of WindowSizer::MonitorInfoProvider that we can use |
-// to fake various monitor layouts and sizes. |
-class TestMonitorInfoProvider : public WindowSizer::MonitorInfoProvider { |
- public: |
- TestMonitorInfoProvider() {} |
- virtual ~TestMonitorInfoProvider() {} |
- |
- void AddMonitor(const gfx::Rect& bounds, const gfx::Rect& work_area) { |
- DCHECK(bounds.Contains(work_area)); |
- monitor_bounds_.push_back(bounds); |
- work_areas_.push_back(work_area); |
- } |
- |
- // Overridden from WindowSizer::MonitorInfoProvider: |
- virtual gfx::Rect GetPrimaryMonitorWorkArea() const { |
- return work_areas_[0]; |
- } |
- |
- virtual gfx::Rect GetPrimaryMonitorBounds() const { |
- return monitor_bounds_[0]; |
- } |
- |
- virtual gfx::Rect GetMonitorWorkAreaMatching( |
- const gfx::Rect& match_rect) const { |
- return work_areas_[GetMonitorIndexMatchingBounds(match_rect)]; |
- } |
- |
- virtual gfx::Point GetBoundsOffsetMatching( |
- const gfx::Rect& match_rect) const { |
- int monitor_index = GetMonitorIndexMatchingBounds(match_rect); |
- gfx::Rect bounds = monitor_bounds_[monitor_index]; |
- const gfx::Rect& work_area = work_areas_[monitor_index]; |
- return gfx::Point(work_area.x() - bounds.x(), work_area.y() - bounds.y()); |
- } |
- |
- virtual void UpdateWorkAreas() { } |
- |
- private: |
- size_t GetMonitorIndexMatchingBounds(const gfx::Rect& match_rect) const { |
- int max_area = 0; |
- size_t max_area_index = 0; |
- // Loop through all the monitors, finding the one that intersects the |
- // largest area of the supplied match rect. |
- for (size_t i = 0; i < work_areas_.size(); ++i) { |
- gfx::Rect overlap(match_rect.Intersect(work_areas_[i])); |
- int area = overlap.width() * overlap.height(); |
- if (area > max_area) { |
- max_area = area; |
- max_area_index = i; |
- } |
- } |
- return max_area_index; |
- } |
- |
- std::vector<gfx::Rect> monitor_bounds_; |
- |
- DISALLOW_COPY_AND_ASSIGN(TestMonitorInfoProvider); |
-}; |
- |
-// Testing implementation of WindowSizer::StateProvider that we use to fake |
-// persistent storage and existing windows. |
-class TestStateProvider : public WindowSizer::StateProvider { |
- public: |
- TestStateProvider() |
- : persistent_maximized_(false), |
- has_persistent_data_(false), |
- has_last_active_data_(false) { |
- } |
- virtual ~TestStateProvider() {} |
- |
- void SetPersistentState(const gfx::Rect& bounds, |
- bool maximized, |
- const gfx::Rect& work_area, |
- bool has_persistent_data) { |
- persistent_bounds_ = bounds; |
- persistent_maximized_ = maximized; |
- persistent_work_area_ = work_area; |
- has_persistent_data_ = has_persistent_data; |
- } |
- |
- void SetLastActiveState(const gfx::Rect& bounds, bool has_last_active_data) { |
- last_active_bounds_ = bounds; |
- has_last_active_data_ = has_last_active_data; |
- } |
- |
- // Overridden from WindowSizer::StateProvider: |
- virtual bool GetPersistentState(gfx::Rect* bounds, |
- bool* maximized, |
- gfx::Rect* saved_work_area) const { |
- *bounds = persistent_bounds_; |
- *maximized = persistent_maximized_; |
- *saved_work_area = persistent_work_area_; |
- return has_persistent_data_; |
- } |
- |
- virtual bool GetLastActiveWindowState(gfx::Rect* bounds) const { |
- *bounds = last_active_bounds_; |
- return has_last_active_data_; |
- } |
- |
- private: |
- gfx::Rect persistent_bounds_; |
- bool persistent_maximized_; |
- gfx::Rect persistent_work_area_; |
- bool has_persistent_data_; |
- |
- gfx::Rect last_active_bounds_; |
- bool has_last_active_data_; |
- |
- DISALLOW_COPY_AND_ASSIGN(TestStateProvider); |
-}; |
- |
-// A convenience function to read the window bounds from the window sizer |
-// according to the specified configuration. |
-enum Source { DEFAULT, LAST_ACTIVE, PERSISTED }; |
-static void GetWindowBounds(const gfx::Rect& monitor1_bounds, |
- const gfx::Rect& monitor1_work_area, |
- const gfx::Rect& monitor2_bounds, |
- const gfx::Rect& state, |
- bool maximized, |
- const gfx::Rect& work_area, |
- Source source, |
- gfx::Rect* out_bounds, |
- bool* out_maximized) { |
- TestMonitorInfoProvider* mip = new TestMonitorInfoProvider; |
- mip->AddMonitor(monitor1_bounds, monitor1_work_area); |
- if (!monitor2_bounds.IsEmpty()) |
- mip->AddMonitor(monitor2_bounds, monitor2_bounds); |
- TestStateProvider* sp = new TestStateProvider; |
- if (source == PERSISTED) |
- sp->SetPersistentState(state, maximized, work_area, true); |
- else if (source == LAST_ACTIVE) |
- sp->SetLastActiveState(state, true); |
- WindowSizer sizer(sp, mip); |
- sizer.DetermineWindowBounds(gfx::Rect(), out_bounds, out_maximized); |
-} |
- |
-// Test that the window is sized appropriately for the first run experience |
-// where the default window bounds calculation is invoked. |
-TEST(WindowSizerTest, DefaultSizeCase) { |
- { // 4:3 monitor case, 1024x768, no taskbar |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), gfx::Rect(), |
- false, gfx::Rect(), DEFAULT, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 1024 - kWindowTilePixels * 2, |
- 768 - kWindowTilePixels * 2), |
- window_bounds); |
- } |
- |
- { // 4:3 monitor case, 1024x768, taskbar on bottom |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, taskbar_bottom_work_area, gfx::Rect(), |
- gfx::Rect(), false, gfx::Rect(), DEFAULT, &window_bounds, |
- &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 1024 - kWindowTilePixels * 2, |
- (taskbar_bottom_work_area.height() - |
- kWindowTilePixels * 2)), |
- window_bounds); |
- } |
- |
- { // 4:3 monitor case, 1024x768, taskbar on right |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, taskbar_right_work_area, gfx::Rect(), |
- gfx::Rect(), false, gfx::Rect(), DEFAULT, &window_bounds, |
- &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- taskbar_right_work_area.width() - kWindowTilePixels*2, |
- 768 - kWindowTilePixels * 2), |
- window_bounds); |
- } |
- |
- { // 4:3 monitor case, 1024x768, taskbar on left |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, taskbar_left_work_area, gfx::Rect(), |
- gfx::Rect(), false, gfx::Rect(), DEFAULT, &window_bounds, |
- &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(taskbar_left_work_area.x() + kWindowTilePixels, |
- kWindowTilePixels, |
- taskbar_left_work_area.width() - kWindowTilePixels * 2, |
- (taskbar_left_work_area.height() - |
- kWindowTilePixels * 2)), |
- window_bounds); |
- } |
- |
- { // 4:3 monitor case, 1024x768, taskbar on top |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, taskbar_top_work_area, gfx::Rect(), |
- gfx::Rect(), false, gfx::Rect(), DEFAULT, &window_bounds, |
- &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, |
- taskbar_top_work_area.y() + kWindowTilePixels, |
- 1024 - kWindowTilePixels * 2, |
- taskbar_top_work_area.height() - kWindowTilePixels * 2), |
- window_bounds); |
- } |
- |
- { // 4:3 monitor case, 1280x1024 |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(twelveeighty, twelveeighty, gfx::Rect(), gfx::Rect(), |
- false, gfx::Rect(), DEFAULT, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 1050, |
- 1024 - kWindowTilePixels * 2), |
- window_bounds); |
- } |
- |
- { // 4:3 monitor case, 1600x1200 |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(sixteenhundred, sixteenhundred, gfx::Rect(), gfx::Rect(), |
- false, gfx::Rect(), DEFAULT, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 1050, |
- 1200 - kWindowTilePixels * 2), |
- window_bounds); |
- } |
- |
- { // 16:10 monitor case, 1680x1050 |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(sixteeneighty, sixteeneighty, gfx::Rect(), gfx::Rect(), |
- false, gfx::Rect(), DEFAULT, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 840 - static_cast<int>(kWindowTilePixels * 1.5), |
- 1050 - kWindowTilePixels * 2), |
- window_bounds); |
- } |
- |
- { // 16:10 monitor case, 1920x1200 |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(nineteentwenty, nineteentwenty, gfx::Rect(), gfx::Rect(), |
- false, gfx::Rect(), DEFAULT, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 960 - static_cast<int>(kWindowTilePixels * 1.5), |
- 1200 - kWindowTilePixels * 2), |
- window_bounds); |
- } |
-} |
- |
-// Test that the next opened window is positioned appropriately given the |
-// bounds of an existing window of the same type. |
-TEST(WindowSizerTest, LastWindowBoundsCase) { |
- { // normal, in the middle of the screen somewhere. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 500, 400), |
- false, gfx::Rect(), LAST_ACTIVE, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels * 2, |
- kWindowTilePixels * 2, 500, 400), window_bounds); |
- } |
- |
- { // taskbar on top. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, taskbar_top_work_area, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 500, 400), |
- false, gfx::Rect(), LAST_ACTIVE, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels * 2, |
- std::max(kWindowTilePixels * 2, |
- 34 /* toolbar height */), |
- 500, 400), window_bounds); |
- } |
- |
- { // too small to satisify the minimum visibility condition. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 29, 29), |
- false, gfx::Rect(), LAST_ACTIVE, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels * 2, |
- kWindowTilePixels * 2, |
- 30 /* not 29 */, |
- 30 /* not 29 */), |
- window_bounds); |
- } |
- |
- |
- { // normal, but maximized |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 500, 400), |
- true, gfx::Rect(), LAST_ACTIVE, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels * 2, |
- kWindowTilePixels * 2, 500, 400), window_bounds); |
- } |
-} |
- |
-// Test that the window opened is sized appropriately given persisted sizes. |
-TEST(WindowSizerTest, PersistedBoundsCase) { |
- { // normal, in the middle of the screen somewhere. |
- gfx::Rect initial_bounds(kWindowTilePixels, kWindowTilePixels, 500, 400); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), initial_bounds, |
- false, gfx::Rect(), PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // normal, maximized. |
- gfx::Rect initial_bounds(0, 0, 1024, 768); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), initial_bounds, |
- true, gfx::Rect(), PERSISTED, &window_bounds, &maximized); |
- EXPECT_TRUE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // normal, on non-primary monitor in negative coords. |
- gfx::Rect initial_bounds(-600, 10, 500, 400); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, left_nonprimary, |
- initial_bounds, false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // normal, on non-primary monitor in negative coords, maximized. |
- gfx::Rect initial_bounds(-1024, 0, 1024, 768); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, left_nonprimary, |
- initial_bounds, true, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_TRUE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // Non-primary monitor resoultion has changed, but the monitor still |
- // completely contains the window. |
- |
- gfx::Rect initial_bounds(1074, 50, 600, 500); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(1024, 0, 800, 600), |
- initial_bounds, false, right_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // Non-primary monitor resoultion has changed, and the window is partially |
- // off-screen. |
- |
- gfx::Rect initial_bounds(1274, 50, 600, 500); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(1024, 0, 800, 600), |
- initial_bounds, false, right_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(1224, 50, 600, 500), window_bounds); |
- } |
- |
- { // Non-primary monitor resoultion has changed, and the window is now too |
- // large for the monitor. |
- |
- gfx::Rect initial_bounds(1274, 50, 900, 700); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(1024, 0, 800, 600), |
- initial_bounds, false, right_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(1024, 0, 800, 600), window_bounds); |
- } |
- |
- { // width and height too small |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 29, 29), |
- false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels, kWindowTilePixels, |
- 30 /* not 29 */, 30 /* not 29 */), |
- window_bounds); |
- } |
- |
-#if defined(OS_MACOSX) |
- { // Saved state is too tall to possibly be resized. Mac resizers |
- // are at the bottom of the window, and no piece of a window can |
- // be moved higher than the menubar. (Perhaps the user changed |
- // resolution to something smaller before relaunching Chrome?) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 30, 5000), |
- false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(tentwentyfour.height(), window_bounds.height()); |
- } |
-#endif // defined(OS_MACOSX) |
-} |
- |
-////////////////////////////////////////////////////////////////////////////// |
-// The following unittests have different results on Mac/non-Mac because we |
-// reposition windows aggressively on Mac. The *WithAggressiveReposition tests |
-// are run on Mac, and the *WithNonAggressiveRepositioning tests are run on |
-// other platforms. |
- |
-#if defined(OS_MACOSX) |
-TEST(WindowSizerTest, LastWindowOffscreenWithAggressiveRepositioning) { |
- { // taskbar on left. The new window overlaps slightly with the taskbar, so |
- // it is moved to be flush with the left edge of the work area. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, taskbar_left_work_area, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 500, 400), |
- false, gfx::Rect(), LAST_ACTIVE, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(taskbar_left_work_area.x(), |
- kWindowTilePixels * 2, 500, 400), window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the bottom |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(10, 729, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(10 + kWindowTilePixels, |
- 0 /* not 729 + kWindowTilePixels */, |
- 500, 400), |
- window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the right |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(985, 10, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not 985 + kWindowTilePixels*/, |
- 10 + kWindowTilePixels, |
- 500, 400), |
- window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the bottom right |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(985, 729, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not 985 + kWindowTilePixels*/, |
- 0 /* not 729 + kWindowTilePixels*/, |
- 500, 400), |
- window_bounds); |
- } |
-} |
- |
-TEST(WindowSizerTest, PersistedWindowOffscreenWithAggressiveRepositioning) { |
- { // off the left |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-471, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not -471 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // off the top |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, -370, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0, 500, 400), window_bounds); |
- } |
- |
- { // off the right |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(995, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not 995 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // off the bottom |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, 739, 500, 400), false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0 /* not 739 */, 500, 400), window_bounds); |
- } |
- |
- { // off the topleft |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-471, -371, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not -471 */, 0 /* not -371 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // off the topright |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(995, -371, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not 995 */, 0 /* not -371 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // off the bottomleft |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-471, 739, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not -471 */, 0 /* not 739 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // off the bottomright |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(995, 739, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not 995 */, 0 /* not 739 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // entirely off left |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-700, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not -700 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off left (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-700, 50, 500, 400), false, left_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off top |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, -500, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0, 500, 400), window_bounds); |
- } |
- |
- { // entirely off top (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, -500, 500, 400), false, top_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0, 500, 400), window_bounds); |
- } |
- |
- { // entirely off right |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(1200, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not 1200 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off right (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(1200, 50, 500, 400), false, right_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(524 /* not 1200 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off bottom |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, 800, 500, 400), false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0 /* not 800 */, 500, 400), window_bounds); |
- } |
- |
- { // entirely off bottom (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, 800, 500, 400), false, bottom_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 368 /* not 800 */, 500, 400), window_bounds); |
- } |
- |
- { // wider than the screen. off both the left and right |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-100, 50, 2000, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0 /* not -100 */, 50, 2000, 400), window_bounds); |
- } |
-} |
-#else |
-TEST(WindowSizerTest, LastWindowOffscreenWithNonAggressiveRepositioning) { |
- { // taskbar on left. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, taskbar_left_work_area, gfx::Rect(), |
- gfx::Rect(kWindowTilePixels, kWindowTilePixels, 500, 400), |
- false, gfx::Rect(), LAST_ACTIVE, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(kWindowTilePixels * 2, |
- kWindowTilePixels * 2, 500, 400), window_bounds); |
- } |
- |
- // Linux does not tile windows, so tile adjustment tests don't make sense. |
-#if !defined(OS_LINUX) |
- { // offset would put the new window offscreen at the bottom but the minimum |
- // visibility condition is barely satisfied without relocation. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(10, 728, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(10 + kWindowTilePixels, 738, |
- 500, 400), window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the bottom and the minimum |
- // visibility condition is satisified by relocation. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(10, 729, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(10 + kWindowTilePixels, 738 /* not 739 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the right but the minimum |
- // visibility condition is barely satisfied without relocation. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(984, 10, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994, 10 + kWindowTilePixels, 500, 400), window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the right and the minimum |
- // visibility condition is satisified by relocation. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(985, 10, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994 /* not 995 */, 10 + kWindowTilePixels, |
- 500, 400), window_bounds); |
- } |
- |
- { // offset would put the new window offscreen at the bottom right and the |
- // minimum visibility condition is satisified by relocation. |
- gfx::Rect window_bounds; |
- bool maximized = false; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(985, 729, 500, 400), false, gfx::Rect(), |
- LAST_ACTIVE, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994 /* not 995 */, 738 /* not 739 */, 500, 400), |
- window_bounds); |
- } |
-#endif // !defined(OS_LINUX) |
-} |
- |
-TEST(WindowSizerTest, PersistedWindowOffscreenWithNonAggressiveRepositioning) { |
- { // off the left but the minimum visibility condition is barely satisfied |
- // without relocaiton. |
- gfx::Rect initial_bounds(-470, 50, 500, 400); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- initial_bounds, false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // off the left and the minimum visibility condition is satisfied by |
- // relocation. |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-471, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(-470 /* not -471 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // off the top |
- gfx::Rect initial_bounds(50, -370, 500, 400); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, -370, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0, 500, 400), window_bounds); |
- } |
- |
- { // off the right but the minimum visibility condition is barely satisified |
- // without relocation. |
- gfx::Rect initial_bounds(994, 50, 500, 400); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- initial_bounds, false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // off the right and the minimum visibility condition is satisified by |
- // relocation. |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(995, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994 /* not 995 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // off the bottom but the minimum visibility condition is barely satisified |
- // without relocation. |
- gfx::Rect initial_bounds(50, 738, 500, 400); |
- |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- initial_bounds, false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(initial_bounds, window_bounds); |
- } |
- |
- { // off the bottom and the minimum visibility condition is satisified by |
- // relocation. |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, 739, 500, 400), false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 738 /* not 739 */, 500, 400), window_bounds); |
- } |
- |
- { // off the topleft |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-471, -371, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(-470 /* not -471 */, 0, 500, 400), |
- window_bounds); |
- } |
- |
- { // off the topright and the minimum visibility condition is satisified by |
- // relocation. |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(995, -371, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994 /* not 995 */, 0, 500, 400), |
- window_bounds); |
- } |
- |
- { // off the bottomleft and the minimum visibility condition is satisified by |
- // relocation. |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-471, 739, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(-470 /* not -471 */, 738 /* not 739 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // off the bottomright and the minimum visibility condition is satisified by |
- // relocation. |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(995, 739, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994 /* not 995 */, 738 /* not 739 */, 500, 400), |
- window_bounds); |
- } |
- |
- { // entirely off left |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-700, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(-470 /* not -700 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off left (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(-700, 50, 500, 400), false, left_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(0, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off top |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, -500, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0, 500, 400), window_bounds); |
- } |
- |
- { // entirely off top (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, -500, 500, 400), false, top_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 0, 500, 400), window_bounds); |
- } |
- |
- { // entirely off right |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(1200, 50, 500, 400), false, gfx::Rect(), |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(994 /* not 1200 */, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off right (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(1200, 50, 500, 400), false, right_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(524, 50, 500, 400), window_bounds); |
- } |
- |
- { // entirely off bottom |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, 800, 500, 400), false, gfx::Rect(), PERSISTED, |
- &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 738 /* not 800 */, 500, 400), window_bounds); |
- } |
- |
- { // entirely off bottom (monitor was detached since last run) |
- gfx::Rect window_bounds; |
- bool maximized; |
- GetWindowBounds(tentwentyfour, tentwentyfour, gfx::Rect(), |
- gfx::Rect(50, 800, 500, 400), false, bottom_nonprimary, |
- PERSISTED, &window_bounds, &maximized); |
- EXPECT_FALSE(maximized); |
- EXPECT_EQ(gfx::Rect(50, 368, 500, 400), window_bounds); |
- } |
-} |
-#endif //defined(OS_MACOSX) |