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

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

Issue 2680013009: Move touch slop suppression from LegacyTouchEventQueue 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 1369 matching lines...) Expand 10 before | Expand all | Expand 10 after
1380 EXPECT_FALSE(IsTimeoutRunning()); 1380 EXPECT_FALSE(IsTimeoutRunning());
1381 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1381 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1382 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1382 EXPECT_EQ(0U, GetAndResetSentEventCount());
1383 1383
1384 // Subsequent events should be handled normally. 1384 // Subsequent events should be handled normally.
1385 PressTouchPoint(0, 1); 1385 PressTouchPoint(0, 1);
1386 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1386 EXPECT_EQ(1U, GetAndResetSentEventCount());
1387 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1387 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1388 } 1388 }
1389 1389
1390 // Tests that TouchMove's are dropped if within the boundary-inclusive slop 1390 // Tests that TouchMove's movedBeyondSlopRegion is set to false if within the
1391 // suppression region for an unconsumed TouchStart. 1391 // boundary-inclusive slop region for an unconsumed TouchStart.
1392 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) { 1392 TEST_F(TouchEventQueueTest, TouchMovedBeyondSlopRegionCheck) {
1393 SetUpForTouchMoveSlopTesting(kSlopLengthDips); 1393 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1394 1394
1395 // Queue a TouchStart. 1395 // Queue a TouchStart.
1396 PressTouchPoint(0, 0); 1396 PressTouchPoint(0, 0);
1397 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1397 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1398 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1398 ASSERT_EQ(1U, GetAndResetSentEventCount());
1399 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1399 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1400 1400
1401 // TouchMove's within the region should be suppressed. 1401 // TouchMove's movedBeyondSlopRegion within the slop region is set to false.
1402 MoveTouchPoint(0, 0, kHalfSlopLengthDips); 1402 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1403 EXPECT_EQ(0U, queued_event_count()); 1403 EXPECT_EQ(1U, queued_event_count());
1404 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1404 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1405 EXPECT_EQ(1U, GetAndResetSentEventCount());
1405 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1406 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1406 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1407 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1407 1408
1408 MoveTouchPoint(0, kHalfSlopLengthDips, 0); 1409 MoveTouchPoint(0, kHalfSlopLengthDips, 0);
1409 EXPECT_EQ(0U, queued_event_count()); 1410 EXPECT_EQ(1U, queued_event_count());
1410 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1411 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1412 EXPECT_EQ(1U, GetAndResetSentEventCount());
1411 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1413 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1412 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1414 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1413 1415
1414 MoveTouchPoint(0, -kHalfSlopLengthDips, 0); 1416 MoveTouchPoint(0, -kHalfSlopLengthDips, 0);
1415 EXPECT_EQ(0U, queued_event_count()); 1417 EXPECT_EQ(1U, queued_event_count());
1416 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1418 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1419 EXPECT_EQ(1U, GetAndResetSentEventCount());
1417 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1420 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1418 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1421 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1419 1422
1420 MoveTouchPoint(0, -kSlopLengthDips, 0); 1423 MoveTouchPoint(0, -kSlopLengthDips, 0);
1421 EXPECT_EQ(0U, queued_event_count()); 1424 EXPECT_EQ(1U, queued_event_count());
1422 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1425 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1426 EXPECT_EQ(1U, GetAndResetSentEventCount());
1423 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1427 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1424 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1428 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1425 1429
1426 MoveTouchPoint(0, 0, kSlopLengthDips); 1430 MoveTouchPoint(0, 0, kSlopLengthDips);
1427 EXPECT_EQ(0U, queued_event_count()); 1431 EXPECT_EQ(1U, queued_event_count());
1428 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1432 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1433 EXPECT_EQ(1U, GetAndResetSentEventCount());
1429 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1434 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1430 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1435 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1431 1436
1432 // As soon as a TouchMove exceeds the (Euclidean) distance, no more 1437 // When a TouchMove exceeds the (Euclidean) distance, the TouchMove's
1433 // TouchMove's should be suppressed. 1438 // movedBeyondSlopRegion is set to true.
1434 const float kFortyFiveDegreeSlopLengthXY = 1439 const float kFortyFiveDegreeSlopLengthXY =
1435 kSlopLengthDips * std::sqrt(2.f) / 2; 1440 kSlopLengthDips * std::sqrt(2.f) / 2;
1436 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f, 1441 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f,
1437 kFortyFiveDegreeSlopLengthXY + .2f); 1442 kFortyFiveDegreeSlopLengthXY + .2f);
1438 EXPECT_EQ(1U, queued_event_count()); 1443 EXPECT_EQ(1U, queued_event_count());
1439 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1444 EXPECT_EQ(1U, GetAndResetSentEventCount());
1440 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1445 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1441 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1446 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1442 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1447 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1443 1448 EXPECT_TRUE(acked_event().movedBeyondSlopRegion);
1444 // Even TouchMove's within the original slop region should now be forwarded.
1445 MoveTouchPoint(0, 0, 0);
1446 EXPECT_EQ(1U, queued_event_count());
1447 EXPECT_EQ(1U, GetAndResetSentEventCount());
1448 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1449 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1450 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1451
1452 // A new touch sequence should reset suppression.
1453 ReleaseTouchPoint(0);
1454 PressTouchPoint(0, 0);
1455 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1456 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1457 ASSERT_EQ(2U, GetAndResetSentEventCount());
1458 ASSERT_EQ(2U, GetAndResetAckedEventCount());
1459 ASSERT_EQ(0U, queued_event_count());
1460
1461 // The slop region is boundary-inclusive.
1462 MoveTouchPoint(0, kSlopLengthDips - 1, 0);
1463 EXPECT_EQ(0U, queued_event_count());
1464 EXPECT_EQ(0U, GetAndResetSentEventCount());
1465 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1466
1467 MoveTouchPoint(0, kSlopLengthDips, 0);
1468 EXPECT_EQ(0U, queued_event_count());
1469 EXPECT_EQ(0U, GetAndResetSentEventCount());
1470 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1471 } 1449 }
1472 1450
1473 // Tests that TouchMove's are not dropped within the slop suppression region if 1451 // Tests that even very small TouchMove's movedBeyondSlopRegion is set to true
1474 // the touchstart was consumed. 1452 // when the slop region's dimension is 0.
1475 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) { 1453 TEST_F(TouchEventQueueTest, MovedBeyondSlopRegionAlwaysTrueIfDimensionZero) {
1476 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1477
1478 // Queue a TouchStart.
1479 PressTouchPoint(0, 0);
1480 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
1481 ASSERT_EQ(1U, GetAndResetSentEventCount());
1482 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1483
1484 // TouchMove's within the region should not be suppressed, as a touch was
1485 // consumed.
1486 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1487 EXPECT_EQ(1U, queued_event_count());
1488 EXPECT_EQ(1U, GetAndResetSentEventCount());
1489 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1490 }
1491
1492 // Tests that even very small TouchMove's are not suppressed when suppression is
1493 // disabled.
1494 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionIfDisabled) {
1495 // Queue a TouchStart. 1454 // Queue a TouchStart.
1496 PressTouchPoint(0, 0); 1455 PressTouchPoint(0, 0);
1497 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1456 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1498 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1457 ASSERT_EQ(1U, GetAndResetSentEventCount());
1499 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1458 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1500 1459
1501 // Small TouchMove's should not be suppressed. 1460 // Small TouchMove's movedBeyondSlopRegion is set to true.
1502 MoveTouchPoint(0, 0.001f, 0.001f); 1461 MoveTouchPoint(0, 0.001f, 0.001f);
1503 EXPECT_EQ(1U, queued_event_count()); 1462 EXPECT_EQ(1U, queued_event_count());
1504 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1463 EXPECT_EQ(1U, GetAndResetSentEventCount());
1505 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1464 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1506 }
1507
1508 // Tests that TouchMove's are not dropped if a secondary pointer is present
1509 // during any movement.
1510 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) {
1511 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1512
1513 // Queue a TouchStart.
1514 PressTouchPoint(0, 0);
1515 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1516 ASSERT_EQ(1U, GetAndResetSentEventCount());
1517 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1518
1519 // TouchMove's within the region should be suppressed.
1520 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1521 EXPECT_EQ(0U, queued_event_count());
1522 EXPECT_EQ(0U, GetAndResetSentEventCount());
1523 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1524
1525 // Simulate a secondary pointer press.
1526 PressTouchPoint(kSlopLengthDips, 0);
1527 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1528 EXPECT_EQ(1U, GetAndResetSentEventCount());
1529 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1530
1531 // TouchMove with a secondary pointer should not be suppressed.
1532 MoveTouchPoint(1, kSlopLengthDips+1, 0);
1533 EXPECT_EQ(1U, queued_event_count());
1534 EXPECT_EQ(1U, GetAndResetSentEventCount());
1535 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1465 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1536 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1466 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1537 1467 EXPECT_TRUE(acked_event().movedBeyondSlopRegion);
1538 // Release the secondary pointer.
1539 ReleaseTouchPoint(0);
1540 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1541 EXPECT_EQ(1U, GetAndResetSentEventCount());
1542 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1543
1544 // TouchMove's should not should be suppressed, even with the original
1545 // unmoved pointer.
1546 MoveTouchPoint(0, 0, 0);
1547 EXPECT_EQ(1U, queued_event_count());
1548 EXPECT_EQ(1U, GetAndResetSentEventCount());
1549 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1550 } 1468 }
1551 1469
1552 // Tests that secondary touch points can be forwarded even if the primary touch 1470 // Tests that secondary touch points can be forwarded even if the primary touch
1553 // point had no consumer. 1471 // point had no consumer.
1554 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) { 1472 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) {
1555 // Queue a TouchStart. 1473 // Queue a TouchStart.
1556 PressTouchPoint(0, 0); 1474 PressTouchPoint(0, 0);
1557 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS); 1475 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS);
1558 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1476 ASSERT_EQ(1U, GetAndResetSentEventCount());
1559 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1477 ASSERT_EQ(1U, GetAndResetAckedEventCount());
(...skipping 1191 matching lines...) Expand 10 before | Expand all | Expand 10 after
2751 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type()); 2669 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type());
2752 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2670 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2753 2671
2754 ReleaseTouchPoint(0); 2672 ReleaseTouchPoint(0);
2755 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); 2673 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
2756 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type()); 2674 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type());
2757 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2675 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2758 } 2676 }
2759 2677
2760 } // namespace content 2678 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/renderer_host/input/touch_event_queue.cc ('k') | third_party/WebKit/Source/core/input/TouchEventManager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698