summaryrefslogtreecommitdiffstats
path: root/dom/workers/test/serviceworkers/test_claim_fetch.html
blob: 8db6d304e47a017a4f04300bf48f13095baf00cd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<!--
  Any copyright is dedicated to the Public Domain.
  http://creativecommons.org/publicdomain/zero/1.0/
-->
<!DOCTYPE HTML>
<html>
<head>
  <title>Bug 1130684 - Test fetch events are intercepted after claim </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" style="display: none">
  <a ping="ping" href="fetch.txt">link</a>
</div>
<pre id="test"></pre>
<script class="testbody" type="text/javascript">
  var registration;

  function register() {
    return navigator.serviceWorker.register("claim_fetch_worker.js",
                                            { scope: "./" })
      .then((swr) => registration = swr);
  }

  function unregister() {
    return registration.unregister().then(function(result) {
      ok(result, "Unregister should return true.");
    });
  }

  function createClient() {
    var p = new Promise(function(res, rej){
      window.onmessage = function(e) {
        if(e.data === "READY") {
          res();
        }
      }
    });

    var content = document.getElementById("content");
    ok(content, "Parent exists.");

    iframe = document.createElement("iframe");
    iframe.setAttribute('src', "sw_clients/service_worker_controlled.html");
    content.appendChild(iframe);

    return p;
  }

  function testFetch(before) {
    return fetch("fetch/real-file.txt").then(function(res) {
      ok(res.ok, "Response should be valid.");
      return res.text().then(function(body) {
        if (before) {
          ok(body !== "Fetch was intercepted", "Fetch events should not be intercepted.");
        } else {
          ok(body === "Fetch was intercepted", "Fetch events should be intercepted.");
        }
      });
    });
  }

  function claimThisPage() {
    ok(registration.active, "Worker is active.");
    var p = new Promise(function (res, rej) {
      navigator.serviceWorker.oncontrollerchange = res;
    });

    registration.active.postMessage("Claim");

    return p;
  }

  function runTest() {
    register()
      .then(createClient)
      .then(testFetch.bind(this, true))
      .then(claimThisPage)
      .then(testFetch.bind(this, false))
      .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>