summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_pane-collapse.js
blob: 465b4740ac5571efedb54236463f5acca7dfeb5c (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
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

/**
 * Tests if the network monitor panes collapse properly.
 */

add_task(async function () {
  const { monitor } = await initNetMonitor(SIMPLE_URL, {
    requestCount: 1,
  });
  info("Starting test... ");

  const { document, store, windowRequire } = monitor.panelWin;
  const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
  const { Prefs } = windowRequire("devtools/client/netmonitor/src/utils/prefs");

  const wait = waitForNetworkEvents(monitor, 1);
  await reloadBrowser();
  await wait;

  ok(
    !document.querySelector(".network-details-bar") &&
      !document.querySelector(".sidebar-toggle"),
    "The details panel should initially be hidden."
  );

  store.dispatch(Actions.toggleNetworkDetails());

  is(
    ~~document.querySelector(".network-details-bar").clientWidth,
    Prefs.networkDetailsWidth,
    "The details panel has an incorrect width."
  );
  ok(
    document.querySelector(".network-details-bar") &&
      document.querySelector(".sidebar-toggle"),
    "The details panel should at this point be visible."
  );

  EventUtils.sendMouseEvent(
    { type: "click" },
    document.querySelector(".sidebar-toggle")
  );

  ok(
    !document.querySelector(".network-details-bar") &&
      !document.querySelector(".sidebar-toggle"),
    "The details panel should not be visible after collapsing."
  );

  store.dispatch(Actions.toggleNetworkDetails());

  is(
    ~~document.querySelector(".network-details-bar").clientWidth,
    Prefs.networkDetailsWidth,
    "The details panel has an incorrect width after uncollapsing."
  );
  ok(
    document.querySelector(".network-details-bar") &&
      document.querySelector(".sidebar-toggle"),
    "The details panel should be visible again after uncollapsing."
  );

  await teardown(monitor);
});