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

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

Issue 2691993005: Revert of Move touch slop suppression from LegacyTouchEventQueue to TouchEventManager (Closed)
Patch Set: 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 movedBeyondSlopRegion is set to false if within the 1390 // Tests that TouchMove's are dropped if within the boundary-inclusive slop
1391 // boundary-inclusive slop region for an unconsumed TouchStart. 1391 // suppression region for an unconsumed TouchStart.
1392 TEST_F(TouchEventQueueTest, TouchMovedBeyondSlopRegionCheck) { 1392 TEST_F(TouchEventQueueTest, TouchMoveSuppressionIncludingSlopBoundary) {
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 movedBeyondSlopRegion within the slop region is set to false. 1401 // TouchMove's within the region should be suppressed.
1402 MoveTouchPoint(0, 0, kHalfSlopLengthDips); 1402 MoveTouchPoint(0, 0, kHalfSlopLengthDips);
1403 EXPECT_EQ(1U, queued_event_count()); 1403 EXPECT_EQ(0U, queued_event_count());
1404 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1404 EXPECT_EQ(0U, GetAndResetSentEventCount());
1405 EXPECT_EQ(1U, GetAndResetSentEventCount());
1406 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1405 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1407 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); 1406 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state());
1408 1407
1409 MoveTouchPoint(0, kHalfSlopLengthDips, 0); 1408 MoveTouchPoint(0, kHalfSlopLengthDips, 0);
1410 EXPECT_EQ(1U, queued_event_count()); 1409 EXPECT_EQ(0U, queued_event_count());
1411 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1410 EXPECT_EQ(0U, GetAndResetSentEventCount());
1412 EXPECT_EQ(1U, GetAndResetSentEventCount());
1413 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1411 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1414 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); 1412 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state());
1415 1413
1416 MoveTouchPoint(0, -kHalfSlopLengthDips, 0); 1414 MoveTouchPoint(0, -kHalfSlopLengthDips, 0);
1417 EXPECT_EQ(1U, queued_event_count()); 1415 EXPECT_EQ(0U, queued_event_count());
1418 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1416 EXPECT_EQ(0U, GetAndResetSentEventCount());
1419 EXPECT_EQ(1U, GetAndResetSentEventCount());
1420 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1417 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1421 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); 1418 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state());
1422 1419
1423 MoveTouchPoint(0, -kSlopLengthDips, 0); 1420 MoveTouchPoint(0, -kSlopLengthDips, 0);
1424 EXPECT_EQ(1U, queued_event_count()); 1421 EXPECT_EQ(0U, queued_event_count());
1425 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1422 EXPECT_EQ(0U, GetAndResetSentEventCount());
1426 EXPECT_EQ(1U, GetAndResetSentEventCount());
1427 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1423 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1428 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); 1424 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state());
1429 1425
1430 MoveTouchPoint(0, 0, kSlopLengthDips); 1426 MoveTouchPoint(0, 0, kSlopLengthDips);
1431 EXPECT_EQ(1U, queued_event_count()); 1427 EXPECT_EQ(0U, queued_event_count());
1432 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1428 EXPECT_EQ(0U, GetAndResetSentEventCount());
1433 EXPECT_EQ(1U, GetAndResetSentEventCount());
1434 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1429 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1435 EXPECT_FALSE(acked_event().movedBeyondSlopRegion); 1430 EXPECT_EQ(INPUT_EVENT_ACK_STATE_NOT_CONSUMED, acked_event_state());
1436 1431
1437 // When a TouchMove exceeds the (Euclidean) distance, the TouchMove's 1432 // As soon as a TouchMove exceeds the (Euclidean) distance, no more
1438 // movedBeyondSlopRegion is set to true. 1433 // TouchMove's should be suppressed.
1439 const float kFortyFiveDegreeSlopLengthXY = 1434 const float kFortyFiveDegreeSlopLengthXY =
1440 kSlopLengthDips * std::sqrt(2.f) / 2; 1435 kSlopLengthDips * std::sqrt(2.f) / 2;
1441 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f, 1436 MoveTouchPoint(0, kFortyFiveDegreeSlopLengthXY + .2f,
1442 kFortyFiveDegreeSlopLengthXY + .2f); 1437 kFortyFiveDegreeSlopLengthXY + .2f);
1443 EXPECT_EQ(1U, queued_event_count()); 1438 EXPECT_EQ(1U, queued_event_count());
1444 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1439 EXPECT_EQ(1U, GetAndResetSentEventCount());
1445 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1440 EXPECT_EQ(0U, GetAndResetAckedEventCount());
1446 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1441 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1447 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1442 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1448 EXPECT_TRUE(acked_event().movedBeyondSlopRegion); 1443
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());
1449 } 1471 }
1450 1472
1451 // Tests that even very small TouchMove's movedBeyondSlopRegion is set to true 1473 // Tests that TouchMove's are not dropped within the slop suppression region if
1452 // when the slop region's dimension is 0. 1474 // the touchstart was consumed.
1453 TEST_F(TouchEventQueueTest, MovedBeyondSlopRegionAlwaysTrueIfDimensionZero) { 1475 TEST_F(TouchEventQueueTest, NoTouchMoveSuppressionAfterTouchConsumed) {
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) {
1454 // Queue a TouchStart. 1495 // Queue a TouchStart.
1455 PressTouchPoint(0, 0); 1496 PressTouchPoint(0, 0);
1456 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1497 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1457 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1498 ASSERT_EQ(1U, GetAndResetSentEventCount());
1458 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1499 ASSERT_EQ(1U, GetAndResetAckedEventCount());
1459 1500
1460 // Small TouchMove's movedBeyondSlopRegion is set to true. 1501 // Small TouchMove's should not be suppressed.
1461 MoveTouchPoint(0, 0.001f, 0.001f); 1502 MoveTouchPoint(0, 0.001f, 0.001f);
1462 EXPECT_EQ(1U, queued_event_count()); 1503 EXPECT_EQ(1U, queued_event_count());
1463 EXPECT_EQ(1U, GetAndResetSentEventCount()); 1504 EXPECT_EQ(1U, GetAndResetSentEventCount());
1464 EXPECT_EQ(0U, GetAndResetAckedEventCount()); 1505 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());
1465 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED); 1535 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NOT_CONSUMED);
1466 EXPECT_EQ(1U, GetAndResetAckedEventCount()); 1536 EXPECT_EQ(1U, GetAndResetAckedEventCount());
1467 EXPECT_TRUE(acked_event().movedBeyondSlopRegion); 1537
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());
1468 } 1550 }
1469 1551
1470 // Tests that secondary touch points can be forwarded even if the primary touch 1552 // Tests that secondary touch points can be forwarded even if the primary touch
1471 // point had no consumer. 1553 // point had no consumer.
1472 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) { 1554 TEST_F(TouchEventQueueTest, SecondaryTouchForwardedAfterPrimaryHadNoConsumer) {
1473 // Queue a TouchStart. 1555 // Queue a TouchStart.
1474 PressTouchPoint(0, 0); 1556 PressTouchPoint(0, 0);
1475 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS); 1557 SendTouchEventAck(INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS);
1476 ASSERT_EQ(1U, GetAndResetSentEventCount()); 1558 ASSERT_EQ(1U, GetAndResetSentEventCount());
1477 ASSERT_EQ(1U, GetAndResetAckedEventCount()); 1559 ASSERT_EQ(1U, GetAndResetAckedEventCount());
(...skipping 1191 matching lines...) Expand 10 before | Expand all | Expand 10 after
2669 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type()); 2751 EXPECT_EQ(WebInputEvent::TouchMove, sent_event().type());
2670 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2752 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2671 2753
2672 ReleaseTouchPoint(0); 2754 ReleaseTouchPoint(0);
2673 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED); 2755 SendTouchEventAck(INPUT_EVENT_ACK_STATE_CONSUMED);
2674 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type()); 2756 EXPECT_EQ(WebInputEvent::TouchEnd, sent_event().type());
2675 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove); 2757 EXPECT_FALSE(sent_event().touchStartOrFirstTouchMove);
2676 } 2758 }
2677 2759
2678 } // namespace content 2760 } // 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