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/ */
// Network throttling integration test.
"use strict";
requestLongerTimeout(2);
add_task(async function () {
await throttleTest({ throttle: true, addLatency: true });
await throttleTest({ throttle: true, addLatency: false });
await throttleTest({ throttle: false, addLatency: false });
});
async function throttleTest(options) {
const { throttle, addLatency } = options;
const { monitor } = await initNetMonitor(SIMPLE_URL, { requestCount: 1 });
const { store, windowRequire, connector } = monitor.panelWin;
const { ACTIVITY_TYPE } = windowRequire(
"devtools/client/netmonitor/src/constants"
);
const { updateNetworkThrottling, triggerActivity } = connector;
const { getSortedRequests } = windowRequire(
"devtools/client/netmonitor/src/selectors/index"
);
info(`Starting test... (throttle = ${throttle}, addLatency = ${addLatency})`);
// When throttling, must be smaller than the length of the content
// of SIMPLE_URL in bytes.
const size = throttle ? 200 : 0;
const latency = addLatency ? 100 : 0;
const throttleProfile = {
latency,
download: size,
upload: 10000,
};
info("sending throttle request");
await updateNetworkThrottling(true, throttleProfile);
const wait = waitForNetworkEvents(monitor, 1);
await triggerActivity(ACTIVITY_TYPE.RELOAD.WITH_CACHE_DISABLED);
await wait;
await waitForRequestData(store, ["eventTimings"]);
const requestItem = getSortedRequests(store.getState())[0];
const reportedOneSecond = requestItem.eventTimings.timings.receive > 1000;
if (throttle) {
ok(reportedOneSecond, "download reported as taking more than one second");
} else {
ok(!reportedOneSecond, "download reported as taking less than one second");
}
await teardown(monitor);
}
|