devtools-tracing 1.1.1 → 1.2.0

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 (528) hide show
  1. package/.claude/settings.local.json +14 -0
  2. package/dist/index.d.ts +4 -0
  3. package/dist/index.js +28854 -0
  4. package/package.json +11 -8
  5. package/generate.ts +0 -649
  6. package/index.ts +0 -17
  7. package/lib/extension-api/ExtensionAPI.d.ts +0 -357
  8. package/lib/front_end/core/common/App.ts +0 -7
  9. package/lib/front_end/core/common/AppProvider.ts +0 -32
  10. package/lib/front_end/core/common/Base64.ts +0 -47
  11. package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
  12. package/lib/front_end/core/common/Color.ts +0 -2506
  13. package/lib/front_end/core/common/ColorConverter.ts +0 -402
  14. package/lib/front_end/core/common/ColorUtils.ts +0 -252
  15. package/lib/front_end/core/common/Console.ts +0 -114
  16. package/lib/front_end/core/common/Debouncer.ts +0 -15
  17. package/lib/front_end/core/common/EventTarget.ts +0 -52
  18. package/lib/front_end/core/common/Gzip.ts +0 -74
  19. package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
  20. package/lib/front_end/core/common/Lazy.ts +0 -31
  21. package/lib/front_end/core/common/Linkifier.ts +0 -55
  22. package/lib/front_end/core/common/MapWithDefault.ts +0 -26
  23. package/lib/front_end/core/common/Mutex.ts +0 -55
  24. package/lib/front_end/core/common/Object.ts +0 -145
  25. package/lib/front_end/core/common/ParsedURL.ts +0 -554
  26. package/lib/front_end/core/common/Progress.ts +0 -180
  27. package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
  28. package/lib/front_end/core/common/ResolverBase.ts +0 -85
  29. package/lib/front_end/core/common/ResourceType.ts +0 -588
  30. package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
  31. package/lib/front_end/core/common/Revealer.ts +0 -192
  32. package/lib/front_end/core/common/Runnable.ts +0 -41
  33. package/lib/front_end/core/common/SegmentedRange.ts +0 -87
  34. package/lib/front_end/core/common/SettingRegistration.ts +0 -339
  35. package/lib/front_end/core/common/Settings.ts +0 -1497
  36. package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
  37. package/lib/front_end/core/common/StringOutputStream.ts +0 -26
  38. package/lib/front_end/core/common/TextDictionary.ts +0 -48
  39. package/lib/front_end/core/common/Throttler.ts +0 -99
  40. package/lib/front_end/core/common/Trie.ts +0 -152
  41. package/lib/front_end/core/common/Worker.ts +0 -60
  42. package/lib/front_end/core/common/common.ts +0 -81
  43. package/lib/front_end/core/host/AidaClient.ts +0 -733
  44. package/lib/front_end/core/host/GdpClient.ts +0 -316
  45. package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
  46. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
  47. package/lib/front_end/core/host/Platform.ts +0 -76
  48. package/lib/front_end/core/host/ResourceLoader.ts +0 -282
  49. package/lib/front_end/core/host/UserMetrics.ts +0 -1230
  50. package/lib/front_end/core/host/host.ts +0 -23
  51. package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
  52. package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
  53. package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
  54. package/lib/front_end/core/i18n/i18n.ts +0 -17
  55. package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
  56. package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
  57. package/lib/front_end/core/i18n/locales.js +0 -14
  58. package/lib/front_end/core/i18n/time-utilities.ts +0 -174
  59. package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
  60. package/lib/front_end/core/platform/Brand.ts +0 -23
  61. package/lib/front_end/core/platform/Constructor.ts +0 -10
  62. package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
  63. package/lib/front_end/core/platform/DateUtilities.ts +0 -15
  64. package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
  65. package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
  66. package/lib/front_end/core/platform/MapUtilities.ts +0 -95
  67. package/lib/front_end/core/platform/MimeType.ts +0 -175
  68. package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
  69. package/lib/front_end/core/platform/StringUtilities.ts +0 -588
  70. package/lib/front_end/core/platform/Timing.ts +0 -17
  71. package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
  72. package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
  73. package/lib/front_end/core/platform/UIString.ts +0 -39
  74. package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
  75. package/lib/front_end/core/platform/platform.ts +0 -45
  76. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
  77. package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
  78. package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
  79. package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
  80. package/lib/front_end/core/root/Runtime.ts +0 -609
  81. package/lib/front_end/core/root/root.ts +0 -6
  82. package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
  83. package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
  84. package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
  85. package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
  86. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
  87. package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
  88. package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
  89. package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
  90. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
  91. package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
  92. package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
  93. package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
  94. package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
  95. package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
  96. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
  97. package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
  98. package/lib/front_end/core/sdk/CSSRule.ts +0 -465
  99. package/lib/front_end/core/sdk/CSSScope.ts +0 -30
  100. package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
  101. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
  102. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
  103. package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
  104. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
  105. package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
  106. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
  107. package/lib/front_end/core/sdk/Connections.ts +0 -293
  108. package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
  109. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
  110. package/lib/front_end/core/sdk/Cookie.ts +0 -319
  111. package/lib/front_end/core/sdk/CookieModel.ts +0 -239
  112. package/lib/front_end/core/sdk/CookieParser.ts +0 -185
  113. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
  114. package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
  115. package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
  116. package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
  117. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
  118. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
  119. package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
  120. package/lib/front_end/core/sdk/FrameManager.ts +0 -259
  121. package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
  122. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
  123. package/lib/front_end/core/sdk/IOModel.ts +0 -91
  124. package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
  125. package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
  126. package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
  127. package/lib/front_end/core/sdk/LogModel.ts +0 -56
  128. package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
  129. package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
  130. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
  131. package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
  132. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
  133. package/lib/front_end/core/sdk/PageLoad.ts +0 -35
  134. package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
  135. package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
  136. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
  137. package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
  138. package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
  139. package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
  140. package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
  141. package/lib/front_end/core/sdk/Resource.ts +0 -232
  142. package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
  143. package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
  144. package/lib/front_end/core/sdk/SDKModel.ts +0 -65
  145. package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
  146. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
  147. package/lib/front_end/core/sdk/Script.ts +0 -534
  148. package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
  149. package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
  150. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
  151. package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
  152. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
  153. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
  154. package/lib/front_end/core/sdk/SourceMap.ts +0 -867
  155. package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
  156. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
  157. package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
  158. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
  159. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
  160. package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
  161. package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
  162. package/lib/front_end/core/sdk/Target.ts +0 -332
  163. package/lib/front_end/core/sdk/TargetManager.ts +0 -453
  164. package/lib/front_end/core/sdk/TraceObject.ts +0 -61
  165. package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
  166. package/lib/front_end/core/sdk/sdk.ts +0 -174
  167. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
  168. package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
  169. package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
  170. package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
  171. package/lib/front_end/generated/protocol.ts +0 -22014
  172. package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
  173. package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
  174. package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
  175. package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
  176. package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
  177. package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
  178. package/lib/front_end/models/bindings/FileUtils.ts +0 -228
  179. package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
  180. package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
  181. package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
  182. package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
  183. package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
  184. package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
  185. package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
  186. package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
  187. package/lib/front_end/models/bindings/TempFile.ts +0 -67
  188. package/lib/front_end/models/bindings/bindings.ts +0 -39
  189. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
  190. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
  191. package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
  192. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
  193. package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
  194. package/lib/front_end/models/formatter/formatter.ts +0 -8
  195. package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
  196. package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
  197. package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
  198. package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
  199. package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
  200. package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
  201. package/lib/front_end/models/stack_trace/Trie.ts +0 -163
  202. package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
  203. package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
  204. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
  205. package/lib/front_end/models/text_utils/ContentData.ts +0 -199
  206. package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
  207. package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
  208. package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
  209. package/lib/front_end/models/text_utils/Text.ts +0 -90
  210. package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
  211. package/lib/front_end/models/text_utils/TextRange.ts +0 -266
  212. package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
  213. package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
  214. package/lib/front_end/models/text_utils/text_utils.ts +0 -27
  215. package/lib/front_end/models/trace/EntityMapper.ts +0 -141
  216. package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
  217. package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
  218. package/lib/front_end/models/trace/ModelImpl.ts +0 -236
  219. package/lib/front_end/models/trace/Name.ts +0 -136
  220. package/lib/front_end/models/trace/Processor.ts +0 -652
  221. package/lib/front_end/models/trace/Styles.ts +0 -1138
  222. package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
  223. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
  224. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
  225. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
  226. package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
  227. package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
  228. package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
  229. package/lib/front_end/models/trace/extras/extras.ts +0 -11
  230. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
  231. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
  232. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
  233. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
  234. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
  235. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
  236. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
  237. package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
  238. package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
  239. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
  240. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
  241. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
  242. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
  243. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
  244. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
  245. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
  246. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
  247. package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
  248. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
  249. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
  250. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
  251. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
  252. package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
  253. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
  254. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
  255. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
  256. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
  257. package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
  258. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
  259. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
  260. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
  261. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
  262. package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
  263. package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
  264. package/lib/front_end/models/trace/handlers/types.ts +0 -75
  265. package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
  266. package/lib/front_end/models/trace/helpers/Network.ts +0 -129
  267. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
  268. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
  269. package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
  270. package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
  271. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
  272. package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
  273. package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
  274. package/lib/front_end/models/trace/insights/Cache.ts +0 -269
  275. package/lib/front_end/models/trace/insights/Common.ts +0 -453
  276. package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
  277. package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
  278. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
  279. package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
  280. package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
  281. package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
  282. package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
  283. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
  284. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
  285. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
  286. package/lib/front_end/models/trace/insights/Models.ts +0 -22
  287. package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
  288. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
  289. package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
  290. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
  291. package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
  292. package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
  293. package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
  294. package/lib/front_end/models/trace/insights/insights.ts +0 -10
  295. package/lib/front_end/models/trace/insights/types.ts +0 -157
  296. package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
  297. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
  298. package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
  299. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
  300. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
  301. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
  302. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
  303. package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
  304. package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
  305. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
  306. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
  307. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
  308. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
  309. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
  310. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
  311. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
  312. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
  313. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
  314. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
  315. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
  316. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
  317. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
  318. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
  319. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
  320. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
  321. package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
  322. package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
  323. package/lib/front_end/models/trace/trace.ts +0 -33
  324. package/lib/front_end/models/trace/types/Configuration.ts +0 -110
  325. package/lib/front_end/models/trace/types/Extensions.ts +0 -136
  326. package/lib/front_end/models/trace/types/File.ts +0 -281
  327. package/lib/front_end/models/trace/types/Overlays.ts +0 -138
  328. package/lib/front_end/models/trace/types/Timing.ts +0 -30
  329. package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
  330. package/lib/front_end/models/trace/types/types.ts +0 -10
  331. package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
  332. package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
  333. package/lib/front_end/models/workspace/FileManager.ts +0 -97
  334. package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
  335. package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
  336. package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
  337. package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
  338. package/lib/front_end/models/workspace/workspace.ts +0 -17
  339. package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
  340. package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
  341. package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
  342. package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
  343. package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
  344. package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
  345. package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
  346. package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
  347. package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
  348. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
  349. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
  350. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
  351. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
  352. package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
  353. package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
  354. package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
  355. package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
  356. package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
  357. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
  358. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
  359. package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
  360. package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
  361. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
  362. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
  363. package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
  364. package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
  365. package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
  366. package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
  367. package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
  368. package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
  369. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
  370. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
  371. package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
  372. package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
  373. package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
  374. package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
  375. package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
  376. package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
  377. package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
  378. package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
  379. package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
  380. package/lib/front_end/third_party/codemirror.next/package.json +0 -43
  381. package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
  382. package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
  383. package/lib/front_end/third_party/i18n/LICENSE +0 -202
  384. package/lib/front_end/third_party/i18n/README.chromium +0 -15
  385. package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
  386. package/lib/front_end/third_party/i18n/i18n.ts +0 -11
  387. package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
  388. package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
  389. package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
  390. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
  391. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
  392. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
  393. package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
  394. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
  395. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
  396. package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
  397. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
  398. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
  399. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
  400. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
  401. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
  402. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
  403. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
  404. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
  405. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
  406. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
  407. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
  408. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
  409. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
  410. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
  411. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
  412. package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
  413. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
  414. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
  415. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
  416. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
  417. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
  418. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
  419. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
  420. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
  421. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
  422. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
  423. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
  424. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
  425. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
  426. package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
  427. package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
  428. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
  429. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
  430. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
  431. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
  432. package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
  433. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
  434. package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
  435. package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
  436. package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
  437. package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
  438. package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
  439. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
  440. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
  441. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
  442. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
  443. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
  444. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
  445. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
  446. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
  447. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
  448. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
  449. package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
  450. package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
  451. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
  452. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
  453. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
  454. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
  455. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
  456. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
  457. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
  458. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
  459. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
  460. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
  461. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
  462. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
  463. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
  464. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
  465. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
  466. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
  467. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
  468. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
  469. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
  470. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
  471. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
  472. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
  473. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
  474. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
  475. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
  476. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
  477. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
  478. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
  479. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
  480. package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
  481. package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
  482. package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
  483. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
  484. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
  485. package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
  486. package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
  487. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
  488. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
  489. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
  490. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
  491. package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
  492. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
  493. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
  494. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
  495. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
  496. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
  497. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
  498. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
  499. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
  500. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
  501. package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
  502. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
  503. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
  504. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
  505. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
  506. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
  507. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
  508. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
  509. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
  510. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
  511. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
  512. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
  513. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
  514. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
  515. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
  516. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
  517. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
  518. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
  519. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
  520. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
  521. package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
  522. package/lib/front_end/third_party/third-party-web/package.json +0 -8
  523. package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
  524. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
  525. package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
  526. package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
  527. package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
  528. package/patches/chrome-devtools-frontend+1.0.1533544.patch +0 -1716
