#include "ui/base/hit_test.h"
#include "ui/events/event.h"
#include "ui/gfx/screen.h"
+#include "ui/views/corewm/window_util.h"
#if defined(OS_WIN)
// Windows headers define macros for these function names which screw with us.
target->bounds().size().ToString());
}
+TEST_F(ToplevelWindowEventHandlerTest, DontDragIfModalChild) {
+ scoped_ptr<aura::Window> w1(CreateWindow(HTCAPTION));
+ scoped_ptr<aura::Window> w2(CreateWindow(HTCAPTION));
+ w2->SetBounds(gfx::Rect(100, 0, 100, 100));
+ w2->SetProperty(aura::client::kModalKey, ui::MODAL_TYPE_WINDOW);
+ views::corewm::AddTransientChild(w1.get(), w2.get());
+ gfx::Size size = w1->bounds().size();
+
+ // Attempt to drag w1, position and size should not change because w1 has a
+ // modal child.
+ DragFromCenterBy(w1.get(), 100, 100);
+ EXPECT_EQ("0,0", w1->bounds().origin().ToString());
+ EXPECT_EQ(size.ToString(), w1->bounds().size().ToString());
+
+ TouchDragFromCenterBy(w1.get(), 100, 100);
+ EXPECT_EQ("0,0", w1->bounds().origin().ToString());
+ EXPECT_EQ(size.ToString(), w1->bounds().size().ToString());
+}
+
// Verifies we don't let windows drag to a -y location.
TEST_F(ToplevelWindowEventHandlerTest, DontDragToNegativeY) {
scoped_ptr<aura::Window> target(CreateWindow(HTTOP));
RunAllPendingInMessageLoop();
EXPECT_NE(old_bounds.ToString(), target->bounds().ToString());
EXPECT_TRUE(window_state->IsMinimized());
- EXPECT_TRUE(window_state->always_restores_to_restore_bounds());
+ EXPECT_TRUE(window_state->unminimize_to_restore_bounds());
EXPECT_EQ(old_bounds.ToString(),
window_state->GetRestoreBoundsInScreen().ToString());
}
RunAllPendingInMessageLoop();
EXPECT_NE(old_bounds.ToString(), window->bounds().ToString());
EXPECT_TRUE(window_state->IsMinimized());
- EXPECT_TRUE(window_state->always_restores_to_restore_bounds());
+ EXPECT_TRUE(window_state->unminimize_to_restore_bounds());
EXPECT_EQ(old_bounds.ToString(),
window_state->GetRestoreBoundsInScreen().ToString());
}
window1->Focus();
generator.PressLeftButton();
generator.MoveMouseBy(10, 11);
- RunAllPendingInMessageLoop();
+ EXPECT_EQ("10,11 100x100", window1->bounds().ToString());
aura::client::WindowMoveClient* move_client =
aura::client::GetWindowMoveClient(window2->GetRootWindow());
aura::client::WINDOW_MOVE_SOURCE_MOUSE));
generator.ReleaseLeftButton();
- RunAllPendingInMessageLoop();
EXPECT_EQ("10,11 100x100", window1->bounds().ToString());
}