Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(112)

Unified Diff: ui/events/gesture_detection/touch_disposition_gesture_filter_unittest.cc

Issue 753743006: Clean up TouchDispositionGestureFilter unit tests. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address Jared's comments. Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/events/gesture_detection/touch_disposition_gesture_filter_unittest.cc
diff --git a/ui/events/gesture_detection/touch_disposition_gesture_filter_unittest.cc b/ui/events/gesture_detection/touch_disposition_gesture_filter_unittest.cc
index eb77e64859b1f21aa3c89c3fd1afaae85e188e85..1452caa1922e55c28327ed361bd3999fab7ffbfe 100644
--- a/ui/events/gesture_detection/touch_disposition_gesture_filter_unittest.cc
+++ b/ui/events/gesture_detection/touch_disposition_gesture_filter_unittest.cc
@@ -42,7 +42,7 @@ class TouchDispositionGestureFilterTest
show_press_bounding_box_ = event.details.bounding_box();
if (cancel_after_next_gesture_) {
cancel_after_next_gesture_ = false;
- CancelTouchPoint();
+ SendPacket(CancelTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
}
}
@@ -71,6 +71,8 @@ class TouchDispositionGestureFilterTest
return ::testing::AssertionSuccess();
}
+ GestureList NoGestures() { return GestureList(0); }
+
GestureList Gestures(EventType type) {
return GestureList(1, type);
}
@@ -104,14 +106,6 @@ class TouchDispositionGestureFilterTest
return gestures;
}
- void SendTouchGestures() {
- touch_event_.set_event_time(base::TimeTicks::Now());
- EXPECT_EQ(TouchDispositionGestureFilter::SUCCESS,
- SendTouchGestures(touch_event_, pending_gesture_packet_));
- GestureEventDataPacket gesture_packet;
- std::swap(gesture_packet, pending_gesture_packet_);
- }
-
TouchDispositionGestureFilter::PacketResult
SendTouchGestures(const MotionEvent& touch,
const GestureEventDataPacket& packet) {
@@ -141,41 +135,50 @@ class TouchDispositionGestureFilterTest
void SendTouchNotConsumedAck() { SendTouchEventAck(false); }
- void PushGesture(EventType type) {
- pending_gesture_packet_.Push(CreateGesture(type));
- }
-
- void PushGesture(EventType type, float x, float y, float diameter) {
- pending_gesture_packet_.Push(CreateGesture(type, x, y, diameter));
- }
-
- void PressTouchPoint(int x, int y) {
+ const MockMotionEvent& PressTouchPoint(float x, float y) {
touch_event_.PressPoint(x, y);
touch_event_.SetRawOffset(raw_offset_.x(), raw_offset_.y());
- SendTouchGestures();
+ return touch_event_;
}
- void MoveTouchPoint(size_t index, int x, int y) {
- touch_event_.MovePoint(index, x, y);
- touch_event_.SetRawOffset(raw_offset_.x(), raw_offset_.y());
- SendTouchGestures();
+ const MockMotionEvent& PressTouchPoint() { return PressTouchPoint(0, 0); }
+
+ const MockMotionEvent& MoveTouchPoint() {
+ touch_event_.MovePoint(0, 0, 0);
+ touch_event_.set_event_time(base::TimeTicks::Now());
+ return touch_event_;
}
- void ReleaseTouchPoint() {
+ const MockMotionEvent& ReleaseTouchPoint() {
touch_event_.ReleasePoint();
- SendTouchGestures();
+ touch_event_.set_event_time(base::TimeTicks::Now());
+ return touch_event_;
}
- void CancelTouchPoint() {
+ const MockMotionEvent& CancelTouchPoint() {
touch_event_.CancelPoint();
- SendTouchGestures();
+ touch_event_.set_event_time(base::TimeTicks::Now());
+ return touch_event_;
+ }
+
+ void SendPacket(const MockMotionEvent& touch_event,
+ GestureList gesture_list) {
+ GestureEventDataPacket gesture_packet;
+ for (EventType type : gesture_list)
+ gesture_packet.Push(CreateGesture(type));
+
+ EXPECT_EQ(TouchDispositionGestureFilter::SUCCESS,
+ SendTouchGestures(touch_event, gesture_packet));
}
void SetRawTouchOffset(const gfx::Vector2dF& raw_offset) {
raw_offset_ = raw_offset;
}
- void ResetTouchPoints() { touch_event_ = MockMotionEvent(); }
+ const MockMotionEvent& ResetTouchPoints() {
+ touch_event_ = MockMotionEvent();
+ return touch_event_;
+ }
bool GesturesSent() const { return !sent_gestures_.empty(); }
@@ -229,15 +232,8 @@ class TouchDispositionGestureFilterTest
float y,
float diameter) {
return GestureEventData(
- GestureEventDetails(type),
- 0,
- MotionEvent::TOOL_TYPE_FINGER,
- base::TimeTicks(),
- touch_event_.GetX(0),
- touch_event_.GetY(0),
- touch_event_.GetRawX(0),
- touch_event_.GetRawY(0),
- 1,
+ GestureEventDetails(type), 0, MotionEvent::TOOL_TYPE_FINGER,
+ base::TimeTicks(), x, y, 0, 0, 1,
gfx::RectF(x - diameter / 2, y - diameter / 2, diameter, diameter),
kDefaultEventFlags);
}
@@ -255,10 +251,10 @@ class TouchDispositionGestureFilterTest
};
TEST_F(TouchDispositionGestureFilterTest, BasicNoGestures) {
- PressTouchPoint(1, 1);
+ PressTouchPoint();
EXPECT_FALSE(GesturesSent());
- MoveTouchPoint(0, 2, 2);
+ MoveTouchPoint();
EXPECT_FALSE(GesturesSent());
// No gestures should be dispatched by the ack, as the queued packets
@@ -274,99 +270,83 @@ TEST_F(TouchDispositionGestureFilterTest, BasicNoGestures) {
}
TEST_F(TouchDispositionGestureFilterTest, BasicGestures) {
+ GestureList press_gestures =
+ Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN);
// An unconsumed touch's gesture should be sent.
- PushGesture(ET_GESTURE_BEGIN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), press_gestures);
EXPECT_FALSE(GesturesSent());
SendTouchNotConsumedAck();
- EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN),
- GetAndResetSentGestures()));
+ EXPECT_TRUE(GesturesMatch(press_gestures, GetAndResetSentGestures()));
// Multiple gestures can be queued for a single event.
- PushGesture(ET_SCROLL_FLING_START);
- PushGesture(ET_SCROLL_FLING_CANCEL);
- PushGesture(ET_GESTURE_END);
- ReleaseTouchPoint();
+ GestureList release_gestures =
+ Gestures(ET_SCROLL_FLING_START, ET_SCROLL_FLING_CANCEL, ET_GESTURE_END);
+ SendPacket(ReleaseTouchPoint(), release_gestures);
EXPECT_FALSE(GesturesSent());
SendTouchNotConsumedAck();
- EXPECT_TRUE(GesturesMatch(Gestures(ET_SCROLL_FLING_START,
- ET_SCROLL_FLING_CANCEL,
- ET_GESTURE_END),
- GetAndResetSentGestures()));
+ EXPECT_TRUE(GesturesMatch(release_gestures, GetAndResetSentGestures()));
}
TEST_F(TouchDispositionGestureFilterTest, BasicGesturesConsumed) {
// A consumed touch's gesture should not be sent.
- PushGesture(ET_GESTURE_BEGIN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_SCROLL_FLING_START);
- PushGesture(ET_SCROLL_FLING_CANCEL);
- PushGesture(ET_GESTURE_END);
- ReleaseTouchPoint();
+ SendPacket(
+ ReleaseTouchPoint(),
+ Gestures(ET_SCROLL_FLING_START, ET_SCROLL_FLING_CANCEL, ET_GESTURE_END));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, ConsumedThenNotConsumed) {
// A consumed touch's gesture should not be sent.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
// Even if the subsequent touch is not consumed, continue dropping gestures.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
// Even if the subsequent touch had no consumer, continue dropping gestures.
- PushGesture(ET_SCROLL_FLING_START);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_SCROLL_FLING_START));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, NotConsumedThenConsumed) {
// A not consumed touch's gesture should be sent.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
// A newly consumed gesture should not be sent.
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(10, 10);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
// And subsequent non-consumed pinch updates should not be sent.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- PushGesture(ET_GESTURE_PINCH_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(),
+ Gestures(ET_GESTURE_SCROLL_UPDATE, ET_GESTURE_PINCH_UPDATE));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_UPDATE),
GetAndResetSentGestures()));
// End events dispatched only when their start events were.
- PushGesture(ET_GESTURE_PINCH_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_PINCH_END));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
@@ -374,27 +354,23 @@ TEST_F(TouchDispositionGestureFilterTest, NotConsumedThenConsumed) {
TEST_F(TouchDispositionGestureFilterTest, ScrollAlternatelyConsumed) {
// A consumed touch's gesture should not be sent.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
for (size_t i = 0; i < 3; ++i) {
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 3, 3);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_UPDATE),
GetAndResetSentGestures()));
}
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
@@ -402,73 +378,63 @@ TEST_F(TouchDispositionGestureFilterTest, ScrollAlternatelyConsumed) {
TEST_F(TouchDispositionGestureFilterTest, NotConsumedThenNoConsumer) {
// An unconsumed touch's gesture should be sent.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
// If the subsequent touch has no consumer (e.g., a secondary pointer is
// pressed but not on a touch handling rect), send the gesture.
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(2, 2);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_BEGIN),
GetAndResetSentGestures()));
// End events should be dispatched when their start events were, independent
// of the ack state.
- PushGesture(ET_GESTURE_PINCH_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_PINCH_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_END),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
}
TEST_F(TouchDispositionGestureFilterTest, EndingEventsSent) {
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(2, 2);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_BEGIN),
GetAndResetSentGestures()));
// Consuming the touchend event can't suppress the match end gesture.
- PushGesture(ET_GESTURE_PINCH_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_PINCH_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_END),
GetAndResetSentGestures()));
// But other events in the same packet are still suppressed.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(),
+ Gestures(ET_GESTURE_SCROLL_UPDATE, ET_GESTURE_SCROLL_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
// ET_GESTURE_SCROLL_END and ET_SCROLL_FLING_START behave the same in this
// regard.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_SCROLL_FLING_START);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_SCROLL_FLING_START));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_SCROLL_FLING_START),
GetAndResetSentGestures()));
@@ -476,121 +442,99 @@ TEST_F(TouchDispositionGestureFilterTest, EndingEventsSent) {
TEST_F(TouchDispositionGestureFilterTest, EndingEventsNotSent) {
// Consuming a begin event ensures no end events are sent.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(2, 2);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_PINCH_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_PINCH_END));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, UpdateEventsSuppressedPerEvent) {
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
// Consuming a single scroll or pinch update should suppress only that event.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(2, 2);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_PINCH_UPDATE);
- MoveTouchPoint(1, 2, 3);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_PINCH_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
// Subsequent updates should not be affected.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 4, 4);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_UPDATE),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_PINCH_UPDATE);
- MoveTouchPoint(0, 4, 5);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_PINCH_UPDATE));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_UPDATE),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_PINCH_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_PINCH_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_END),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
}
TEST_F(TouchDispositionGestureFilterTest, UpdateEventsDependOnBeginEvents) {
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
// Scroll and pinch gestures depend on the scroll begin gesture being
// dispatched.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(2, 2);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_PINCH_UPDATE);
- MoveTouchPoint(1, 2, 3);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_PINCH_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_PINCH_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_PINCH_END));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, MultipleTouchSequences) {
// Queue two touch-to-gestures sequences.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
- PushGesture(ET_GESTURE_TAP);
- ReleaseTouchPoint();
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
- PushGesture(ET_GESTURE_SCROLL_END);
- ReleaseTouchPoint();
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_TAP));
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_SCROLL_END));
// The first gesture sequence should not be allowed.
SendTouchConsumedAck();
@@ -610,56 +554,53 @@ TEST_F(TouchDispositionGestureFilterTest, FlingCancelledOnNewTouchSequence) {
SetRawTouchOffset(raw_offset);
// Simulate a fling.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_TAP_DOWN, ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(
Gestures(
ET_GESTURE_TAP_DOWN, ET_GESTURE_TAP_CANCEL, ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_SCROLL_FLING_START);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_SCROLL_FLING_START));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_SCROLL_FLING_START),
GetAndResetSentGestures()));
// A new touch sequence should cancel the outstanding fling.
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(1, 1), NoGestures());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_SCROLL_FLING_CANCEL),
GetAndResetSentGestures()));
EXPECT_EQ(CurrentTouchTime(), LastSentGestureTime());
EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(1, 1));
EXPECT_EQ(LastSentGestureRawLocation(), gfx::PointF(1, 1) + raw_offset);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, ScrollEndedOnTouchReleaseIfNoFling) {
// Simulate a scroll.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ // Touch position will be used for synthesized scroll end gesture.
+ SendPacket(PressTouchPoint(2, 3),
+ Gestures(ET_GESTURE_TAP_DOWN, ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(
Gestures(
ET_GESTURE_TAP_DOWN, ET_GESTURE_TAP_CANCEL, ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
EXPECT_EQ(CurrentTouchTime(), LastSentGestureTime());
- EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(1, 1));
+ EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(2, 3));
}
TEST_F(TouchDispositionGestureFilterTest, ScrollEndedOnNewTouchSequence) {
// Simulate a scroll.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_TAP_DOWN, ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(
Gestures(
@@ -668,7 +609,9 @@ TEST_F(TouchDispositionGestureFilterTest, ScrollEndedOnNewTouchSequence) {
// A new touch sequence should end the outstanding scroll.
ResetTouchPoints();
- PressTouchPoint(2, 3);
+
+ // Touch position will be used for synthesized scroll end gesture.
+ SendPacket(PressTouchPoint(2, 3), NoGestures());
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
@@ -678,10 +621,9 @@ TEST_F(TouchDispositionGestureFilterTest, ScrollEndedOnNewTouchSequence) {
TEST_F(TouchDispositionGestureFilterTest, FlingCancelledOnScrollBegin) {
// Simulate a fling sequence.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PushGesture(ET_SCROLL_FLING_START);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_TAP_DOWN, ET_GESTURE_SCROLL_BEGIN,
+ ET_SCROLL_FLING_START));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN,
ET_GESTURE_TAP_CANCEL,
@@ -690,9 +632,8 @@ TEST_F(TouchDispositionGestureFilterTest, FlingCancelledOnScrollBegin) {
GetAndResetSentGestures()));
// The new fling should cancel the preceding one.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PushGesture(ET_SCROLL_FLING_START);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(),
+ Gestures(ET_GESTURE_SCROLL_BEGIN, ET_SCROLL_FLING_START));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_SCROLL_FLING_CANCEL,
ET_GESTURE_SCROLL_BEGIN,
@@ -702,14 +643,13 @@ TEST_F(TouchDispositionGestureFilterTest, FlingCancelledOnScrollBegin) {
TEST_F(TouchDispositionGestureFilterTest, FlingNotCancelledIfGFCEventReceived) {
// Simulate a fling that is started then cancelled.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
- PushGesture(ET_SCROLL_FLING_START);
- MoveTouchPoint(0, 2, 3);
+ SendPacket(MoveTouchPoint(), Gestures(ET_SCROLL_FLING_START));
SendTouchNotConsumedAck();
- PushGesture(ET_SCROLL_FLING_CANCEL);
- ReleaseTouchPoint();
+ GestureEventDataPacket packet;
+ packet.Push(CreateGesture(ET_SCROLL_FLING_CANCEL, 2, 3, 0));
+ SendTouchGestures(ReleaseTouchPoint(), packet);
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN,
ET_SCROLL_FLING_START,
@@ -719,23 +659,21 @@ TEST_F(TouchDispositionGestureFilterTest, FlingNotCancelledIfGFCEventReceived) {
// A new touch sequence will not inject a ET_SCROLL_FLING_CANCEL, as the fling
// has already been cancelled.
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, TapCancelledWhenScrollBegins) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
// If the subsequent touch turns into a scroll, the tap should be cancelled.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL,
ET_GESTURE_SCROLL_BEGIN),
@@ -743,38 +681,37 @@ TEST_F(TouchDispositionGestureFilterTest, TapCancelledWhenScrollBegins) {
}
TEST_F(TouchDispositionGestureFilterTest, TapCancelledWhenTouchConsumed) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
// If the subsequent touch is consumed, the tap should be cancelled.
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- MoveTouchPoint(0, 2, 2);
+ GestureEventDataPacket packet;
+ packet.Push(CreateGesture(ET_GESTURE_SCROLL_BEGIN, 2, 3, 0));
+ SendTouchGestures(MoveTouchPoint(), packet);
+
SendTouchConsumedAck();
EXPECT_TRUE(
GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL, ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(1, 1));
+ EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(2, 3));
}
TEST_F(TouchDispositionGestureFilterTest,
TapNotCancelledIfTapEndingEventReceived) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(
GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN), GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_TAP);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_TAP));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SHOW_PRESS, ET_GESTURE_TAP),
GetAndResetSentGestures()));
// The tap should not be cancelled as it was terminated by a |ET_GESTURE_TAP|.
- PressTouchPoint(2, 2);
+ SendPacket(PressTouchPoint(), NoGestures());
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
}
@@ -782,8 +719,7 @@ TEST_F(TouchDispositionGestureFilterTest,
TEST_F(TouchDispositionGestureFilterTest, TimeoutGestures) {
// If the sequence is allowed, and there are no preceding gestures, the
// timeout gestures should be forwarded immediately.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
@@ -796,8 +732,7 @@ TEST_F(TouchDispositionGestureFilterTest, TimeoutGestures) {
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_LONG_PRESS),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_LONG_TAP);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_LONG_TAP));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL,
ET_GESTURE_LONG_TAP),
@@ -805,20 +740,18 @@ TEST_F(TouchDispositionGestureFilterTest, TimeoutGestures) {
// If the sequence is disallowed, and there are no preceding gestures, the
// timeout gestures should be dropped immediately.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
SendTimeoutGesture(ET_GESTURE_SHOW_PRESS);
EXPECT_FALSE(GesturesSent());
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
// If the sequence has a pending ack, the timeout gestures should
// remain queued until the ack is received.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
EXPECT_FALSE(GesturesSent());
SendTimeoutGesture(ET_GESTURE_LONG_PRESS);
@@ -836,10 +769,8 @@ TEST_F(TouchDispositionGestureFilterTest, SpuriousAcksIgnored) {
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 3,3);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN,
@@ -869,16 +800,14 @@ TEST_F(TouchDispositionGestureFilterTest, PacketsWithInvalidOrderIgnored) {
TEST_F(TouchDispositionGestureFilterTest, ConsumedTouchCancel) {
// An unconsumed touch's gesture should be sent.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
EXPECT_FALSE(GesturesSent());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_TAP_CANCEL);
- PushGesture(ET_GESTURE_SCROLL_END);
- CancelTouchPoint();
+ SendPacket(CancelTouchPoint(),
+ Gestures(ET_GESTURE_TAP_CANCEL, ET_GESTURE_SCROLL_END));
EXPECT_FALSE(GesturesSent());
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL,
@@ -887,12 +816,11 @@ TEST_F(TouchDispositionGestureFilterTest, ConsumedTouchCancel) {
}
TEST_F(TouchDispositionGestureFilterTest, TimeoutEventAfterRelease) {
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_TAP_DOWN);
- PushGesture(ET_GESTURE_TAP_UNCONFIRMED);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(),
+ Gestures(ET_GESTURE_TAP_DOWN, ET_GESTURE_TAP_UNCONFIRMED));
SendTouchNotConsumedAck();
EXPECT_TRUE(
GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN, ET_GESTURE_TAP_UNCONFIRMED),
@@ -904,8 +832,7 @@ TEST_F(TouchDispositionGestureFilterTest, TimeoutEventAfterRelease) {
}
TEST_F(TouchDispositionGestureFilterTest, ShowPressInsertedBeforeTap) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
@@ -914,8 +841,7 @@ TEST_F(TouchDispositionGestureFilterTest, ShowPressInsertedBeforeTap) {
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_UNCONFIRMED),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_TAP);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_TAP));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SHOW_PRESS,
ET_GESTURE_TAP),
@@ -923,8 +849,7 @@ TEST_F(TouchDispositionGestureFilterTest, ShowPressInsertedBeforeTap) {
}
TEST_F(TouchDispositionGestureFilterTest, ShowPressNotInsertedIfAlreadySent) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
@@ -933,8 +858,7 @@ TEST_F(TouchDispositionGestureFilterTest, ShowPressNotInsertedIfAlreadySent) {
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SHOW_PRESS),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_TAP);
- ReleaseTouchPoint();
+ SendPacket(ReleaseTouchPoint(), Gestures(ET_GESTURE_TAP));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP),
GetAndResetSentGestures()));
@@ -944,14 +868,13 @@ TEST_F(TouchDispositionGestureFilterTest, TapAndScrollCancelledOnTouchCancel) {
const gfx::Vector2dF raw_offset(1.3f, 3.7f);
SetRawTouchOffset(raw_offset);
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(1, 1), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
// A cancellation motion event should cancel the tap.
- CancelTouchPoint();
+ SendPacket(CancelTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL),
GetAndResetSentGestures()));
@@ -959,15 +882,14 @@ TEST_F(TouchDispositionGestureFilterTest, TapAndScrollCancelledOnTouchCancel) {
EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(1, 1));
EXPECT_EQ(LastSentGestureRawLocation(), gfx::PointF(1, 1) + raw_offset);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(1, 1), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
// A cancellation motion event should end the scroll, even if the touch was
// consumed.
- CancelTouchPoint();
+ SendPacket(CancelTouchPoint(), NoGestures());
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END),
GetAndResetSentGestures()));
@@ -979,59 +901,58 @@ TEST_F(TouchDispositionGestureFilterTest, TapAndScrollCancelledOnTouchCancel) {
TEST_F(TouchDispositionGestureFilterTest,
ConsumedScrollUpdateMakesFlingScrollEnd) {
// A consumed touch's gesture should not be sent.
- PushGesture(ET_GESTURE_BEGIN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(
GesturesMatch(Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_SCROLL_FLING_START);
- PushGesture(ET_SCROLL_FLING_CANCEL);
- PushGesture(ET_GESTURE_END);
- ReleaseTouchPoint();
+ GestureEventDataPacket packet;
+ packet.Push(CreateGesture(ET_SCROLL_FLING_START));
+ packet.Push(CreateGesture(ET_SCROLL_FLING_CANCEL));
+ packet.Push(CreateGesture(ET_GESTURE_END, 2, 3, 0));
+ SendTouchGestures(ReleaseTouchPoint(), packet);
+
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_END, ET_GESTURE_END),
GetAndResetSentGestures()));
- EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(2, 2));
+ EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(2, 3));
- PushGesture(ET_GESTURE_BEGIN);
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_BEGIN, ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
}
TEST_F(TouchDispositionGestureFilterTest, TapCancelledOnTouchCancel) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ // Touch position is used for synthesized tap cancel.
+ SendPacket(PressTouchPoint(2, 3), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
// A cancellation motion event should cancel the tap.
- CancelTouchPoint();
+ SendPacket(CancelTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL),
GetAndResetSentGestures()));
EXPECT_EQ(CurrentTouchTime(), LastSentGestureTime());
- EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(1, 1));
+ EXPECT_EQ(LastSentGestureLocation(), gfx::PointF(2, 3));
}
// Test that a GestureEvent whose dispatch causes a cancel event to be fired
// won't cause a crash.
TEST_F(TouchDispositionGestureFilterTest, TestCancelMidGesture) {
SetCancelAfterNextGesture(true);
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ // Synthesized tap cancel uses touch position.
+ SendPacket(PressTouchPoint(1, 1), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN,
ET_GESTURE_TAP_CANCEL),
@@ -1041,20 +962,17 @@ TEST_F(TouchDispositionGestureFilterTest, TestCancelMidGesture) {
// Test that a MultiFingerSwipe event is dispatched when appropriate.
TEST_F(TouchDispositionGestureFilterTest, TestAllowedMultiFingerSwipe) {
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_SWIPE);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SWIPE));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SWIPE),
GetAndResetSentGestures()));
@@ -1062,49 +980,49 @@ TEST_F(TouchDispositionGestureFilterTest, TestAllowedMultiFingerSwipe) {
// Test that a MultiFingerSwipe event is dispatched when appropriate.
TEST_F(TouchDispositionGestureFilterTest, TestDisallowedMultiFingerSwipe) {
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
- PushGesture(ET_GESTURE_SCROLL_BEGIN);
- MoveTouchPoint(0, 0, 0);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_BEGIN));
SendTouchConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SCROLL_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_PINCH_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_PINCH_BEGIN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_PINCH_BEGIN),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_SWIPE);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_SWIPE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
}
TEST_F(TouchDispositionGestureFilterTest, TapCancelOnSecondFingerDown) {
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL),
GetAndResetSentGestures()));
}
TEST_F(TouchDispositionGestureFilterTest, ShowPressBoundingBox) {
- PushGesture(ET_GESTURE_TAP_DOWN, 9, 9, 8);
- PressTouchPoint(9, 9);
+ GestureEventDataPacket press_packet;
+ press_packet.Push(CreateGesture(ET_GESTURE_TAP_DOWN, 9, 9, 8));
+ SendTouchGestures(PressTouchPoint(), press_packet);
+
SendTouchNotConsumedAck();
EXPECT_TRUE(
GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN), GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_TAP, 10, 10, 10);
- ReleaseTouchPoint();
+ GestureEventDataPacket release_packet;
+ release_packet.Push(CreateGesture(ET_GESTURE_TAP, 10, 10, 10));
+ SendTouchGestures(ReleaseTouchPoint(), release_packet);
+
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_SHOW_PRESS, ET_GESTURE_TAP),
GetAndResetSentGestures()));
@@ -1112,9 +1030,8 @@ TEST_F(TouchDispositionGestureFilterTest, ShowPressBoundingBox) {
}
TEST_F(TouchDispositionGestureFilterTest, TapCancelledBeforeGestureEnd) {
- PushGesture(ET_GESTURE_BEGIN);
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(),
+ Gestures(ET_GESTURE_BEGIN, ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_BEGIN, ET_GESTURE_TAP_DOWN),
GetAndResetSentGestures()));
@@ -1125,8 +1042,7 @@ TEST_F(TouchDispositionGestureFilterTest, TapCancelledBeforeGestureEnd) {
SendTimeoutGesture(ET_GESTURE_LONG_PRESS);
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_LONG_PRESS),
GetAndResetSentGestures()));
- PushGesture(ET_GESTURE_END);
- CancelTouchPoint();
+ SendPacket(CancelTouchPoint(), Gestures(ET_GESTURE_END));
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL, ET_GESTURE_END),
GetAndResetSentGestures()));
@@ -1134,15 +1050,14 @@ TEST_F(TouchDispositionGestureFilterTest, TapCancelledBeforeGestureEnd) {
TEST_F(TouchDispositionGestureFilterTest, EventFlagPropagation) {
// Real gestures should propagate flags from their causal touches.
- PushGesture(ET_GESTURE_TAP_DOWN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_TAP_DOWN));
SendTouchNotConsumedAck();
EXPECT_TRUE(
GesturesMatch(Gestures(ET_GESTURE_TAP_DOWN), GetAndResetSentGestures()));
EXPECT_EQ(kDefaultEventFlags, LastSentGestureFlags());
// Synthetic gestures lack flags.
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), NoGestures());
SendTouchNotConsumedAck();
EXPECT_TRUE(GesturesMatch(Gestures(ET_GESTURE_TAP_CANCEL),
GetAndResetSentGestures()));
@@ -1151,8 +1066,7 @@ TEST_F(TouchDispositionGestureFilterTest, EventFlagPropagation) {
TEST_F(TouchDispositionGestureFilterTest, PreviousScrollPrevented) {
- PushGesture(ET_GESTURE_BEGIN);
- PressTouchPoint(1, 1);
+ SendPacket(PressTouchPoint(), Gestures(ET_GESTURE_BEGIN));
EXPECT_FALSE(GesturesSent());
SendTouchNotConsumedAck();
EXPECT_TRUE(
@@ -1160,29 +1074,25 @@ TEST_F(TouchDispositionGestureFilterTest, PreviousScrollPrevented) {
// The sent scroll update should always reflect whether any preceding scroll
// update has been dropped.
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
ASSERT_TRUE(GesturesSent());
EXPECT_FALSE(last_sent_gesture()
.details.previous_scroll_update_in_sequence_prevented());
GetAndResetSentGestures();
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, -2, -2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchConsumedAck();
EXPECT_FALSE(GesturesSent());
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
ASSERT_TRUE(GesturesSent());
EXPECT_TRUE(last_sent_gesture()
.details.previous_scroll_update_in_sequence_prevented());
GetAndResetSentGestures();
- PushGesture(ET_GESTURE_SCROLL_UPDATE);
- MoveTouchPoint(0, 2, 2);
+ SendPacket(MoveTouchPoint(), Gestures(ET_GESTURE_SCROLL_UPDATE));
SendTouchNotConsumedAck();
ASSERT_TRUE(GesturesSent());
EXPECT_TRUE(last_sent_gesture()
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698