diff options
author | japhet@chromium.org <japhet@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-05-12 19:12:29 +0000 |
---|---|---|
committer | japhet@chromium.org <japhet@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-05-12 19:12:29 +0000 |
commit | b90b874fe7023537531fbd08df403694e3e3a520 (patch) | |
tree | 3b988f12c4e6f933ec94dd0b3aa32a17e7ac2ee8 | |
parent | 034fbbd8fb6271e4193f97bdda129791c0ba6b72 (diff) | |
download | chromium_src-b90b874fe7023537531fbd08df403694e3e3a520.zip chromium_src-b90b874fe7023537531fbd08df403694e3e3a520.tar.gz chromium_src-b90b874fe7023537531fbd08df403694e3e3a520.tar.bz2 |
Test that serializing a document with an iframe that was downloaded doesn't cause a renderer crash.
BUG=42212
TEST=DomSerializerTests.SerializeDocumentWithDownloadedIFrame
Review URL: http://codereview.chromium.org/1917007
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@47054 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | webkit/data/dom_serializer/dummy.exe | 0 | ||||
-rw-r--r-- | webkit/data/dom_serializer/iframe-src-is-exe.htm | 8 | ||||
-rw-r--r-- | webkit/glue/dom_serializer_unittest.cc | 14 |
3 files changed, 22 insertions, 0 deletions
diff --git a/webkit/data/dom_serializer/dummy.exe b/webkit/data/dom_serializer/dummy.exe new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/webkit/data/dom_serializer/dummy.exe diff --git a/webkit/data/dom_serializer/iframe-src-is-exe.htm b/webkit/data/dom_serializer/iframe-src-is-exe.htm new file mode 100644 index 0000000..ed32b12 --- /dev/null +++ b/webkit/data/dom_serializer/iframe-src-is-exe.htm @@ -0,0 +1,8 @@ +<html>
+<body>
+This tests that we can serialize a page that has a downloaded url in an iframe without crashing.
+
+<iframe src="dummy.exe"></iframe>
+
+</body>
+</html>
\ No newline at end of file diff --git a/webkit/glue/dom_serializer_unittest.cc b/webkit/glue/dom_serializer_unittest.cc index ce5be4d..a38d82f 100644 --- a/webkit/glue/dom_serializer_unittest.cc +++ b/webkit/glue/dom_serializer_unittest.cc @@ -836,4 +836,18 @@ TEST_F(DomSerializerTests, SerializeHTMLDOMWithEmptyHead) { ASSERT_TRUE(std::string(text_node_contents.utf8()) == "hello world"); } +// Test that we don't crash when the page contains an iframe that +// was handled as a download (http://crbug.com/42212). +TEST_F(DomSerializerTests, SerializeDocumentWithDownloadedIFrame) { + FilePath page_file_path = data_dir_; + page_file_path = page_file_path.AppendASCII("dom_serializer"); + page_file_path = page_file_path.AppendASCII("iframe-src-is-exe.htm"); + GURL file_url = net::FilePathToFileURL(page_file_path); + ASSERT_TRUE(file_url.SchemeIsFile()); + // Load the test file. + LoadPageFromURL(file_url); + // Do a recursive serialization. We pass if we don't crash. + SerializeDomForURL(file_url, true); +} + } // namespace |