summaryrefslogtreecommitdiffstats
path: root/docshell/test/mochitest/test_bug1747033.html
blob: 539b78fec05af31e8555ae9a27db74c20f17f66b (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
<!DOCTYPE HTML>
<html>
<head>
  <meta charset="utf-8">
  <title>Test history after loading multipart</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
  <script>
    SimpleTest.waitForExplicitFinish();

    function runTest() {
      let bc = new BroadcastChannel("bug1747033");
      new Promise(resolve => {
        bc.addEventListener("message", ({ data: { historyLength } }) => {
          is(historyLength, 1, "Correct length for first normal load.");

          resolve();
        }, { once: true });

        window.open("file_bug1747033.sjs", "", "noopener");
      }).then(() => {
        return new Promise(resolve => {
          let loaded = 0;
          bc.addEventListener("message", function listener({ data: { historyLength } }) {
            ++loaded;

            is(historyLength, 2, `Correct length for multipart load ${loaded}.`);

            // We want 3 parts in total.
            if (loaded < 3) {
              if (loaded == 2) {
                // We've had 2 parts, make the server send the last part.
                fetch("file_bug1747033.sjs?sendLastPart");
              } else {
                fetch("file_bug1747033.sjs?sendNextPart");
              }
              return;
            }

            bc.removeEventListener("message", listener);
            resolve();
          });

          bc.postMessage({ cmd: "load", arg: "file_bug1747033.sjs?multipart" });
        });
      }).then(() => {
        return new Promise(resolve => {
          bc.addEventListener("message", ({ data: { historyLength } }) => {
            is(historyLength, 2, "Correct length after calling replaceState in multipart.");

            resolve();
          }, { once: true });

          bc.postMessage({ cmd: "replaceState", arg: "file_bug1747033.sjs?replaced" });
        });
      }).then(() => {
        return new Promise(resolve => {
          bc.addEventListener("message", ({ data: { historyLength } }) => {
            is(historyLength, 3, "Correct length for first normal load after multipart.");

            resolve();
          }, { once: true });

          bc.postMessage({ cmd: "load", arg: "file_bug1747033.sjs" });
        });
      }).then(() => {
        return new Promise(resolve => {
          let goneBack = 0;
          bc.addEventListener("message", function listener({ data: { historyLength } }) {
            ++goneBack;

            is(historyLength, 3, "Correct length after going back.");

            if (goneBack == 1) {
              bc.postMessage({ cmd: "back" });
            } else if (goneBack == 2) {
              bc.removeEventListener("message", listener);
              resolve();
            }
          });

          bc.postMessage({ cmd: "back" });
        });
      }).then(() => {
        bc.postMessage({ cmd: "close" });

        SimpleTest.finish();
      });
    }
  </script>
</head>
<body onload="runTest();">
<p id="display"></p>
<div id="content" style="display: none"></div>
<pre id="test"></pre>
</body>
</html>