summaryrefslogtreecommitdiffstats
path: root/browser/components/sessionstore/test/browser_capabilities.js
blob: f02b0ede76bdfee32971723085f6198c0c0ea539 (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
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

/**
 * These tests ensures that disabling features by flipping nsIDocShell.allow*
 * properties are (re)stored as disabled. Disallowed features must be
 * re-enabled when the tab is re-used by another tab restoration.
 */
add_task(async function docshell_capabilities() {
  let tab = await createTab();
  let browser = tab.linkedBrowser;
  let { browsingContext, docShell } = browser;

  // Get the list of capabilities for docShells.
  let flags = Object.keys(docShell).filter(k => k.startsWith("allow"));

  // Check that everything is allowed by default for new tabs.
  let state = JSON.parse(ss.getTabState(tab));
  ok(!("disallow" in state), "everything allowed by default");
  ok(
    flags.every(f => docShell[f]),
    "all flags set to true"
  );

  // Flip a couple of allow* flags.
  docShell.allowImages = false;
  docShell.allowMetaRedirects = false;
  browsingContext.allowJavascript = false;

  // Now reload the document to ensure that these capabilities
  // are taken into account.
  browser.reload();
  await promiseBrowserLoaded(browser);

  // Flush to make sure chrome received all data.
  await TabStateFlusher.flush(browser);

  // Check that we correctly save disallowed features.
  let disallowedState = JSON.parse(ss.getTabState(tab));
  let disallow = new Set(disallowedState.disallow.split(","));
  ok(disallow.has("Images"), "images not allowed");
  ok(disallow.has("MetaRedirects"), "meta redirects not allowed");
  is(disallow.size, 2, "two capabilities disallowed");

  // Reuse the tab to restore a new, clean state into it.
  await promiseTabState(tab, {
    entries: [{ url: "about:robots", triggeringPrincipal_base64 }],
  });

  // Flush to make sure chrome received all data.
  await TabStateFlusher.flush(browser);

  // After restoring disallowed features must be available again.
  state = JSON.parse(ss.getTabState(tab));
  ok(!("disallow" in state), "everything allowed again");
  ok(
    flags.every(f => docShell[f]),
    "all flags set to true"
  );

  // Restore the state with disallowed features.
  await promiseTabState(tab, disallowedState);

  // Check that docShell flags are set.
  ok(!docShell.allowImages, "images not allowed");
  ok(!docShell.allowMetaRedirects, "meta redirects not allowed");

  // Check that docShell allowJavascript flag is not set.
  ok(browsingContext.allowJavascript, "Javascript still allowed");

  // Check that we correctly restored features as disabled.
  state = JSON.parse(ss.getTabState(tab));
  disallow = new Set(state.disallow.split(","));
  ok(disallow.has("Images"), "images not allowed anymore");
  ok(disallow.has("MetaRedirects"), "meta redirects not allowed anymore");
  ok(!disallow.has("Javascript"), "Javascript still allowed");
  is(disallow.size, 2, "two capabilities disallowed");

  // Clean up after ourselves.
  gBrowser.removeTab(tab);
});

async function createTab() {
  let tab = BrowserTestUtils.addTab(gBrowser, "about:rights");
  let browser = tab.linkedBrowser;
  await promiseBrowserLoaded(browser);
  return tab;
}