@paulirish/trace_engine 0.0.10 → 0.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (205) hide show
  1. package/analyze-trace.mjs +1 -1
  2. package/core/platform/DevToolsPath.d.ts +4 -13
  3. package/core/platform/DevToolsPath.js +7 -4
  4. package/core/platform/DevToolsPath.js.map +1 -7
  5. package/core/platform/MimeType.d.ts +27 -0
  6. package/core/platform/MimeType.js +119 -86
  7. package/core/platform/MimeType.js.map +1 -7
  8. package/core/platform/Timing.d.ts +7 -0
  9. package/core/platform/Timing.js +7 -4
  10. package/core/platform/Timing.js.map +1 -7
  11. package/core/platform/UIString.d.ts +2 -5
  12. package/core/platform/UIString.js +5 -2
  13. package/core/platform/UIString.js.map +1 -7
  14. package/core/platform/UserVisibleError.js +19 -10
  15. package/core/platform/UserVisibleError.js.map +1 -7
  16. package/core/platform/array-utilities.d.ts +48 -10
  17. package/core/platform/array-utilities.js +160 -124
  18. package/core/platform/array-utilities.js.map +1 -7
  19. package/core/platform/brand.d.ts +14 -0
  20. package/core/platform/brand.js +5 -1
  21. package/core/platform/brand.js.map +1 -7
  22. package/core/platform/date-utilities.js +10 -6
  23. package/core/platform/date-utilities.js.map +1 -7
  24. package/core/platform/dom-utilities.d.ts +3 -1
  25. package/core/platform/dom-utilities.js +94 -83
  26. package/core/platform/dom-utilities.js.map +1 -7
  27. package/core/platform/keyboard-utilities.d.ts +2 -0
  28. package/core/platform/keyboard-utilities.js +15 -24
  29. package/core/platform/keyboard-utilities.js.map +1 -7
  30. package/core/platform/map-utilities.d.ts +4 -0
  31. package/core/platform/map-utilities.js +66 -60
  32. package/core/platform/map-utilities.js.map +1 -7
  33. package/core/platform/number-utilities.js +66 -55
  34. package/core/platform/number-utilities.js.map +1 -7
  35. package/core/platform/platform.d.ts +5 -1
  36. package/core/platform/platform.js +54 -37
  37. package/core/platform/platform.js.map +1 -7
  38. package/core/platform/promise-utilities.d.ts +10 -0
  39. package/core/platform/promise-utilities.js +16 -8
  40. package/core/platform/promise-utilities.js.map +1 -7
  41. package/core/platform/set-utilities.js +20 -17
  42. package/core/platform/set-utilities.js.map +1 -7
  43. package/core/platform/string-utilities.d.ts +32 -1
  44. package/core/platform/string-utilities.js +453 -379
  45. package/core/platform/string-utilities.js.map +1 -7
  46. package/core/platform/typescript-utilities.d.ts +5 -5
  47. package/core/platform/typescript-utilities.js +19 -7
  48. package/core/platform/typescript-utilities.js.map +1 -7
  49. package/generated/protocol.d.ts +2081 -347
  50. package/generated/protocol.js +5 -2230
  51. package/models/cpu_profile/CPUProfileDataModel.d.ts +77 -0
  52. package/models/cpu_profile/CPUProfileDataModel.js +492 -359
  53. package/models/cpu_profile/CPUProfileDataModel.js.map +1 -7
  54. package/models/cpu_profile/ProfileTreeModel.d.ts +29 -0
  55. package/models/cpu_profile/ProfileTreeModel.js +87 -82
  56. package/models/cpu_profile/ProfileTreeModel.js.map +1 -7
  57. package/models/cpu_profile/cpu_profile.d.ts +3 -0
  58. package/models/cpu_profile/cpu_profile.js +7 -7
  59. package/models/cpu_profile/cpu_profile.js.map +1 -7
  60. package/models/trace/EntriesFilter.d.ts +55 -0
  61. package/models/trace/EntriesFilter.js +227 -166
  62. package/models/trace/EntriesFilter.js.map +1 -7
  63. package/models/trace/LegacyTracingModel.js.map +1 -7
  64. package/models/trace/ModelImpl.d.ts +110 -0
  65. package/models/trace/ModelImpl.js +161 -102
  66. package/models/trace/ModelImpl.js.map +1 -7
  67. package/models/trace/Processor.d.ts +36 -0
  68. package/models/trace/Processor.js +197 -163
  69. package/models/trace/Processor.js.map +1 -7
  70. package/models/trace/TracingManager.js.map +1 -7
  71. package/models/trace/extras/FetchNodes.d.ts +46 -0
  72. package/models/trace/extras/FetchNodes.js +132 -91
  73. package/models/trace/extras/FetchNodes.js.map +1 -7
  74. package/models/trace/extras/FilmStrip.d.ts +19 -0
  75. package/models/trace/extras/FilmStrip.js +38 -31
  76. package/models/trace/extras/FilmStrip.js.map +1 -7
  77. package/models/trace/extras/MainThreadActivity.d.ts +2 -0
  78. package/models/trace/extras/MainThreadActivity.js +72 -56
  79. package/models/trace/extras/MainThreadActivity.js.map +1 -7
  80. package/models/trace/extras/Metadata.d.ts +2 -0
  81. package/models/trace/extras/Metadata.js +42 -26
  82. package/models/trace/extras/Metadata.js.map +1 -7
  83. package/models/trace/extras/extras.js.map +1 -7
  84. package/models/trace/handlers/AnimationHandler.d.ts +8 -0
  85. package/models/trace/handlers/AnimationHandler.js +22 -20
  86. package/models/trace/handlers/AnimationHandler.js.map +1 -7
  87. package/models/trace/handlers/AuctionWorkletsHandler.d.ts +8 -0
  88. package/models/trace/handlers/AuctionWorkletsHandler.js +143 -89
  89. package/models/trace/handlers/AuctionWorkletsHandler.js.map +1 -7
  90. package/models/trace/handlers/FramesHandler.d.ts +76 -0
  91. package/models/trace/handlers/FramesHandler.js +424 -355
  92. package/models/trace/handlers/FramesHandler.js.map +1 -7
  93. package/models/trace/handlers/GPUHandler.d.ts +11 -0
  94. package/models/trace/handlers/GPUHandler.js +41 -37
  95. package/models/trace/handlers/GPUHandler.js.map +1 -7
  96. package/models/trace/handlers/InitiatorsHandler.d.ts +10 -0
  97. package/models/trace/handlers/InitiatorsHandler.js +164 -113
  98. package/models/trace/handlers/InitiatorsHandler.js.map +1 -7
  99. package/models/trace/handlers/InvalidationsHandler.d.ts +10 -0
  100. package/models/trace/handlers/InvalidationsHandler.js +101 -79
  101. package/models/trace/handlers/InvalidationsHandler.js.map +1 -7
  102. package/models/trace/handlers/LargestImagePaintHandler.d.ts +5 -0
  103. package/models/trace/handlers/LargestImagePaintHandler.js +32 -12
  104. package/models/trace/handlers/LargestImagePaintHandler.js.map +1 -7
  105. package/models/trace/handlers/LargestTextPaintHandler.d.ts +5 -0
  106. package/models/trace/handlers/LargestTextPaintHandler.js +20 -12
  107. package/models/trace/handlers/LargestTextPaintHandler.js.map +1 -7
  108. package/models/trace/handlers/LayerTreeHandler.d.ts +13 -0
  109. package/models/trace/handlers/LayerTreeHandler.js +96 -70
  110. package/models/trace/handlers/LayerTreeHandler.js.map +1 -7
  111. package/models/trace/handlers/LayoutShiftsHandler.d.ts +44 -0
  112. package/models/trace/handlers/LayoutShiftsHandler.js +304 -227
  113. package/models/trace/handlers/LayoutShiftsHandler.js.map +1 -7
  114. package/models/trace/handlers/MemoryHandler.d.ts +7 -0
  115. package/models/trace/handlers/MemoryHandler.js +14 -11
  116. package/models/trace/handlers/MemoryHandler.js.map +1 -7
  117. package/models/trace/handlers/MetaHandler.d.ts +37 -0
  118. package/models/trace/handlers/MetaHandler.js +314 -226
  119. package/models/trace/handlers/MetaHandler.js.map +1 -7
  120. package/models/trace/handlers/ModelHandlers.d.ts +21 -0
  121. package/models/trace/handlers/ModelHandlers.js +25 -22
  122. package/models/trace/handlers/ModelHandlers.js.map +1 -7
  123. package/models/trace/handlers/NetworkRequestsHandler.d.ts +17 -0
  124. package/models/trace/handlers/NetworkRequestsHandler.js +342 -218
  125. package/models/trace/handlers/NetworkRequestsHandler.js.map +1 -7
  126. package/models/trace/handlers/PageLoadMetricsHandler.d.ts +67 -0
  127. package/models/trace/handlers/PageLoadMetricsHandler.js +357 -284
  128. package/models/trace/handlers/PageLoadMetricsHandler.js.map +1 -7
  129. package/models/trace/handlers/RendererHandler.d.ts +101 -0
  130. package/models/trace/handlers/RendererHandler.js +295 -191
  131. package/models/trace/handlers/RendererHandler.js.map +1 -7
  132. package/models/trace/handlers/SamplesHandler.d.ts +46 -0
  133. package/models/trace/handlers/SamplesHandler.js +195 -158
  134. package/models/trace/handlers/SamplesHandler.js.map +1 -7
  135. package/models/trace/handlers/ScreenshotsHandler.d.ts +7 -0
  136. package/models/trace/handlers/ScreenshotsHandler.js +63 -41
  137. package/models/trace/handlers/ScreenshotsHandler.js.map +1 -7
  138. package/models/trace/handlers/Threads.d.ts +33 -0
  139. package/models/trace/handlers/Threads.js +85 -67
  140. package/models/trace/handlers/Threads.js.map +1 -7
  141. package/models/trace/handlers/UserInteractionsHandler.d.ts +57 -0
  142. package/models/trace/handlers/UserInteractionsHandler.js +240 -141
  143. package/models/trace/handlers/UserInteractionsHandler.js.map +1 -7
  144. package/models/trace/handlers/UserTimingsHandler.d.ts +28 -0
  145. package/models/trace/handlers/UserTimingsHandler.js +91 -80
  146. package/models/trace/handlers/UserTimingsHandler.js.map +1 -7
  147. package/models/trace/handlers/WarningsHandler.d.ts +14 -0
  148. package/models/trace/handlers/WarningsHandler.js +100 -62
  149. package/models/trace/handlers/WarningsHandler.js.map +1 -7
  150. package/models/trace/handlers/WorkersHandler.d.ts +11 -0
  151. package/models/trace/handlers/WorkersHandler.js +40 -38
  152. package/models/trace/handlers/WorkersHandler.js.map +1 -7
  153. package/models/trace/handlers/handlers.d.ts +3 -0
  154. package/models/trace/handlers/handlers.js +7 -4
  155. package/models/trace/handlers/handlers.js.map +1 -7
  156. package/models/trace/handlers/types.d.ts +45 -0
  157. package/models/trace/handlers/types.js +15 -15
  158. package/models/trace/handlers/types.js.map +1 -7
  159. package/models/trace/helpers/SamplesIntegrator.d.ts +49 -0
  160. package/models/trace/helpers/SamplesIntegrator.js +381 -204
  161. package/models/trace/helpers/SamplesIntegrator.js.map +1 -7
  162. package/models/trace/helpers/Timing.d.ts +26 -0
  163. package/models/trace/helpers/Timing.js +131 -110
  164. package/models/trace/helpers/Timing.js.map +1 -7
  165. package/models/trace/helpers/Trace.d.ts +37 -0
  166. package/models/trace/helpers/Trace.js +200 -166
  167. package/models/trace/helpers/Trace.js.map +1 -7
  168. package/models/trace/helpers/TreeHelpers.d.ts +90 -0
  169. package/models/trace/helpers/TreeHelpers.js +203 -100
  170. package/models/trace/helpers/TreeHelpers.js.map +1 -7
  171. package/models/trace/helpers/helpers.d.ts +4 -0
  172. package/models/trace/helpers/helpers.js +8 -5
  173. package/models/trace/helpers/helpers.js.map +1 -7
  174. package/models/trace/root-causes/LayoutShift.d.ts +119 -0
  175. package/models/trace/root-causes/LayoutShift.js +470 -323
  176. package/models/trace/root-causes/LayoutShift.js.map +1 -7
  177. package/models/trace/root-causes/RootCauses.d.ts +14 -0
  178. package/models/trace/root-causes/RootCauses.js +9 -6
  179. package/models/trace/root-causes/RootCauses.js.map +1 -7
  180. package/models/trace/root-causes/root-causes.d.ts +1 -0
  181. package/models/trace/root-causes/root-causes.js +5 -2
  182. package/models/trace/root-causes/root-causes.js.map +1 -7
  183. package/models/trace/trace.d.ts +11 -0
  184. package/models/trace/trace.js +17 -23
  185. package/models/trace/trace.js.map +1 -7
  186. package/models/trace/types/Configuration.d.ts +33 -0
  187. package/models/trace/types/Configuration.js +25 -14
  188. package/models/trace/types/Configuration.js.map +1 -7
  189. package/models/trace/types/File.d.ts +23 -0
  190. package/models/trace/types/File.js +5 -6
  191. package/models/trace/types/File.js.map +1 -7
  192. package/models/trace/types/Timing.d.ts +25 -0
  193. package/models/trace/types/Timing.js +10 -11
  194. package/models/trace/types/Timing.js.map +1 -7
  195. package/models/trace/types/TraceEvents.d.ts +1571 -0
  196. package/models/trace/types/TraceEvents.js +174 -381
  197. package/models/trace/types/TraceEvents.js.map +1 -7
  198. package/models/trace/types/types.d.ts +4 -0
  199. package/models/trace/types/types.js +8 -5
  200. package/models/trace/types/types.js.map +1 -7
  201. package/package.json +1 -1
  202. package/TracingManager.js +0 -0
  203. package/extras/extras.js +0 -0
  204. package/trace.mjs +0 -6980
  205. package/trace.mjs.map +0 -8
