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 148f1f3845c312b3d1e44ef60270c76375da8da1..2eaf3c7105c762b390caecab60893a86efd665c8 100644 |
--- a/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc |
+++ b/chrome/browser/chromeos/accessibility/touch_exploration_controller_browsertest.cc |
@@ -7,6 +7,8 @@ |
#include "ash/accessibility_delegate.h" |
#include "ash/shell.h" |
#include "ash/test/ash_test_base.h" |
+#include "base/test/simple_test_tick_clock.h" |
+#include "base/time/time.h" |
#include "chrome/browser/ui/browser.h" |
#include "chrome/browser/ui/tabs/tab_strip_model.h" |
#include "chrome/test/base/in_process_browser_test.h" |
@@ -16,13 +18,18 @@ |
#include "ui/aura/window_tree_host.h" |
#include "ui/compositor/compositor.h" |
#include "ui/compositor/test/draw_waiter_for_test.h" |
+#include "ui/events/event.h" |
+#include "ui/events/event_utils.h" |
#include "ui/events/test/test_event_handler.h" |
namespace ui { |
class TouchExplorationTest : public InProcessBrowserTest { |
public: |
- TouchExplorationTest() {} |
+ TouchExplorationTest() : simulated_clock_(new base::SimpleTestTickClock()) { |
+ // Tests fail if time is ever 0. |
+ simulated_clock_->Advance(base::TimeDelta::FromMilliseconds(10)); |
+ } |
virtual ~TouchExplorationTest() {} |
protected: |
@@ -33,6 +40,14 @@ class TouchExplorationTest : public InProcessBrowserTest { |
ad->ToggleSpokenFeedback(ash::A11Y_NOTIFICATION_NONE); |
} |
+ base::TimeDelta Now() { |
+ return base::TimeDelta::FromInternalValue( |
+ simulated_clock_->NowTicks().ToInternalValue()); |
+ } |
+ |
+ ui::GestureDetector::Config gesture_detector_config_; |
+ base::SimpleTestTickClock* simulated_clock_; |
+ |
private: |
DISALLOW_COPY_AND_ASSIGN(TouchExplorationTest); |
}; |
@@ -57,13 +72,26 @@ IN_PROC_BROWSER_TEST_F(TouchExplorationTest, ToggleOnOff) { |
SwitchTouchExplorationMode(true); |
aura::test::EventGenerator generator(root_window); |
- generator.set_current_location(gfx::Point(100, 200)); |
- generator.PressTouchId(1); |
+ 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. |
- generator.MoveTouchId(gfx::Point(109, 209), 1); |
+ // or after 300 ms has elapsed if the finger does not move fast enough. |
+ generator.Dispatch(&touch_move); |
+ |
// 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()); |
@@ -76,9 +104,20 @@ IN_PROC_BROWSER_TEST_F(TouchExplorationTest, ToggleOnOff) { |
event_handler->Reset(); |
SwitchTouchExplorationMode(true); |
- generator.set_current_location(gfx::Point(500, 600)); |
- generator.PressTouchId(2); |
- generator.MoveTouchId(gfx::Point(509, 609), 2); |
+ 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( |
+ ui::ET_TOUCH_MOVED, |
+ gfx::Point(509, 609), |
+ 2, |
+ initial_time + base::TimeDelta::FromSecondsD(delta_time)); |
+ |
+ 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()); |