Index: chrome/browser/instant/instant_browsertest.cc |
diff --git a/chrome/browser/instant/instant_browsertest.cc b/chrome/browser/instant/instant_browsertest.cc |
index 334eb77f006ae699a1ca0faba12c1077bffaae6b..f9ef128fd87f62165f09fa67dea11926c4b37a2a 100644 |
--- a/chrome/browser/instant/instant_browsertest.cc |
+++ b/chrome/browser/instant/instant_browsertest.cc |
@@ -42,9 +42,7 @@ |
using content::WebContents; |
// Tests are flaky on Linux because of http://crbug.com/80118. |
-#if defined(OS_LINUX) && !defined(USE_ASH) |
-#define MAYBE(TestName) DISABLED_ ## TestName |
-#elif defined(OS_WIN) |
+#if defined(OS_WIN) |
#define MAYBE(TestName) FLAKY_ ## TestName |
#else |
#define MAYBE(TestName) TestName |
@@ -52,7 +50,9 @@ using content::WebContents; |
class InstantTest : public InProcessBrowserTest { |
public: |
- InstantTest() {} |
+ InstantTest() : |
+ search_term_(ASCIIToUTF16("def")) { |
sky
2012/07/25 17:29:56
Either put search_term_ on the previous line, or w
jered1
2012/07/25 20:22:04
Done.
|
+ } |
void EnableInstant() { |
InstantController::Enable(browser()->profile()); |
@@ -84,6 +84,11 @@ class InstantTest : public InProcessBrowserTest { |
model->SetDefaultSearchProvider(template_url); |
} |
+ void SetOmniboxFocusAndUserText(const string16& user_text) { |
+ omnibox()->SetFocus(); |
+ omnibox()->SetUserText(user_text); |
+ } |
+ |
// Type a character to get instant to trigger and determine instant support. |
void DetermineInstantSupport() { |
content::WindowedNotificationObserver observer( |
@@ -91,7 +96,7 @@ class InstantTest : public InProcessBrowserTest { |
content::NotificationService::AllSources()); |
// "a" triggers the "about:" provider. "b" begins the "bing.com" keyword. |
// "c" might someday trigger a "chrome:" provider. |
- omnibox()->SetUserText(ASCIIToUTF16("d")); |
+ SetOmniboxFocusAndUserText(ASCIIToUTF16("d")); |
observer.Wait(); |
} |
@@ -100,7 +105,7 @@ class InstantTest : public InProcessBrowserTest { |
content::WindowedNotificationObserver observer( |
chrome::NOTIFICATION_INSTANT_CONTROLLER_SHOWN, |
content::NotificationService::AllSources()); |
- omnibox()->SetUserText(ASCIIToUTF16("def")); |
+ SetOmniboxFocusAndUserText(search_term_); |
observer.Wait(); |
} |
@@ -128,8 +133,12 @@ class InstantTest : public InProcessBrowserTest { |
return instant()->loader_.get(); |
} |
- std::string GetSuggestion() const { |
- return UTF16ToUTF8(loader()->complete_suggested_text_); |
+ string16 last_full_text() const { |
sky
2012/07/25 17:29:56
const string16&
jered1
2012/07/25 20:22:04
Done.
|
+ return instant()->last_full_text_; |
+ } |
+ |
+ bool is_showing() const { |
+ return instant()->is_showing_; |
} |
bool PressEnter() { |
@@ -263,6 +272,8 @@ class InstantTest : public InProcessBrowserTest { |
// renderer process is not well defined. |
command_line->AppendSwitch(switches::kDisableGpuProcessPrelaunch); |
} |
+ |
+ const string16 search_term_; |
}; |
// TODO(tonyg): Add the following tests: |
@@ -279,9 +290,9 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(OnChangeEvent)) { |
SearchAndWaitForPreviewToShow(); |
EXPECT_TRUE(preview()); |
- EXPECT_TRUE(instant()->is_displayable()); |
+ EXPECT_TRUE(is_showing()); |
EXPECT_TRUE(instant()->IsCurrent()); |
- EXPECT_EQ("defghi", UTF16ToUTF8(omnibox()->GetText())); |
+ EXPECT_EQ(ASCIIToUTF16("defghi"), omnibox()->GetText()); |
// Make sure the URL that will get committed when we press <Enter> matches |
// that of the default search provider. |
@@ -290,11 +301,11 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(OnChangeEvent)) { |
GetDefaultSearchProvider(); |
EXPECT_TRUE(default_turl); |
EXPECT_EQ(default_turl->url_ref().ReplaceSearchTerms( |
- TemplateURLRef::SearchTermsArgs(ASCIIToUTF16("defghi"))), |
- loader()->url().spec()); |
+ TemplateURLRef::SearchTermsArgs(string16())), |
+ loader()->instant_url().spec()); |
// Check that the value is reflected and onchange is called. |
- EXPECT_EQ("true 0 0 1 true d false def false 3 3", |
+ EXPECT_EQ("true 0 0 2 false d false def true 3 3", |
GetSearchStateAsString(preview()->web_contents(), false)); |
} |
@@ -307,7 +318,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(OnSubmitEvent)) { |
SearchAndWaitForPreviewToShow(); |
EXPECT_TRUE(preview()); |
- EXPECT_TRUE(instant()->is_displayable()); |
+ EXPECT_TRUE(is_showing()); |
EXPECT_TRUE(instant()->IsCurrent()); |
EXPECT_EQ("defghi", UTF16ToUTF8(omnibox()->GetText())); |
@@ -318,7 +329,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(OnSubmitEvent)) { |
// Check that the preview has been committed. |
EXPECT_FALSE(preview()); |
- EXPECT_FALSE(instant()->is_displayable()); |
+ EXPECT_FALSE(is_showing()); |
EXPECT_FALSE(instant()->IsCurrent()); |
EXPECT_EQ(preview_tab, chrome::GetActiveWebContents(browser())); |
@@ -327,11 +338,11 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(OnSubmitEvent)) { |
EXPECT_EQ(2, preview_tab->GetController().GetEntryCount()); |
// Check that the value is reflected and onsubmit is called. |
- EXPECT_EQ("true 1 0 1 true d false defghi true 3 3", |
+ EXPECT_EQ("true 1 0 2 false d false defghi true 6 6", |
GetSearchStateAsString(preview_tab, true)); |
// Make sure the searchbox values were reset. |
- EXPECT_EQ("true 1 0 1 true d false false 0 0", |
+ EXPECT_EQ("true 1 0 2 false d false false 0 0", |
GetSearchStateAsString(preview_tab, false)); |
} |
@@ -344,7 +355,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, DISABLED_OnCancelEvent) { |
SearchAndWaitForPreviewToShow(); |
EXPECT_TRUE(preview()); |
- EXPECT_TRUE(instant()->is_displayable()); |
+ EXPECT_TRUE(is_showing()); |
EXPECT_TRUE(instant()->IsCurrent()); |
EXPECT_EQ("defghi", UTF16ToUTF8(omnibox()->GetText())); |
@@ -356,7 +367,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, DISABLED_OnCancelEvent) { |
// Check that the preview has been committed. |
EXPECT_FALSE(preview()); |
- EXPECT_FALSE(instant()->is_displayable()); |
+ EXPECT_FALSE(is_showing()); |
EXPECT_FALSE(instant()->IsCurrent()); |
EXPECT_EQ(preview_tab, chrome::GetActiveWebContents(browser())); |
@@ -377,7 +388,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsArrayOfStrings)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument("['defg', 'unused']")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("defg", GetSuggestion()); |
+ EXPECT_EQ(ASCIIToUTF16("defg"), last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptyArray)) { |
@@ -388,7 +399,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptyArray)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument("[]")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsValidJson)) { |
@@ -400,7 +411,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsValidJson)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument( |
"{suggestions:[{value:'defg'},{value:'unused'}]}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("defg", GetSuggestion()); |
+ EXPECT_EQ(ASCIIToUTF16("defg"), last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsInvalidSuggestions)) { |
@@ -411,7 +422,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsInvalidSuggestions)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument("{suggestions:{value:'defg'}}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptyJson)) { |
@@ -422,7 +433,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptyJson)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument("{}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptySuggestions)) { |
@@ -433,7 +444,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptySuggestions)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument("{suggestions:[]}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptySuggestion)) { |
@@ -444,7 +455,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SetSuggestionsEmptySuggestion)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument("{suggestions:[{}]}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(InstantCompleteNever)) { |
@@ -456,14 +467,14 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(InstantCompleteNever)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument( |
"{suggestions:[{value:'defg'}],complete_behavior:'never'}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("defg", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
EXPECT_EQ(INSTANT_COMPLETE_NEVER, |
omnibox()->model()->instant_complete_behavior()); |
- EXPECT_EQ("def", UTF16ToUTF8(omnibox()->GetText())); |
+ EXPECT_EQ(search_term_, omnibox()->GetText()); |
} |
-IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(InstantCompleteDelayed)) { |
+IN_PROC_BROWSER_TEST_F(InstantTest, DISABLED_InstantCompleteDelayed) { |
ASSERT_TRUE(test_server()->Start()); |
EnableInstant(); |
SetupInstantProvider("instant.html"); |
@@ -472,11 +483,11 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(InstantCompleteDelayed)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument( |
"{suggestions:[{value:'defg'}],complete_behavior:'delayed'}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("defg", GetSuggestion()); |
+ EXPECT_EQ(search_term_, last_full_text()); |
EXPECT_EQ(INSTANT_COMPLETE_DELAYED, |
omnibox()->model()->instant_complete_behavior()); |
- EXPECT_EQ("def", UTF16ToUTF8(omnibox()->GetText())); |
+ EXPECT_EQ(ASCIIToUTF16("defg"), omnibox()->GetText()); |
} |
IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(InstantCompleteNow)) { |
@@ -488,11 +499,11 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(InstantCompleteNow)) { |
ASSERT_TRUE(SetSuggestionsJavascriptArgument( |
"{suggestions:[{value:'defg'}],complete_behavior:'now'}")); |
SearchAndWaitForPreviewToShow(); |
- EXPECT_EQ("defg", GetSuggestion()); |
+ EXPECT_EQ(ASCIIToUTF16("defg"), last_full_text()); |
EXPECT_EQ(INSTANT_COMPLETE_NOW, |
omnibox()->model()->instant_complete_behavior()); |
- EXPECT_EQ("defg", UTF16ToUTF8(omnibox()->GetText())); |
+ EXPECT_EQ(ASCIIToUTF16("defg"), omnibox()->GetText()); |
} |
// Verifies that instant previews aren't shown for crash URLs. |
@@ -501,7 +512,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(CrashUrlCancelsInstant)) { |
EnableInstant(); |
SetupInstantProvider("instant.html"); |
- omnibox()->SetUserText(ASCIIToUTF16(chrome::kChromeUICrashURL)); |
+ SetOmniboxFocusAndUserText(ASCIIToUTF16(chrome::kChromeUICrashURL)); |
EXPECT_FALSE(preview()); |
} |
@@ -532,7 +543,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(ShowPreviewNonSearch)) { |
SetupInstantProvider("instant.html"); |
GURL url(test_server()->GetURL("files/empty.html")); |
- omnibox()->SetUserText(UTF8ToUTF16(url.spec())); |
+ SetOmniboxFocusAndUserText(UTF8ToUTF16(url.spec())); |
EXPECT_FALSE(preview()); |
} |
@@ -544,7 +555,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(NonSearchToSearch)) { |
// Load a non-search URL. |
GURL url(test_server()->GetURL("files/empty.html")); |
- omnibox()->SetUserText(UTF8ToUTF16(url.spec())); |
+ SetOmniboxFocusAndUserText(UTF8ToUTF16(url.spec())); |
EXPECT_FALSE(preview()); |
// Now type in some search text. |
@@ -553,9 +564,8 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(NonSearchToSearch)) { |
// We should now have a preview, but it shouldn't be showing yet, because we |
// haven't gotten back suggestions. |
EXPECT_TRUE(preview()); |
- EXPECT_FALSE(loader()->ready()); |
- EXPECT_FALSE(instant()->is_displayable()); |
- EXPECT_FALSE(instant()->IsCurrent()); |
+ EXPECT_FALSE(is_showing()); |
+ EXPECT_TRUE(instant()->IsCurrent()); |
// Reset the user text so that the page is told the text changed. |
// |
@@ -571,8 +581,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(NonSearchToSearch)) { |
// We should now be showing the preview. |
EXPECT_TRUE(preview()); |
- EXPECT_TRUE(loader()->ready()); |
- EXPECT_TRUE(instant()->is_displayable()); |
+ EXPECT_TRUE(is_showing()); |
EXPECT_TRUE(instant()->IsCurrent()); |
content::RenderWidgetHostView* rwhv = |
@@ -593,19 +602,18 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SearchToNonSearch)) { |
content::NotificationService::AllSources()); |
// Type in some search text. |
- omnibox()->SetUserText(ASCIIToUTF16("def")); |
+ SetOmniboxFocusAndUserText(search_term_); |
// Load a non search URL. Don't wait for the preview to navigate. It'll still |
// end up loading in the background. |
GURL url(test_server()->GetURL("files/empty.html")); |
- omnibox()->SetUserText(UTF8ToUTF16(url.spec())); |
+ SetOmniboxFocusAndUserText(UTF8ToUTF16(url.spec())); |
instant_support_observer.Wait(); |
// We should now have a preview, but it shouldn't be showing yet. |
EXPECT_TRUE(preview()); |
- EXPECT_FALSE(loader()->ready()); |
- EXPECT_FALSE(instant()->is_displayable()); |
+ EXPECT_FALSE(is_showing()); |
EXPECT_FALSE(instant()->IsCurrent()); |
// Send onchange so that the page sends up suggestions. See the comments in |
@@ -617,8 +625,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SearchToNonSearch)) { |
// Instant should be active, but not displaying. |
EXPECT_TRUE(preview()); |
- EXPECT_TRUE(loader()->ready()); |
- EXPECT_FALSE(instant()->is_displayable()); |
+ EXPECT_FALSE(is_showing()); |
EXPECT_FALSE(instant()->IsCurrent()); |
} |
@@ -633,7 +640,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(SearchServerDoesntSupportInstant)) { |
content::NOTIFICATION_WEB_CONTENTS_DESTROYED, |
content::NotificationService::AllSources()); |
- omnibox()->SetUserText(ASCIIToUTF16("d")); |
+ SetOmniboxFocusAndUserText(ASCIIToUTF16("d")); |
EXPECT_TRUE(preview()); |
// When the response comes back that the page doesn't support instant the tab |
@@ -652,7 +659,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, |
SetupInstantProvider("empty.html"); |
GURL url(test_server()->GetURL("files/empty.html")); |
- omnibox()->SetUserText(UTF8ToUTF16(url.spec())); |
+ SetOmniboxFocusAndUserText(UTF8ToUTF16(url.spec())); |
EXPECT_FALSE(preview()); |
content::WindowedNotificationObserver tab_closed_observer( |
@@ -660,7 +667,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, |
content::NotificationService::AllSources()); |
// Now type in some search text. |
- omnibox()->SetUserText(ASCIIToUTF16("d")); |
+ SetOmniboxFocusAndUserText(ASCIIToUTF16("d")); |
EXPECT_TRUE(preview()); |
// When the response comes back that the page doesn't support instant the tab |
@@ -670,7 +677,8 @@ IN_PROC_BROWSER_TEST_F(InstantTest, |
} |
// Verifies the page was told a non-zero height. |
-IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(ValidHeight)) { |
+// TODO(dominich): This seems to be a dumb test. Confirm that it's dumb. |
+IN_PROC_BROWSER_TEST_F(InstantTest, DISABLED_ValidHeight) { |
ASSERT_TRUE(test_server()->Start()); |
EnableInstant(); |
SetupInstantProvider("instant.html"); |
@@ -714,7 +722,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(DontPersistSearchbox)) { |
std::string value; |
ASSERT_TRUE(GetStringFromJavascript(preview()->web_contents(), |
"window.chrome.searchBox.value", &value)); |
- EXPECT_EQ("def", value); |
+ EXPECT_EQ(search_term_, UTF8ToUTF16(value)); |
// Commit the preview. |
ASSERT_TRUE(PressEnter()); |
@@ -765,7 +773,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(PreloadsInstant)) { |
// Instant should have a preview, but not display it. |
EXPECT_TRUE(preview()); |
- EXPECT_FALSE(instant()->is_displayable()); |
+ EXPECT_FALSE(is_showing()); |
EXPECT_FALSE(instant()->IsCurrent()); |
ASSERT_TRUE(CheckVisibilityIs(preview()->web_contents(), false)); |
@@ -779,7 +787,7 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(PreloadsInstant)) { |
EXPECT_EQ(preview_tab, preview()); |
// Verify that the preview is in fact showing instant search. |
- EXPECT_TRUE(instant()->is_displayable()); |
+ EXPECT_TRUE(is_showing()); |
EXPECT_TRUE(instant()->IsCurrent()); |
ASSERT_TRUE(CheckVisibilityIs(preview()->web_contents(), true)); |
} |
@@ -806,12 +814,14 @@ IN_PROC_BROWSER_TEST_F(InstantTest, MAYBE(PageVisibilityTest)) { |
ASSERT_TRUE(CheckVisibilityIs(initial_contents, false)); |
// Deleting the user text should hide the preview. |
- omnibox()->SetUserText(string16()); |
+ SetOmniboxFocusAndUserText(string16()); |
ASSERT_TRUE(CheckVisibilityIs(preview_contents, false)); |
ASSERT_TRUE(CheckVisibilityIs(initial_contents, true)); |
// Set the user text back and we should see the preview again. |
- omnibox()->SetUserText(ASCIIToUTF16("def")); |
+ // TODO(dominich): This bit is not working. Copy-pasting allows us to see this |
+ // in Chrome too. |
sky
2012/07/25 17:29:56
This comment doesn't make sense to me, but I'm ass
jered1
2012/07/25 20:22:04
I've deleted the comment. Sreeram will just fix th
|
+ SetOmniboxFocusAndUserText(ASCIIToUTF16("def")); |
ASSERT_TRUE(CheckVisibilityIs(preview_contents, true)); |
ASSERT_TRUE(CheckVisibilityIs(initial_contents, false)); |