summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/markup/test/browser_markup_subgrid_display_badge.js
blob: 0118e5ae33a94bc0910aae7b8e5725394dcfab2b (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
/* Any copyright is dedicated to the Public Domain.
 http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

const TEST_URL = URL_ROOT + "doc_markup_subgrid.html";

add_task(async function () {
  const { inspector } = await openInspectorForURL(TEST_URL);
  const { highlighters, store } = inspector;

  info("Check the subgrid display badge is shown and not active.");
  await selectNode("main", inspector);
  const eltContainer = await getContainerForSelector("main", inspector);
  const subgridDisplayBadge = eltContainer.elt.querySelector(
    ".inspector-badge.interactive[data-display]"
  );
  ok(
    !subgridDisplayBadge.classList.contains("active"),
    "subgrid display badge is not active."
  );
  ok(
    subgridDisplayBadge.classList.contains("interactive"),
    "subgrid display badge is interactive."
  );

  info("Check the initial state of the grid highlighter.");
  ok(
    !highlighters.gridHighlighters.size,
    "No CSS grid highlighter exists in the highlighters overlay."
  );

  info("Toggling ON the CSS grid highlighter from the subgrid display badge.");
  const onHighlighterShown = highlighters.once("grid-highlighter-shown");
  let onCheckboxChange = waitUntilState(
    store,
    state => state.grids.length === 2 && state.grids[1].highlighted
  );
  subgridDisplayBadge.click();
  await onHighlighterShown;
  await onCheckboxChange;

  info(
    "Check that the CSS grid highlighter is created and the display badge state."
  );
  is(
    highlighters.gridHighlighters.size,
    1,
    "CSS grid highlighter is created in the highlighters overlay."
  );
  ok(
    subgridDisplayBadge.classList.contains("active"),
    "subgrid display badge is active."
  );
  ok(
    subgridDisplayBadge.classList.contains("interactive"),
    "subgrid display badge is interactive."
  );

  info("Toggling OFF the CSS grid highlighter from the subgrid display badge.");
  const onHighlighterHidden = highlighters.once("grid-highlighter-hidden");
  onCheckboxChange = waitUntilState(
    store,
    state => state.grids.length == 2 && !state.grids[1].highlighted
  );
  subgridDisplayBadge.click();
  await onHighlighterHidden;
  await onCheckboxChange;

  ok(
    !subgridDisplayBadge.classList.contains("active"),
    "subgrid display badge is not active."
  );
  ok(
    subgridDisplayBadge.classList.contains("interactive"),
    "subgrid display badge is interactive."
  );
});