@@ -1,237 +1,361 @@
1
- import * as Platform from "../../../core/platform/platform.js";
2
- import { HandlerState } from "./types.js";
3
- import { data as metaHandlerData } from "./MetaHandler.js";
4
- import * as Helpers from "../helpers/helpers.js";
5
- import * as Types from "../types/types.js";
6
- const MILLISECONDS_TO_MICROSECONDS = 1e3;
7
- const SECONDS_TO_MICROSECONDS = 1e6;
8
- const requestMap = /* @__PURE__ */ new Map();
9
- const requestsByOrigin = /* @__PURE__ */ new Map();
1
+ // Copyright 2022 The Chromium Authors. All rights reserved.
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+ import * as Platform from '../../../core/platform/platform.js';
5
+ import { data as metaHandlerData } from './MetaHandler.js';
6
+ import * as Helpers from '../helpers/helpers.js';
7
+ import * as Types from '../types/types.js';
8
+ const MILLISECONDS_TO_MICROSECONDS = 1000;
9
+ const SECONDS_TO_MICROSECONDS = 1000000;
10
+ const requestMap = new Map();
11
+ const requestsByOrigin = new Map();
10
12
  const requestsByTime = [];
11
13
  function storeTraceEventWithRequestId(requestId, key, value) {
12
- if (!requestMap.has(requestId)) {
13
- requestMap.set(requestId, {});
14
- }
15
- const traceEvents = requestMap.get(requestId);
16
- if (!traceEvents) {
17
- throw new Error(`Unable to locate trace events for request ID ${requestId}`);
18
- }
19
- if (Array.isArray(traceEvents[key])) {
20
- const target = traceEvents[key];
21
- const values = value;
22
- target.push(...values);
23
- } else {
24
- traceEvents[key] = value;
25
- }
14
+ if (!requestMap.has(requestId)) {
15
+ requestMap.set(requestId, {});
16
+ }
17
+ const traceEvents = requestMap.get(requestId);
18
+ if (!traceEvents) {
19
+ throw new Error(`Unable to locate trace events for request ID ${requestId}`);
20
+ }
21
+ if (Array.isArray(traceEvents[key])) {
22
+ const target = traceEvents[key];
23
+ const values = value;
24
+ target.push(...values);
25
+ }
26
+ else {
27
+ traceEvents[key] = value;
28
+ }
26
29
  }
