| 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 2eaf3c7105c762b390caecab60893a86efd665c8..1a2a8097bb2089ac5dbcc94495b2c1f2b6bc46e4 100644
|
| --- a/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc
|
| +++ b/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc
|
| @@ -14,6 +14,7 @@
|
| #include "chrome/test/base/in_process_browser_test.h"
|
| #include "chrome/test/base/ui_test_utils.h"
|
| #include "content/public/test/browser_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"
|
| @@ -33,6 +34,27 @@ class TouchExplorationTest : public InProcessBrowserTest {
|
| virtual ~TouchExplorationTest() {}
|
|
|
| protected:
|
| + virtual void SetUpOnMainThread() OVERRIDE {
|
| + // The RenderView for WebContents is created as a result of the
|
| + // navigation to the New Tab page which is done as part of the test
|
| + // SetUp. The creation involves sending a resize message to the renderer
|
| + // process. Here we wait for the resize ack to be received, because
|
| + // currently WindowEventDispatcher has code to hold touch and mouse
|
| + // move events until resize is complete (crbug.com/384342) which
|
| + // interferes with this test.
|
| + content::WebContents* web_contents =
|
| + browser()->tab_strip_model()->GetActiveWebContents();
|
| + content::WaitForResizeComplete(web_contents);
|
| + root_window_ = ash::Shell::GetInstance()->GetPrimaryRootWindow();
|
| + event_handler_.reset(new ui::test::TestEventHandler());
|
| + root_window_->AddPreTargetHandler(event_handler_.get());
|
| + }
|
| +
|
| + virtual void CleanUpOnMainThread() OVERRIDE {
|
| + SwitchTouchExplorationMode(false);
|
| + root_window_->RemovePreTargetHandler(event_handler_.get());
|
| + }
|
| +
|
| void SwitchTouchExplorationMode(bool on) {
|
| ash::AccessibilityDelegate* ad =
|
| ash::Shell::GetInstance()->accessibility_delegate();
|
| @@ -47,6 +69,8 @@ class TouchExplorationTest : public InProcessBrowserTest {
|
|
|
| ui::GestureDetector::Config gesture_detector_config_;
|
| base::SimpleTestTickClock* simulated_clock_;
|
| + aura::Window* root_window_;
|
| + scoped_ptr<ui::test::TestEventHandler> event_handler_;
|
|
|
| private:
|
| DISALLOW_COPY_AND_ASSIGN(TouchExplorationTest);
|
| @@ -56,73 +80,110 @@ private:
|
| // get rewritten when the touch exploration mode is on, and aren't affected
|
| // after the touch exploration mode is turned off.
|
| IN_PROC_BROWSER_TEST_F(TouchExplorationTest, ToggleOnOff) {
|
| - // The RenderView for WebContents is created as a result of the navigation
|
| - // to the New Tab page which is done as part of the test SetUp. The creation
|
| - // involves sending a resize message to the renderer process. Here we wait
|
| - // for the resize ack to be received, because currently WindowEventDispatcher
|
| - // has code to hold touch and mouse move events until resize is complete
|
| - // (crbug.com/384342) which interferes with this test.
|
| - content::WebContents* web_contents =
|
| - browser()->tab_strip_model()->GetActiveWebContents();
|
| - content::WaitForResizeComplete(web_contents);
|
| - 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::test::EventGenerator generator(root_window_);
|
|
|
| base::TimeDelta initial_time = Now();
|
| ui::TouchEvent initial_press(
|
| ui::ET_TOUCH_PRESSED, gfx::Point(100, 200), 1, initial_time);
|
| - float delta_time =
|
| - (initial_press.location() - gfx::Point(109,209)).Length() /
|
| - gesture_detector_config_.minimum_swipe_velocity;
|
| - ui::TouchEvent touch_move(
|
| - ui::ET_TOUCH_MOVED,
|
| - gfx::Point(109, 209),
|
| - 1,
|
| - initial_time + base::TimeDelta::FromSecondsD(delta_time));
|
| -
|
| generator.Dispatch(&initial_press);
|
|
|
| // Since the touch exploration controller doesn't know if the user is
|
| // double-tapping or not, touch exploration is only initiated if the
|
| - // user moves more than 8 pixels away from the initial location (the "slop"),
|
| - // or after 300 ms has elapsed if the finger does not move fast enough.
|
| - generator.Dispatch(&touch_move);
|
| + // 300 ms has elapsed and the finger does not move fast enough to begin
|
| + // gestures. Here, the touch move event is not important as a move, but
|
| + // a way to create time advancement.
|
| + ui::TouchEvent touch_time_advance(ui::ET_TOUCH_MOVED,
|
| + gfx::Point(100, 200),
|
| + 1,
|
| + initial_time +
|
| + gesture_detector_config_.double_tap_timeout +
|
| + base::TimeDelta::FromMilliseconds(1));
|
| + generator.Dispatch(&touch_time_advance);
|
|
|
| // Number of mouse events may be greater than 1 because of ET_MOUSE_ENTERED.
|
| - EXPECT_GT(event_handler->num_mouse_events(), 0);
|
| - EXPECT_EQ(0, event_handler->num_touch_events());
|
| - event_handler->Reset();
|
| + EXPECT_GT(event_handler_->num_mouse_events(), 0);
|
| + EXPECT_EQ(0, event_handler_->num_touch_events());
|
| + event_handler_->Reset();
|
|
|
| SwitchTouchExplorationMode(false);
|
| generator.MoveTouchId(gfx::Point(11, 12), 1);
|
| - EXPECT_EQ(0, event_handler->num_mouse_events());
|
| - EXPECT_EQ(1, event_handler->num_touch_events());
|
| - event_handler->Reset();
|
| + EXPECT_EQ(0, event_handler_->num_mouse_events());
|
| + EXPECT_EQ(1, event_handler_->num_touch_events());
|
| + event_handler_->Reset();
|
|
|
| SwitchTouchExplorationMode(true);
|
| initial_time = Now();
|
| ui::TouchEvent second_initial_press(
|
| ui::ET_TOUCH_PRESSED, gfx::Point(500, 600), 2, initial_time);
|
| - delta_time =
|
| - (second_initial_press.location() - gfx::Point(509, 609)).Length() /
|
| - gesture_detector_config_.minimum_swipe_velocity;
|
| - ui::TouchEvent second_move(
|
| + generator.Dispatch(&second_initial_press);
|
| + ui::TouchEvent second_touch_time_advance(
|
| ui::ET_TOUCH_MOVED,
|
| - gfx::Point(509, 609),
|
| + gfx::Point(500, 600),
|
| 2,
|
| - initial_time + base::TimeDelta::FromSecondsD(delta_time));
|
| + initial_time + gesture_detector_config_.double_tap_timeout +
|
| + base::TimeDelta::FromMilliseconds(1));
|
| + generator.Dispatch(&second_touch_time_advance);
|
| + EXPECT_GT(event_handler_->num_mouse_events(), 0);
|
| + EXPECT_EQ(0, event_handler_->num_touch_events());
|
| +}
|
|
|
| - generator.Dispatch(&second_initial_press);
|
| - generator.Dispatch(&second_move);
|
| - EXPECT_GT(event_handler->num_mouse_events(), 0);
|
| - EXPECT_EQ(0, event_handler->num_touch_events());
|
| +// 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) {
|
| + SwitchTouchExplorationMode(true);
|
| + aura::test::EventGenerator generator(root_window_);
|
| + aura::client::CursorClient* cursor_client =
|
| + aura::client::GetCursorClient(root_window_);
|
|
|
| - SwitchTouchExplorationMode(false);
|
| - root_window->RemovePreTargetHandler(event_handler.get());
|
| + // Mouse events should show the cursor.
|
| + generator.MoveMouseTo(gfx::Point(30, 31));
|
| + EXPECT_TRUE(cursor_client->IsMouseEventsEnabled());
|
| + EXPECT_TRUE(cursor_client->IsCursorVisible());
|
| +
|
| + // The cursor should be shown immediately after the press, and hidden
|
| + // after the move.
|
| + base::TimeDelta initial_time = Now();
|
| + ui::TouchEvent initial_press(
|
| + ui::ET_TOUCH_PRESSED, gfx::Point(100, 200), 1, initial_time);
|
| + generator.Dispatch(&initial_press);
|
| + EXPECT_TRUE(cursor_client->IsMouseEventsEnabled());
|
| + EXPECT_TRUE(cursor_client->IsCursorVisible());
|
| +
|
| + // Initiate touch explore by waiting for the tap timer timeout. Time is
|
| + // advanced by sending a move event after the timeout period.
|
| + ui::TouchEvent touch_time_advance(
|
| + ui::ET_TOUCH_MOVED,
|
| + gfx::Point(100, 200),
|
| + 1,
|
| + initial_time + gesture_detector_config_.double_tap_timeout +
|
| + base::TimeDelta::FromMilliseconds(1));
|
| + generator.Dispatch(&touch_time_advance);
|
| + 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());
|
| }
|
|
|
| } // namespace ui
|
|
|