@@ -1,672 +0,0 @@
1
- // Copyright 2022 The Chromium Authors
2
- // Use of this source code is governed by a BSD-style license that can be
3
- // found in the LICENSE file.
4
-
5
- import * as Platform from '../../../core/platform/platform.js';
6
- import * as Protocol from '../../../generated/protocol.js';
7
- import * as Helpers from '../helpers/helpers.js';
8
- import * as Types from '../types/types.js';
9
-
10
- import * as HandlerHelpers from './helpers.js';
11
- import {data as metaHandlerData} from './MetaHandler.js';
12
- import type {HandlerName} from './types.js';
13
-
14
- const MILLISECONDS_TO_MICROSECONDS = 1000;
15
- const SECONDS_TO_MICROSECONDS = 1000000;
16
-
17
- /**
18
- * Network requests from traces are actually formed of 5 trace records.
19
- * This handler tracks all trace records based on the request ID, and
20
- * then creates a new synthetic trace event for those network requests.
21
- *
22
- * This interface, then, defines the shape of the object we intend to
23
- * keep for each request in the trace. In the finalize we will convert
24
- * these 5 types of trace records to a synthetic complete event that
25
- * represents a composite of these trace records.
26
- **/
27
- export interface TraceEventsForNetworkRequest {
28
- changePriority?: Types.Events.ResourceChangePriority;
29
- willSendRequests?: Types.Events.ResourceWillSendRequest[];
30
- sendRequests?: Types.Events.ResourceSendRequest[];
31
- receiveResponse?: Types.Events.ResourceReceiveResponse;
32
- resourceFinish?: Types.Events.ResourceFinish;
33
- receivedData?: Types.Events.ResourceReceivedData[];
34
- resourceMarkAsCached?: Types.Events.ResourceMarkAsCached;
35
- }
36
-
37
- export interface WebSocketTraceDataForFrame {
38
- frame: string;
39
- webSocketIdentifier: number;
40
- events: Types.Events.WebSocketEvent[];
41
- syntheticConnection: Types.Events.SyntheticWebSocketConnection|null;
42
- }
43
- export interface WebSocketTraceDataForWorker {
44
- workerId: string;
45
- webSocketIdentifier: number;
46
- events: Types.Events.WebSocketEvent[];
47
- syntheticConnection: Types.Events.SyntheticWebSocketConnection|null;
48
- }
49
- export type WebSocketTraceData = WebSocketTraceDataForFrame|WebSocketTraceDataForWorker;
50
-
51
- let webSocketData = new Map<number, WebSocketTraceData>();
52
- let linkPreconnectEvents: Types.Events.LinkPreconnect[] = [];
53
-
54
- interface NetworkRequestData {
55
- byId: Map<string, Types.Events.SyntheticNetworkRequest>;
56
- byTime: Types.Events.SyntheticNetworkRequest[];
57
- eventToInitiator: Map<Types.Events.SyntheticNetworkRequest, Types.Events.SyntheticNetworkRequest>;
58
- webSocket: WebSocketTraceData[];
59
- entityMappings: HandlerHelpers.EntityMappings;
60
- linkPreconnectEvents: Types.Events.LinkPreconnect[];
61
- }
62
-
63
- let requestMap = new Map<string, TraceEventsForNetworkRequest>();
64
- let requestsById = new Map<string, Types.Events.SyntheticNetworkRequest>();
65
- let requestsByTime: Types.Events.SyntheticNetworkRequest[] = [];
66
-
67
- let networkRequestEventByInitiatorUrl = new Map<string, Types.Events.SyntheticNetworkRequest[]>();
68
- let eventToInitiatorMap = new Map<Types.Events.SyntheticNetworkRequest, Types.Events.SyntheticNetworkRequest>();
69
-
70
- /**
71
- * These are to store ThirdParty data relationships between entities and events. To reduce iterating through data
72
- * more than we have to, here we start building the caches. After this, the RendererHandler will update
73
- * the relationships. When handling ThirdParty references, use the one in the RendererHandler instead.
74
- */
75
- let entityMappings: HandlerHelpers.EntityMappings = {
76
- eventsByEntity: new Map<HandlerHelpers.Entity, Types.Events.Event[]>(),
77
- entityByEvent: new Map<Types.Events.Event, HandlerHelpers.Entity>(),
78
- createdEntityCache: new Map<string, HandlerHelpers.Entity>(),
79
- entityByUrlCache: new Map<string, HandlerHelpers.Entity>(),
80
- };
81
-
82
- function storeTraceEventWithRequestId<K extends keyof TraceEventsForNetworkRequest>(
83
- requestId: string, key: K, value: TraceEventsForNetworkRequest[K]): void {
84
- if (!requestMap.has(requestId)) {
85
- requestMap.set(requestId, {});
86
- }
87
-
88
- const traceEvents = requestMap.get(requestId);
89
- if (!traceEvents) {
90
- throw new Error(`Unable to locate trace events for request ID ${requestId}`);
91
- }
92
-
93
- if (Array.isArray(traceEvents[key])) {
94
- const target = traceEvents[key] as Types.Events.Event[];
95
- const values = value as Types.Events.Event[];
96
- target.push(...values);
97
- } else {
98
- traceEvents[key] = value;
99
- }
100
- }
101
-
102
- function firstPositiveValueInList(entries: Array<number|null>): number {
103
- for (const entry of entries) {
104
- if (entry && entry > 0) {
105
- return entry;
106
- }
107
- }
108
-
109
- // In the event we don't find a positive value, we return 0 so as to
110
- // be a mathematical noop. It's typically not correct to return – say –
111
- // a -1 here because it would affect the calculation of stats below.
112
- return 0;
113
- }
114
-
115
- export function reset(): void {
116
- requestsById = new Map();
117
- requestMap = new Map();
118
- requestsByTime = [];
119
- networkRequestEventByInitiatorUrl = new Map();
120
- eventToInitiatorMap = new Map();
121
- webSocketData = new Map();
122
- entityMappings = {
123
- eventsByEntity: new Map<HandlerHelpers.Entity, Types.Events.Event[]>(),
124
- entityByEvent: new Map<Types.Events.Event, HandlerHelpers.Entity>(),
125
- createdEntityCache: new Map<string, HandlerHelpers.Entity>(),
126
- entityByUrlCache: new Map<string, HandlerHelpers.Entity>(),
127
- };
128
- linkPreconnectEvents = [];
129
- }
130
-
131
- export function handleEvent(event: Types.Events.Event): void {
132
- if (Types.Events.isResourceChangePriority(event)) {
133
- storeTraceEventWithRequestId(event.args.data.requestId, 'changePriority', event);
134
- return;
135
- }
136
-
137
- if (Types.Events.isResourceWillSendRequest(event)) {
138
- storeTraceEventWithRequestId(event.args.data.requestId, 'willSendRequests', [event]);
139
- return;
140
- }
141
-
142
- if (Types.Events.isResourceSendRequest(event)) {
143
- storeTraceEventWithRequestId(event.args.data.requestId, 'sendRequests', [event]);
144
- return;
145
- }
146
-
147
- if (Types.Events.isResourceReceiveResponse(event)) {
148
- storeTraceEventWithRequestId(event.args.data.requestId, 'receiveResponse', event);
149
- return;
150
- }
151
-
152
- if (Types.Events.isResourceReceivedData(event)) {
153
- storeTraceEventWithRequestId(event.args.data.requestId, 'receivedData', [event]);
154
- return;
155
- }
156
-
157
- if (Types.Events.isResourceFinish(event)) {
158
- storeTraceEventWithRequestId(event.args.data.requestId, 'resourceFinish', event);
159
- return;
160
- }
161
-
162
- if (Types.Events.isResourceMarkAsCached(event)) {
163
- storeTraceEventWithRequestId(event.args.data.requestId, 'resourceMarkAsCached', event);
164
- return;
165
- }
166
-
167
- if (Types.Events.isWebSocketCreate(event) || Types.Events.isWebSocketInfo(event) ||
168
- Types.Events.isWebSocketTransfer(event)) {
169
- const identifier = event.args.data.identifier;
170
- if (!webSocketData.has(identifier)) {
171
- if (event.args.data.frame) {
172
- webSocketData.set(identifier, {
173
- frame: event.args.data.frame,
174
- webSocketIdentifier: identifier,
175
- events: [],
176
- syntheticConnection: null,
177
- });
178
- } else if (event.args.data.workerId) {
179
- webSocketData.set(identifier, {
180
- workerId: event.args.data.workerId,
181
- webSocketIdentifier: identifier,
182
- events: [],
183
- syntheticConnection: null,
184
- });
185
- }
186
- }
187
-
188
- webSocketData.get(identifier)?.events.push(event);
189
- }
190
-
191
- if (Types.Events.isLinkPreconnect(event)) {
192
- linkPreconnectEvents.push(event);
193
- return;
194
- }
195
- }
196
-
197
- export async function finalize(): Promise<void> {
198
- const {rendererProcessesByFrame} = metaHandlerData();
199
- for (const [requestId, request] of requestMap.entries()) {
200
- // If we have an incomplete set of events here, we choose to drop the network
201
- // request rather than attempt to synthesize the missing data.
202
- if (!request.sendRequests) {
203
- continue;
204
- }
205
-
206
- // In the data we may get multiple willSendRequests and sendRequests, which
207
- // will indicate that there are redirects for a given (sub)resource. In the
208
- // case of a navigation, e.g., example.com/ we will get willSendRequests,
209
- // and we should use these to calculate time spent in redirects.
210
- // In the case of sub-resources, however, e.g., example.com/foo.js we will
211
- // *only* get sendRequests, and we use these instead of willSendRequests
212
- // to detect the time in redirects. We always use the sendRequest for the
213
- // url, priority etc since it contains those values, but we use the
214
- // willSendRequest (if it exists) to calculate the timestamp and durations
215
- // of redirects.
216
- const redirects: Types.Events.SyntheticNetworkRedirect[] = [];
217
- for (let i = 0; i < request.sendRequests.length - 1; i++) {
218
- const sendRequest = request.sendRequests[i];
219
- const nextSendRequest = request.sendRequests[i + 1];
220
-
221
- // Use the willSendRequests as the source for redirects if possible.
222
- // We default to those of the sendRequests, however, since willSendRequest
223
- // is not guaranteed to be present in the data for every request.
224
- let ts = sendRequest.ts;
225
- let dur = Types.Timing.Micro(nextSendRequest.ts - sendRequest.ts);
226
- if (request.willSendRequests?.[i] && request.willSendRequests[i + 1]) {
227
- const willSendRequest = request.willSendRequests[i];
228
- const nextWillSendRequest = request.willSendRequests[i + 1];
229
- ts = willSendRequest.ts;
230
- dur = Types.Timing.Micro(nextWillSendRequest.ts - willSendRequest.ts);
231
- }
232
-
233
- redirects.push({
234
- url: sendRequest.args.data.url,
235
- priority: sendRequest.args.data.priority,
236
- requestMethod: sendRequest.args.data.requestMethod,
237
- ts,
238
- dur,
239
- });
240
- }
241
-
242
- const firstSendRequest = request.sendRequests[0];
243
- const finalSendRequest = request.sendRequests[request.sendRequests.length - 1];
244
-
245
- // We currently do not want to include data URI requests. We may revisit this in the future.
246
- if (finalSendRequest.args.data.url.startsWith('data:')) {
247
- continue;
248
- }
249
-
250
- /**
251
- * LR loses transfer size information, but passes it in the 'X-TotalFetchedSize' header.
252
- * 'X-TotalFetchedSize' is the canonical transfer size in LR.
253
- *
254
- * In Lightrider, due to instrumentation limitations, our values for encodedDataLength are bogus
255
- * and not valid. However the resource's true encodedDataLength/transferSize is shared via a
256
- * special response header, X-TotalFetchedSize. In this situation, we read this value from
257
- * responseReceived, use it for the transferSize and ignore the original encodedDataLength values.
258
- */
259
- // @ts-expect-error
260
- const isLightrider = globalThis.isLightrider;
261
- if (isLightrider && request.resourceFinish && request.receiveResponse?.args.data.headers) {
262
- const lrSizeHeader = request.receiveResponse.args.data.headers.find(h => h.name === 'X-TotalFetchedSize');
263
- if (lrSizeHeader) {
264
- const size = parseFloat(lrSizeHeader.value);
265
- if (!isNaN(size)) {
266
- request.resourceFinish.args.data.encodedDataLength = size;
267
- }
268
- }
269
- }
270
-
271
- // If a ResourceFinish event with an encoded data length is received,
272
- // then the resource was not cached; it was fetched before it was
273
- // requested, e.g. because it was pushed in this navigation.
274
- const isPushedResource = request.resourceFinish?.args.data.encodedDataLength !== 0;
275
- // This works around crbug.com/998397, which reports pushed resources, and resources served by a service worker as disk cached.
276
- const isDiskCached = !!request.receiveResponse && request.receiveResponse.args.data.fromCache &&
277
- !request.receiveResponse.args.data.fromServiceWorker && !isPushedResource;
278
- // If the request contains a resourceMarkAsCached event, it was served from memory cache.
279
- // The timing data returned is from the original (uncached) request, which
280
- // means that if we leave the above network record data as-is when the
281
- // request came from either the disk cache or memory cache, our calculations
282
- // will be incorrect.
283
- //
284
- // So we use this flag so when we calculate the timestamps of the various
285
- // events, we can overwrite them.
286
- // These timestamps may not be perfect (indeed they don't always match
287
- // the Network CDP domain exactly, which is likely an artifact of the way
288
- // the data is routed on the backend), but they're the closest we have.
289
- const isMemoryCached = request.resourceMarkAsCached !== undefined;
290
- // If a request has `resourceMarkAsCached` field, the `timing` field is not correct.
291
- // So let's discard it and override to 0 (which will be handled in later logic if timing field is undefined).
292
- let timing = isMemoryCached ? undefined : request.receiveResponse?.args.data.timing;
293
-
294
- /**
295
- * LR gets additional, accurate timing information from its underlying fetch infrastructure. This
296
- * is passed in via X-Headers similar to 'X-TotalFetchedSize'.
297
- *
298
- * See `_updateTimingsForLightrider` in Lighthouse for more detail.
299
- */
300
- let lrServerResponseTime;
301
- if (isLightrider && request.receiveResponse?.args.data.headers) {
302
- timing = {
303
- requestTime: Helpers.Timing.microToSeconds(request.sendRequests.at(0)?.ts ?? 0 as Types.Timing.Micro),
304
- connectEnd: 0 as Types.Timing.Milli,
305
- connectStart: 0 as Types.Timing.Milli,
306
- dnsEnd: 0 as Types.Timing.Milli,
307
- dnsStart: 0 as Types.Timing.Milli,
308
- proxyEnd: 0 as Types.Timing.Milli,
309
- proxyStart: 0 as Types.Timing.Milli,
310
- pushEnd: 0 as Types.Timing.Milli,
311
- pushStart: 0 as Types.Timing.Milli,
312
- receiveHeadersEnd: 0 as Types.Timing.Milli,
313
- receiveHeadersStart: 0 as Types.Timing.Milli,
314
- sendEnd: 0 as Types.Timing.Milli,
315
- sendStart: 0 as Types.Timing.Milli,
316
- sslEnd: 0 as Types.Timing.Milli,
317
- sslStart: 0 as Types.Timing.Milli,
318
- workerReady: 0 as Types.Timing.Milli,
319
- workerStart: 0 as Types.Timing.Milli,
320
-
321
- ...timing,
322
- };
323
-
324
- const TCPMsHeader = request.receiveResponse.args.data.headers.find(h => h.name === 'X-TCPMs');
325
- const TCPMs = TCPMsHeader ? Math.max(0, parseInt(TCPMsHeader.value, 10)) : 0;
326
-
327
- if (request.receiveResponse.args.data.protocol.startsWith('h3')) {
328
- timing.connectStart = 0 as Types.Timing.Milli;
329
- timing.connectEnd = TCPMs as Types.Timing.Milli;
330
- } else {
331
- timing.connectStart = 0 as Types.Timing.Milli;
332
- timing.sslStart = TCPMs / 2 as Types.Timing.Milli;
333
- timing.connectEnd = TCPMs as Types.Timing.Milli;
334
- timing.sslEnd = TCPMs as Types.Timing.Milli;
335
- }
336
-
337
- // Lightrider does not have any equivalent for `sendEnd` timing values. The
338
- // closest we can get to the server response time is from a header that
339
- // Lightrider sets.
340
- const ResponseMsHeader = request.receiveResponse.args.data.headers.find(h => h.name === 'X-ResponseMs');
341
- if (ResponseMsHeader) {
342
- lrServerResponseTime = Math.max(0, parseInt(ResponseMsHeader.value, 10)) as Types.Timing.Milli;
343
- }
344
- }
345
-
346
- // TODO: consider allowing chrome / about.
347
- const allowedProtocols = [
348
- 'blob:',
349
- 'file:',
350
- 'filesystem:',
351
- 'http:',
352
- 'https:',
353
- ];
354
- if (!allowedProtocols.some(p => firstSendRequest.args.data.url.startsWith(p))) {
355
- continue;
356
- }
357
-
358
- const initialPriority = finalSendRequest.args.data.priority;
359
- let finalPriority = initialPriority;
360
- if (request.changePriority) {
361
- finalPriority = request.changePriority.args.data.priority;
362
- }
363
-
364
- // Network timings are complicated.
365
- // https://raw.githubusercontent.com/GoogleChrome/lighthouse/main/docs/Network-Timings.svg is generally correct, but.. less so for navigations/redirects/etc.
366
-
367
- // Start time
368
- // =======================
369
- // The time where the request started, which is either the first willSendRequest
370
- // event if there is one, or, if there is not, the sendRequest.
371
- const startTime = (request.willSendRequests?.length) ? Types.Timing.Micro(request.willSendRequests[0].ts) :
372
- Types.Timing.Micro(firstSendRequest.ts);
373
-
374
- // End redirect time
375
- // =======================
376
- // It's possible that when we start requesting data we will receive redirections.
377
- // Here we note the time of the *last* willSendRequest / sendRequest event,
378
- // which is used later on in the calculations for time queueing etc.
379
- const endRedirectTime = (request.willSendRequests?.length) ?
380
- Types.Timing.Micro(request.willSendRequests[request.willSendRequests.length - 1].ts) :
381
- Types.Timing.Micro(finalSendRequest.ts);
382
-
383
- // Finish time and end time
384
- // =======================
385
- // The finish time and the end time are subtly different.
386
- // - Finish time: records the point at which the network stack stopped receiving the data
387
- // - End time: the timestamp of the finish event itself (if one exists)
388
- //
389
- // The end time, then, will be slightly after the finish time.
390
- const endTime = request.resourceFinish ? request.resourceFinish.ts : endRedirectTime;
391
- const finishTime = request.resourceFinish?.args.data.finishTime ?
392
- Types.Timing.Micro(request.resourceFinish.args.data.finishTime * SECONDS_TO_MICROSECONDS) :
393
- Types.Timing.Micro(endTime);
394
-
395
- // Network duration
396
- // =======================
397
- // Time spent on the network.
398
- const networkDuration = Types.Timing.Micro(timing ? (finishTime || endRedirectTime) - endRedirectTime : 0);
399
-
400
- // Processing duration
401
- // =======================
402
- // Time spent from start to end.
403
- const processingDuration = Types.Timing.Micro(endTime - (finishTime || endTime));
404
-
405
- // Redirection duration
406
- // =======================
407
- // Time between the first willSendRequest / sendRequest and last. This we place in *front* of the
408
- // queueing, since the queueing time that we know about from the trace data is only the last request,
409
- // i.e., the one that occurs after all the redirects.
410
- const redirectionDuration = Types.Timing.Micro(endRedirectTime - startTime);
411
-
412
- // Queueing
413
- // =======================
414
- // The amount of time queueing is the time between the request's start time to the requestTime
415
- // arg recorded in the receiveResponse event. In the cases where the recorded start time is larger
416
- // that the requestTime we set queueing time to zero.
417
- const queueingFromTraceData = timing ? timing.requestTime * SECONDS_TO_MICROSECONDS - endRedirectTime : 0;
418
- const queueing = Types.Timing.Micro(Platform.NumberUtilities.clamp(queueingFromTraceData, 0, Number.MAX_VALUE));
419
-
420
- // Stalled
421
- // =======================
422
- // If the request is cached, the amount of time stalled is the time between the start time and
423
- // receiving a response.
424
- // Otherwise it is whichever positive number comes first from the following timing info:
425
- // DNS start, Connection start, Send Start, or the time duration between our start time and
426
- // receiving a response.
427
- const stalled = timing ?
428
- Types.Timing.Micro(firstPositiveValueInList([
429
- timing.dnsStart * MILLISECONDS_TO_MICROSECONDS,
430
- timing.connectStart * MILLISECONDS_TO_MICROSECONDS,
431
- timing.sendStart * MILLISECONDS_TO_MICROSECONDS,
432
- request.receiveResponse ? (request.receiveResponse.ts - endRedirectTime) : null,
433
- ])) :
434
- (request.receiveResponse ? Types.Timing.Micro(request.receiveResponse.ts - startTime) : Types.Timing.Micro(0));
435
-
436
- // Sending HTTP request
437
- // =======================
438
- // Time when the HTTP request is sent.
439
- const sendStartTime = timing ?
440
- Types.Timing.Micro(
441
- timing.requestTime * SECONDS_TO_MICROSECONDS + timing.sendStart * MILLISECONDS_TO_MICROSECONDS) :
442
- startTime;
443
-
444
- // Waiting
445
- // =======================
446
- // Time from when the send finished going to when the headers were received.
447
- const waiting = timing ?
448
- Types.Timing.Micro((timing.receiveHeadersEnd - timing.sendEnd) * MILLISECONDS_TO_MICROSECONDS) :
449
- Types.Timing.Micro(0);
450
-
451
- // Server Response Time
452
- // =======================
453
- // Time from when the send finished going to when the first byte of headers were received.
454
- const serverResponseTime = timing ?
455
- Types.Timing.Micro(
456
- ((timing.receiveHeadersStart ?? timing.receiveHeadersEnd) - timing.sendEnd) *
457
- MILLISECONDS_TO_MICROSECONDS) :
458
- Types.Timing.Micro(0);
459
-
460
- // Download
461
- // =======================
462
- // Time from receipt of headers to the finish time.
463
- const downloadStart = timing ?
464
- Types.Timing.Micro(
465
- timing.requestTime * SECONDS_TO_MICROSECONDS + timing.receiveHeadersEnd * MILLISECONDS_TO_MICROSECONDS) :
466
- startTime;
467
- const download = timing ? Types.Timing.Micro(((finishTime || downloadStart) - downloadStart)) :
468
- request.receiveResponse ? Types.Timing.Micro(endTime - request.receiveResponse.ts) :
469
- Types.Timing.Micro(0);
470
-
471
- const totalTime = Types.Timing.Micro(networkDuration + processingDuration);
472
-
473
- // Collect a few values from the timing info.
474
- // If the Network request is cached, these fields will be zero, so the minus will zero out them.
475
- const dnsLookup = timing ? Types.Timing.Micro((timing.dnsEnd - timing.dnsStart) * MILLISECONDS_TO_MICROSECONDS) :
476
- Types.Timing.Micro(0);
477
- const ssl = timing ? Types.Timing.Micro((timing.sslEnd - timing.sslStart) * MILLISECONDS_TO_MICROSECONDS) :
478
- Types.Timing.Micro(0);
479
- const proxyNegotiation = timing ?
480
- Types.Timing.Micro((timing.proxyEnd - timing.proxyStart) * MILLISECONDS_TO_MICROSECONDS) :
481
- Types.Timing.Micro(0);
482
- const requestSent = timing ?
483
- Types.Timing.Micro((timing.sendEnd - timing.sendStart) * MILLISECONDS_TO_MICROSECONDS) :
484
- Types.Timing.Micro(0);
485
- const initialConnection = timing ?
486
- Types.Timing.Micro((timing.connectEnd - timing.connectStart) * MILLISECONDS_TO_MICROSECONDS) :
487
- Types.Timing.Micro(0);
488
-
489
- // Finally get some of the general data from the trace events.
490
- const {frame, url, renderBlocking} = finalSendRequest.args.data;
491
- const {encodedDataLength, decodedBodyLength} =
492
- request.resourceFinish ? request.resourceFinish.args.data : {encodedDataLength: 0, decodedBodyLength: 0};
493
- const parsedUrl = new URL(url);
494
- const isHttps = parsedUrl.protocol === 'https:';
495
- const requestingFrameUrl =
496
- Helpers.Trace.activeURLForFrameAtTime(frame, finalSendRequest.ts, rendererProcessesByFrame) || '';
497
- // Construct a synthetic trace event for this network request.
498
- const networkEvent =
499
- Helpers.SyntheticEvents.SyntheticEventsManager.registerSyntheticEvent<Types.Events.SyntheticNetworkRequest>({
500
- rawSourceEvent: finalSendRequest,
501
- args: {
502
- data: {
503
- // All data we create from trace events should be added to |syntheticData|.
504
- syntheticData: {
505
- dnsLookup,
506
- download,
507
- downloadStart,
508
- finishTime,
509
- initialConnection,
510
- isDiskCached,
511
- isHttps,
512
- isMemoryCached,
513
- isPushedResource,
514
- networkDuration,
515
- processingDuration,
516
- proxyNegotiation,
517
- queueing,
518
- redirectionDuration,
519
- requestSent,
520
- sendStartTime,
521
- ssl,
522
- stalled,
523
- totalTime,
524
- waiting,
525
- serverResponseTime,
526
- },
527
- // All fields below are from TraceEventsForNetworkRequest.
528
- decodedBodyLength,
529
- encodedDataLength,
530
- frame,
531
- fromServiceWorker: request.receiveResponse?.args.data.fromServiceWorker,
532
- isLinkPreload: finalSendRequest.args.data.isLinkPreload || false,
533
- mimeType: request.receiveResponse?.args.data.mimeType ?? '',
534
- priority: finalPriority,
535
- initialPriority,
536
- protocol: request.receiveResponse?.args.data.protocol ?? 'unknown',
537
- redirects,
538
- // In the event the property isn't set, assume non-blocking.
539
- renderBlocking: renderBlocking ?? 'non_blocking',
540
- requestId,
541
- requestingFrameUrl,
542
- requestMethod: finalSendRequest.args.data.requestMethod,
543
- resourceType: finalSendRequest.args.data.resourceType ?? Protocol.Network.ResourceType.Other,
544
- statusCode: request.receiveResponse?.args.data.statusCode ?? 0,
545
- responseHeaders: request.receiveResponse?.args.data.headers ?? null,
546
- fetchPriorityHint: finalSendRequest.args.data.fetchPriorityHint ?? 'auto',
547
- initiator: finalSendRequest.args.data.initiator,
548
- stackTrace: finalSendRequest.args.data.stackTrace,
549
- timing,
550
- lrServerResponseTime,
551
- url,
552
- failed: request.resourceFinish?.args.data.didFail ?? false,
553
- finished: Boolean(request.resourceFinish),
554
- hasResponse: Boolean(request.receiveResponse),
555
- connectionId: request.receiveResponse?.args.data.connectionId,
556
- connectionReused: request.receiveResponse?.args.data.connectionReused,
557
- },
558
- },
559
- cat: 'loading',
560
- name: Types.Events.Name.SYNTHETIC_NETWORK_REQUEST,
561
- ph: Types.Events.Phase.COMPLETE,
562
- dur: Types.Timing.Micro(endTime - startTime),
563
- tdur: Types.Timing.Micro(endTime - startTime),
564
- ts: Types.Timing.Micro(startTime),
565
- tts: Types.Timing.Micro(startTime),
566
- pid: finalSendRequest.pid,
567
- tid: finalSendRequest.tid,
568
- });
569
-
570
- // However, there are also times where we just want to loop through all
571
- // the captured requests, so here we store all of them together.
572
- requestsByTime.push(networkEvent);
573
- requestsById.set(networkEvent.args.data.requestId, networkEvent);
574
-
575
- // Update entity relationships for network events
576
- HandlerHelpers.addNetworkRequestToEntityMapping(networkEvent, entityMappings, request);
577
-
578
- // Establish initiator relationships
579
- const initiatorUrl = networkEvent.args.data.initiator?.url ||
580
- Helpers.Trace.getStackTraceTopCallFrameInEventPayload(networkEvent)?.url;
581
- if (initiatorUrl) {
582
- const events = networkRequestEventByInitiatorUrl.get(initiatorUrl) ?? [];
583
- events.push(networkEvent);
584
- networkRequestEventByInitiatorUrl.set(initiatorUrl, events);
585
- }
586
- }
587
-
588
- for (const request of requestsByTime) {
589
- const initiatedEvents = networkRequestEventByInitiatorUrl.get(request.args.data.url);
590
-
591
- if (initiatedEvents) {
592
- for (const initiatedEvent of initiatedEvents) {
593
- eventToInitiatorMap.set(initiatedEvent, request);
594
- }
595
- }
596
- }
597
-
598
- finalizeWebSocketData();
599
- }
600
-
601
- export function data(): NetworkRequestData {
602
- return {
603
- byId: requestsById,
604
- byTime: requestsByTime,
605
- eventToInitiator: eventToInitiatorMap,
606
- webSocket: [...webSocketData.values()],
607
- entityMappings: {
608
- entityByEvent: entityMappings.entityByEvent,
609
- eventsByEntity: entityMappings.eventsByEntity,
610
- createdEntityCache: entityMappings.createdEntityCache,
611
- entityByUrlCache: entityMappings.entityByUrlCache,
612
- },
613
- linkPreconnectEvents,
614
- };
615
- }
616
-
617
- export function deps(): HandlerName[] {
618
- return ['Meta'];
619
- }
620
-
621
- function finalizeWebSocketData(): void {
622
- // for each WebSocketTraceData in webSocketData map, we create a synthetic event
623
- // to represent the entire WebSocket connection. This is done by finding the start and end event
624
- // if they exist, and if they don't, we use the first event in the list for start, and the traceBounds.max
625
- // for the end. So each WebSocketTraceData will have
626
- // {
627
- // events: the list of WebSocket events
628
- // syntheticConnection: the synthetic event representing the entire WebSocket connection
629
- // }
630
- webSocketData.forEach(data => {
631
- let startEvent: Types.Events.WebSocketEvent|null = null;
632
- let endEvent: Types.Events.WebSocketDestroy|null = null;
633
- for (const event of data.events) {
634
- if (Types.Events.isWebSocketCreate(event)) {
635
- startEvent = event;
636
- }
637
- if (Types.Events.isWebSocketDestroy(event)) {
638
- endEvent = event;
639
- }
640
- }
641
- data.syntheticConnection = createSyntheticWebSocketConnection(startEvent, endEvent, data.events[0]);
642
- });
643
- }
644
-
645
- function createSyntheticWebSocketConnection(
646
- startEvent: Types.Events.WebSocketCreate|null, endEvent: Types.Events.WebSocketDestroy|null,
647
- firstRecordedEvent: Types.Events.WebSocketEvent): Types.Events.SyntheticWebSocketConnection {
648
- const {traceBounds} = metaHandlerData();
649
- const startTs = startEvent ? startEvent.ts : traceBounds.min;
650
- const endTs = endEvent ? endEvent.ts : traceBounds.max;
651
- const duration = endTs - startTs;
652
- const mainEvent = startEvent || endEvent || firstRecordedEvent;
653
- return {
654
- name: 'SyntheticWebSocketConnection',
655
- cat: mainEvent.cat,
656
- ph: Types.Events.Phase.COMPLETE,
657
- ts: startTs,
658
- dur: duration as Types.Timing.Micro,
659
- pid: mainEvent.pid,
660
- tid: mainEvent.tid,
661
- s: mainEvent.s,
662
- rawSourceEvent: mainEvent,
663
- _tag: 'SyntheticEntryTag',
664
- args: {
665
- data: {
666
- identifier: mainEvent.args.data.identifier,
667
- priority: Protocol.Network.ResourcePriority.Low,
668
- url: mainEvent.args.data.url || '',
669
- },
670
- },
671
- };
672
- }