summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/test/browser_inspector_highlighter-geometry_03.js
blob: 0fa7bb96b8fd86357f297922bbd2a00ea13a5afd (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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

/* Globals defined in: devtools/client/inspector/test/head.js */

"use strict";

// Test that the right arrows/labels are shown even when the css properties are
// in several different css rules.

const TEST_URL = URL_ROOT + "doc_inspector_highlighter-geometry_01.html";
const ID = "geometry-editor-";
const HIGHLIGHTER_TYPE = "GeometryEditorHighlighter";
const PROPS = ["left", "right", "top", "bottom"];

add_task(function* () {
  let helper = yield openInspectorForURL(TEST_URL)
                       .then(getHighlighterHelperFor(HIGHLIGHTER_TYPE));

  helper.prefix = ID;

  let { finalize } = helper;

  yield checkArrowsLabelsAndHandlers(
    "#node2", ["top", "left", "bottom", "right"],
     helper);

  yield checkArrowsLabelsAndHandlers("#node3", ["top", "left"], helper);

  yield finalize();
});

function* checkArrowsLabelsAndHandlers(selector, expectedProperties,
  {show, hide, isElementHidden}
) {
  info("Getting node " + selector + " from the page");

  yield show(selector);

  for (let name of expectedProperties) {
    let hidden = (yield isElementHidden("arrow-" + name)) &&
                 (yield isElementHidden("handler-" + name));
    ok(!hidden,
      "The " + name + " label/arrow & handler is visible for node " + selector);
  }

  // Testing that the other arrows are hidden
  for (let name of PROPS) {
    if (expectedProperties.indexOf(name) !== -1) {
      continue;
    }
    let hidden = (yield isElementHidden("arrow-" + name)) &&
                 (yield isElementHidden("handler-" + name));
    ok(hidden,
      "The " + name + " arrow & handler is hidden for node " + selector);
  }

  info("Hiding the highlighter");
  yield hide();
}