Chromium Code Reviews| Index: chrome/browser/ui/ash/ash_keyboard_controller_proxy_unittest.cc |
| diff --git a/chrome/browser/ui/ash/ash_keyboard_controller_proxy_unittest.cc b/chrome/browser/ui/ash/ash_keyboard_controller_proxy_unittest.cc |
| index 4f4da622d0a6af17a49ea7ee7c29df5d394037de..b8b2bf84119c6de3a8dd0778c0c1537e9819b3ba 100644 |
| --- a/chrome/browser/ui/ash/ash_keyboard_controller_proxy_unittest.cc |
| +++ b/chrome/browser/ui/ash/ash_keyboard_controller_proxy_unittest.cc |
| @@ -131,7 +131,7 @@ TEST_F(AshKeyboardControllerProxyTest, VirtualKeyboardContainerAnimation) { |
| // animation starts. |
| EXPECT_TRUE(keyboard_container->IsVisible()); |
| EXPECT_TRUE(proxy()->GetKeyboardWindow()->IsVisible()); |
| - EXPECT_EQ(0.0, layer->opacity()); |
| + float show_start_opacity = layer->opacity(); |
| gfx::Transform transform; |
| transform.Translate(0, proxy()->GetKeyboardWindow()->bounds().height()); |
| EXPECT_EQ(transform, layer->transform()); |
| @@ -139,18 +139,45 @@ TEST_F(AshKeyboardControllerProxyTest, VirtualKeyboardContainerAnimation) { |
| RunAnimationForLayer(layer); |
| EXPECT_TRUE(keyboard_container->IsVisible()); |
| EXPECT_TRUE(proxy()->GetKeyboardWindow()->IsVisible()); |
| - EXPECT_EQ(1.0, layer->opacity()); |
| + float show_end_opacity = layer->opacity(); |
| + EXPECT_LT(show_start_opacity, show_end_opacity); |
| EXPECT_EQ(gfx::Transform(), layer->transform()); |
| HideKeyboard(keyboard_container); |
| - // Keyboard container and window should be visible before hide animation |
| - // finishes. |
| EXPECT_TRUE(keyboard_container->IsVisible()); |
| + EXPECT_TRUE(keyboard_container->layer()->visible()); |
| EXPECT_TRUE(proxy()->GetKeyboardWindow()->IsVisible()); |
| + float hide_start_opacity = layer->opacity(); |
| RunAnimationForLayer(layer); |
| EXPECT_FALSE(keyboard_container->IsVisible()); |
| + EXPECT_FALSE(keyboard_container->layer()->visible()); |
| EXPECT_FALSE(proxy()->GetKeyboardWindow()->IsVisible()); |
| - EXPECT_EQ(0.0, layer->opacity()); |
| + float hide_end_opacity = layer->opacity(); |
| + EXPECT_GT(hide_start_opacity, hide_end_opacity); |
| EXPECT_EQ(transform, layer->transform()); |
| } |
| + |
| +// Test for crbug.com/333284. |
|
James Cook
2014/01/16 17:55:03
It's great that you wrote a test specifically for
|
| +TEST_F(AshKeyboardControllerProxyTest, VirtualKeyboardContainerShowWhileHide) { |
| + // We cannot short-circuit animations for this test. |
| + ui::ScopedAnimationDurationScaleMode normal_duration_mode( |
| + ui::ScopedAnimationDurationScaleMode::NORMAL_DURATION); |
| + |
| + aura::Window* keyboard_container(controller()->GetContainerWindow()); |
| + ui::Layer* layer = keyboard_container->layer(); |
| + |
| + EXPECT_FALSE(keyboard_container->IsVisible()); |
| + ShowKeyboard(keyboard_container); |
| + RunAnimationForLayer(layer); |
| + |
| + HideKeyboard(keyboard_container); |
| + // Before hide animation finishes, show keyboard again. |
| + ShowKeyboard(keyboard_container); |
| + |
| + RunAnimationForLayer(layer); |
| + EXPECT_TRUE(keyboard_container->IsVisible()); |
| + EXPECT_TRUE(proxy()->GetKeyboardWindow()->IsVisible()); |
| + EXPECT_EQ(1.0, layer->opacity()); |
| + EXPECT_EQ(gfx::Transform(), layer->transform()); |
| +} |