OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 "build/build_config.h" | 5 #include "build/build_config.h" |
6 | 6 |
7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
8 #include "base/format_macros.h" | 8 #include "base/format_macros.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/message_loop.h" | 10 #include "base/message_loop.h" |
(...skipping 288 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
299 gfx::NativeWindow window = browser()->window()->GetNativeHandle(); | 299 gfx::NativeWindow window = browser()->window()->GetNativeHandle(); |
300 browser()->SelectTabContentsAt(0, true); | 300 browser()->SelectTabContentsAt(0, true); |
301 // Try the above, but with ctrl+tab. Since tab normally changes focus, | 301 // Try the above, but with ctrl+tab. Since tab normally changes focus, |
302 // this has regressed in the past. Loop through several times to be sure. | 302 // this has regressed in the past. Loop through several times to be sure. |
303 for (int j = 0; j < 15; j++) { | 303 for (int j = 0; j < 15; j++) { |
304 ViewID vid = kFocusPage[i][j % 5] ? VIEW_ID_TAB_CONTAINER_FOCUS_VIEW : | 304 ViewID vid = kFocusPage[i][j % 5] ? VIEW_ID_TAB_CONTAINER_FOCUS_VIEW : |
305 VIEW_ID_LOCATION_BAR; | 305 VIEW_ID_LOCATION_BAR; |
306 ASSERT_TRUE(IsViewFocused(vid)); | 306 ASSERT_TRUE(IsViewFocused(vid)); |
307 | 307 |
308 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 308 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
309 window, app::VKEY_TAB, true, false, false, false)); | 309 window, base::VKEY_TAB, true, false, false, false)); |
310 } | 310 } |
311 | 311 |
312 // As above, but with ctrl+shift+tab. | 312 // As above, but with ctrl+shift+tab. |
313 browser()->SelectTabContentsAt(4, true); | 313 browser()->SelectTabContentsAt(4, true); |
314 for (int j = 14; j >= 0; --j) { | 314 for (int j = 14; j >= 0; --j) { |
315 ViewID vid = kFocusPage[i][j % 5] ? VIEW_ID_TAB_CONTAINER_FOCUS_VIEW : | 315 ViewID vid = kFocusPage[i][j % 5] ? VIEW_ID_TAB_CONTAINER_FOCUS_VIEW : |
316 VIEW_ID_LOCATION_BAR; | 316 VIEW_ID_LOCATION_BAR; |
317 ASSERT_TRUE(IsViewFocused(vid)); | 317 ASSERT_TRUE(IsViewFocused(vid)); |
318 | 318 |
319 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 319 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
320 window, app::VKEY_TAB, true, true, false, false)); | 320 window, base::VKEY_TAB, true, true, false, false)); |
321 } | 321 } |
322 } | 322 } |
323 } | 323 } |
324 | 324 |
325 // Tabs remember focus with find-in-page box. | 325 // Tabs remember focus with find-in-page box. |
326 IN_PROC_BROWSER_TEST_F(BrowserFocusTest, MAYBE_TabsRememberFocusFindInPage) { | 326 IN_PROC_BROWSER_TEST_F(BrowserFocusTest, MAYBE_TabsRememberFocusFindInPage) { |
327 BringBrowserWindowToFront(); | 327 BringBrowserWindowToFront(); |
328 ASSERT_TRUE(test_server()->Start()); | 328 ASSERT_TRUE(test_server()->Start()); |
329 | 329 |
330 // First we navigate to our test page. | 330 // First we navigate to our test page. |
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
473 SCOPED_TRACE(StringPrintf("inner loop %" PRIuS, j)); | 473 SCOPED_TRACE(StringPrintf("inner loop %" PRIuS, j)); |
474 // Let's make sure the focus is on the expected element in the page. | 474 // Let's make sure the focus is on the expected element in the page. |
475 std::string actual; | 475 std::string actual; |
476 ASSERT_TRUE(ui_test_utils::ExecuteJavaScriptAndExtractString( | 476 ASSERT_TRUE(ui_test_utils::ExecuteJavaScriptAndExtractString( |
477 browser()->GetSelectedTabContents()->render_view_host(), | 477 browser()->GetSelectedTabContents()->render_view_host(), |
478 L"", | 478 L"", |
479 L"window.domAutomationController.send(getFocusedElement());", | 479 L"window.domAutomationController.send(getFocusedElement());", |
480 &actual)); | 480 &actual)); |
481 ASSERT_STREQ(kExpElementIDs[j], actual.c_str()); | 481 ASSERT_STREQ(kExpElementIDs[j], actual.c_str()); |
482 | 482 |
483 ASSERT_TRUE(ui_controls::SendKeyPress(window, app::VKEY_TAB, | 483 ASSERT_TRUE(ui_controls::SendKeyPress(window, base::VKEY_TAB, |
484 false, false, false, false)); | 484 false, false, false, false)); |
485 | 485 |
486 if (j < arraysize(kExpElementIDs) - 1) { | 486 if (j < arraysize(kExpElementIDs) - 1) { |
487 ASSERT_NO_FATAL_FAILURE( | 487 ASSERT_NO_FATAL_FAILURE( |
488 ui_test_utils::WaitForFocusChange( | 488 ui_test_utils::WaitForFocusChange( |
489 browser()->GetSelectedTabContents()->render_view_host())); | 489 browser()->GetSelectedTabContents()->render_view_host())); |
490 } else { | 490 } else { |
491 // On the last tab key press, the focus returns to the browser. | 491 // On the last tab key press, the focus returns to the browser. |
492 ASSERT_NO_FATAL_FAILURE( | 492 ASSERT_NO_FATAL_FAILURE( |
493 ui_test_utils::WaitForFocusInBrowser(browser())); | 493 ui_test_utils::WaitForFocusInBrowser(browser())); |
494 } | 494 } |
495 } | 495 } |
496 | 496 |
497 // At this point the renderer has sent us a message asking to advance the | 497 // At this point the renderer has sent us a message asking to advance the |
498 // focus (as the end of the focus loop was reached in the renderer). | 498 // focus (as the end of the focus loop was reached in the renderer). |
499 // We need to run the message loop to process it. | 499 // We need to run the message loop to process it. |
500 ui_test_utils::RunAllPendingInMessageLoop(); | 500 ui_test_utils::RunAllPendingInMessageLoop(); |
501 } | 501 } |
502 | 502 |
503 // Now let's try reverse focus traversal. | 503 // Now let's try reverse focus traversal. |
504 for (int i = 0; i < 3; ++i) { | 504 for (int i = 0; i < 3; ++i) { |
505 SCOPED_TRACE(StringPrintf("outer loop: %d", i)); | 505 SCOPED_TRACE(StringPrintf("outer loop: %d", i)); |
506 // Location bar should be focused. | 506 // Location bar should be focused. |
507 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); | 507 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); |
508 | 508 |
509 // Now let's press shift-tab to move the focus in reverse. | 509 // Now let's press shift-tab to move the focus in reverse. |
510 for (size_t j = 0; j < 7; ++j) { | 510 for (size_t j = 0; j < 7; ++j) { |
511 SCOPED_TRACE(StringPrintf("inner loop: %" PRIuS, j)); | 511 SCOPED_TRACE(StringPrintf("inner loop: %" PRIuS, j)); |
512 ASSERT_TRUE(ui_controls::SendKeyPress(window, app::VKEY_TAB, | 512 ASSERT_TRUE(ui_controls::SendKeyPress(window, base::VKEY_TAB, |
513 false, true, false, false)); | 513 false, true, false, false)); |
514 | 514 |
515 if (j < arraysize(kExpElementIDs) - 1) { | 515 if (j < arraysize(kExpElementIDs) - 1) { |
516 ASSERT_NO_FATAL_FAILURE( | 516 ASSERT_NO_FATAL_FAILURE( |
517 ui_test_utils::WaitForFocusChange( | 517 ui_test_utils::WaitForFocusChange( |
518 browser()->GetSelectedTabContents()->render_view_host())); | 518 browser()->GetSelectedTabContents()->render_view_host())); |
519 } else { | 519 } else { |
520 // On the last tab key press, the focus returns to the browser. | 520 // On the last tab key press, the focus returns to the browser. |
521 ASSERT_NO_FATAL_FAILURE( | 521 ASSERT_NO_FATAL_FAILURE( |
522 ui_test_utils::WaitForFocusInBrowser(browser())); | 522 ui_test_utils::WaitForFocusInBrowser(browser())); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
577 for (int i = 0; i < 2; ++i) { | 577 for (int i = 0; i < 2; ++i) { |
578 // Location bar should be focused. | 578 // Location bar should be focused. |
579 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); | 579 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); |
580 | 580 |
581 // Now let's press tab to move the focus. | 581 // Now let's press tab to move the focus. |
582 for (size_t j = 0; j < 7; ++j) { | 582 for (size_t j = 0; j < 7; ++j) { |
583 // Let's make sure the focus is on the expected element in the page. | 583 // Let's make sure the focus is on the expected element in the page. |
584 std::string actual = interstitial_page->GetFocusedElement(); | 584 std::string actual = interstitial_page->GetFocusedElement(); |
585 ASSERT_STREQ(kExpElementIDs[j], actual.c_str()); | 585 ASSERT_STREQ(kExpElementIDs[j], actual.c_str()); |
586 | 586 |
587 ASSERT_TRUE(ui_controls::SendKeyPress(window, app::VKEY_TAB, | 587 ASSERT_TRUE(ui_controls::SendKeyPress(window, base::VKEY_TAB, |
588 false, false, false, false)); | 588 false, false, false, false)); |
589 | 589 |
590 if (j < arraysize(kExpElementIDs) - 1) { | 590 if (j < arraysize(kExpElementIDs) - 1) { |
591 ASSERT_NO_FATAL_FAILURE(interstitial_page->WaitForFocusChange()); | 591 ASSERT_NO_FATAL_FAILURE(interstitial_page->WaitForFocusChange()); |
592 } else { | 592 } else { |
593 // On the last tab key press, the focus returns to the browser. | 593 // On the last tab key press, the focus returns to the browser. |
594 ASSERT_NO_FATAL_FAILURE( | 594 ASSERT_NO_FATAL_FAILURE( |
595 ui_test_utils::WaitForFocusInBrowser(browser())); | 595 ui_test_utils::WaitForFocusInBrowser(browser())); |
596 } | 596 } |
597 } | 597 } |
598 | 598 |
599 // At this point the renderer has sent us a message asking to advance the | 599 // At this point the renderer has sent us a message asking to advance the |
600 // focus (as the end of the focus loop was reached in the renderer). | 600 // focus (as the end of the focus loop was reached in the renderer). |
601 // We need to run the message loop to process it. | 601 // We need to run the message loop to process it. |
602 ui_test_utils::RunAllPendingInMessageLoop(); | 602 ui_test_utils::RunAllPendingInMessageLoop(); |
603 } | 603 } |
604 | 604 |
605 // Now let's try reverse focus traversal. | 605 // Now let's try reverse focus traversal. |
606 for (int i = 0; i < 2; ++i) { | 606 for (int i = 0; i < 2; ++i) { |
607 // Location bar should be focused. | 607 // Location bar should be focused. |
608 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); | 608 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); |
609 | 609 |
610 // Now let's press shift-tab to move the focus in reverse. | 610 // Now let's press shift-tab to move the focus in reverse. |
611 for (size_t j = 0; j < 7; ++j) { | 611 for (size_t j = 0; j < 7; ++j) { |
612 ASSERT_TRUE(ui_controls::SendKeyPress(window, app::VKEY_TAB, | 612 ASSERT_TRUE(ui_controls::SendKeyPress(window, base::VKEY_TAB, |
613 false, true, false, false)); | 613 false, true, false, false)); |
614 | 614 |
615 if (j < arraysize(kExpElementIDs) - 1) { | 615 if (j < arraysize(kExpElementIDs) - 1) { |
616 ASSERT_NO_FATAL_FAILURE(interstitial_page->WaitForFocusChange()); | 616 ASSERT_NO_FATAL_FAILURE(interstitial_page->WaitForFocusChange()); |
617 } else { | 617 } else { |
618 // On the last tab key press, the focus returns to the browser. | 618 // On the last tab key press, the focus returns to the browser. |
619 ASSERT_NO_FATAL_FAILURE( | 619 ASSERT_NO_FATAL_FAILURE( |
620 ui_test_utils::WaitForFocusInBrowser(browser())); | 620 ui_test_utils::WaitForFocusInBrowser(browser())); |
621 } | 621 } |
622 | 622 |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
675 | 675 |
676 // Open some page (any page that doesn't steal focus). | 676 // Open some page (any page that doesn't steal focus). |
677 GURL url = test_server()->GetURL(kTypicalPage); | 677 GURL url = test_server()->GetURL(kTypicalPage); |
678 ui_test_utils::NavigateToURL(browser(), url); | 678 ui_test_utils::NavigateToURL(browser(), url); |
679 | 679 |
680 gfx::NativeWindow window = browser()->window()->GetNativeHandle(); | 680 gfx::NativeWindow window = browser()->window()->GetNativeHandle(); |
681 | 681 |
682 #if defined(OS_MACOSX) | 682 #if defined(OS_MACOSX) |
683 // Press Cmd+F, which will make the Find box open and request focus. | 683 // Press Cmd+F, which will make the Find box open and request focus. |
684 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 684 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
685 window, app::VKEY_F, false, false, false, true)); | 685 window, base::VKEY_F, false, false, false, true)); |
686 #else | 686 #else |
687 // Press Ctrl+F, which will make the Find box open and request focus. | 687 // Press Ctrl+F, which will make the Find box open and request focus. |
688 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 688 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
689 window, app::VKEY_F, true, false, false, false)); | 689 window, base::VKEY_F, true, false, false, false)); |
690 #endif | 690 #endif |
691 | 691 |
692 // Ideally, we wouldn't sleep here and instead would intercept the | 692 // Ideally, we wouldn't sleep here and instead would intercept the |
693 // RenderViewHostDelegate::HandleKeyboardEvent() callback. To do that, we | 693 // RenderViewHostDelegate::HandleKeyboardEvent() callback. To do that, we |
694 // could create a RenderViewHostDelegate wrapper and hook-it up by either: | 694 // could create a RenderViewHostDelegate wrapper and hook-it up by either: |
695 // - creating a factory used to create the delegate | 695 // - creating a factory used to create the delegate |
696 // - making the test a private and overwriting the delegate member directly. | 696 // - making the test a private and overwriting the delegate member directly. |
697 MessageLoop::current()->PostDelayedTask( | 697 MessageLoop::current()->PostDelayedTask( |
698 FROM_HERE, new MessageLoop::QuitTask(), kActionDelayMs); | 698 FROM_HERE, new MessageLoop::QuitTask(), kActionDelayMs); |
699 ui_test_utils::RunMessageLoop(); | 699 ui_test_utils::RunMessageLoop(); |
700 | 700 |
701 ASSERT_TRUE(IsViewFocused(VIEW_ID_FIND_IN_PAGE_TEXT_FIELD)); | 701 ASSERT_TRUE(IsViewFocused(VIEW_ID_FIND_IN_PAGE_TEXT_FIELD)); |
702 | 702 |
703 browser()->FocusLocationBar(); | 703 browser()->FocusLocationBar(); |
704 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); | 704 ASSERT_TRUE(IsViewFocused(VIEW_ID_LOCATION_BAR)); |
705 | 705 |
706 // Now press Ctrl+F again and focus should move to the Find box. | 706 // Now press Ctrl+F again and focus should move to the Find box. |
707 #if defined(OS_MACOSX) | 707 #if defined(OS_MACOSX) |
708 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 708 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
709 window, app::VKEY_F, false, false, false, true)); | 709 window, base::VKEY_F, false, false, false, true)); |
710 #else | 710 #else |
711 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 711 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
712 window, app::VKEY_F, true, false, false, false)); | 712 window, base::VKEY_F, true, false, false, false)); |
713 #endif | 713 #endif |
714 ASSERT_TRUE(IsViewFocused(VIEW_ID_FIND_IN_PAGE_TEXT_FIELD)); | 714 ASSERT_TRUE(IsViewFocused(VIEW_ID_FIND_IN_PAGE_TEXT_FIELD)); |
715 | 715 |
716 // Set focus to the page. | 716 // Set focus to the page. |
717 ClickOnView(VIEW_ID_TAB_CONTAINER); | 717 ClickOnView(VIEW_ID_TAB_CONTAINER); |
718 ASSERT_TRUE(IsViewFocused(VIEW_ID_TAB_CONTAINER_FOCUS_VIEW)); | 718 ASSERT_TRUE(IsViewFocused(VIEW_ID_TAB_CONTAINER_FOCUS_VIEW)); |
719 | 719 |
720 // Now press Ctrl+F again and focus should move to the Find box. | 720 // Now press Ctrl+F again and focus should move to the Find box. |
721 #if defined(OS_MACOSX) | 721 #if defined(OS_MACOSX) |
722 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 722 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
723 window, app::VKEY_F, false, false, false, true)); | 723 window, base::VKEY_F, false, false, false, true)); |
724 #else | 724 #else |
725 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 725 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
726 window, app::VKEY_F, true, false, false, false)); | 726 window, base::VKEY_F, true, false, false, false)); |
727 #endif | 727 #endif |
728 | 728 |
729 // See remark above on why we wait. | 729 // See remark above on why we wait. |
730 MessageLoop::current()->PostDelayedTask( | 730 MessageLoop::current()->PostDelayedTask( |
731 FROM_HERE, new MessageLoop::QuitTask(), kActionDelayMs); | 731 FROM_HERE, new MessageLoop::QuitTask(), kActionDelayMs); |
732 ui_test_utils::RunMessageLoop(); | 732 ui_test_utils::RunMessageLoop(); |
733 ASSERT_TRUE(IsViewFocused(VIEW_ID_FIND_IN_PAGE_TEXT_FIELD)); | 733 ASSERT_TRUE(IsViewFocused(VIEW_ID_FIND_IN_PAGE_TEXT_FIELD)); |
734 } | 734 } |
735 | 735 |
736 // Makes sure the focus is in the right location when opening the different | 736 // Makes sure the focus is in the right location when opening the different |
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
803 ui_test_utils::CrashTab(browser()->GetSelectedTabContents()); | 803 ui_test_utils::CrashTab(browser()->GetSelectedTabContents()); |
804 browser()->Reload(CURRENT_TAB); | 804 browser()->Reload(CURRENT_TAB); |
805 ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser())); | 805 ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser())); |
806 | 806 |
807 // Focus should now be on the tab contents. | 807 // Focus should now be on the tab contents. |
808 browser()->ShowDownloadsTab(); | 808 browser()->ShowDownloadsTab(); |
809 ASSERT_TRUE(IsViewFocused(VIEW_ID_TAB_CONTAINER_FOCUS_VIEW)); | 809 ASSERT_TRUE(IsViewFocused(VIEW_ID_TAB_CONTAINER_FOCUS_VIEW)); |
810 } | 810 } |
811 | 811 |
812 } // namespace | 812 } // namespace |
OLD | NEW |