OLD | NEW |
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 "base/bind.h" | 5 #include "base/bind.h" |
6 #include "base/memory/scoped_ptr.h" | 6 #include "base/memory/scoped_ptr.h" |
7 #include "base/time/time.h" | 7 #include "base/time/time.h" |
8 #include "content/browser/renderer_host/input/synthetic_gesture.h" | 8 #include "content/browser/renderer_host/input/synthetic_gesture.h" |
9 #include "content/browser/renderer_host/input/synthetic_gesture_controller.h" | 9 #include "content/browser/renderer_host/input/synthetic_gesture_controller.h" |
10 #include "content/browser/renderer_host/input/synthetic_gesture_target.h" | 10 #include "content/browser/renderer_host/input/synthetic_gesture_target.h" |
(...skipping 367 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
378 } | 378 } |
379 | 379 |
380 void QueueSyntheticGesture(scoped_ptr<SyntheticGesture> gesture) { | 380 void QueueSyntheticGesture(scoped_ptr<SyntheticGesture> gesture) { |
381 controller_->QueueSyntheticGesture(gesture.Pass(), | 381 controller_->QueueSyntheticGesture(gesture.Pass(), |
382 base::Bind(&SyntheticGestureControllerTest::OnSyntheticGestureCompleted, | 382 base::Bind(&SyntheticGestureControllerTest::OnSyntheticGestureCompleted, |
383 base::Unretained(this))); | 383 base::Unretained(this))); |
384 } | 384 } |
385 | 385 |
386 void FlushInputUntilComplete() { | 386 void FlushInputUntilComplete() { |
387 while (target_->flush_requested()) { | 387 while (target_->flush_requested()) { |
388 target_->ClearFlushRequest(); | 388 while (target_->flush_requested()) { |
389 time_ += base::TimeDelta::FromMilliseconds(kFlushInputRateInMs); | 389 target_->ClearFlushRequest(); |
390 controller_->Flush(time_); | 390 time_ += base::TimeDelta::FromMilliseconds(kFlushInputRateInMs); |
| 391 controller_->Flush(time_); |
| 392 } |
| 393 controller_->OnDidFlushInput(); |
391 } | 394 } |
392 } | 395 } |
393 | 396 |
394 void OnSyntheticGestureCompleted(SyntheticGesture::Result result) { | 397 void OnSyntheticGestureCompleted(SyntheticGesture::Result result) { |
395 DCHECK_NE(result, SyntheticGesture::GESTURE_RUNNING); | 398 DCHECK_NE(result, SyntheticGesture::GESTURE_RUNNING); |
396 if (result == SyntheticGesture::GESTURE_FINISHED) | 399 if (result == SyntheticGesture::GESTURE_FINISHED) |
397 num_success_++; | 400 num_success_++; |
398 else | 401 else |
399 num_failure_++; | 402 num_failure_++; |
400 } | 403 } |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
476 QueueSyntheticGesture(gesture_2.PassAs<SyntheticGesture>()); | 479 QueueSyntheticGesture(gesture_2.PassAs<SyntheticGesture>()); |
477 FlushInputUntilComplete(); | 480 FlushInputUntilComplete(); |
478 | 481 |
479 EXPECT_TRUE(finished_1); | 482 EXPECT_TRUE(finished_1); |
480 EXPECT_TRUE(finished_2); | 483 EXPECT_TRUE(finished_2); |
481 | 484 |
482 EXPECT_EQ(2, num_success_); | 485 EXPECT_EQ(2, num_success_); |
483 EXPECT_EQ(0, num_failure_); | 486 EXPECT_EQ(0, num_failure_); |
484 } | 487 } |
485 | 488 |
| 489 TEST_F(SyntheticGestureControllerTest, GestureCompletedOnDidFlushInput) { |
| 490 CreateControllerAndTarget<MockSyntheticGestureTarget>(); |
| 491 |
| 492 bool finished_1, finished_2; |
| 493 scoped_ptr<MockSyntheticGesture> gesture_1( |
| 494 new MockSyntheticGesture(&finished_1, 2)); |
| 495 scoped_ptr<MockSyntheticGesture> gesture_2( |
| 496 new MockSyntheticGesture(&finished_2, 4)); |
| 497 |
| 498 QueueSyntheticGesture(gesture_1.PassAs<SyntheticGesture>()); |
| 499 QueueSyntheticGesture(gesture_2.PassAs<SyntheticGesture>()); |
| 500 |
| 501 while (target_->flush_requested()) { |
| 502 target_->ClearFlushRequest(); |
| 503 time_ += base::TimeDelta::FromMilliseconds(kFlushInputRateInMs); |
| 504 controller_->Flush(time_); |
| 505 } |
| 506 EXPECT_EQ(0, num_success_); |
| 507 controller_->OnDidFlushInput(); |
| 508 EXPECT_EQ(1, num_success_); |
| 509 |
| 510 while (target_->flush_requested()) { |
| 511 target_->ClearFlushRequest(); |
| 512 time_ += base::TimeDelta::FromMilliseconds(kFlushInputRateInMs); |
| 513 controller_->Flush(time_); |
| 514 } |
| 515 EXPECT_EQ(1, num_success_); |
| 516 controller_->OnDidFlushInput(); |
| 517 EXPECT_EQ(2, num_success_); |
| 518 } |
| 519 |
486 gfx::Vector2d AddTouchSlopToVector(const gfx::Vector2d& vector, | 520 gfx::Vector2d AddTouchSlopToVector(const gfx::Vector2d& vector, |
487 SyntheticGestureTarget* target) { | 521 SyntheticGestureTarget* target) { |
488 const int kTouchSlop = target->GetTouchSlopInDips(); | 522 const int kTouchSlop = target->GetTouchSlopInDips(); |
489 | 523 |
490 int x = vector.x(); | 524 int x = vector.x(); |
491 if (x > 0) | 525 if (x > 0) |
492 x += kTouchSlop; | 526 x += kTouchSlop; |
493 else if (x < 0) | 527 else if (x < 0) |
494 x -= kTouchSlop; | 528 x -= kTouchSlop; |
495 | 529 |
(...skipping 462 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
958 EXPECT_TRUE(tap_target->GestureFinished()); | 992 EXPECT_TRUE(tap_target->GestureFinished()); |
959 EXPECT_EQ(tap_target->position(), params.position); | 993 EXPECT_EQ(tap_target->position(), params.position); |
960 EXPECT_EQ(tap_target->GetDuration().InMilliseconds(), params.duration_ms); | 994 EXPECT_EQ(tap_target->GetDuration().InMilliseconds(), params.duration_ms); |
961 EXPECT_GE(GetTotalTime(), | 995 EXPECT_GE(GetTotalTime(), |
962 base::TimeDelta::FromMilliseconds(params.duration_ms)); | 996 base::TimeDelta::FromMilliseconds(params.duration_ms)); |
963 } | 997 } |
964 | 998 |
965 } // namespace | 999 } // namespace |
966 | 1000 |
967 } // namespace content | 1001 } // namespace content |
OLD | NEW |