Chromium Code Reviews| Index: content/browser/renderer_host/input/touch_event_queue_unittest.cc |
| diff --git a/content/browser/renderer_host/input/touch_event_queue_unittest.cc b/content/browser/renderer_host/input/touch_event_queue_unittest.cc |
| index 8d50b0b7483270b230d2a30a40e73e28a388678a..6d0d1a1c9f242d604a8e56d5a8f9fba5ef272fe0 100644 |
| --- a/content/browser/renderer_host/input/touch_event_queue_unittest.cc |
| +++ b/content/browser/renderer_host/input/touch_event_queue_unittest.cc |
| @@ -872,7 +872,7 @@ TEST_F(TouchEventQueueTest, ImmediateAckWithFollowupEvents) { |
| SetFollowupEvent(followup_event); |
| // Now, enqueue a stationary touch that will not be forwarded. This should be |
| - // immediately ack'ed with "NO_CONSUMER_EXISTS". The followup event should |
| + // immediately ack'ed with "NOT_CONSUMED". The followup event should |
| // then be enqueued and immediately sent to the renderer. |
| WebTouchEvent stationary_event; |
| stationary_event.touchesLength = 1; |
| @@ -884,7 +884,7 @@ TEST_F(TouchEventQueueTest, ImmediateAckWithFollowupEvents) { |
| EXPECT_EQ(1U, queued_event_count()); |
| EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| - EXPECT_EQ(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS, acked_event_state()); |
| + EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); |
| EXPECT_EQ(WebInputEvent::TouchMove, acked_event().type); |
| } |
| @@ -1438,7 +1438,7 @@ TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) { |
| EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| // TouchMove with a secondary pointer should not be suppressed. |
| - MoveTouchPoint(1, kSlopLengthDips, 0); |
| + MoveTouchPoint(1, kSlopLengthDips+1, 0); |
| EXPECT_EQ(1U, queued_event_count()); |
| EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| @@ -1502,7 +1502,7 @@ TEST_F(TouchEventQueueTest, NoForwardingAfterScrollWithNoTouchConsumers) { |
| MoveTouchPoint(0, 20, 5); |
| EXPECT_EQ(0U, GetAndResetSentEventCount()); |
| EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| - EXPECT_EQ(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS, acked_event_state()); |
| + EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); |
|
jdduke (slow)
2015/02/13 16:37:37
This doesn't look right, see my other comment. Let
USE s.singapati at gmail.com
2015/02/16 10:52:01
Done.
|
| // The secondary pointer press should not be forwarded. |
| PressTouchPoint(20, 0); |
| @@ -1528,7 +1528,7 @@ TEST_F(TouchEventQueueTest, AsyncTouch) { |
| SendGestureEventAck(WebInputEvent::GestureScrollUpdate, |
| INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| - MoveTouchPoint(0, 10, 5); |
| + MoveTouchPoint(0, 10, 5+i); |
| SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| EXPECT_FALSE(HasPendingAsyncTouchMove()); |
| EXPECT_TRUE(sent_event().cancelable); |
| @@ -1538,7 +1538,7 @@ TEST_F(TouchEventQueueTest, AsyncTouch) { |
| // Consuming a scroll event will throttle subsequent touchmoves. |
| SendGestureEventAck(WebInputEvent::GestureScrollUpdate, |
| INPUT_EVENT_ACK_STATE_CONSUMED); |
| - MoveTouchPoint(0, 10, 5); |
| + MoveTouchPoint(0, 10, 7+i); |
| SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| EXPECT_TRUE(HasPendingAsyncTouchMove()); |
| EXPECT_EQ(0U, queued_event_count()); |
| @@ -1629,7 +1629,7 @@ TEST_F(TouchEventQueueTest, AsyncTouchThrottledAfterScroll) { |
| EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| - MoveTouchPoint(0, 0, 5); |
| + MoveTouchPoint(0, 0, 6); |
| followup_scroll.type = WebInputEvent::GestureScrollUpdate; |
| SetFollowupEvent(followup_scroll); |
| SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); |
| @@ -1707,11 +1707,11 @@ TEST_F(TouchEventQueueTest, AsyncTouchThrottledAfterScroll) { |
| // The pending touchmove should be coalesced with the next (now synchronous) |
| // touchmove. |
| - MoveTouchPoint(0, 0, 25); |
| + MoveTouchPoint(0, 0, 26); |
| EXPECT_TRUE(sent_event().cancelable); |
| EXPECT_FALSE(HasPendingAsyncTouchMove()); |
| EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type); |
| - EXPECT_EQ(WebTouchPoint::StateStationary, sent_event().touches[0].state); |
| + EXPECT_EQ(WebTouchPoint::StateMoved, sent_event().touches[0].state); |
| EXPECT_EQ(WebTouchPoint::StateMoved, sent_event().touches[1].state); |
| EXPECT_EQ(1U, queued_event_count()); |
| EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| @@ -2192,28 +2192,69 @@ TEST_F(TouchEventQueueTest, PointerStatesWhenOtherThanPositionChanged) { |
| // Change touch point rotationAngle. |
| ChangeTouchPointRotationAngle(0, 1.1f); |
| + SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| // TouchMove is sent. Test for pointer state. |
| const WebTouchEvent& event3 = sent_event(); |
| EXPECT_EQ(WebInputEvent::TouchMove, event3.type); |
| EXPECT_EQ(WebTouchPoint::StateMoved, event3.touches[0].state); |
| - // TODO(jdduke): Now trying to forward a TouchMove event without really |
| - // changing touch point properties. Update below test with testing for |
| - // rejected TouchMove with ack state INPUT_EVENT_ACK_STATE_NOT_CONSUMED, |
| - // crbug.com/452032. Or should it be in a separte test?. |
| + EXPECT_EQ(0U, queued_event_count()); |
| + EXPECT_EQ(4U, GetAndResetSentEventCount()); |
| + EXPECT_EQ(4U, GetAndResetAckedEventCount()); |
| +} |
| - // Do not change any properties, but use previous values. |
| - MoveTouchPoint(0, 1.f, 1.f); |
| - ChangeTouchPointRadius(0, 1.5f, 1.f); |
| +// Tests that TouchMoves are filtered when none of the points are changed. |
| +TEST_F(TouchEventQueueTest, FilterTouchMovesWhenNoPointerChanged) { |
| + PressTouchPoint(1, 1); |
| + PressTouchPoint(2, 2); |
| + SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| + SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| + EXPECT_EQ(0U, queued_event_count()); |
| + EXPECT_EQ(2U, GetAndResetSentEventCount()); |
| + EXPECT_EQ(2U, GetAndResetAckedEventCount()); |
| + |
| + // Move 1st touch point. |
| + MoveTouchPoint(0, 10, 10); |
| + EXPECT_EQ(1U, queued_event_count()); |
| + EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| + EXPECT_EQ(0U, GetAndResetAckedEventCount()); |
| - // Receive an ACK for previous TouchMove. |
| + // TouchMove should be allowed and test for touches state. |
| + const WebTouchEvent& event1 = sent_event(); |
| + EXPECT_EQ(WebInputEvent::TouchMove, event1.type); |
| + EXPECT_EQ(WebTouchPoint::StateMoved, event1.touches[0].state); |
| + EXPECT_EQ(WebTouchPoint::StateStationary, event1.touches[1].state); |
| + |
| + // Do not really move any touch points, but use previous values. |
| + MoveTouchPoint(0, 10, 10); |
| + ChangeTouchPointRadius(1, 1, 1); |
| + MoveTouchPoint(1, 2, 2); |
| + EXPECT_EQ(2U, queued_event_count()); |
| + EXPECT_EQ(0U, GetAndResetSentEventCount()); |
| + |
| + // Receive an ACK for 1st TouchMove. |
| SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| - // TouchMove is sent, but pointer state should be StateStationary. |
| - const WebTouchEvent& event4 = sent_event(); |
| - EXPECT_EQ(WebInputEvent::TouchMove, event4.type); |
| - EXPECT_EQ(WebTouchPoint::StateStationary, event4.touches[0].state); |
| + // Tries to forward TouchMove but should be filtered |
| + // when none of the touch points have changed. |
| + EXPECT_EQ(0U, queued_event_count()); |
| + EXPECT_EQ(0U, GetAndResetSentEventCount()); |
| + EXPECT_EQ(4U, GetAndResetAckedEventCount()); |
| + EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); |
| + |
| + // Move 2nd touch point. |
| + MoveTouchPoint(1, 3, 3); |
| + SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); |
| + EXPECT_EQ(0U, queued_event_count()); |
| + EXPECT_EQ(1U, GetAndResetSentEventCount()); |
| + EXPECT_EQ(1U, GetAndResetAckedEventCount()); |
| + |
| + // TouchMove should be allowed and test for touches state. |
| + const WebTouchEvent& event2 = sent_event(); |
| + EXPECT_EQ(WebInputEvent::TouchMove, event2.type); |
| + EXPECT_EQ(WebTouchPoint::StateStationary, event2.touches[0].state); |
| + EXPECT_EQ(WebTouchPoint::StateMoved, event2.touches[1].state); |
| } |
| } // namespace content |