diff options
author | michaeln@chromium.org <michaeln@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-06-28 22:32:32 +0000 |
---|---|---|
committer | michaeln@chromium.org <michaeln@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-06-28 22:32:32 +0000 |
commit | 446f96cfad3a74fd4e08a5a29c299e25917abb47 (patch) | |
tree | 82626e93cfe47423f4f2680569cd921b114164e4 /chrome | |
parent | 860a23a03cd9546ffcb2ab33645c7d2bb3259c1b (diff) | |
download | chromium_src-446f96cfad3a74fd4e08a5a29c299e25917abb47.zip chromium_src-446f96cfad3a74fd4e08a5a29c299e25917abb47.tar.gz chromium_src-446f96cfad3a74fd4e08a5a29c299e25917abb47.tar.bz2 |
Run appcache layout tests in chrome using the ui test harness.
BUG=39365
TEST=yes
Review URL: http://codereview.chromium.org/2879003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@51059 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r-- | chrome/browser/appcache/appcache_ui_test.cc | 75 | ||||
-rw-r--r-- | chrome/chrome_tests.gypi | 1 | ||||
-rw-r--r-- | chrome/test/data/layout_tests/layout_test_controller.html | 2 | ||||
-rw-r--r-- | chrome/test/ui/ui_layout_test.cc | 17 |
4 files changed, 91 insertions, 4 deletions
diff --git a/chrome/browser/appcache/appcache_ui_test.cc b/chrome/browser/appcache/appcache_ui_test.cc new file mode 100644 index 0000000..23afd8b --- /dev/null +++ b/chrome/browser/appcache/appcache_ui_test.cc @@ -0,0 +1,75 @@ +// Copyright (c) 2010 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 "chrome/test/ui/ui_layout_test.h" + +class AppCacheUITest : public UILayoutTest { + protected: + virtual ~AppCacheUITest() {} +}; + +TEST_F(AppCacheUITest, FLAKY_AppCacheLayoutTests) { + static const char* kLayoutTestFiles[] = { + "404-manifest.html", + "404-resource.html", + "auth.html", + "cyrillic-uri.html", + "deferred-events-delete-while-raising.html", + "deferred-events.html", + "destroyed-frame.html", + "detached-iframe.html", + "different-origin-manifest.html", + "different-scheme.html", + "empty-manifest.html", + "fallback.html", + "foreign-iframe-main.html", + "main-resource-hash.html", + "manifest-containing-itself.html", + "manifest-parsing.html", + "manifest-redirect-2.html", + "manifest-redirect.html", + "manifest-with-empty-file.html", + "navigating-away-while-cache-attempt-in-progress.html", + "offline-access.html", + "online-whitelist.html", + "reload.html", + "remove-cache.html", + "resource-redirect-2.html", + "resource-redirect.html", + "simple.html", + "top-frame-1.html", + "top-frame-2.html", + "top-frame-3.html", + "top-frame-4.html", + "whitelist-wildcard.html", + "wrong-content-type.html", + "wrong-signature-2.html", + "wrong-signature.html", + "xhr-foreign-resource.html", + + // TOOD(michaeln): investigate these more closely + // "crash-when-navigating-away-then-back.html", + // "credential-url.html", + // "different-https-origin-resource-main.html", + // "fail-on-update.html", + // "idempotent-update.html", not sure this is a valid test + // "local-content.html", + // "max-size.html", we use a different quota scheme + // "update-cache.html", bug 38006 + }; + + FilePath http_test_dir; + http_test_dir = http_test_dir.AppendASCII("http"); + http_test_dir = http_test_dir.AppendASCII("tests"); + + FilePath appcache_test_dir; + appcache_test_dir = appcache_test_dir.AppendASCII("appcache"); + InitializeForLayoutTest(http_test_dir, appcache_test_dir, kHttpPort); + + StartHttpServer(new_http_root_dir_); + for (size_t i = 0; i < arraysize(kLayoutTestFiles); ++i) + RunLayoutTest(kLayoutTestFiles[i], kHttpPort); + StopHttpServer(); +} diff --git a/chrome/chrome_tests.gypi b/chrome/chrome_tests.gypi index ee8e88a..e956ce6 100644 --- a/chrome/chrome_tests.gypi +++ b/chrome/chrome_tests.gypi @@ -302,6 +302,7 @@ ], 'sources': [ 'app/chrome_main_uitest.cc', + 'browser/appcache/appcache_ui_test.cc', 'browser/browser_encoding_uitest.cc', 'browser/browser_uitest.cc', 'browser/cookie_modal_dialog_uitest.cc', diff --git a/chrome/test/data/layout_tests/layout_test_controller.html b/chrome/test/data/layout_tests/layout_test_controller.html index e82d675..e2bf813 100644 --- a/chrome/test/data/layout_tests/layout_test_controller.html +++ b/chrome/test/data/layout_tests/layout_test_controller.html @@ -22,7 +22,7 @@ function LayoutTestController() { }; this.DelayedNotifyDone2 = function () { - var token = encodeURIComponent(document.firstChild.innerText); + var token = encodeURIComponent(document.body.innerText); document.cookie = "%COOKIE%=" + token; }; diff --git a/chrome/test/ui/ui_layout_test.cc b/chrome/test/ui/ui_layout_test.cc index 73556a9..6c5415f 100644 --- a/chrome/test/ui/ui_layout_test.cc +++ b/chrome/test/ui/ui_layout_test.cc @@ -156,6 +156,16 @@ void UILayoutTest::AddResourceForLayoutTest(const FilePath& parent_dir, ASSERT_TRUE(file_util::CopyDirectory(src_dir, dest_dir, true)); } +static size_t FindInsertPosition(const std::string& html) { + size_t tag_start = html.find("<html"); + if (tag_start == std::string::npos) + return 0; + size_t tag_end = html.find(">", tag_start); + if (tag_end == std::string::npos) + return 0; + return tag_end + 1; +} + void UILayoutTest::RunLayoutTest(const std::string& test_case_file_name, int port) { SCOPED_TRACE(test_case_file_name.c_str()); @@ -175,9 +185,10 @@ void UILayoutTest::RunLayoutTest(const std::string& test_case_file_name, ASSERT_TRUE(file_util::ReadFileToString(test_file_path, &test_html)); // Injects the layout test controller into the test HTML. - test_html.insert(0, layout_test_controller_); - ReplaceSubstringsAfterOffset( - &test_html, 0, "%COOKIE%", status_cookie.c_str()); + size_t insertion_position = FindInsertPosition(test_html); + test_html.insert(insertion_position, layout_test_controller_); + ReplaceFirstSubstringAfterOffset( + &test_html, insertion_position, "%COOKIE%", status_cookie.c_str()); // Creates the new layout test HTML file. FilePath new_test_file_path(new_layout_test_dir_); |