summaryrefslogtreecommitdiffstats
path: root/content/worker
diff options
context:
space:
mode:
authorjam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-29 17:47:14 +0000
committerjam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-29 17:47:14 +0000
commit6d0e9ecbcb06eedf6a5937c022eae7f4af673f04 (patch)
tree15bfde0b2ae50e97dd4264f4ef1db865295b1ca4 /content/worker
parent6d610bbe20885750ca2e689af59910c592208620 (diff)
downloadchromium_src-6d0e9ecbcb06eedf6a5937c022eae7f4af673f04.zip
chromium_src-6d0e9ecbcb06eedf6a5937c022eae7f4af673f04.tar.gz
chromium_src-6d0e9ecbcb06eedf6a5937c022eae7f4af673f04.tar.bz2
Rewrite HTML5 workers ui_tests to browser_tests. Compared to ui_tests, browser_tests are faster, less flaky and sharded. They're also portable to content_browsertests once we have it.
A bunch of these tests have bitrotted because they've been disabled for so long, so there are a number of fixes throughout (some were checked into WebKit). I'll keep an eye out on flakiness of the renabled tests and disable if necessary. I haven't seen any flakiness when running them now dozens of times on my Win/Mac/Linux, so I'm renabling all disabled tests (36!). I'll keep a close eye on the tree and flakiness dashboard afterwards. BUG=98716,48148,69881,70861,59786,36800,35965,36555,101996,34996,16934,22599 Review URL: https://chromiumcodereview.appspot.com/9802025 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@129641 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/worker')
-rw-r--r--content/worker/DEPS4
-rw-r--r--content/worker/test/OWNERS4
-rw-r--r--content/worker/test/worker_uitest.cc624
3 files changed, 0 insertions, 632 deletions
diff --git a/content/worker/DEPS b/content/worker/DEPS
index 7ad48a7..ba093bb 100644
--- a/content/worker/DEPS
+++ b/content/worker/DEPS
@@ -1,8 +1,4 @@
include_rules = [
- "-chrome",
- "+chrome/app", # For UI test
- "+chrome/test", # For UI test
- "+content/browser/worker_host", # For UI test.
"+sandbox/src",
"+webkit/appcache",
"+webkit/glue",
diff --git a/content/worker/test/OWNERS b/content/worker/test/OWNERS
deleted file mode 100644
index ea496eb..0000000
--- a/content/worker/test/OWNERS
+++ /dev/null
@@ -1,4 +0,0 @@
-dimich@chromium.org
-jianli@chromium.org
-levin@chromium.org
-dslomov@chromium.org
diff --git a/content/worker/test/worker_uitest.cc b/content/worker/test/worker_uitest.cc
deleted file mode 100644
index b68358d9..0000000
--- a/content/worker/test/worker_uitest.cc
+++ /dev/null
@@ -1,624 +0,0 @@
-// Copyright (c) 2012 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 "base/file_path.h"
-#include "base/string_util.h"
-#include "base/test/test_timeouts.h"
-#include "base/threading/platform_thread.h"
-#include "chrome/app/chrome_command_ids.h"
-#include "chrome/test/automation/automation_proxy.h"
-#include "chrome/test/automation/browser_proxy.h"
-#include "chrome/test/automation/tab_proxy.h"
-#include "chrome/test/base/layout_test_http_server.h"
-#include "chrome/test/base/ui_test_utils.h"
-#include "chrome/test/ui/ui_layout_test.h"
-#include "content/browser/worker_host/worker_service_impl.h"
-#include "content/public/common/url_constants.h"
-#include "net/test/test_server.h"
-
-using content::WorkerServiceImpl;
-
-namespace {
-
-const char kTestCompleteCookie[] = "status";
-const char kTestCompleteSuccess[] = "OK";
-const FilePath::CharType* kTestDir =
- FILE_PATH_LITERAL("workers");
-const FilePath::CharType* kManySharedWorkersFile =
- FILE_PATH_LITERAL("many_shared_workers.html");
-const FilePath::CharType* kQuerySharedWorkerShutdownFile =
- FILE_PATH_LITERAL("queued_shared_worker_shutdown.html");
-const FilePath::CharType* kShutdownSharedWorkerFile =
- FILE_PATH_LITERAL("shutdown_shared_worker.html");
-const FilePath::CharType* kSingleSharedWorkersFile =
- FILE_PATH_LITERAL("single_shared_worker.html");
-const FilePath::CharType* kWorkerClose =
- FILE_PATH_LITERAL("worker_close.html");
-
-} // anonymous namespace
-
-class WorkerTest : public UILayoutTest {
- protected:
- virtual ~WorkerTest() { }
-
- void RunTest(const FilePath& test_case, const std::string& query) {
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
-
- FilePath test_file_path = ui_test_utils::GetTestFilePath(
- FilePath(kTestDir), test_case);
- GURL url = ui_test_utils::GetFileUrlWithQuery(test_file_path, query);
- ASSERT_TRUE(tab->NavigateToURL(url));
-
- std::string value = WaitUntilCookieNonEmpty(tab.get(), url,
- kTestCompleteCookie, TestTimeouts::action_max_timeout_ms());
- ASSERT_STREQ(kTestCompleteSuccess, value.c_str());
- }
-
- void RunIncognitoTest(const FilePath& test_case) {
- scoped_refptr<BrowserProxy> browser(automation()->GetBrowserWindow(0));
- ASSERT_TRUE(browser.get());
-
- // Open an Incognito window.
- ASSERT_TRUE(browser->RunCommand(IDC_NEW_INCOGNITO_WINDOW));
- scoped_refptr<BrowserProxy> incognito(automation()->GetBrowserWindow(1));
- ASSERT_TRUE(incognito.get());
- int window_count;
- ASSERT_TRUE(automation()->GetBrowserWindowCount(&window_count));
- ASSERT_EQ(2, window_count);
-
- scoped_refptr<TabProxy> tab(incognito->GetTab(0));
- ASSERT_TRUE(tab.get());
-
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir), test_case);
- ASSERT_TRUE(tab->NavigateToURL(url));
-
- std::string value = WaitUntilCookieNonEmpty(tab.get(), url,
- kTestCompleteCookie, TestTimeouts::action_max_timeout_ms());
-
- // Close the incognito window
- ASSERT_TRUE(incognito->RunCommand(IDC_CLOSE_WINDOW));
- ASSERT_TRUE(automation()->GetBrowserWindowCount(&window_count));
- ASSERT_EQ(1, window_count);
-
- ASSERT_STREQ(kTestCompleteSuccess, value.c_str());
- }
-
- bool WaitForProcessCountToBeAtLeast(int tabs, int workers) {
- // The 1 is for the browser process.
- int number_of_processes = 1 + workers + tabs;
-#if defined(OS_POSIX) && !defined(OS_MACOSX)
- // On Unix, we also have a zygote process and a sandbox host process.
- number_of_processes += 2;
-#endif
-
- int cur_process_count;
- for (int i = 0; i < 100; ++i) {
- cur_process_count = 0;
- if (!GetBrowserProcessCount(&cur_process_count))
- return false;
- if (cur_process_count >= number_of_processes)
- return true;
-
- // Sometimes the worker processes can take a while to shut down on the
- // bots, so use a longer timeout period to avoid spurious failures.
- base::PlatformThread::Sleep(TestTimeouts::action_max_timeout() / 100);
- }
-
- EXPECT_GE(cur_process_count, number_of_processes);
- return false;
- }
-
- void RunWorkerFastLayoutTest(const std::string& test_case_file_name) {
- FilePath fast_test_dir;
- fast_test_dir = fast_test_dir.AppendASCII("fast");
-
- FilePath worker_test_dir;
- worker_test_dir = worker_test_dir.AppendASCII("workers");
- InitializeForLayoutTest(fast_test_dir, worker_test_dir, kNoHttpPort);
-
- // Worker tests also rely on common files in js/resources.
- FilePath js_dir = fast_test_dir.AppendASCII("js");
- FilePath resource_dir;
- resource_dir = resource_dir.AppendASCII("resources");
- AddResourceForLayoutTest(js_dir, resource_dir);
-
- printf("Test: %s\n", test_case_file_name.c_str());
- RunLayoutTest(test_case_file_name, kNoHttpPort);
-
- // Navigate to a blank page so that any workers are cleaned up.
- // This helps leaks trackers do a better job of reporting.
- scoped_refptr<TabProxy> tab(GetActiveTab());
- GURL about_url(chrome::kAboutBlankURL);
- EXPECT_EQ(AUTOMATION_MSG_NAVIGATION_SUCCESS, tab->NavigateToURL(about_url));
- }
-
- void RunWorkerStorageLayoutTest(const std::string& test_case_file_name) {
- FilePath worker_test_dir;
- worker_test_dir = worker_test_dir.AppendASCII("fast");
- worker_test_dir = worker_test_dir.AppendASCII("workers");
-
- FilePath storage_test_dir;
- storage_test_dir = storage_test_dir.AppendASCII("storage");
- InitializeForLayoutTest(worker_test_dir, storage_test_dir, kNoHttpPort);
-
- // Storage worker tests also rely on common files in 'resources'.
- FilePath resource_dir;
- resource_dir = resource_dir.AppendASCII("resources");
- AddResourceForLayoutTest(worker_test_dir.Append(storage_test_dir),
- resource_dir);
-
- printf("Test: %s\n", test_case_file_name.c_str());
- RunLayoutTest(test_case_file_name, kNoHttpPort);
-
- // Navigate to a blank page so that any workers are cleaned up.
- // This helps leaks trackers do a better job of reporting.
- scoped_refptr<TabProxy> tab(GetActiveTab());
- GURL about_url(chrome::kAboutBlankURL);
- EXPECT_EQ(AUTOMATION_MSG_NAVIGATION_SUCCESS, tab->NavigateToURL(about_url));
- }
-
- bool NavigateAndWaitForAuth(TabProxy* tab, const GURL& url) {
- // Pass a large number of navigations to tell the tab to block until an auth
- // dialog pops up.
- EXPECT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
- tab->NavigateToURLBlockUntilNavigationsComplete(url, 100));
- return tab->NeedsAuth();
- }
-};
-
-
-TEST_F(WorkerTest, SingleWorker) {
- RunTest(FilePath(FILE_PATH_LITERAL("single_worker.html")), "");
-}
-
-TEST_F(WorkerTest, MultipleWorkers) {
- RunTest(FilePath(FILE_PATH_LITERAL("multi_worker.html")), "");
-}
-
-TEST_F(WorkerTest, SingleSharedWorker) {
- RunTest(FilePath(FILE_PATH_LITERAL("single_worker.html")), "shared=true");
-}
-
-// Flaky on Win XP only. http://crbug.com/96435
-#if defined(OS_WIN)
-#define MultipleSharedWorkers DISABLED_MultipleSharedWorkers
-#endif
-TEST_F(WorkerTest, MultipleSharedWorkers) {
- RunTest(FilePath(FILE_PATH_LITERAL("multi_worker.html")), "shared=true");
-}
-
-#if defined(OS_LINUX) || defined(OS_CHROMEOS)
-// http://crbug.com/80446
-#define DISABLED_TerminateQueuedWorkers DISABLED_TerminateQueuedWorkers
-#endif
-TEST_F(WorkerTest, DISABLED_TerminateQueuedWorkers) {
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, 0));
- RunTest(FilePath(FILE_PATH_LITERAL("terminate_queued_workers.html")), "");
- // Make sure all workers exit.
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, 0));
-}
-
-#if defined(OS_LINUX)
-// http://crbug.com/30021
-#define IncognitoSharedWorkers DISABLED_IncognitoSharedWorkers
-#endif
-// Incognito windows should not share workers with non-incognito windows
-TEST_F(WorkerTest, IncognitoSharedWorkers) {
- // Load a non-incognito tab and have it create a shared worker
- RunTest(FilePath(FILE_PATH_LITERAL("incognito_worker.html")), "");
- // Incognito worker should not share with non-incognito
- RunIncognitoTest(FilePath(FILE_PATH_LITERAL("incognito_worker.html")));
-}
-
-const FilePath::CharType kDocRoot[] =
- FILE_PATH_LITERAL("chrome/test/data/workers");
-
-#if defined(OS_WIN)
-// http://crbug.com/33344 - NavigateAndWaitForAuth times out on the Windows
-// build bots.
-#define WorkerHttpAuth DISABLED_WorkerHttpAuth
-#endif
-// Make sure that auth dialog is displayed from worker context.
-TEST_F(WorkerTest, WorkerHttpAuth) {
- net::TestServer test_server(net::TestServer::TYPE_HTTP,
- net::TestServer::kLocalhost,
- FilePath(kDocRoot));
- ASSERT_TRUE(test_server.Start());
-
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
-
- GURL url = test_server.GetURL("files/worker_auth.html");
- EXPECT_TRUE(NavigateAndWaitForAuth(tab, url));
-}
-
-#if defined(OS_WIN)
-// http://crbug.com/33344 - NavigateAndWaitForAuth times out on the Windows
-// build bots.
-#define SharedWorkerHttpAuth DISABLED_SharedWorkerHttpAuth
-#endif
-// Make sure that auth dialog is displayed from shared worker context.
-TEST_F(WorkerTest, DISABLED_SharedWorkerHttpAuth) {
- net::TestServer test_server(net::TestServer::TYPE_HTTP,
- net::TestServer::kLocalhost,
- FilePath(kDocRoot));
- ASSERT_TRUE(test_server.Start());
-
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
-
- GURL url = test_server.GetURL("files/shared_worker_auth.html");
- EXPECT_TRUE(NavigateAndWaitForAuth(tab, url));
- // TODO(atwilson): Add support to automation framework to test for auth
- // dialogs displayed by non-navigating tabs.
-}
-
-// Crashy, http://crbug.com/35965.
-// Flaky, http://crbug.com/36555.
-TEST_F(WorkerTest, DISABLED_WorkerClonePort) {
- RunWorkerFastLayoutTest("worker-cloneport.html");
-}
-
-// http://crbug.com/101996 (started flaking with WebKit roll 98537:98582).
-TEST_F(WorkerTest, DISABLED_WorkerContextMultiPort) {
- RunWorkerFastLayoutTest("worker-context-multi-port.html");
-}
-
-TEST_F(WorkerTest, WorkerMessagePort) {
- RunWorkerFastLayoutTest("worker-messageport.html");
-}
-
-TEST_F(WorkerTest, WorkerMessagePortGC) {
- RunWorkerFastLayoutTest("worker-messageport-gc.html");
-}
-
-// http://crbug.com/101996 (started flaking with WebKit roll 98537:98582).
-TEST_F(WorkerTest, DISABLED_WorkerMultiPort) {
- RunWorkerFastLayoutTest("worker-multi-port.html");
-}
-
-//
-// SharedWorkerFastLayoutTests
-//
-TEST_F(WorkerTest, SharedWorkerFastConstructor) {
- RunWorkerFastLayoutTest("shared-worker-constructor.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastContextGC) {
- RunWorkerFastLayoutTest("shared-worker-context-gc.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastEventListener) {
- RunWorkerFastLayoutTest("shared-worker-event-listener.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastException) {
- RunWorkerFastLayoutTest("shared-worker-exception.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastGC) {
- RunWorkerFastLayoutTest("shared-worker-gc.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastInIframe) {
- RunWorkerFastLayoutTest("shared-worker-in-iframe.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastLoadError) {
- RunWorkerFastLayoutTest("shared-worker-load-error.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastLocation) {
- RunWorkerFastLayoutTest("shared-worker-location.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastName) {
- RunWorkerFastLayoutTest("shared-worker-name.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastNavigator) {
- RunWorkerFastLayoutTest("shared-worker-navigator.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastReplaceGlobalConstructor) {
- RunWorkerFastLayoutTest("shared-worker-replace-global-constructor.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastReplaceSelf) {
- RunWorkerFastLayoutTest("shared-worker-replace-self.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastScriptError) {
- RunWorkerFastLayoutTest("shared-worker-script-error.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastShared) {
- RunWorkerFastLayoutTest("shared-worker-shared.html");
-}
-
-TEST_F(WorkerTest, SharedWorkerFastSimple) {
- RunWorkerFastLayoutTest("shared-worker-simple.html");
-}
-
-// http://crbug.com/16934
-TEST_F(WorkerTest, DISABLED_WorkerHttpLayoutTests) {
- static const char* kLayoutTestFiles[] = {
- "shared-worker-importScripts.html",
- "shared-worker-redirect.html",
- // flakey? BUG 16934 "text-encoding.html",
-#if defined(OS_WIN)
- // Fails on the mac (and linux?):
- // http://code.google.com/p/chromium/issues/detail?id=22599
- "worker-importScripts.html",
-#endif
- "worker-redirect.html",
- };
-
- FilePath http_test_dir;
- http_test_dir = http_test_dir.AppendASCII("http");
- http_test_dir = http_test_dir.AppendASCII("tests");
-
- FilePath worker_test_dir;
- worker_test_dir = worker_test_dir.AppendASCII("workers");
- InitializeForLayoutTest(http_test_dir, worker_test_dir, kHttpPort);
-
- LayoutTestHttpServer http_server(new_http_root_dir_, kHttpPort);
- ASSERT_TRUE(http_server.Start());
- for (size_t i = 0; i < arraysize(kLayoutTestFiles); ++i)
- RunLayoutTest(kLayoutTestFiles[i], kHttpPort);
- ASSERT_TRUE(http_server.Stop());
-}
-
-TEST_F(WorkerTest, WorkerWebSocketLayoutTests) {
- static const char* kLayoutTestFiles[] = {
- "close-in-onmessage-crash.html",
- "close-in-shared-worker.html",
- "close-in-worker.html",
- "shared-worker-simple.html",
- "worker-handshake-challenge-randomness.html",
- "worker-simple.html"
- };
-
- FilePath websocket_test_dir;
- websocket_test_dir = websocket_test_dir.AppendASCII("http");
- websocket_test_dir = websocket_test_dir.AppendASCII("tests");
-
- FilePath worker_test_dir;
- worker_test_dir = worker_test_dir.AppendASCII("websocket");
- worker_test_dir = worker_test_dir.AppendASCII("tests");
- worker_test_dir = worker_test_dir.AppendASCII("hybi");
- worker_test_dir = worker_test_dir.AppendASCII("workers");
- InitializeForLayoutTest(websocket_test_dir, worker_test_dir, kHttpPort);
-
- FilePath websocket_root_dir(temp_test_dir_);
- websocket_root_dir = websocket_root_dir.AppendASCII("LayoutTests");
- ui_test_utils::TestWebSocketServer websocket_server;
- ASSERT_TRUE(websocket_server.Start(websocket_root_dir));
-
- LayoutTestHttpServer http_server(new_http_root_dir_, kHttpPort);
- ASSERT_TRUE(http_server.Start());
- for (size_t i = 0; i < arraysize(kLayoutTestFiles); ++i)
- RunLayoutTest(kLayoutTestFiles[i], kHttpPort);
- ASSERT_TRUE(http_server.Stop());
-}
-
-TEST_F(WorkerTest, DISABLED_WorkerXhrHttpLayoutTests) {
- static const char* kLayoutTestFiles[] = {
- "abort-exception-assert.html",
-#if defined(OS_WIN)
- // Fails on the mac (and linux?):
- // http://code.google.com/p/chromium/issues/detail?id=22599
- "close.html",
-#endif
- // These tests (and the shared-worker versions below) are disabled due to
- // limitations in lighttpd (doesn't handle all of the HTTP methods).
- // "methods-async.html",
- // "methods.html",
-
- "shared-worker-close.html",
- // Disabled due to limitations in lighttpd (does not handle methods other
- // than GET/PUT/POST).
- // "shared-worker-methods-async.html",
- // "shared-worker-methods.html",
- "shared-worker-xhr-file-not-found.html",
-
- "xmlhttprequest-file-not-found.html"
- };
-
- FilePath http_test_dir;
- http_test_dir = http_test_dir.AppendASCII("http");
- http_test_dir = http_test_dir.AppendASCII("tests");
-
- FilePath worker_test_dir;
- worker_test_dir = worker_test_dir.AppendASCII("xmlhttprequest");
- worker_test_dir = worker_test_dir.AppendASCII("workers");
- InitializeForLayoutTest(http_test_dir, worker_test_dir, kHttpPort);
-
- LayoutTestHttpServer http_server(new_http_root_dir_, kHttpPort);
- ASSERT_TRUE(http_server.Start());
- for (size_t i = 0; i < arraysize(kLayoutTestFiles); ++i)
- RunLayoutTest(kLayoutTestFiles[i], kHttpPort);
- ASSERT_TRUE(http_server.Stop());
-}
-
-// Flaky, http://crbug.com/34996.
-TEST_F(WorkerTest, DISABLED_MessagePorts) {
- static const char* kLayoutTestFiles[] = {
- "message-channel-gc.html",
- "message-channel-gc-2.html",
- "message-channel-gc-3.html",
- "message-channel-gc-4.html",
- "message-port.html",
- "message-port-clone.html",
- "message-port-constructor-for-deleted-document.html",
- "message-port-deleted-document.html",
- "message-port-deleted-frame.html",
- "message-port-inactive-document.html",
- "message-port-multi.html",
- "message-port-no-wrapper.html",
- // Only works with run-webkit-tests --leaks.
- // "message-channel-listener-circular-ownership.html",
- };
-
- FilePath fast_test_dir;
- fast_test_dir = fast_test_dir.AppendASCII("fast");
-
- FilePath worker_test_dir;
- worker_test_dir = worker_test_dir.AppendASCII("events");
- InitializeForLayoutTest(fast_test_dir, worker_test_dir, kNoHttpPort);
-
- // MessagePort tests also rely on common files in js/resources.
- FilePath js_dir = fast_test_dir.AppendASCII("js");
- FilePath resource_dir;
- resource_dir = resource_dir.AppendASCII("resources");
- AddResourceForLayoutTest(js_dir, resource_dir);
-
- for (size_t i = 0; i < arraysize(kLayoutTestFiles); ++i)
- RunLayoutTest(kLayoutTestFiles[i], kNoHttpPort);
-}
-
-TEST_F(WorkerTest, LimitPerPage) {
- int max_workers_per_tab = WorkerServiceImpl::kMaxWorkersPerTabWhenSeparate;
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kManySharedWorkersFile));
- url = GURL(url.spec() + StringPrintf("?count=%d", max_workers_per_tab + 1));
-
- NavigateToURL(url);
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, max_workers_per_tab));
-}
-
-// http://crbug.com/36800
-#if defined(OS_WIN)
-#define MAYBE_LimitTotal DISABLED_LimitTotal
-#else
-#define MAYBE_LimitTotal LimitTotal
-#endif // defined(OS_WIN)
-TEST_F(WorkerTest, MAYBE_LimitTotal) {
- int max_workers_per_tab = WorkerServiceImpl::kMaxWorkersPerTabWhenSeparate;
- int total_workers = WorkerServiceImpl::kMaxWorkersWhenSeparate;
-
- // Adding 1 so that we cause some workers to be queued.
- int tab_count = (total_workers / max_workers_per_tab) + 1;
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kManySharedWorkersFile));
- url = GURL(url.spec() + StringPrintf("?count=%d", max_workers_per_tab));
-
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
- ASSERT_TRUE(tab->NavigateToURL(
- GURL(url.spec() + StringPrintf("&client_id=%d", 0))));
- scoped_refptr<BrowserProxy> window(automation()->GetBrowserWindow(0));
- ASSERT_TRUE(window.get());
- for (int i = 1; i < tab_count; ++i) {
- ASSERT_TRUE(window->AppendTab(GURL(
- url.spec() + StringPrintf("&client_id=%d", i))));
- }
-
- // Check that we didn't create more than the max number of workers.
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(tab_count, total_workers));
-
- // Now close a page and check that the queued workers were started.
- const FilePath::CharType* kGoogleDir = FILE_PATH_LITERAL("google");
- const FilePath::CharType* kGoogleFile = FILE_PATH_LITERAL("google.html");
- ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_SUCCESS,
- tab->NavigateToURL(ui_test_utils::GetTestUrl(FilePath(kGoogleDir),
- FilePath(kGoogleFile))));
-
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(tab_count, total_workers));
-}
-
-// Flaky, http://crbug.com/59786.
-TEST_F(WorkerTest, DISABLED_WorkerClose) {
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kWorkerClose));
- ASSERT_TRUE(tab->NavigateToURL(url));
- std::string value = WaitUntilCookieNonEmpty(tab.get(), url,
- kTestCompleteCookie, TestTimeouts::action_max_timeout_ms());
- ASSERT_STREQ(kTestCompleteSuccess, value.c_str());
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, 0));
-}
-
-// Flaky, http://crbug.com/70861.
-TEST_F(WorkerTest, DISABLED_QueuedSharedWorkerShutdown) {
- // Tests to make sure that queued shared workers are started up when
- // shared workers shut down.
- int max_workers_per_tab = WorkerServiceImpl::kMaxWorkersPerTabWhenSeparate;
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kQuerySharedWorkerShutdownFile));
- url = GURL(url.spec() + StringPrintf("?count=%d", max_workers_per_tab));
-
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
- ASSERT_TRUE(tab->NavigateToURL(url));
- std::string value = WaitUntilCookieNonEmpty(tab.get(), url,
- kTestCompleteCookie, TestTimeouts::action_max_timeout_ms());
- ASSERT_STREQ(kTestCompleteSuccess, value.c_str());
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, max_workers_per_tab));
-}
-
-// Flaky, http://crbug.com/69881.
-TEST_F(WorkerTest, DISABLED_MultipleTabsQueuedSharedWorker) {
- // Tests to make sure that only one instance of queued shared workers are
- // started up even when those instances are on multiple tabs.
- int max_workers_per_tab = WorkerServiceImpl::kMaxWorkersPerTabWhenSeparate;
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kManySharedWorkersFile));
- url = GURL(url.spec() + StringPrintf("?count=%d", max_workers_per_tab+1));
-
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
- ASSERT_TRUE(tab->NavigateToURL(url));
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, max_workers_per_tab));
-
- // Create same set of workers in new tab (leaves one worker queued from this
- // tab).
- scoped_refptr<BrowserProxy> window(automation()->GetBrowserWindow(0));
- ASSERT_TRUE(window.get());
- ASSERT_TRUE(window->AppendTab(url));
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(2, max_workers_per_tab));
-
- // Now shutdown one of the shared workers - this will fire both queued
- // workers, but only one instance should be started
- GURL url2 = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kShutdownSharedWorkerFile));
- url2 = GURL(url2.spec() + "?id=0");
- ASSERT_TRUE(window->AppendTab(url2));
-
- std::string value = WaitUntilCookieNonEmpty(tab.get(), url,
- kTestCompleteCookie, TestTimeouts::action_max_timeout_ms());
- ASSERT_STREQ(kTestCompleteSuccess, value.c_str());
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(3, max_workers_per_tab));
-}
-
-// Flaky: http://crbug.com/48148
-TEST_F(WorkerTest, DISABLED_QueuedSharedWorkerStartedFromOtherTab) {
- // Tests to make sure that queued shared workers are started up when
- // an instance is launched from another tab.
- int max_workers_per_tab = WorkerServiceImpl::kMaxWorkersPerTabWhenSeparate;
- GURL url = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kManySharedWorkersFile));
- url = GURL(url.spec() + StringPrintf("?count=%d", max_workers_per_tab+1));
-
- scoped_refptr<TabProxy> tab(GetActiveTab());
- ASSERT_TRUE(tab.get());
- ASSERT_TRUE(tab->NavigateToURL(url));
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(1, max_workers_per_tab));
- // First window has hit its limit. Now launch second window which creates
- // the same worker that was queued in the first window, to ensure it gets
- // connected to the first window too.
- scoped_refptr<BrowserProxy> window(automation()->GetBrowserWindow(0));
- ASSERT_TRUE(window.get());
- GURL url2 = ui_test_utils::GetTestUrl(FilePath(kTestDir),
- FilePath(kSingleSharedWorkersFile));
- url2 = GURL(url2.spec() + StringPrintf("?id=%d", max_workers_per_tab));
- ASSERT_TRUE(window->AppendTab(url2));
-
- std::string value = WaitUntilCookieNonEmpty(tab.get(), url,
- kTestCompleteCookie, TestTimeouts::action_max_timeout_ms());
- ASSERT_STREQ(kTestCompleteSuccess, value.c_str());
- ASSERT_TRUE(WaitForProcessCountToBeAtLeast(2, max_workers_per_tab+1));
-}