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

Unified Diff: chrome/browser/ui/webui/web_ui_browsertest.cc

Issue 7645007: WebUI Testing: async support - global mocking, deferred runs, continued run. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Minor comment fix. Created 9 years, 4 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 | « chrome/browser/ui/webui/web_ui_browsertest.h ('k') | chrome/chrome_tests.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/webui/web_ui_browsertest.cc
diff --git a/chrome/browser/ui/webui/web_ui_browsertest.cc b/chrome/browser/ui/webui/web_ui_browsertest.cc
index ad385f0b2d84a63db9c40fce204945101fe9c5a8..96204d134809ab658afea8db38c32642bb9835b8 100644
--- a/chrome/browser/ui/webui/web_ui_browsertest.cc
+++ b/chrome/browser/ui/webui/web_ui_browsertest.cc
@@ -79,12 +79,17 @@ bool WebUIBrowserTest::RunJavascriptFunction(
function_name, function_arguments, false, false, NULL);
}
-bool WebUIBrowserTest::RunJavascriptTestF(const std::string& test_fixture,
+bool WebUIBrowserTest::RunJavascriptTestF(bool is_async,
+ const std::string& test_fixture,
const std::string& test_name) {
ConstValueVector args;
args.push_back(Value::CreateStringValue(test_fixture));
args.push_back(Value::CreateStringValue(test_name));
- return RunJavascriptTest("RUN_TEST_F", args);
+
+ if (is_async)
+ return RunJavascriptAsyncTest("RUN_TEST_F", args);
+ else
+ return RunJavascriptTest("RUN_TEST_F", args);
}
bool WebUIBrowserTest::RunJavascriptTest(const std::string& test_name) {
@@ -198,11 +203,34 @@ void WebUIBrowserTest::BrowsePrintPreload(
tabstrip_observer.WaitForObservation();
}
+const char WebUIBrowserTest::kDummyURL[] = "chrome://DummyURL";
+
WebUIBrowserTest::WebUIBrowserTest()
: test_handler_(new WebUITestHandler()),
libraries_preloaded_(false) {}
+namespace {
+
+class MockWebUIProvider : public TestChromeWebUIFactory::WebUIProvider {
+ public:
+ MockWebUIProvider() {}
+
+ // Returns a new ChromeWebUI
+ WebUI* NewWebUI(TabContents* tab_contents, const GURL& url) OVERRIDE {
+ return new ChromeWebUI(tab_contents);
+ }
+};
+
+base::LazyInstance<MockWebUIProvider> mock_provider_(
+ base::LINKER_INITIALIZED);
+
+} // namespace
+
void WebUIBrowserTest::SetUpInProcessBrowserTestFixture() {
+ InProcessBrowserTest::SetUpInProcessBrowserTestFixture();
+ TestChromeWebUIFactory::AddFactoryOverride(GURL(kDummyURL).host(),
+ mock_provider_.Pointer());
+
ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_data_directory_));
test_data_directory_ = test_data_directory_.Append(kWebUITestFolder);
@@ -221,6 +249,11 @@ void WebUIBrowserTest::SetUpInProcessBrowserTestFixture() {
AddLibrary(FilePath(kWebUILibraryJS));
}
+void WebUIBrowserTest::TearDownInProcessBrowserTestFixture() {
+ InProcessBrowserTest::TearDownInProcessBrowserTestFixture();
+ TestChromeWebUIFactory::RemoveFactoryOverride(GURL(kDummyURL).host());
+}
+
WebUIMessageHandler* WebUIBrowserTest::GetMockMessageHandler() {
return NULL;
}
@@ -414,8 +447,6 @@ class WebUIBrowserAsyncTest : public WebUIBrowserTest {
protected:
WebUIBrowserAsyncTest() {}
- static const char kDummyURL[];
-
// Class to synchronize asynchronous javascript activity with the tests.
class AsyncWebUIMessageHandler : public WebUIMessageHandler {
public:
@@ -451,35 +482,11 @@ class WebUIBrowserAsyncTest : public WebUIBrowserTest {
::testing::StrictMock<AsyncWebUIMessageHandler> message_handler_;
private:
- // Class to provide a ChromeWebUI for |kDummyURL|.
- class MockWebUIProvider : public TestChromeWebUIFactory::WebUIProvider {
- public:
- MockWebUIProvider() {}
-
- // Returns a new ChromeWebUI
- WebUI* NewWebUI(TabContents* tab_contents, const GURL& url) OVERRIDE {
- return new ChromeWebUI(tab_contents);
- }
- };
-
// Provide this object's handler.
virtual WebUIMessageHandler* GetMockMessageHandler() OVERRIDE {
return &message_handler_;
}
- // Set up the kDummyURL to be a WebUI page.
- virtual void SetUpInProcessBrowserTestFixture() OVERRIDE {
- WebUIBrowserTest::SetUpInProcessBrowserTestFixture();
- TestChromeWebUIFactory::AddFactoryOverride(GURL(kDummyURL).host(),
- &mock_provider_);
- }
-
- // Tear down the kDummyURL WebUI page.
- virtual void TearDownInProcessBrowserTestFixture() OVERRIDE {
- WebUIBrowserTest::TearDownInProcessBrowserTestFixture();
- TestChromeWebUIFactory::RemoveFactoryOverride(GURL(kDummyURL).host());
- }
-
// Set up and browse to kDummyURL for all tests.
virtual void SetUpOnMainThread() OVERRIDE {
WebUIBrowserTest::SetUpOnMainThread();
@@ -487,14 +494,9 @@ class WebUIBrowserAsyncTest : public WebUIBrowserTest {
ui_test_utils::NavigateToURL(browser(), GURL(kDummyURL));
}
- // Provider for this object.
- MockWebUIProvider mock_provider_;
-
DISALLOW_COPY_AND_ASSIGN(WebUIBrowserAsyncTest);
};
-const char WebUIBrowserAsyncTest::kDummyURL[] = "chrome://Dummy";
-
// Test that assertions fail immediately after assertion fails (no testContinues
// message). (Sync version).
IN_PROC_BROWSER_TEST_F(WebUIBrowserAsyncTest, TestSyncOkTestFail) {
« no previous file with comments | « chrome/browser/ui/webui/web_ui_browsertest.h ('k') | chrome/chrome_tests.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698