Bug 1346936 - support SourceMap header in addition to X-SourceMap; r?ehsan draft
authorTom Tromey <tom@tromey.com>
Mon, 15 May 2017 11:58:23 -0600
changeset 577948 25dcee4879a230556ab0228b659c127709f6c7a0
parent 577588 77dbf5613f9047e21710337a428ce45a7ea22dce
child 628640 027e669b82428cfa80803f478c35720270506d80
push id58842
push userbmo:ttromey@mozilla.com
push dateMon, 15 May 2017 18:10:41 +0000
reviewersehsan
bugs1346936
milestone55.0a1
Bug 1346936 - support SourceMap header in addition to X-SourceMap; r?ehsan According to the source map spec, the X-SourceMap header is deprecated in favor of SourceMap. This adds support for the newer name. The test case is a copy of the X-SourceMap test with the obvious change. MozReview-Commit-ID: 8J6YN8xMIfb
dom/base/test/chrome/chrome.ini
dom/base/test/chrome/nochrome_bug1346936.html
dom/base/test/chrome/nochrome_bug1346936.js
dom/base/test/chrome/nochrome_bug1346936.js^headers^
dom/base/test/chrome/test_bug1346936.html
dom/base/test/moz.build
dom/script/ScriptLoader.cpp
--- a/dom/base/test/chrome/chrome.ini
+++ b/dom/base/test/chrome/chrome.ini
@@ -56,16 +56,17 @@ support-files = ../file_bug357450.js
 [test_bug814638.xul]
 [test_bug816340.xul]
 [test_bug884693.xul]
 [test_bug914381.html]
 [test_bug990812.xul]
 [test_bug1063837.xul]
 [test_bug1139964.xul]
 [test_bug1209621.xul]
+[test_bug1346936.html]
 [test_cpows.xul]
 [test_registerElement_content.xul]
 [test_registerElement_ep.xul]
 [test_domparsing.xul]
 [test_fileconstructor.xul]
 [test_nsITextInputProcessor.xul]
 [test_range_getClientRectsAndTexts.html]
 [test_title.xul]
new file mode 100644
--- /dev/null
+++ b/dom/base/test/chrome/nochrome_bug1346936.html
@@ -0,0 +1,3 @@
+<!DOCTYPE HTML>
+<html>
+</html>
new file mode 100644
--- /dev/null
+++ b/dom/base/test/chrome/nochrome_bug1346936.js
@@ -0,0 +1,4 @@
+//# sourceMappingURL=bar.js.map
+
+// Define a single function to prevent script source from being gc'd
+function foo() {}
new file mode 100644
--- /dev/null
+++ b/dom/base/test/chrome/nochrome_bug1346936.js^headers^
@@ -0,0 +1,1 @@
+SourceMap: foo.js.map
new file mode 100644
--- /dev/null
+++ b/dom/base/test/chrome/test_bug1346936.html
@@ -0,0 +1,61 @@
+<!DOCTYPE HTML>
+<html>
+<!--
+https://bugzilla.mozilla.org/show_bug.cgi?id=1346936
+-->
+<head>
+  <title>Test for Bug 1346936</title>
+  <script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
+  <script type="application/javascript"  src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"></script>
+  <link rel="stylesheet" type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css"/>
+</head>
+<body>
+<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1346936">Mozilla Bug 1346936</a>
+<style type="text/css">
+#link1 a { -moz-user-select:none; }
+</style>
+<div id="link1"><a href="http://www.mozilla.org/">link1</a></div>
+<div id="link2"><a href="http://www.mozilla.org/">link2</a></div>
+<p id="display"></p>
+<div id="content" style="display: none">
+  
+</div>
+<pre id="test">
+<script type="application/javascript">
+
+/** Test for Bug 1346936 **/
+
+Components.utils.import("resource://gre/modules/jsdebugger.jsm");
+addDebuggerToGlobal(this);
+
+window.onload = function () {
+    SimpleTest.waitForExplicitFinish();
+
+    var iframe = document.createElement("iframe");
+    iframe.src = "http://mochi.test:8888/tests/dom/base/test/chrome/nochrome_bug1346936.html";
+    iframe.onload = function () {
+        var script = iframe.contentWindow.document.createElement("script");
+        script.src = "http://mochi.test:8888/tests/dom/base/test/chrome/nochrome_bug1346936.js";
+        script.onload = function () {
+            var dbg = new Debugger(iframe.contentWindow);
+            ok(dbg, "Should be able to create debugger");
+
+            var scripts = dbg.findScripts({
+                url: "http://mochi.test:8888/tests/dom/base/test/chrome/nochrome_bug1346936.js"
+            });
+            ok(scripts.length > 0, "Should be able to find script");
+
+            is(scripts[0].source.sourceMapURL, "foo.js.map");
+            SimpleTest.finish();
+        }
+
+        iframe.contentWindow.document.body.appendChild(script);
+    };
+
+    document.body.appendChild(iframe);
+};
+
+</script>
+</pre>
+</body>
+</html>
--- a/dom/base/test/moz.build
+++ b/dom/base/test/moz.build
@@ -26,12 +26,15 @@ BROWSER_CHROME_MANIFESTS += [
 TEST_DIRS += [
     'gtest',
     'jsmodules'
 ]
 
 TEST_HARNESS_FILES.testing.mochitest.tests.dom.base.test.chrome += [
     'chrome/bug421622-referer.sjs',
     'chrome/bug884693.sjs',
+    'chrome/nochrome_bug1346936.html',
+    'chrome/nochrome_bug1346936.js',
+    'chrome/nochrome_bug1346936.js^headers^',
     'chrome/nochrome_bug765993.html',
     'chrome/nochrome_bug765993.js',
     'chrome/nochrome_bug765993.js^headers^',
 ]
--- a/dom/script/ScriptLoader.cpp
+++ b/dom/script/ScriptLoader.cpp
@@ -2725,17 +2725,20 @@ ScriptLoader::PrepareLoadedRequest(Scrip
   if (httpChannel) {
     bool requestSucceeded;
     rv = httpChannel->GetRequestSucceeded(&requestSucceeded);
     if (NS_SUCCEEDED(rv) && !requestSucceeded) {
       return NS_ERROR_NOT_AVAILABLE;
     }
 
     nsAutoCString sourceMapURL;
-    rv = httpChannel->GetResponseHeader(NS_LITERAL_CSTRING("X-SourceMap"), sourceMapURL);
+    rv = httpChannel->GetResponseHeader(NS_LITERAL_CSTRING("SourceMap"), sourceMapURL);
+    if (NS_FAILED(rv)) {
+      rv = httpChannel->GetResponseHeader(NS_LITERAL_CSTRING("X-SourceMap"), sourceMapURL);
+    }
     if (NS_SUCCEEDED(rv)) {
       aRequest->mHasSourceMapURL = true;
       aRequest->mSourceMapURL = NS_ConvertUTF8toUTF16(sourceMapURL);
     }
 
     if (httpChannel->GetIsTrackingResource()) {
       aRequest->SetIsTracking();
     }