summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authortc@google.com <tc@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-29 18:45:11 +0000
committertc@google.com <tc@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-29 18:45:11 +0000
commit022d781a2cc19279a89e3f32ade891ba133e6077 (patch)
treed96c73e8c237066dc88d3daeed209e1fbcda03ac /chrome
parent922e38964eba7f23f2f5f5e5ce3b547f2940bdf3 (diff)
downloadchromium_src-022d781a2cc19279a89e3f32ade891ba133e6077.zip
chromium_src-022d781a2cc19279a89e3f32ade891ba133e6077.tar.gz
chromium_src-022d781a2cc19279a89e3f32ade891ba133e6077.tar.bz2
Disable alternate error pages on frames and iframes. This is
a request from the link doctor team. Add a UI test that verifies that no link doctor page is loaded. Review URL: http://codereview.chromium.org/5032 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2684 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/errorpage_uitest.cc27
-rw-r--r--chrome/test/data/iframe404-inner.html1
-rw-r--r--chrome/test/data/iframe404-inner.html.mock-http-headers2
-rw-r--r--chrome/test/data/iframe404.html2
4 files changed, 32 insertions, 0 deletions
diff --git a/chrome/browser/errorpage_uitest.cc b/chrome/browser/errorpage_uitest.cc
index 8da9f1d..ec63430 100644
--- a/chrome/browser/errorpage_uitest.cc
+++ b/chrome/browser/errorpage_uitest.cc
@@ -5,6 +5,7 @@
#include "base/string_util.h"
#include "chrome/test/ui/ui_test.h"
#include "chrome/browser/automation/url_request_failed_dns_job.h"
+#include "net/url_request/url_request_unittest.h"
class ErrorPageTest : public UITest {
};
@@ -32,3 +33,29 @@ TEST_F(ErrorPageTest, DNSError) {
}
};
+TEST_F(ErrorPageTest, IFrame404) {
+ // iframes that have 404 pages should not trigger an alternate error page.
+ // In this test, the iframe sets the title of the parent page to "SUCCESS"
+ // when the iframe loads. If the iframe fails to load (because an alternate
+ // error page loads instead), then the title will remain as "FAIL".
+ TestServer server(L"chrome/test/data");
+ GURL test_url = server.TestServerPage("files/iframe404.html");
+ NavigateToURL(test_url);
+
+ // Verify that the url is in the title. Since it's set via Javascript, we
+ // need to give it a chance to run.
+ int i;
+ std::wstring title;
+ for (i = 0; i < 10; ++i) {
+ Sleep(kWaitForActionMaxMsec / 10);
+ title = GetActiveTabTitle();
+ if (title == L"SUCCESS") {
+ // Success, bail out.
+ break;
+ }
+ }
+
+ if (i == 10) {
+ FAIL() << "iframe 404 didn't load properly";
+ }
+};
diff --git a/chrome/test/data/iframe404-inner.html b/chrome/test/data/iframe404-inner.html
new file mode 100644
index 0000000..c992efc0
--- /dev/null
+++ b/chrome/test/data/iframe404-inner.html
@@ -0,0 +1 @@
+<script>window.parent.document.title="SUCCESS"</script>
diff --git a/chrome/test/data/iframe404-inner.html.mock-http-headers b/chrome/test/data/iframe404-inner.html.mock-http-headers
new file mode 100644
index 0000000..0590363
--- /dev/null
+++ b/chrome/test/data/iframe404-inner.html.mock-http-headers
@@ -0,0 +1,2 @@
+HTTP/1.0 404 Not Found
+Content-type: text/html
diff --git a/chrome/test/data/iframe404.html b/chrome/test/data/iframe404.html
new file mode 100644
index 0000000..3089555
--- /dev/null
+++ b/chrome/test/data/iframe404.html
@@ -0,0 +1,2 @@
+<title>FAILURE</title>
+<iframe src="iframe404-inner.html"></iframe>