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

Side by Side Diff: content/browser/renderer_host/input/touch_event_queue_unittest.cc

Issue 2669663002: Move touch slop suppression to TouchEventManager (Closed)
Patch Set: slop region Created 3 years, 10 months 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/browser/renderer_host/input/touch_event_queue.h" 5 #include "content/browser/renderer_host/input/touch_event_queue.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <memory> 9 #include <memory>
10 #include <utility> 10 #include <utility>
(...skipping 1370 matching lines...) Expand 10 before | Expand all | Expand 10 after
1381 EXPECT_FALSE(IsTimeoutRunning()); 1381 EXPECT_FALSE(IsTimeoutRunning());
1382 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1382 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1383 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1383 EXPECT_EQ(0U, GetAndResetSentEventCount());
1384 1384
1385 // Subsequent events should be handled normally. 1385 // Subsequent events should be handled normally.
1386 PressTouchPoint(0, 1); 1386 PressTouchPoint(0, 1);
1387 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1387 EXPECT_EQ(1U, GetAndResetSentEventCount());
1388 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1388 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1389 } 1389 }
1390 1390
1391 // Tests that TouchMove's are dropped if within the boundary-inclusive slop 1391 // Tests that TouchMove's movedBeyondSlopRegion is set to false if within the
1392 // suppression region for an unconsumed TouchStart. 1392 // boundary-inclusive slop region for an unconsumed TouchStart.
1393 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) { 1393 TEST_F(TouchEventQueueTest, TouchMovedBeyondSlopRegionCheck) {
1394 SetUpForTouchMoveSlopTesting(kSlopLengthDips); 1394 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1395 1395
1396 // Queue a TouchStart. 1396 // Queue a TouchStart.
1397 PressTouchPoint(0, 0); 1397 PressTouchPoint(0, 0);
1398 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1398 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1399 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1399 ASSERT_EQ(1U, GetAndResetSentEventCount());
1400 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1400 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1401 1401
1402 // TouchMove's within the region should be suppressed. 1402 // TouchMove's movedBeyondSlopRegion within the slop region is set to false.
1403 MoveTouchPoint(0, 0, kHalfSlopLengthDips); 1403 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1404 EXPECT_EQ(0U, queued_event_count()); 1404 EXPECT_EQ(1U, queued_event_count());
1405 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1405 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1406 EXPECT_EQ(1U, GetAndResetSentEventCount());
1406 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1407 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1407 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1408 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1408 1409
1409 MoveTouchPoint(0, kHalfSlopLengthDips, 0); 1410 MoveTouchPoint(0, kHalfSlopLengthDips, 0);
1410 EXPECT_EQ(0U, queued_event_count()); 1411 EXPECT_EQ(1U, queued_event_count());
1411 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1412 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1413 EXPECT_EQ(1U, GetAndResetSentEventCount());
1412 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1414 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1413 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1415 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1414 1416
1415 MoveTouchPoint(0, -kHalfSlopLengthDips, 0); 1417 MoveTouchPoint(0, -kHalfSlopLengthDips, 0);
1416 EXPECT_EQ(0U, queued_event_count()); 1418 EXPECT_EQ(1U, queued_event_count());
1417 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1419 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1420 EXPECT_EQ(1U, GetAndResetSentEventCount());
1418 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1421 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1419 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1422 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1420 1423
1421 MoveTouchPoint(0, -kSlopLengthDips, 0); 1424 MoveTouchPoint(0, -kSlopLengthDips, 0);
1422 EXPECT_EQ(0U, queued_event_count()); 1425 EXPECT_EQ(1U, queued_event_count());
1423 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1426 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1427 EXPECT_EQ(1U, GetAndResetSentEventCount());
1424 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1428 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1425 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1429 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1426 1430
1427 MoveTouchPoint(0, 0, kSlopLengthDips); 1431 MoveTouchPoint(0, 0, kSlopLengthDips);
1428 EXPECT_EQ(0U, queued_event_count()); 1432 EXPECT_EQ(1U, queued_event_count());
1429 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1433 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1434 EXPECT_EQ(1U, GetAndResetSentEventCount());
1430 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1435 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1431 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1436 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1432 1437
1433 // As soon as a TouchMove exceeds the (Euclidean) distance, no more 1438 // When a TouchMove exceeds the (Euclidean) distance, the TouchMove's
1434 // TouchMove's should be suppressed. 1439 // movedBeyondSlopRegion is set to true.
1435 const float kFortyFiveDegreeSlopLengthXY = 1440 const float kFortyFiveDegreeSlopLengthXY =
1436 kSlopLengthDips * std::sqrt(2.f) / 2; 1441 kSlopLengthDips * std::sqrt(2.f) / 2;
1437 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f, 1442 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f,
1438 kFortyFiveDegreeSlopLengthXY + .2f); 1443 kFortyFiveDegreeSlopLengthXY + .2f);
1439 EXPECT_EQ(1U, queued_event_count()); 1444 EXPECT_EQ(1U, queued_event_count());
1440 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1445 EXPECT_EQ(1U, GetAndResetSentEventCount());
1441 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1446 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1442 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1447 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1443 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1448 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1444 1449 EXPECT_TRUE(acked_event().movedBeyondSlopRegion);
1445 // Even TouchMove's within the original slop region should now be forwarded.
1446 MoveTouchPoint(0, 0, 0);
1447 EXPECT_EQ(1U, queued_event_count());
1448 EXPECT_EQ(1U, GetAndResetSentEventCount());
1449 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1450 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1451 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1452
1453 // A new touch sequence should reset suppression.
1454 ReleaseTouchPoint(0);
1455 PressTouchPoint(0, 0);
1456 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1457 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1458 ASSERT_EQ(2U, GetAndResetSentEventCount());
1459 ASSERT_EQ(2U, GetAndResetAckedEventCount());
1460 ASSERT_EQ(0U, queued_event_count());
1461
1462 // The slop region is boundary-inclusive.
1463 MoveTouchPoint(0, kSlopLengthDips - 1, 0);
1464 EXPECT_EQ(0U, queued_event_count());
1465 EXPECT_EQ(0U, GetAndResetSentEventCount());
1466 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1467
1468 MoveTouchPoint(0, kSlopLengthDips, 0);
1469 EXPECT_EQ(0U, queued_event_count());
1470 EXPECT_EQ(0U, GetAndResetSentEventCount());
1471 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1472 } 1450 }
1473 1451
1474 // Tests that TouchMove's are not dropped within the slop suppression region if 1452 // Tests that TouchMove's are not dropped within the slop suppression region if
tdresser 2017/02/06 14:25:59 We're still referring to suppression.
lanwei 2017/02/06 21:36:23 Removed, we cannot test it anymore.
1475 // the touchstart was consumed. 1453 // the touchstart was consumed.
1476 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) { 1454 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) {
1477 SetUpForTouchMoveSlopTesting(kSlopLengthDips); 1455 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1478 1456
1479 // Queue a TouchStart. 1457 // Queue a TouchStart.
1480 PressTouchPoint(0, 0); 1458 PressTouchPoint(0, 0);
1481 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); 1459 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
1482 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1460 ASSERT_EQ(1U, GetAndResetSentEventCount());
1483 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1461 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1484 1462
1485 // TouchMove's within the region should not be suppressed, as a touch was 1463 // TouchMove's within the region should not be suppressed, as a touch was
1486 // consumed. 1464 // consumed.
1487 MoveTouchPoint(0, 0, kHalfSlopLengthDips); 1465 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1488 EXPECT_EQ(1U, queued_event_count()); 1466 EXPECT_EQ(1U, queued_event_count());
1489 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1467 EXPECT_EQ(1U, GetAndResetSentEventCount());
1490 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1468 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1491 } 1469 }
1492 1470
1493 // Tests that even very small TouchMove's are not suppressed when suppression is 1471 // Tests that even very small TouchMove's movedBeyondSlopRegion is set to true
1494 // disabled. 1472 // when the slop region's dimension is 0.
1495 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionIfDisabled) { 1473 TEST_F(TouchEventQueueTest, MovedBeyondSlopRegionAlwaysTrueIfDimensionZero) {
1496 // Queue a TouchStart. 1474 // Queue a TouchStart.
1497 PressTouchPoint(0, 0); 1475 PressTouchPoint(0, 0);
1498 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1476 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1499 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1477 ASSERT_EQ(1U, GetAndResetSentEventCount());
1500 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1478 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1501 1479
1502 // Small TouchMove's should not be suppressed. 1480 // Small TouchMove's movedBeyondSlopRegion is set to true.
1503 MoveTouchPoint(0, 0.001f, 0.001f); 1481 MoveTouchPoint(0, 0.001f, 0.001f);
1504 EXPECT_EQ(1U, queued_event_count()); 1482 EXPECT_EQ(1U, queued_event_count());
1505 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1483 EXPECT_EQ(1U, GetAndResetSentEventCount());
1506 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1484 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1507 }
1508
1509 // Tests that TouchMove's are not dropped if a secondary pointer is present
1510 // during any movement.
1511 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) {
1512 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1513
1514 // Queue a TouchStart.
1515 PressTouchPoint(0, 0);
1516 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1517 ASSERT_EQ(1U, GetAndResetSentEventCount());
1518 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1519
1520 // TouchMove's within the region should be suppressed.
1521 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1522 EXPECT_EQ(0U, queued_event_count());
1523 EXPECT_EQ(0U, GetAndResetSentEventCount());
1524 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1525
1526 // Simulate a secondary pointer press.
1527 PressTouchPoint(kSlopLengthDips, 0);
1528 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1529 EXPECT_EQ(1U, GetAndResetSentEventCount());
1530 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1531
1532 // TouchMove with a secondary pointer should not be suppressed.
1533 MoveTouchPoint(1, kSlopLengthDips+1, 0);
1534 EXPECT_EQ(1U, queued_event_count());
1535 EXPECT_EQ(1U, GetAndResetSentEventCount());
1536 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1485 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1537 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1486 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1538 1487 EXPECT_TRUE(acked_event().movedBeyondSlopRegion);
1539 // Release the secondary pointer.
1540 ReleaseTouchPoint(0);
1541 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1542 EXPECT_EQ(1U, GetAndResetSentEventCount());
1543 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1544
1545 // TouchMove's should not should be suppressed, even with the original
1546 // unmoved pointer.
1547 MoveTouchPoint(0, 0, 0);
1548 EXPECT_EQ(1U, queued_event_count());
1549 EXPECT_EQ(1U, GetAndResetSentEventCount());
1550 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1551 } 1488 }
1552 1489
1553 // Tests that secondary touch points can be forwarded even if the primary touch 1490 // Tests that secondary touch points can be forwarded even if the primary touch
1554 // point had no consumer. 1491 // point had no consumer.
1555 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) { 1492 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) {
1556 // Queue a TouchStart. 1493 // Queue a TouchStart.
1557 PressTouchPoint(0, 0); 1494 PressTouchPoint(0, 0);
1558 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS); 1495 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS);
1559 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1496 ASSERT_EQ(1U, GetAndResetSentEventCount());
1560 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1497 ASSERT_EQ(1U, GetAndResetAckedEventCount());
(...skipping 1191 matching lines...) Expand 10 before | Expand all | Expand 10 after
2752 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type()); 2689 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type());
2753 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2690 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2754 2691
2755 ReleaseTouchPoint(0); 2692 ReleaseTouchPoint(0);
2756 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); 2693 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
2757 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type()); 2694 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type());
2758 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2695 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2759 } 2696 }
2760 2697
2761 } // namespace content 2698 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698