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

Unified Diff: chrome/browser/ui/search/instant_extended_browsertest.cc

Issue 13461032: Fix Windows InstantExtendedTest focus issues with OmniboxViewViews. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Restore BringBrowserWindowToFront calls; fix comment typo. Created 7 years, 8 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/search/instant_extended_browsertest.cc
diff --git a/chrome/browser/ui/search/instant_extended_browsertest.cc b/chrome/browser/ui/search/instant_extended_browsertest.cc
index 981ce6a0f8bb5ae7dca867f80b7098ae1311a202..da6da5681bdb32371c757759ee05fdb0bb901cc0 100644
--- a/chrome/browser/ui/search/instant_extended_browsertest.cc
+++ b/chrome/browser/ui/search/instant_extended_browsertest.cc
@@ -118,6 +118,16 @@ class InstantExtendedTest : public InProcessBrowserTest,
&on_change_calls_);
}
+ // A convenience function to explicitly blur the omnibox and focus |contents|.
+ // TODO(msw|jered|sreeram): Fix test focus issues; see http://crbug.com/226189
+ void BlurOmniboxAndFocusContents(content::WebContents* contents) {
+ omnibox()->model()->OnWillKillFocus(contents->GetView()->GetNativeView());
+ omnibox()->model()->OnKillFocus();
+ contents->GetView()->Focus();
+ EXPECT_FALSE(omnibox()->model()->has_focus());
+ EXPECT_TRUE(ui_test_utils::IsViewFocused(browser(), VIEW_ID_TAB_CONTAINER));
+ }
+
int on_most_visited_change_calls_;
int most_visited_items_count_;
int first_most_visited_item_id_;
@@ -171,12 +181,10 @@ IN_PROC_BROWSER_TEST_F(InstantExtendedTest, ExtendedModeIsOn) {
IN_PROC_BROWSER_TEST_F(InstantExtendedTest, OmniboxFocusLoadsInstant) {
ASSERT_NO_FATAL_FAILURE(SetupInstant(browser()));
- // Explicitly unfocus the omnibox.
+ // Blur the omnibox and focus the active web contents.
EXPECT_TRUE(ui_test_utils::BringBrowserWindowToFront(browser()));
- ui_test_utils::ClickOnView(browser(), VIEW_ID_TAB_CONTAINER);
-
- EXPECT_TRUE(ui_test_utils::IsViewFocused(browser(), VIEW_ID_TAB_CONTAINER));
- EXPECT_FALSE(omnibox()->model()->has_focus());
+ BlurOmniboxAndFocusContents(
+ browser()->tab_strip_model()->GetActiveWebContents());
// Delete any existing overlay.
instant()->overlay_.reset();
@@ -202,9 +210,8 @@ IN_PROC_BROWSER_TEST_F(InstantExtendedTest, OmniboxFocusLoadsInstant) {
EXPECT_EQ(overlay, instant()->GetOverlayContents());
// Unfocusing and refocusing the omnibox should also preserve the overlay.
- ui_test_utils::ClickOnView(browser(), VIEW_ID_TAB_CONTAINER);
- EXPECT_TRUE(ui_test_utils::IsViewFocused(browser(), VIEW_ID_TAB_CONTAINER));
-
+ BlurOmniboxAndFocusContents(
+ browser()->tab_strip_model()->GetActiveWebContents());
FocusOmnibox();
EXPECT_FALSE(ui_test_utils::IsViewFocused(browser(), VIEW_ID_TAB_CONTAINER));
EXPECT_EQ(overlay, instant()->GetOverlayContents());
@@ -367,15 +374,13 @@ IN_PROC_BROWSER_TEST_F(InstantExtendedTest,
browser()->window()->GetLocationBar()->AcceptInput();
observer.Wait();
- // With a committed results page, do a search by unfocusing the omnibox and
- // focusing the contents.
+ // With a committed results page, do a search by blurring the omnibox and
+ // focusing the contents. Call handleOnChange before focusing the contents.
SetOmniboxText("hello");
- // Calling handleOnChange manually to make sure it is called before the
- // Focus() call below.
EXPECT_TRUE(content::ExecuteScript(instant()->instant_tab()->contents(),
"suggestion = 'hello kitty';"
"handleOnChange();"));
- instant()->instant_tab()->contents()->GetView()->Focus();
+ BlurOmniboxAndFocusContents(instant()->instant_tab()->contents());
// Search term extraction should kick in with the autocompleted text.
EXPECT_EQ(ASCIIToUTF16("hello kitty"), omnibox()->GetText());
@@ -412,7 +417,7 @@ IN_PROC_BROWSER_TEST_F(InstantExtendedTest,
EXPECT_TRUE(ExecuteScript("suggestion = 'exams are great';"
"behavior = 2;"
"handleOnChange();"));
- instant()->overlay()->contents()->GetView()->Focus();
+ BlurOmniboxAndFocusContents(instant()->overlay()->contents());
EXPECT_EQ(ASCIIToUTF16("exams are great"), omnibox()->GetText());
// TODO(jered): Remove this after fixing OnBlur().
@@ -645,10 +650,10 @@ IN_PROC_BROWSER_TEST_F(InstantExtendedTest, OmniboxHasFocusOnNewTab) {
ASSERT_NO_FATAL_FAILURE(SetupInstant(browser()));
FocusOmniboxAndWaitForInstantExtendedSupport();
- // Explicitly unfocus the omnibox.
+ // Explicitly blur the omnibox.
EXPECT_TRUE(ui_test_utils::BringBrowserWindowToFront(browser()));
- ui_test_utils::ClickOnView(browser(), VIEW_ID_TAB_CONTAINER);
- EXPECT_FALSE(omnibox()->model()->has_focus());
+ BlurOmniboxAndFocusContents(
+ browser()->tab_strip_model()->GetActiveWebContents());
// Open new tab. Preloaded NTP contents should have been used.
ui_test_utils::NavigateToURLWithDisposition(
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698