| // Copyright 2013 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include "chrome/browser/instant/instant_test_utils.h" |
| |
| #include "base/command_line.h" |
| #include "chrome/browser/prefs/pref_service.h" |
| #include "chrome/browser/profiles/profile.h" |
| #include "chrome/browser/search_engines/template_url_service.h" |
| #include "chrome/browser/search_engines/template_url_service_factory.h" |
| #include "chrome/common/chrome_switches.h" |
| #include "chrome/common/pref_names.h" |
| #include "chrome/test/base/interactive_test_utils.h" |
| #include "chrome/test/base/ui_test_utils.h" |
| #include "content/public/browser/render_process_host.h" |
| #include "content/public/browser/web_contents.h" |
| #include "content/public/common/result_codes.h" |
| #include "content/public/test/browser_test_utils.h" |
| |
| namespace { |
| |
| std::string WrapScript(const std::string& script) { |
| return "domAutomationController.send(" + script + ")"; |
| } |
| |
| } // namespace |
| |
| // InstantTestModelObserver -------------------------------------------------- |
| |
| InstantTestModelObserver::InstantTestModelObserver( |
| InstantModel* model, |
| chrome::search::Mode::Type desired_mode_type) |
| : model_(model), |
| desired_mode_type_(desired_mode_type) { |
| model_->AddObserver(this); |
| } |
| |
| InstantTestModelObserver::~InstantTestModelObserver() { |
| model_->RemoveObserver(this); |
| } |
| |
| void InstantTestModelObserver::WaitUntilDesiredPreviewState() { |
| run_loop_.Run(); |
| } |
| |
| void InstantTestModelObserver::PreviewStateChanged(const InstantModel& model) { |
| if (model.mode().mode == desired_mode_type_) |
| run_loop_.Quit(); |
| } |
| |
| // InstantTestBase ----------------------------------------------------------- |
| |
| void InstantTestBase::SetupInstant() { |
| CommandLine::ForCurrentProcess()->AppendSwitchASCII( |
| switches::kInstantURL, instant_url_.spec()); |
| SetupInstantUsingTemplateURL(); |
| |
| // TODO(shishir): Fix this ugly hack. |
| instant()->SetInstantEnabled(false, true); |
| instant()->SetInstantEnabled(true, false); |
| } |
| |
| void InstantTestBase::SetupInstantUsingTemplateURL() { |
| TemplateURLService* service = |
| TemplateURLServiceFactory::GetForProfile(browser()->profile()); |
| ui_test_utils::WaitForTemplateURLServiceToLoad(service); |
| |
| TemplateURLData data; |
| // Necessary to use exact URL for both the main URL and the alternate URL for |
| // search term extraction to work in InstantExtended. |
| data.SetURL(instant_url_.spec() + "q={searchTerms}"); |
| data.instant_url = instant_url_.spec(); |
| data.alternate_urls.push_back(instant_url_.spec() + "#q={searchTerms}"); |
| data.search_terms_replacement_key = "strk"; |
| |
| TemplateURL* template_url = new TemplateURL(browser()->profile(), data); |
| service->Add(template_url); // Takes ownership of |template_url|. |
| service->SetDefaultSearchProvider(template_url); |
| browser()->profile()->GetPrefs()->SetBoolean(prefs::kInstantEnabled, true); |
| } |
| |
| void InstantTestBase::KillInstantRenderView() { |
| base::KillProcess( |
| instant()->GetPreviewContents()->GetRenderProcessHost()->GetHandle(), |
| content::RESULT_CODE_KILLED, |
| false); |
| } |
| |
| void InstantTestBase::FocusOmnibox() { |
| // If the omnibox already has focus, just notify Instant. |
| if (omnibox()->model()->has_focus()) { |
| instant()->OmniboxFocusChanged(OMNIBOX_FOCUS_VISIBLE, |
| OMNIBOX_FOCUS_CHANGE_EXPLICIT, NULL); |
| } else { |
| browser()->window()->GetLocationBar()->FocusLocation(false); |
| } |
| } |
| |
| void InstantTestBase::SetOmniboxText(const std::string& text) { |
| FocusOmnibox(); |
| omnibox()->SetUserText(UTF8ToUTF16(text)); |
| } |
| |
| void InstantTestBase::SetOmniboxTextAndWaitForInstantToShow( |
| const std::string& text) { |
| InstantTestModelObserver observer( |
| instant()->model(), chrome::search::Mode::MODE_SEARCH_SUGGESTIONS); |
| SetOmniboxText(text); |
| observer.WaitUntilDesiredPreviewState(); |
| } |
| |
| bool InstantTestBase::GetBoolFromJS(content::WebContents* contents, |
| const std::string& script, |
| bool* result) { |
| return content::ExecuteScriptAndExtractBool( |
| contents, WrapScript(script), result); |
| } |
| |
| bool InstantTestBase::GetIntFromJS(content::WebContents* contents, |
| const std::string& script, |
| int* result) { |
| return content::ExecuteScriptAndExtractInt( |
| contents, WrapScript(script), result); |
| } |
| |
| bool InstantTestBase::GetStringFromJS(content::WebContents* contents, |
| const std::string& script, |
| std::string* result) { |
| return content::ExecuteScriptAndExtractString( |
| contents, WrapScript(script), result); |
| } |
| |
| bool InstantTestBase::ExecuteScript(const std::string& script) { |
| return content::ExecuteScript(instant()->GetPreviewContents(), script); |
| } |
| |
| bool InstantTestBase::CheckVisibilityIs(content::WebContents* contents, |
| bool expected) { |
| bool actual = !expected; // Purposely start with a mis-match. |
| // We can only use ASSERT_*() in a method that returns void, hence this |
| // convoluted check. |
| return GetBoolFromJS(contents, "!document.webkitHidden", &actual) && |
| actual == expected; |
| } |