<!-- Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ --> <!DOCTYPE HTML> <html> <head> <title>Bug 1182113 - Test service worker XSLT interception</title> <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> </head> <body> <p id="display"></p> <div id="content"></div> <pre id="test"></pre> <script class="testbody" type="text/javascript"> var registration; var worker; function start() { return navigator.serviceWorker.register("xslt_worker.js", { scope: "./" }) .then((swr) => { registration = swr; // Ensure the registration is active before continuing var worker = registration.installing; return new Promise((resolve) => { if (worker.state === 'activated') { resolve(); return; } worker.addEventListener('statechange', () => { if (worker.state === 'activated') { resolve(); } }); }); }); } function unregister() { return registration.unregister().then(function(result) { ok(result, "Unregister should return true."); }, function(e) { dump("Unregistering the SW failed with " + e + "\n"); }); } function getXmlString(xmlObject) { serializer = new XMLSerializer(); return serializer.serializeToString(iframe.contentDocument); } function synthetic() { content = document.getElementById("content"); ok(content, "parent exists."); iframe = document.createElement("iframe"); content.appendChild(iframe); iframe.setAttribute('src', "xslt/test.xml"); var p = new Promise(function(res, rej) { iframe.onload = function(e) { dump("Set request mode\n"); registration.active.postMessage("synthetic"); xmlString = getXmlString(iframe.contentDocument); ok(!xmlString.includes("Error"), "Load synthetic cross origin XSLT should be allowed"); res(); }; }); return p; } function cors() { var p = new Promise(function(res, rej) { iframe.onload = function(e) { xmlString = getXmlString(iframe.contentDocument); ok(!xmlString.includes("Error"), "Load CORS cross origin XSLT should be allowed"); res(); }; }); registration.active.postMessage("cors"); iframe.setAttribute('src', "xslt/test.xml"); return p; } function opaque() { var p = new Promise(function(res, rej) { iframe.onload = function(e) { xmlString = getXmlString(iframe.contentDocument); ok(xmlString.includes("Error"), "Load opaque cross origin XSLT should not be allowed"); res(); }; }); registration.active.postMessage("opaque"); iframe.setAttribute('src', "xslt/test.xml"); return p; } function runTest() { start() .then(synthetic) .then(opaque) .then(cors) .then(unregister) .catch(function(e) { ok(false, "Some test failed with error " + e); }).then(SimpleTest.finish); } SimpleTest.waitForExplicitFinish(); SpecialPowers.pushPrefEnv({"set": [ ["dom.serviceWorkers.exemptFromPerDomainMax", true], ["dom.serviceWorkers.enabled", true], ["dom.serviceWorkers.testing.enabled", true], ]}, runTest); </script> </pre> </body> </html>