summaryrefslogtreecommitdiffstats
path: root/devtools/client/styleeditor/test/browser_styleeditor_add_stylesheet.js
blob: d8315d212920d8fb311aacfeb813f56348badc78 (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
/* vim: set ts=2 et sw=2 tw=80: */
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";

// Test that a newly-added style sheet shows up in the style editor.

const TESTCASE_URI = TEST_BASE_HTTPS + "simple.html";

add_task(function* () {
  let { ui } = yield openStyleEditorForURL(TESTCASE_URI);

  is(ui.editors.length, 2, "Two sheets present after load.");

  // We have to wait for the length to change, because we might still
  // be seeing events from the initial open.
  let added = new Promise(resolve => {
    let handler = () => {
      if (ui.editors.length === 3) {
        ui.off("editor-added", handler);
        resolve();
      }
    };
    ui.on("editor-added", handler);
  });

  info("Adding a style sheet");
  yield ContentTask.spawn(gBrowser.selectedBrowser, null, () => {
    let document = content.document;
    const style = document.createElement("style");
    style.appendChild(document.createTextNode("div { background: #f06; }"));
    document.head.appendChild(style);
  });
  yield added;

  is(ui.editors.length, 3, "Three sheets present after new style sheet");
});