[SCM] WebKit Debian packaging branch, webkit-1.1, updated. upstream/1.1.21-584-g1e41756

kov at webkit.org kov at webkit.org
Fri Feb 26 22:20:17 UTC 2010


The following commit has been merged in the webkit-1.1 branch:
commit 04b1b2f2a0ff5b7882fddfef9401f23c30afd206
Author: kov at webkit.org <kov at webkit.org@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Date:   Mon Feb 15 20:35:55 2010 +0000

    2010-02-15 Gustavo Noronha Silva <gustavo.noronha at collabora.co.uk>
    
            Reviewed by Xan Lopez.
    
            [GTK] Crashes when going back to a page that has data: URIs, with page cache enabled
            https://bugs.webkit.org/show_bug.cgi?id=34944
    
            Set the URL in the newly created response, when parsing data:
            URIs.
    
            Test: fast/harness/page-cache-crash-on-data-urls.html
    
            * platform/network/soup/ResourceHandleSoup.cpp:
            (WebCore::parseDataUrl):
    
    git-svn-id: http://svn.webkit.org/repository/webkit/trunk@54786 268f45cc-cd09-0410-ab3c-d52691b4dbfc

diff --git a/LayoutTests/ChangeLog b/LayoutTests/ChangeLog
index b96db8a..d307e9a 100644
--- a/LayoutTests/ChangeLog
+++ b/LayoutTests/ChangeLog
@@ -1,3 +1,14 @@
+2010-02-15  Gustavo Noronha Silva  <gustavo.noronha at collabora.co.uk>
+
+        Reviewed by Xan Lopez.
+
+        [GTK] Crashes when going back to a page that has data: URIs, with page cache enabled
+        https://bugs.webkit.org/show_bug.cgi?id=34944
+
+        * fast/harness/page-cache-crash-on-data-urls-expected.txt: Added.
+        * fast/harness/page-cache-crash-on-data-urls.html: Added.
+        * fast/harness/resources/cached-page-with-data-urls.html: Added.
+
 2010-02-15  Dan Bernstein  <mitz at apple.com>
 
         Reviewed by Simon Fraser.
diff --git a/LayoutTests/fast/harness/page-cache-crash-on-data-urls-expected.txt b/LayoutTests/fast/harness/page-cache-crash-on-data-urls-expected.txt
new file mode 100644
index 0000000..7ce1867
--- /dev/null
+++ b/LayoutTests/fast/harness/page-cache-crash-on-data-urls-expected.txt
@@ -0,0 +1,8 @@
+This tests that going back in history with page cache enabled is not going to crash/ASSERT when the previous page has data:// URLs.
+
+open page with data urls
+page with data urls, about to navigate to page-2.
+page-2, about to go back to page-1
+Back on page with data urls, timer is still firing.
+PASS.
+
diff --git a/LayoutTests/fast/harness/page-cache-crash-on-data-urls.html b/LayoutTests/fast/harness/page-cache-crash-on-data-urls.html
new file mode 100644
index 0000000..9bef46e
--- /dev/null
+++ b/LayoutTests/fast/harness/page-cache-crash-on-data-urls.html
@@ -0,0 +1,36 @@
+<html>
+<script>
+window.finish = function()
+{
+    if (layoutTestController)
+        layoutTestController.notifyDone();
+}
+
+window.log = function(message) {
+     document.getElementById("result").innerHTML += message + "<br>";
+}
+
+window.failure = function(message) {
+    log("FAIL: " + message);
+    finish();
+}
+
+function test()
+{
+    if (window.layoutTestController) {
+        layoutTestController.dumpAsText();
+        layoutTestController.waitUntilDone();
+        layoutTestController.setCanOpenWindows();
+        layoutTestController.overridePreference("WebKitUsesPageCachePreferenceKey", 1);
+    }
+    log("open page with data urls");
+    window.open("resources/cached-page-with-data-urls.html");
+}
+</script>
+
+<body onload="test()">
+<p>This tests that going back in history with page cache enabled is
+not going to crash/ASSERT when the previous page has data:// URLs.</p>
+<div id="result"></div>
+</body>
+</html>
diff --git a/LayoutTests/fast/harness/resources/cached-page-with-data-urls.html b/LayoutTests/fast/harness/resources/cached-page-with-data-urls.html
new file mode 100644
index 0000000..f85166d
--- /dev/null
+++ b/LayoutTests/fast/harness/resources/cached-page-with-data-urls.html
@@ -0,0 +1,26 @@
+<script>
+
+var intervalId;
+function check() {
+    // This flag is set by cached-page-2 when it loads.
+    // If the timer is fired before cached-page-2 loads, just bail and wait.
+    if (!window.opener.canExit)
+        return;
+
+    clearInterval(intervalId);
+    window.opener.log("Back on page with data urls, timer is still firing.");
+    window.opener.log("PASS.");
+    window.opener.finish();
+}
+
+function loadNext()
+{
+    intervalId = setInterval(check, 10);
+
+    window.opener.log("page with data urls, about to navigate to page-2.")
+    location.href = "cached-page-2.html";
+}
+</script>
+<body onload="loadNext()">
+<img src=""/>
+</body>
diff --git a/WebCore/ChangeLog b/WebCore/ChangeLog
index 728cd2a..979ff11 100644
--- a/WebCore/ChangeLog
+++ b/WebCore/ChangeLog
@@ -1,3 +1,18 @@
+2010-02-15  Gustavo Noronha Silva  <gustavo.noronha at collabora.co.uk>
+
+        Reviewed by Xan Lopez.
+
+        [GTK] Crashes when going back to a page that has data: URIs, with page cache enabled
+        https://bugs.webkit.org/show_bug.cgi?id=34944
+
+        Set the URL in the newly created response, when parsing data:
+        URIs.
+
+        Test: fast/harness/page-cache-crash-on-data-urls.html
+
+        * platform/network/soup/ResourceHandleSoup.cpp:
+        (WebCore::parseDataUrl):
+
 2010-02-15  Dan Bernstein  <mitz at apple.com>
 
         Reviewed by Simon Fraser.
diff --git a/WebCore/platform/network/soup/ResourceHandleSoup.cpp b/WebCore/platform/network/soup/ResourceHandleSoup.cpp
index ee8e7aa..9a315cd 100644
--- a/WebCore/platform/network/soup/ResourceHandleSoup.cpp
+++ b/WebCore/platform/network/soup/ResourceHandleSoup.cpp
@@ -380,6 +380,7 @@ static gboolean parseDataUrl(gpointer callback_data)
     String charset = extractCharsetFromMediaType(mediaType);
 
     ResourceResponse response;
+    response.setURL(handle->request().url());
     response.setMimeType(mimeType);
 
     if (isBase64) {

-- 
WebKit Debian packaging



More information about the Pkg-webkit-commits mailing list