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

"use strict";

// Tests that the 3 pane inspector toggle can render the middle and right panels of equal
// sizes when the original sidebar can be doubled in width and be smaller than half the
// toolbox's width in the BOTTOM host.

const SIDEBAR_WIDTH = 200;

add_task(async function () {
  info("Switch to 2 pane inspector to test the 3 pane toggle button behavior");
  await pushPref("devtools.inspector.three-pane-enabled", false);

  const { inspector } = await openInspectorForURL("about:blank");
  const { panelDoc: doc } = inspector;
  const button = doc.querySelector(".sidebar-toggle");
  const toolboxWidth = doc.getElementById("inspector-splitter-box").clientWidth;

  if (toolboxWidth < 600) {
    ok(true, "Can't run the full test because the toolbox width is too small.");
  } else {
    info("Set the sidebar width to 200px");
    inspector.splitBox.setState({ width: SIDEBAR_WIDTH });

    info("Click on the toggle button to toggle ON 3 pane inspector");
    let onRuleViewAdded = inspector.once("ruleview-added");
    EventUtils.synthesizeMouseAtCenter(
      button,
      {},
      inspector.panelDoc.defaultView
    );
    await onRuleViewAdded;

    info("Checking the sizes of the 3 pane inspector");
    let sidebarWidth = inspector.splitBox.state.width;
    const sidebarSplitBoxWidth =
      inspector.sidebarSplitBoxRef.current.state.width;
    is(sidebarWidth, SIDEBAR_WIDTH * 2, "Got correct main split box width");
    is(
      sidebarSplitBoxWidth,
      SIDEBAR_WIDTH,
      "Got correct sidebar split box width"
    );

    info("Click on the toggle button to toggle OFF the 3 pane inspector");
    onRuleViewAdded = inspector.once("ruleview-added");
    EventUtils.synthesizeMouseAtCenter(
      button,
      {},
      inspector.panelDoc.defaultView
    );
    await onRuleViewAdded;

    info("Checking the sidebar size of the 2 pane inspector");
    sidebarWidth = inspector.splitBox.state.width;
    is(sidebarWidth, SIDEBAR_WIDTH, "Got correct sidebar width");
  }
});