summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_footer-summary.js
blob: e0b12bcf770db361e52ed40b9dd0edaf284bac89 (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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

/**
 * Test if the summary text displayed in the network requests menu footer is correct.
 */

add_task(async function () {
  const {
    getFormattedSize,
    getFormattedTime,
  } = require("resource://devtools/client/netmonitor/src/utils/format-utils.js");

  requestLongerTimeout(2);

  const { tab, monitor } = await initNetMonitor(FILTERING_URL, {
    requestCount: 1,
  });
  info("Starting test... ");

  const { document, store, windowRequire } = monitor.panelWin;
  const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
  const { getDisplayedRequestsSummary } = windowRequire(
    "devtools/client/netmonitor/src/selectors/index"
  );
  const { L10N } = windowRequire("devtools/client/netmonitor/src/utils/l10n");
  const { PluralForm } = windowRequire("devtools/shared/plural-form");

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

  for (let i = 0; i < 2; i++) {
    info(`Performing requests in batch #${i}`);
    const wait = waitForNetworkEvents(monitor, 8);
    await SpecialPowers.spawn(tab.linkedBrowser, [], async function () {
      content.wrappedJSObject.performRequests(
        '{ "getMedia": true, "getFlash": true }'
      );
    });
    await wait;

    testStatus();

    const buttons = ["html", "css", "js", "xhr", "fonts", "images", "media"];
    for (const button of buttons) {
      const buttonEl = document.querySelector(
        `.requests-list-filter-${button}-button`
      );
      EventUtils.sendMouseEvent({ type: "click" }, buttonEl);
      testStatus();
    }
  }

  await teardown(monitor);

  function testStatus() {
    const state = store.getState();
    const totalRequestsCount = state.requests.requests.length;
    const requestsSummary = getDisplayedRequestsSummary(state);
    info(
      `Current requests: ${requestsSummary.count} of ${totalRequestsCount}.`
    );

    const valueCount = document.querySelector(
      ".requests-list-network-summary-count"
    ).textContent;
    info("Current summary count: " + valueCount);
    const expectedCount = PluralForm.get(
      requestsSummary.count,
      L10N.getStr("networkMenu.summary.requestsCount2")
    ).replace("#1", requestsSummary.count);

    if (!totalRequestsCount || !requestsSummary.count) {
      is(
        valueCount,
        L10N.getStr("networkMenu.summary.requestsCountEmpty"),
        "The current summary text is incorrect, expected an 'empty' label."
      );
      return;
    }

    const valueTransfer = document.querySelector(
      ".requests-list-network-summary-transfer"
    ).textContent;
    info("Current summary transfer: " + valueTransfer);
    const expectedTransfer = L10N.getFormatStrWithNumbers(
      "networkMenu.summary.transferred",
      getFormattedSize(requestsSummary.contentSize),
      getFormattedSize(requestsSummary.transferredSize)
    );

    const valueFinish = document.querySelector(
      ".requests-list-network-summary-finish"
    ).textContent;
    info("Current summary finish: " + valueFinish);
    const expectedFinish = L10N.getFormatStrWithNumbers(
      "networkMenu.summary.finish",
      getFormattedTime(requestsSummary.ms)
    );

    info(`Computed total bytes: ${requestsSummary.bytes}`);
    info(`Computed total ms: ${requestsSummary.ms}`);

    is(valueCount, expectedCount, "The current summary count is correct.");
    is(
      valueTransfer,
      expectedTransfer,
      "The current summary transfer is correct."
    );
    is(valueFinish, expectedFinish, "The current summary finish is correct.");
  }
});