Index: chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc |
diff --git a/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc b/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc |
index 43ef9138f037c1cfb05a14ddd36db9d836f23ff6..a1eb63194959feb7ba071012edd69302fd03beb0 100644 |
--- a/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc |
+++ b/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc |
@@ -9,6 +9,7 @@ |
#include "ash/test/ash_test_base.h" |
#include "chrome/test/base/in_process_browser_test.h" |
#include "chrome/test/base/ui_test_utils.h" |
+#include "ui/aura/client/cursor_client.h" |
#include "ui/aura/test/event_generator.h" |
#include "ui/aura/window_tree_host.h" |
#include "ui/compositor/compositor.h" |
@@ -84,4 +85,58 @@ IN_PROC_BROWSER_TEST_F(TouchExplorationTest, ToggleOnOff) { |
root_window->RemovePreTargetHandler(event_handler.get()); |
} |
+// This test makes sure that after the user clicks with split tap, |
+// they continue to touch exploration mode if the original touch exploration |
+// finger is still on the screen. |
+IN_PROC_BROWSER_TEST_F(TouchExplorationTest, SplitTapExplore) { |
mfomitchev
2014/06/27 19:15:46
One more thing: I've just realized that a change I
evy
2014/06/30 23:28:46
Done.
|
+ aura::Window* root_window = ash::Shell::GetInstance()->GetPrimaryRootWindow(); |
+ scoped_ptr<ui::test::TestEventHandler> |
+ event_handler(new ui::test::TestEventHandler()); |
+ root_window->AddPreTargetHandler(event_handler.get()); |
+ SwitchTouchExplorationMode(true); |
+ aura::test::EventGenerator generator(root_window); |
+ aura::client::CursorClient* cursor_client = |
+ aura::client::GetCursorClient(root_window); |
+ |
+ // Mouse events should show the cursor. |
+ //generator.MoveMouseTo(gfx::Point(30, 31)); |
mfomitchev
2014/06/27 19:15:46
Why is this commented out?
evy
2014/06/30 23:28:46
whoops, fixed
|
+ EXPECT_TRUE(cursor_client->IsMouseEventsEnabled()); |
+ EXPECT_TRUE(cursor_client->IsCursorVisible()); |
+ |
+ // After a press the cursor should be hidden. |
mfomitchev
2014/06/27 19:15:46
Shown after immediately after press, hidden after
evy
2014/06/30 23:28:46
Done.
|
+ generator.set_current_location(gfx::Point(100, 200)); |
+ generator.PressTouchId(1); |
+ EXPECT_TRUE(cursor_client->IsMouseEventsEnabled()); |
+ EXPECT_TRUE(cursor_client->IsCursorVisible()); |
+ // Initiate touch explore by moving out of the slop. |
+ generator.MoveTouchId(gfx::Point(109, 209), 1); |
+ EXPECT_TRUE(cursor_client->IsMouseEventsEnabled()); |
+ EXPECT_FALSE(cursor_client->IsCursorVisible()); |
+ event_handler->Reset(); |
+ |
+ // Press and release with a second finger for split tap. This should send |
+ // touch press and release events which should send a click press and release. |
+ // Once the press is passed through, mouse events should be disabled. |
+ // Mouse events are reenabled after the release. |
+ generator.set_current_location(gfx::Point(102, 202)); |
+ generator.PressTouchId(2); |
+ EXPECT_FALSE(cursor_client->IsMouseEventsEnabled()); |
+ EXPECT_FALSE(cursor_client->IsCursorVisible()); |
+ generator.ReleaseTouchId(2); |
+ EXPECT_TRUE(cursor_client->IsMouseEventsEnabled()); |
+ EXPECT_FALSE(cursor_client->IsCursorVisible()); |
+ EXPECT_EQ(2, event_handler->num_touch_events()); |
+ event_handler->Reset(); |
+ |
+ // Continuing to move the touch exploration finger should send more mouse |
+ // events. |
+ generator.MoveTouchId(gfx::Point(509, 609), 1); |
+ EXPECT_EQ(0, event_handler->num_touch_events()); |
+ EXPECT_TRUE(cursor_client->IsMouseEventsEnabled()); |
+ EXPECT_FALSE(cursor_client->IsCursorVisible()); |
+ |
+ SwitchTouchExplorationMode(false); |
+ root_window->RemovePreTargetHandler(event_handler.get()); |
+} |
+ |
} // namespace ui |