| Index: ui/keyboard/keyboard_controller_unittest.cc
|
| diff --git a/ui/keyboard/keyboard_controller_unittest.cc b/ui/keyboard/keyboard_controller_unittest.cc
|
| index c2b47f3cb5f35a59aa2ea5b94a90539fdaa06fe5..6357440a8cf411381af6f32cf408305e8dcbecf3 100644
|
| --- a/ui/keyboard/keyboard_controller_unittest.cc
|
| +++ b/ui/keyboard/keyboard_controller_unittest.cc
|
| @@ -299,7 +299,8 @@ TEST_F(KeyboardControllerTest, KeyboardSize) {
|
| const gfx::Rect& initial_bounds = container->bounds();
|
| // The container should be positioned at the bottom of screen and has 0
|
| // height.
|
| - ASSERT_EQ(gfx::Rect(), initial_bounds);
|
| + ASSERT_EQ(0, initial_bounds.height());
|
| + ASSERT_EQ(screen_bounds.height(), initial_bounds.y());
|
| VerifyKeyboardWindowSize(container, keyboard);
|
|
|
| // In FULL_WIDTH mode, attempt to change window width or move window up from
|
| @@ -340,6 +341,38 @@ TEST_F(KeyboardControllerTest, FloatingKeyboardSize) {
|
| VerifyKeyboardWindowSize(container, keyboard);
|
| }
|
|
|
| +TEST_F(KeyboardControllerTest, KeyboardSizeMultiRootWindow) {
|
| + aura::Window* container(controller()->GetContainerWindow());
|
| + aura::Window* keyboard(ui()->GetKeyboardWindow());
|
| + gfx::Rect screen_bounds = root_window()->bounds();
|
| + root_window()->AddChild(container);
|
| + container->AddChild(keyboard);
|
| + const gfx::Rect& initial_bounds = container->bounds();
|
| + // The container should be positioned at the bottom of screen and has 0
|
| + // height.
|
| + ASSERT_EQ(0, initial_bounds.height());
|
| + ASSERT_EQ(screen_bounds.height(), initial_bounds.y());
|
| + VerifyKeyboardWindowSize(container, keyboard);
|
| +
|
| + // Adding new root window.
|
| + std::unique_ptr<aura::WindowTreeHost> secondary_tree_host =
|
| + base::WrapUnique<aura::WindowTreeHost>(
|
| + aura::WindowTreeHost::Create(gfx::Rect(0, 0, 1000, 500)));
|
| + secondary_tree_host->InitHost();
|
| + EXPECT_EQ(1000, secondary_tree_host->window()->bounds().width());
|
| + EXPECT_EQ(500, secondary_tree_host->window()->bounds().height());
|
| +
|
| + // Move the keyboard into the secondary root window.
|
| + controller()->HideKeyboard(
|
| + KeyboardController::HideReason::HIDE_REASON_AUTOMATIC);
|
| + root_window()->RemoveChild(container);
|
| + secondary_tree_host->window()->AddChild(container);
|
| +
|
| + const gfx::Rect& new_bounds = container->bounds();
|
| + EXPECT_EQ(500, new_bounds.y());
|
| + VerifyKeyboardWindowSize(container, keyboard);
|
| +}
|
| +
|
| // Tests that tapping/clicking inside the keyboard does not give it focus.
|
| TEST_F(KeyboardControllerTest, ClickDoesNotFocusKeyboard) {
|
| keyboard::SetAccessibilityKeyboardEnabled(true);
|
|
|