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

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 1371 matching lines...) Expand 10 before | Expand all | Expand 10 after
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 are dropped if within the boundary-inclusive slop
1392 // suppression region for an unconsumed TouchStart. 1392 // suppression region for an unconsumed TouchStart.
tdresser 2017/02/02 21:30:54 Remove references in this file to slop suppression
lanwei 2017/02/03 21:39:33 Done.
1393 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) { 1393 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) {
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 within the region will not be suppressed in the browser side,
1403 // but its movedBeyondSlopRegion is set to false.
1403 MoveTouchPoint(0, 0, kHalfSlopLengthDips); 1404 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1404 EXPECT_EQ(0U, queued_event_count()); 1405 EXPECT_EQ(1U, queued_event_count());
1405 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1406 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1407 EXPECT_EQ(1U, GetAndResetSentEventCount());
1406 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1408 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1407 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1409 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1408 1410
1409 MoveTouchPoint(0, kHalfSlopLengthDips, 0); 1411 MoveTouchPoint(0, kHalfSlopLengthDips, 0);
1410 EXPECT_EQ(0U, queued_event_count()); 1412 EXPECT_EQ(1U, queued_event_count());
1411 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1413 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1414 EXPECT_EQ(1U, GetAndResetSentEventCount());
1412 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1415 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1413 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1416 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1414 1417
1415 MoveTouchPoint(0, -kHalfSlopLengthDips, 0); 1418 MoveTouchPoint(0, -kHalfSlopLengthDips, 0);
1416 EXPECT_EQ(0U, queued_event_count()); 1419 EXPECT_EQ(1U, queued_event_count());
1417 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1420 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1421 EXPECT_EQ(1U, GetAndResetSentEventCount());
1418 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1422 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1419 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1423 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1420 1424
1421 MoveTouchPoint(0, -kSlopLengthDips, 0); 1425 MoveTouchPoint(0, -kSlopLengthDips, 0);
1422 EXPECT_EQ(0U, queued_event_count()); 1426 EXPECT_EQ(1U, queued_event_count());
1423 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1427 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1428 EXPECT_EQ(1U, GetAndResetSentEventCount());
1424 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1429 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1425 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1430 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1426 1431
1427 MoveTouchPoint(0, 0, kSlopLengthDips); 1432 MoveTouchPoint(0, 0, kSlopLengthDips);
1428 EXPECT_EQ(0U, queued_event_count()); 1433 EXPECT_EQ(1U, queued_event_count());
1429 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1434 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1435 EXPECT_EQ(1U, GetAndResetSentEventCount());
1430 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1436 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1431 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state()); 1437 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1432 1438
1433 // As soon as a TouchMove exceeds the (Euclidean) distance, no more 1439 // When a TouchMove exceeds the (Euclidean) distance, the TouchMove's should
1434 // TouchMove's should be suppressed. 1440 // not be suppressed and its movedBeyondSlopRegion is set to true.
tdresser 2017/02/02 21:30:54 Don't refer to suppression here anymore. It implie
lanwei 2017/02/03 21:39:33 Done.
1435 const float kFortyFiveDegreeSlopLengthXY = 1441 const float kFortyFiveDegreeSlopLengthXY =
1436 kSlopLengthDips * std::sqrt(2.f) / 2; 1442 kSlopLengthDips * std::sqrt(2.f) / 2;
1437 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f, 1443 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f,
1438 kFortyFiveDegreeSlopLengthXY + .2f); 1444 kFortyFiveDegreeSlopLengthXY + .2f);
1439 EXPECT_EQ(1U, queued_event_count()); 1445 EXPECT_EQ(1U, queued_event_count());
1440 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1446 EXPECT_EQ(1U, GetAndResetSentEventCount());
1441 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1447 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1442 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1448 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1443 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1449 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1450 EXPECT_TRUE(acked_event().movedBeyondSlopRegion);
1444 1451
1445 // Even TouchMove's within the original slop region should now be forwarded. 1452 // Even TouchMove's within the original slop region should now be forwarded.
1446 MoveTouchPoint(0, 0, 0); 1453 MoveTouchPoint(0, 0, 0);
1447 EXPECT_EQ(1U, queued_event_count()); 1454 EXPECT_EQ(1U, queued_event_count());
1448 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1455 EXPECT_EQ(1U, GetAndResetSentEventCount());
1449 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1456 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1450 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1457 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1451 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1458 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1452 1459
1453 // A new touch sequence should reset suppression. 1460 // A new touch sequence should reset suppression.
1454 ReleaseTouchPoint(0); 1461 ReleaseTouchPoint(0);
1455 PressTouchPoint(0, 0); 1462 PressTouchPoint(0, 0);
1456 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1463 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1457 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1464 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1458 ASSERT_EQ(2U, GetAndResetSentEventCount()); 1465 ASSERT_EQ(2U, GetAndResetSentEventCount());
1459 ASSERT_EQ(2U, GetAndResetAckedEventCount()); 1466 ASSERT_EQ(2U, GetAndResetAckedEventCount());
1460 ASSERT_EQ(0U, queued_event_count()); 1467 ASSERT_EQ(0U, queued_event_count());
1461 1468
1462 // The slop region is boundary-inclusive. 1469 // The slop region is boundary-inclusive.
1463 MoveTouchPoint(0, kSlopLengthDips - 1, 0); 1470 MoveTouchPoint(0, kSlopLengthDips - 1, 0);
1464 EXPECT_EQ(0U, queued_event_count()); 1471 EXPECT_EQ(1U, queued_event_count());
1465 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1472 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1473 EXPECT_EQ(1U, GetAndResetSentEventCount());
1466 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1474 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1475 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1476
1467 1477
1468 MoveTouchPoint(0, kSlopLengthDips, 0); 1478 MoveTouchPoint(0, kSlopLengthDips, 0);
1469 EXPECT_EQ(0U, queued_event_count()); 1479 EXPECT_EQ(1U, queued_event_count());
1470 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1480 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1481 EXPECT_EQ(1U, GetAndResetSentEventCount());
1471 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1482 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1483 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1472 } 1484 }
1473 1485
1474 // Tests that TouchMove's are not dropped within the slop suppression region if 1486 // Tests that TouchMove's are not dropped within the slop suppression region if
1475 // the touchstart was consumed. 1487 // the touchstart was consumed.
1476 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) { 1488 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) {
1477 SetUpForTouchMoveSlopTesting(kSlopLengthDips); 1489 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1478 1490
1479 // Queue a TouchStart. 1491 // Queue a TouchStart.
1480 PressTouchPoint(0, 0); 1492 PressTouchPoint(0, 0);
1481 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); 1493 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
(...skipping 28 matching lines...) Expand all
1510 // during any movement. 1522 // during any movement.
1511 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) { 1523 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterMultiTouch) {
1512 SetUpForTouchMoveSlopTesting(kSlopLengthDips); 1524 SetUpForTouchMoveSlopTesting(kSlopLengthDips);
1513 1525
1514 // Queue a TouchStart. 1526 // Queue a TouchStart.
1515 PressTouchPoint(0, 0); 1527 PressTouchPoint(0, 0);
1516 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1528 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1517 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1529 ASSERT_EQ(1U, GetAndResetSentEventCount());
1518 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1530 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1519 1531
1520 // TouchMove's within the region should be suppressed. 1532 // TouchMove's within the region will not be suppressed in the browser side,
1533 // but its movedBeyondSlopRegion is set to true.
1521 MoveTouchPoint(0, 0, kHalfSlopLengthDips); 1534 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1522 EXPECT_EQ(0U, queued_event_count()); 1535 EXPECT_EQ(1U, queued_event_count());
1523 EXPECT_EQ(0U, GetAndResetSentEventCount()); 1536 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1537 EXPECT_EQ(1U, GetAndResetSentEventCount());
1524 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1538 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1539 EXPECT_FALSE(acked_event().movedBeyondSlopRegion);
1525 1540
1526 // Simulate a secondary pointer press. 1541 // Simulate a secondary pointer press.
1527 PressTouchPoint(kSlopLengthDips, 0); 1542 PressTouchPoint(kSlopLengthDips, 0);
1528 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1543 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1529 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1544 EXPECT_EQ(1U, GetAndResetSentEventCount());
1530 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1545 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1531 1546
1532 // TouchMove with a secondary pointer should not be suppressed. 1547 // TouchMove with a secondary pointer should not be suppressed.
1533 MoveTouchPoint(1, kSlopLengthDips+1, 0); 1548 MoveTouchPoint(1, kSlopLengthDips+1, 0);
1534 EXPECT_EQ(1U, queued_event_count()); 1549 EXPECT_EQ(1U, queued_event_count());
1535 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1550 EXPECT_EQ(1U, GetAndResetSentEventCount());
1536 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1551 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1537 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1552 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1538 1553
1539 // Release the secondary pointer. 1554 // Release the secondary pointer.
1540 ReleaseTouchPoint(0); 1555 ReleaseTouchPoint(0);
1541 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1556 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1542 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1557 EXPECT_EQ(1U, GetAndResetSentEventCount());
1543 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1558 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1544 1559
1545 // TouchMove's should not should be suppressed, even with the original 1560 // TouchMove's should not be suppressed, even with the original
tdresser 2017/02/02 21:30:54 Don't talk about suppression anymore.
lanwei 2017/02/03 21:39:33 Done.
1546 // unmoved pointer. 1561 // unmoved pointer.
1547 MoveTouchPoint(0, 0, 0); 1562 MoveTouchPoint(0, 0, 0);
1548 EXPECT_EQ(1U, queued_event_count()); 1563 EXPECT_EQ(1U, queued_event_count());
1549 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1564 EXPECT_EQ(1U, GetAndResetSentEventCount());
1550 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1565 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1551 } 1566 }
1552 1567
1553 // Tests that secondary touch points can be forwarded even if the primary touch 1568 // Tests that secondary touch points can be forwarded even if the primary touch
1554 // point had no consumer. 1569 // point had no consumer.
1555 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) { 1570 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) {
(...skipping 1196 matching lines...) Expand 10 before | Expand all | Expand 10 after
2752 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type()); 2767 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type());
2753 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2768 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2754 2769
2755 ReleaseTouchPoint(0); 2770 ReleaseTouchPoint(0);
2756 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); 2771 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
2757 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type()); 2772 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type());
2758 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2773 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2759 } 2774 }
2760 2775
2761 } // namespace content 2776 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698