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

"use strict";

/**
 * Test that clicking on the security indicator opens the security details tab.
 */

add_task(async function () {
  const { tab, monitor } = await initNetMonitor(CUSTOM_GET_URL, {
    requestCount: 1,
  });
  const { document, store, windowRequire } = monitor.panelWin;
  const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");

  store.dispatch(Actions.batchEnable(false));

  info("Requesting a resource over HTTPS.");
  await performRequestAndWait(
    "https://example.com" + CORS_SJS_PATH + "?request_2"
  );
  await performRequestAndWait(
    "https://example.com" + CORS_SJS_PATH + "?request_1"
  );

  is(store.getState().requests.requests.length, 2, "Two events event logged.");

  await clickAndTestSecurityIcon();

  info("Selecting headers panel again.");
  clickOnSidebarTab(document, "headers");

  info("Sorting the items by filename.");
  EventUtils.sendMouseEvent(
    { type: "click" },
    document.querySelector("#requests-list-file-button")
  );

  info(
    "Testing that security icon can be clicked after the items were sorted."
  );

  await clickAndTestSecurityIcon();

  return teardown(monitor);

  async function performRequestAndWait(url) {
    const wait = waitForNetworkEvents(monitor, 1);
    await SpecialPowers.spawn(
      tab.linkedBrowser,
      [{ url }],
      async function (args) {
        content.wrappedJSObject.performRequests(1, args.url);
      }
    );
    return wait;
  }

  async function clickAndTestSecurityIcon() {
    const icon = document.querySelector(".requests-security-state-icon");
    info(
      "Clicking security icon of the first request and waiting for panel update."
    );
    EventUtils.synthesizeMouseAtCenter(icon, {}, monitor.panelWin);
    await waitUntil(() =>
      document.querySelector("#security-panel .security-info-value")
    );

    ok(
      document.querySelector("#security-tab[aria-selected=true]"),
      "Security tab is selected."
    );
  }
});