27
30
  function firstPositiveValueInList(entries) {
28
- for (const entry of entries) {
29
- if (entry > 0) {
30
- return entry;
31
+ for (const entry of entries) {
32
+ if (entry > 0) {
33
+ return entry;
34
+ }
31
35
  }
32
- }
33
- return 0;
36
+ // In the event we don't find a positive value, we return 0 so as to
37
+ // be a mathematical noop. It's typically not correct to return – say –
38
+ // a -1 here because it would affect the calculation of stats below.
39
+ return 0;
34
40
  }
35
- let handlerState = HandlerState.UNINITIALIZED;
41
+ let handlerState = 1 /* HandlerState.UNINITIALIZED */;
36
42
  export function reset() {
37
- requestsByOrigin.clear();
38
- requestMap.clear();
39
- requestsByTime.length = 0;
40
- handlerState = HandlerState.UNINITIALIZED;
43
+ requestsByOrigin.clear();
44
+ requestMap.clear();
45
+ requestsByTime.length = 0;
46
+ handlerState = 1 /* HandlerState.UNINITIALIZED */;
41
47
  }
42
48
  export function initialize() {
43
- handlerState = HandlerState.INITIALIZED;
49
+ handlerState = 2 /* HandlerState.INITIALIZED */;
44
50
  }
45
51
  export function handleEvent(event) {
46
- if (handlerState !== HandlerState.INITIALIZED) {
47
- throw new Error("Network Request handler is not initialized");
48
- }
49
- if (Types.TraceEvents.isTraceEventResourceChangePriority(event)) {
50
- storeTraceEventWithRequestId(event.args.data.requestId, "changePriority", event);
51
- return;
52
- }
53
- if (Types.TraceEvents.isTraceEventResourceWillSendRequest(event)) {
54
- storeTraceEventWithRequestId(event.args.data.requestId, "willSendRequests", [event]);
55
- return;
56
- }
57
- if (Types.TraceEvents.isTraceEventResourceSendRequest(event)) {
58
- storeTraceEventWithRequestId(event.args.data.requestId, "sendRequests", [event]);
59
- return;
60
- }
61
- if (Types.TraceEvents.isTraceEventResourceReceiveResponse(event)) {
62
- storeTraceEventWithRequestId(event.args.data.requestId, "receiveResponse", event);
63
- return;
64
- }
65
- if (Types.TraceEvents.isTraceEventResourceReceivedData(event)) {
66
- storeTraceEventWithRequestId(event.args.data.requestId, "receivedData", [event]);
67
- return;
68
- }
69
- if (Types.TraceEvents.isTraceEventResourceFinish(event)) {
70
- storeTraceEventWithRequestId(event.args.data.requestId, "resourceFinish", event);
71
- return;
72
- }
73
- if (Types.TraceEvents.isTraceEventResourceMarkAsCached(event)) {
74
- storeTraceEventWithRequestId(event.args.data.requestId, "resourceMarkAsCached", event);
75
- return;
76
- }
52
+ if (handlerState !== 2 /* HandlerState.INITIALIZED */) {
53
+ throw new Error('Network Request handler is not initialized');
54
+ }
55
+ if (Types.TraceEvents.isTraceEventResourceChangePriority(event)) {
56
+ storeTraceEventWithRequestId(event.args.data.requestId, 'changePriority', event);
57
+ return;
58
+ }
59
+ if (Types.TraceEvents.isTraceEventResourceWillSendRequest(event)) {
60
+ storeTraceEventWithRequestId(event.args.data.requestId, 'willSendRequests', [event]);
61
+ return;
62
+ }
63
+ if (Types.TraceEvents.isTraceEventResourceSendRequest(event)) {
64
+ storeTraceEventWithRequestId(event.args.data.requestId, 'sendRequests', [event]);
65
+ return;
66
+ }
67
+ if (Types.TraceEvents.isTraceEventResourceReceiveResponse(event)) {
68
+ storeTraceEventWithRequestId(event.args.data.requestId, 'receiveResponse', event);
69
+ return;
70
+ }
71
+ if (Types.TraceEvents.isTraceEventResourceReceivedData(event)) {
72
+ storeTraceEventWithRequestId(event.args.data.requestId, 'receivedData', [event]);
73
+ return;
74
+ }
75
+ if (Types.TraceEvents.isTraceEventResourceFinish(event)) {
76
+ storeTraceEventWithRequestId(event.args.data.requestId, 'resourceFinish', event);
77
+ return;
78
+ }
79
+ if (Types.TraceEvents.isTraceEventResourceMarkAsCached(event)) {
80
+ storeTraceEventWithRequestId(event.args.data.requestId, 'resourceMarkAsCached', event);
81
+ return;
82
+ }
77
83
  }
78
84
  export async function finalize() {
79
- if (handlerState !== HandlerState.INITIALIZED) {
80
- throw new Error("Network Request handler is not initialized");
81
- }
82
- const { rendererProcessesByFrame } = metaHandlerData();
83
- for (const [requestId, request] of requestMap.entries()) {
84
- if (!request.sendRequests || !request.receiveResponse) {
85
- continue;
86
- }
87
- const redirects = [];
88
- for (let i = 0; i < request.sendRequests.length - 1; i++) {
89
- const sendRequest = request.sendRequests[i];
90
- const nextSendRequest = request.sendRequests[i + 1];
91
- let ts = sendRequest.ts;
92
- let dur = Types.Timing.MicroSeconds(nextSendRequest.ts - sendRequest.ts);
93
- if (request.willSendRequests && request.willSendRequests[i] && request.willSendRequests[i + 1]) {
94
- const willSendRequest = request.willSendRequests[i];
95
- const nextWillSendRequest = request.willSendRequests[i + 1];
96
- ts = willSendRequest.ts;
97
- dur = Types.Timing.MicroSeconds(nextWillSendRequest.ts - willSendRequest.ts);
98
- }
99
- redirects.push({
100
- url: sendRequest.args.data.url,
101
- priority: sendRequest.args.data.priority,
102
- requestMethod: sendRequest.args.data.requestMethod,
103
- ts,
104
- dur
105
- });
106
- }
107
- const isPushedResource = request.resourceFinish?.args.data.encodedDataLength !== 0;
108
- const isDiskCached = request.receiveResponse.args.data.fromCache && !request.receiveResponse.args.data.fromServiceWorker && !isPushedResource;
109
- const isMemoryCached = request.resourceMarkAsCached !== void 0;
110
- const isCached = isMemoryCached || isDiskCached;
111
- const timing = request.receiveResponse.args.data.timing;
112
- if (!timing && !isCached) {
113
- continue;
114
- }
115
- const firstSendRequest = request.sendRequests[0];
116
- const finalSendRequest = request.sendRequests[request.sendRequests.length - 1];
117
- const initialPriority = finalSendRequest.args.data.priority;
118
- let finalPriority = initialPriority;
119
- if (request.changePriority) {
120
- finalPriority = request.changePriority.args.data.priority;
121
- }
122
- const startTime = request.willSendRequests && request.willSendRequests.length ? Types.Timing.MicroSeconds(request.willSendRequests[0].ts) : Types.Timing.MicroSeconds(firstSendRequest.ts);
123
- const endRedirectTime = request.willSendRequests && request.willSendRequests.length ? Types.Timing.MicroSeconds(request.willSendRequests[request.willSendRequests.length - 1].ts) : Types.Timing.MicroSeconds(finalSendRequest.ts);
124
- const endTime = request.resourceFinish ? request.resourceFinish.ts : endRedirectTime;
125
- const finishTime = request.resourceFinish?.args.data.finishTime ? Types.Timing.MicroSeconds(request.resourceFinish.args.data.finishTime * SECONDS_TO_MICROSECONDS) : Types.Timing.MicroSeconds(endTime);
126
- const networkDuration = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((finishTime || endRedirectTime) - endRedirectTime);
127
- const processingDuration = Types.Timing.MicroSeconds(endTime - (finishTime || endTime));
128
- const redirectionDuration = Types.Timing.MicroSeconds(endRedirectTime - startTime);
129
- const queueing = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds(Platform.NumberUtilities.clamp(timing.requestTime * SECONDS_TO_MICROSECONDS - endRedirectTime, 0, Number.MAX_VALUE));
130
- const stalled = isCached ? Types.Timing.MicroSeconds(request.receiveResponse.ts - startTime) : Types.Timing.MicroSeconds(firstPositiveValueInList([
131
- timing.dnsStart * MILLISECONDS_TO_MICROSECONDS,
132
- timing.connectStart * MILLISECONDS_TO_MICROSECONDS,
133
- timing.sendStart * MILLISECONDS_TO_MICROSECONDS,
134
- request.receiveResponse.ts - endRedirectTime
135
- ]));
136
- const sendStartTime = isCached ? startTime : Types.Timing.MicroSeconds(timing.requestTime * SECONDS_TO_MICROSECONDS + timing.sendStart * MILLISECONDS_TO_MICROSECONDS);
137
- const waiting = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((timing.receiveHeadersEnd - timing.sendEnd) * MILLISECONDS_TO_MICROSECONDS);
138
- const downloadStart = isCached ? startTime : Types.Timing.MicroSeconds(timing.requestTime * SECONDS_TO_MICROSECONDS + timing.receiveHeadersEnd * MILLISECONDS_TO_MICROSECONDS);
139
- const download = isCached ? Types.Timing.MicroSeconds(endTime - request.receiveResponse.ts) : Types.Timing.MicroSeconds((finishTime || downloadStart) - downloadStart);
140
- const totalTime = Types.Timing.MicroSeconds(networkDuration + processingDuration);
141
- const dnsLookup = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((timing.dnsEnd - timing.dnsStart) * MILLISECONDS_TO_MICROSECONDS);
142
- const ssl = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((timing.sslEnd - timing.sslStart) * MILLISECONDS_TO_MICROSECONDS);
143
- const proxyNegotiation = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((timing.proxyEnd - timing.proxyStart) * MILLISECONDS_TO_MICROSECONDS);
144
- const requestSent = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((timing.sendEnd - timing.sendStart) * MILLISECONDS_TO_MICROSECONDS);
145
- const initialConnection = isCached ? Types.Timing.MicroSeconds(0) : Types.Timing.MicroSeconds((timing.connectEnd - timing.connectStart) * MILLISECONDS_TO_MICROSECONDS);
146
- const { frame, url, renderBlocking } = finalSendRequest.args.data;
147
- const { encodedDataLength, decodedBodyLength } = request.resourceFinish ? request.resourceFinish.args.data : { encodedDataLength: 0, decodedBodyLength: 0 };
148
- const { host, protocol, pathname, search } = new URL(url);
149
- const isHttps = protocol === "https:";
150
- const requestingFrameUrl = Helpers.Trace.activeURLForFrameAtTime(frame, finalSendRequest.ts, rendererProcessesByFrame) || "";
151
- const networkEvent = {
152
- args: {
153
- data: {
154
- syntheticData: {
155
- dnsLookup,
156
- download,
157
- downloadStart,
158
- finishTime,
159
- initialConnection,
160
- isDiskCached,
161
- isHttps,
162
- isMemoryCached,
163
- isPushedResource,
164
- networkDuration,
165
- processingDuration,
166
- proxyNegotiation,
167
- queueing,
168
- redirectionDuration,
169
- requestSent,
170
- sendStartTime,
171
- ssl,
172
- stalled,
173
- totalTime,
174
- waiting
175
- },
176
- decodedBodyLength,
177
- encodedDataLength,
178
- frame,
179
- fromServiceWorker: request.receiveResponse.args.data.fromServiceWorker,
180
- host,
181
- mimeType: request.receiveResponse.args.data.mimeType,
182
- pathname,
183
- priority: finalPriority,
184
- initialPriority,
185
- protocol,
186
- redirects,
187
- renderBlocking: renderBlocking ? renderBlocking : "non_blocking",
188
- requestId,
189
- requestingFrameUrl,
190
- requestMethod: finalSendRequest.args.data.requestMethod,
191
- search,
192
- statusCode: request.receiveResponse.args.data.statusCode,
193
- stackTrace: finalSendRequest.args.data.stackTrace,
194
- timing,
195
- url
85
+ if (handlerState !== 2 /* HandlerState.INITIALIZED */) {
86
+ throw new Error('Network Request handler is not initialized');
87
+ }
88
+ const { rendererProcessesByFrame } = metaHandlerData();
89
+ for (const [requestId, request] of requestMap.entries()) {
90
+ // If we have an incomplete set of events here, we choose to drop the network
91
+ // request rather than attempt to synthesize the missing data.
92
+ if (!request.sendRequests || !request.receiveResponse) {
93
+ continue;
196
94
  }
197
- },
198
- cat: "loading",
199
- name: "SyntheticNetworkRequest",
200
- ph: Types.TraceEvents.Phase.COMPLETE,
201
- dur: Types.Timing.MicroSeconds(endTime - startTime),
202
- tdur: Types.Timing.MicroSeconds(endTime - startTime),
203
- ts: Types.Timing.MicroSeconds(startTime),
204
- tts: Types.Timing.MicroSeconds(startTime),
205
- pid: finalSendRequest.pid,
206
- tid: finalSendRequest.tid
207
- };
208
- const requests = Platform.MapUtilities.getWithDefault(requestsByOrigin, host, () => {
209
- return {
210
- renderBlocking: [],
211
- nonRenderBlocking: [],
212
- all: []
213
- };
214
- });
215
- if (networkEvent.args.data.renderBlocking === "non_blocking") {
216
- requests.nonRenderBlocking.push(networkEvent);
217
- } else {
218
- requests.renderBlocking.push(networkEvent);
219
- }
220
- requests.all.push(networkEvent);
221
- requestsByTime.push(networkEvent);
222
- }
223
- handlerState = HandlerState.FINALIZED;
95
+ // In the data we may get multiple willSendRequests and sendRequests, which
96
+ // will indicate that there are redirects for a given (sub)resource. In the
97
+ // case of a navigation, e.g., example.com/ we will get willSendRequests,
98
+ // and we should use these to calculate time spent in redirects.
99
+ // In the case of sub-resources, however, e.g., example.com/foo.js we will
100
+ // *only* get sendRequests, and we use these instead of willSendRequests
101
+ // to detect the time in redirects. We always use the sendRequest for the
102
+ // url, priority etc since it contains those values, but we use the
103
+ // willSendRequest (if it exists) to calculate the timestamp and durations
104
+ // of redirects.
105
+ const redirects = [];
106
+ for (let i = 0; i < request.sendRequests.length - 1; i++) {
107
+ const sendRequest = request.sendRequests[i];
108
+ const nextSendRequest = request.sendRequests[i + 1];
109
+ // Use the willSendRequests as the source for redirects if possible.
110
+ // We default to those of the sendRequests, however, since willSendRequest
111
+ // is not guaranteed to be present in the data for every request.
112
+ let ts = sendRequest.ts;
113
+ let dur = Types.Timing.MicroSeconds(nextSendRequest.ts - sendRequest.ts);
114
+ if (request.willSendRequests && request.willSendRequests[i] && request.willSendRequests[i + 1]) {
115
+ const willSendRequest = request.willSendRequests[i];
116
+ const nextWillSendRequest = request.willSendRequests[i + 1];
117
+ ts = willSendRequest.ts;
118
+ dur = Types.Timing.MicroSeconds(nextWillSendRequest.ts - willSendRequest.ts);
119
+ }
120
+ redirects.push({
121
+ url: sendRequest.args.data.url,
122
+ priority: sendRequest.args.data.priority,
123
+ requestMethod: sendRequest.args.data.requestMethod,
124
+ ts,
125
+ dur,
126
+ });
127
+ }
128
+ // If a ResourceFinish event with an encoded data length is received,
129
+ // then the resource was not cached; it was fetched before it was
130
+ // requested, e.g. because it was pushed in this navigation.
131
+ const isPushedResource = request.resourceFinish?.args.data.encodedDataLength !== 0;
132
+ // This works around crbug.com/998397, which reports pushed resources, and resources served by a service worker as disk cached.
133
+ const isDiskCached = request.receiveResponse.args.data.fromCache &&
134
+ !request.receiveResponse.args.data.fromServiceWorker && !isPushedResource;
135
+ // If the request contains a resourceMarkAsCached event, it was served from memory cache.
136
+ const isMemoryCached = request.resourceMarkAsCached !== undefined;
137
+ // The timing data returned is from the original (uncached) request, which
138
+ // means that if we leave the above network record data as-is when the
139
+ // request came from either the disk cache or memory cache, our calculations
140
+ // will be incorrect.
141
+ //
142
+ // Here we add a flag so when we calculate the timestamps of the various
143
+ // events, we can overwrite them.
144
+ // These timestamps may not be perfect (indeed they don't always match
145
+ // the Network CDP domain exactly, which is likely an artifact of the way
146
+ // the data is routed on the backend), but they're the closest we have.
147
+ const isCached = isMemoryCached || isDiskCached;
148
+ const timing = request.receiveResponse.args.data.timing;
149
+ // If a non-cached request has no |timing| indicates data URLs, we ignore it.
150
+ if (!timing && !isCached) {
151
+ continue;
152
+ }
153
+ const firstSendRequest = request.sendRequests[0];
154
+ const finalSendRequest = request.sendRequests[request.sendRequests.length - 1];
155
+ const initialPriority = finalSendRequest.args.data.priority;
156
+ let finalPriority = initialPriority;
157
+ if (request.changePriority) {
158
+ finalPriority = request.changePriority.args.data.priority;
159
+ }
160
+ // Start time
161
+ // =======================
162
+ // The time where the request started, which is either the first willSendRequest
163
+ // event if there is one, or, if there is not, the sendRequest.
164
+ const startTime = (request.willSendRequests && request.willSendRequests.length) ?
165
+ Types.Timing.MicroSeconds(request.willSendRequests[0].ts) :
166
+ Types.Timing.MicroSeconds(firstSendRequest.ts);
167
+ // End redirect time
168
+ // =======================
169
+ // It's possible that when we start requesting data we will receive redirections.
170
+ // Here we note the time of the *last* willSendRequest / sendRequest event,
171
+ // which is used later on in the calculations for time queueing etc.
172
+ const endRedirectTime = (request.willSendRequests && request.willSendRequests.length) ?
173
+ Types.Timing.MicroSeconds(request.willSendRequests[request.willSendRequests.length - 1].ts) :
174
+ Types.Timing.MicroSeconds(finalSendRequest.ts);
175
+ // Finish time and end time
176
+ // =======================
177
+ // The finish time and the end time are subtly different.
178
+ // - Finish time: records the point at which the network stack stopped receiving the data
179
+ // - End time: the timestamp of the finish event itself (if one exists)
180
+ //
181
+ // The end time, then, will be slightly after the finish time.
182
+ const endTime = request.resourceFinish ? request.resourceFinish.ts : endRedirectTime;
183
+ const finishTime = request.resourceFinish?.args.data.finishTime ?
184
+ Types.Timing.MicroSeconds(request.resourceFinish.args.data.finishTime * SECONDS_TO_MICROSECONDS) :
185
+ Types.Timing.MicroSeconds(endTime);
186
+ // Network duration
187
+ // =======================
188
+ // Time spent on the network.
189
+ const networkDuration = isCached ? Types.Timing.MicroSeconds(0) :
190
+ Types.Timing.MicroSeconds((finishTime || endRedirectTime) - endRedirectTime);
191
+ // Processing duration
192
+ // =======================
193
+ // Time spent from start to end.
194
+ const processingDuration = Types.Timing.MicroSeconds(endTime - (finishTime || endTime));
195
+ // Redirection duration
196
+ // =======================
197
+ // Time between the first willSendRequest / sendRequest and last. This we place in *front* of the
198
+ // queueing, since the queueing time that we know about from the trace data is only the last request,
199
+ // i.e., the one that occurs after all the redirects.
200
+ const redirectionDuration = Types.Timing.MicroSeconds(endRedirectTime - startTime);
201
+ // Queueing
202
+ // =======================
203
+ // The amount of time queueing is the time between the request's start time to the requestTime
204
+ // arg recorded in the receiveResponse event. In the cases where the recorded start time is larger
205
+ // that the requestTime we set queueing time to zero.
206
+ const queueing = isCached ?
207
+ Types.Timing.MicroSeconds(0) :
208
+ Types.Timing.MicroSeconds(Platform.NumberUtilities.clamp((timing.requestTime * SECONDS_TO_MICROSECONDS - endRedirectTime), 0, Number.MAX_VALUE));
209
+ // Stalled
210
+ // =======================
211
+ // If the request is cached, the amount of time stalled is the time between the start time and
212
+ // receiving a response.
213
+ // Otherwise it is whichever positive number comes first from the following timing info:
214
+ // DNS start, Connection start, Send Start, or the time duration between our start time and
215
+ // receiving a response.
216
+ const stalled = isCached ? Types.Timing.MicroSeconds(request.receiveResponse.ts - startTime) :
217
+ Types.Timing.MicroSeconds(firstPositiveValueInList([
218
+ timing.dnsStart * MILLISECONDS_TO_MICROSECONDS,
219
+ timing.connectStart * MILLISECONDS_TO_MICROSECONDS,
220
+ timing.sendStart * MILLISECONDS_TO_MICROSECONDS,
221
+ (request.receiveResponse.ts - endRedirectTime),
222
+ ]));
223
+ // Sending HTTP request
224
+ // =======================
225
+ // Time when the HTTP request is sent.
226
+ const sendStartTime = isCached ?
227
+ startTime :
228
+ Types.Timing.MicroSeconds(timing.requestTime * SECONDS_TO_MICROSECONDS + timing.sendStart * MILLISECONDS_TO_MICROSECONDS);
229
+ // Waiting
230
+ // =======================
231
+ // Time from when the send finished going to when the headers were received.
232
+ const waiting = isCached ?
233
+ Types.Timing.MicroSeconds(0) :
234
+ Types.Timing.MicroSeconds((timing.receiveHeadersEnd - timing.sendEnd) * MILLISECONDS_TO_MICROSECONDS);
235
+ // Download
236
+ // =======================
237
+ // Time from receipt of headers to the finish time.
238
+ const downloadStart = isCached ?
239
+ startTime :
240
+ Types.Timing.MicroSeconds(timing.requestTime * SECONDS_TO_MICROSECONDS + timing.receiveHeadersEnd * MILLISECONDS_TO_MICROSECONDS);
241
+ const download = isCached ? Types.Timing.MicroSeconds(endTime - request.receiveResponse.ts) :
242
+ Types.Timing.MicroSeconds(((finishTime || downloadStart) - downloadStart));
243
+ const totalTime = Types.Timing.MicroSeconds(networkDuration + processingDuration);
244
+ // Collect a few values from the timing info.
245
+ // If the Network request is cached, we zero out them.
246
+ const dnsLookup = isCached ?
247
+ Types.Timing.MicroSeconds(0) :
248
+ Types.Timing.MicroSeconds((timing.dnsEnd - timing.dnsStart) * MILLISECONDS_TO_MICROSECONDS);
249
+ const ssl = isCached ? Types.Timing.MicroSeconds(0) :
250
+ Types.Timing.MicroSeconds((timing.sslEnd - timing.sslStart) * MILLISECONDS_TO_MICROSECONDS);
251
+ const proxyNegotiation = isCached ?
252
+ Types.Timing.MicroSeconds(0) :
253
+ Types.Timing.MicroSeconds((timing.proxyEnd - timing.proxyStart) * MILLISECONDS_TO_MICROSECONDS);
254
+ const requestSent = isCached ?
255
+ Types.Timing.MicroSeconds(0) :
256
+ Types.Timing.MicroSeconds((timing.sendEnd - timing.sendStart) * MILLISECONDS_TO_MICROSECONDS);
257
+ const initialConnection = isCached ?
258
+ Types.Timing.MicroSeconds(0) :
259
+ Types.Timing.MicroSeconds((timing.connectEnd - timing.connectStart) * MILLISECONDS_TO_MICROSECONDS);
260
+ // Finally get some of the general data from the trace events.
261
+ const { frame, url, renderBlocking } = finalSendRequest.args.data;
262
+ const { encodedDataLength, decodedBodyLength } = request.resourceFinish ? request.resourceFinish.args.data : { encodedDataLength: 0, decodedBodyLength: 0 };
263
+ const { host, protocol, pathname, search } = new URL(url);
264
+ const isHttps = protocol === 'https:';
265
+ const requestingFrameUrl = Helpers.Trace.activeURLForFrameAtTime(frame, finalSendRequest.ts, rendererProcessesByFrame) || '';
266
+ // Construct a synthetic trace event for this network request.
267
+ const networkEvent = {
268
+ args: {
269
+ data: {
270
+ // All data we create from trace events should be added to |syntheticData|.
271
+ syntheticData: {
272
+ dnsLookup,
273
+ download,
274
+ downloadStart,
275
+ finishTime,
276
+ initialConnection,
277
+ isDiskCached,
278
+ isHttps,
279
+ isMemoryCached,
280
+ isPushedResource,
281
+ networkDuration,
282
+ processingDuration,
283
+ proxyNegotiation,
284
+ queueing,
285
+ redirectionDuration,
286
+ requestSent,
287
+ sendStartTime,
288
+ ssl,
289
+ stalled,
290
+ totalTime,
291
+ waiting,
292
+ },
293
+ // All fields below are from TraceEventsForNetworkRequest.
294
+ decodedBodyLength,
295
+ encodedDataLength,
296
+ frame,
297
+ fromServiceWorker: request.receiveResponse.args.data.fromServiceWorker,
298
+ host,
299
+ mimeType: request.receiveResponse.args.data.mimeType,
300
+ pathname,
301
+ priority: finalPriority,
302
+ initialPriority,
303
+ protocol,
304
+ redirects,
305
+ // In the event the property isn't set, assume non-blocking.
306
+ renderBlocking: renderBlocking ? renderBlocking : 'non_blocking',
307
+ requestId,
308
+ requestingFrameUrl,
309
+ requestMethod: finalSendRequest.args.data.requestMethod,
310
+ search,
311
+ statusCode: request.receiveResponse.args.data.statusCode,
312
+ stackTrace: finalSendRequest.args.data.stackTrace,
313
+ timing,
314
+ url,
315
+ },
316
+ },
317
+ cat: 'loading',
318
+ name: 'SyntheticNetworkRequest',
319
+ ph: "X" /* Types.TraceEvents.Phase.COMPLETE */,
320
+ dur: Types.Timing.MicroSeconds(endTime - startTime),
321
+ tdur: Types.Timing.MicroSeconds(endTime - startTime),
322
+ ts: Types.Timing.MicroSeconds(startTime),
323
+ tts: Types.Timing.MicroSeconds(startTime),
324
+ pid: finalSendRequest.pid,
325
+ tid: finalSendRequest.tid,
326
+ };
327
+ const requests = Platform.MapUtilities.getWithDefault(requestsByOrigin, host, () => {
328
+ return {
329
+ renderBlocking: [],
330
+ nonRenderBlocking: [],
331
+ all: [],
332
+ };
333
+ });
334
+ // For ease of rendering we sometimes want to differentiate between
335
+ // render-blocking and non-render-blocking, so we divide the data here.
336
+ if (networkEvent.args.data.renderBlocking === 'non_blocking') {
337
+ requests.nonRenderBlocking.push(networkEvent);
338
+ }
339
+ else {
340
+ requests.renderBlocking.push(networkEvent);
341
+ }
342
+ // However, there are also times where we just want to loop through all
343
+ // the captured requests, so here we store all of them together.
344
+ requests.all.push(networkEvent);
345
+ requestsByTime.push(networkEvent);
346
+ }
347
+ handlerState = 3 /* HandlerState.FINALIZED */;
224
348
  }
225
349
  export function data() {
226
- if (handlerState !== HandlerState.FINALIZED) {
227
- throw new Error("Network Request handler is not finalized");
228
- }
229
- return {
230
- byOrigin: new Map(requestsByOrigin),
231
- byTime: [...requestsByTime]
232
- };
350
+ if (handlerState !== 3 /* HandlerState.FINALIZED */) {
351
+ throw new Error('Network Request handler is not finalized');
352
+ }
353
+ return {
354
+ byOrigin: new Map(requestsByOrigin),
355
+ byTime: [...requestsByTime],
356
+ };
233
357
  }
234
358
  export function deps() {
235
- return ["Meta"];
359
+ return ['Meta'];
236
360
  }
237
- //# sourceMappingURL=NetworkRequestsHandler.js.map
361
+ //# sourceMappingURL=NetworkRequestsHandler.js.map