summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/test/browser_inspector_highlighter-hover_03.js
blob: fcd88be7f43d9618db112aafd24e6c1b712081f8 (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
/* 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 once a node has been hovered over and marked as such, if it is
// navigated away using the keyboard, the highlighter moves to the new node, and
// if it is then navigated back to, it is briefly highlighted again

const TEST_PAGE = "data:text/html;charset=utf-8," +
                  "<p id=\"one\">one</p><p id=\"two\">two</p>";

add_task(function* () {
  let {inspector} = yield openInspectorForURL(TEST_PAGE);

  info("Making sure the markup-view frame is focused");
  inspector.markup._frame.focus();

  // Mock the highlighter to easily track which node gets highlighted.
  // We don't need to test here that the highlighter is actually visible, we
  // just care about whether the markup-view asks it to be shown
  let highlightedNode = null;
  inspector.toolbox._highlighter.showBoxModel = function (nodeFront) {
    highlightedNode = nodeFront;
    return promise.resolve();
  };
  inspector.toolbox._highlighter.hideBoxModel = function () {
    return promise.resolve();
  };

  function* isHighlighting(selector, desc) {
    let nodeFront = yield getNodeFront(selector, inspector);
    is(highlightedNode, nodeFront, desc);
  }

  info("Hover over <p#one> line in the markup-view");
  yield hoverContainer("#one", inspector);
  yield isHighlighting("#one", "<p#one> is highlighted");

  info("Navigate to <p#two> with the keyboard");
  let onUpdated = inspector.once("inspector-updated");
  EventUtils.synthesizeKey("VK_DOWN", {}, inspector.panelWin);
  yield onUpdated;
  onUpdated = inspector.once("inspector-updated");
  EventUtils.synthesizeKey("VK_DOWN", {}, inspector.panelWin);
  yield onUpdated;
  yield isHighlighting("#two", "<p#two> is highlighted");

  info("Navigate back to <p#one> with the keyboard");
  onUpdated = inspector.once("inspector-updated");
  EventUtils.synthesizeKey("VK_UP", {}, inspector.panelWin);
  yield onUpdated;
  yield isHighlighting("#one", "<p#one> is highlighted again");
});