devtools-tracing 1.0.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 (397) hide show
  1. package/generate.ts +643 -0
  2. package/index.ts +16 -0
  3. package/lib/front_end/core/common/App.ts +7 -0
  4. package/lib/front_end/core/common/AppProvider.ts +32 -0
  5. package/lib/front_end/core/common/Base64.ts +47 -0
  6. package/lib/front_end/core/common/CharacterIdMap.ts +30 -0
  7. package/lib/front_end/core/common/Color.ts +2506 -0
  8. package/lib/front_end/core/common/ColorConverter.ts +402 -0
  9. package/lib/front_end/core/common/ColorUtils.ts +252 -0
  10. package/lib/front_end/core/common/Console.ts +114 -0
  11. package/lib/front_end/core/common/Debouncer.ts +15 -0
  12. package/lib/front_end/core/common/EventTarget.ts +52 -0
  13. package/lib/front_end/core/common/Gzip.ts +74 -0
  14. package/lib/front_end/core/common/JavaScriptMetaData.ts +29 -0
  15. package/lib/front_end/core/common/Lazy.ts +31 -0
  16. package/lib/front_end/core/common/Linkifier.ts +55 -0
  17. package/lib/front_end/core/common/MapWithDefault.ts +26 -0
  18. package/lib/front_end/core/common/Mutex.ts +55 -0
  19. package/lib/front_end/core/common/Object.ts +145 -0
  20. package/lib/front_end/core/common/ParsedURL.ts +554 -0
  21. package/lib/front_end/core/common/Progress.ts +180 -0
  22. package/lib/front_end/core/common/QueryParamHandler.ts +7 -0
  23. package/lib/front_end/core/common/ResolverBase.ts +85 -0
  24. package/lib/front_end/core/common/ResourceType.ts +588 -0
  25. package/lib/front_end/core/common/ReturnToPanel.ts +17 -0
  26. package/lib/front_end/core/common/Revealer.ts +192 -0
  27. package/lib/front_end/core/common/Runnable.ts +41 -0
  28. package/lib/front_end/core/common/SegmentedRange.ts +87 -0
  29. package/lib/front_end/core/common/SettingRegistration.ts +339 -0
  30. package/lib/front_end/core/common/Settings.ts +1497 -0
  31. package/lib/front_end/core/common/SimpleHistoryManager.ts +124 -0
  32. package/lib/front_end/core/common/StringOutputStream.ts +26 -0
  33. package/lib/front_end/core/common/TextDictionary.ts +48 -0
  34. package/lib/front_end/core/common/Throttler.ts +99 -0
  35. package/lib/front_end/core/common/Trie.ts +152 -0
  36. package/lib/front_end/core/common/Worker.ts +60 -0
  37. package/lib/front_end/core/common/common.ts +81 -0
  38. package/lib/front_end/core/host/AidaClient.ts +733 -0
  39. package/lib/front_end/core/host/GdpClient.ts +316 -0
  40. package/lib/front_end/core/host/InspectorFrontendHost.ts +648 -0
  41. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +551 -0
  42. package/lib/front_end/core/host/Platform.ts +76 -0
  43. package/lib/front_end/core/host/ResourceLoader.ts +282 -0
  44. package/lib/front_end/core/host/UserMetrics.ts +1230 -0
  45. package/lib/front_end/core/host/host.ts +23 -0
  46. package/lib/front_end/core/i18n/ByteUtilities.ts +82 -0
  47. package/lib/front_end/core/i18n/DevToolsLocale.ts +87 -0
  48. package/lib/front_end/core/i18n/NumberFormatter.ts +82 -0
  49. package/lib/front_end/core/i18n/i18n.ts +17 -0
  50. package/lib/front_end/core/i18n/i18nImpl.ts +204 -0
  51. package/lib/front_end/core/i18n/i18nTypes.ts +10 -0
  52. package/lib/front_end/core/i18n/locales.js +14 -0
  53. package/lib/front_end/core/i18n/time-utilities.ts +174 -0
  54. package/lib/front_end/core/platform/ArrayUtilities.ts +271 -0
  55. package/lib/front_end/core/platform/Brand.ts +23 -0
  56. package/lib/front_end/core/platform/Constructor.ts +10 -0
  57. package/lib/front_end/core/platform/DOMUtilities.ts +138 -0
  58. package/lib/front_end/core/platform/DateUtilities.ts +15 -0
  59. package/lib/front_end/core/platform/DevToolsPath.ts +53 -0
  60. package/lib/front_end/core/platform/KeyboardUtilities.ts +38 -0
  61. package/lib/front_end/core/platform/MapUtilities.ts +95 -0
  62. package/lib/front_end/core/platform/MimeType.ts +175 -0
  63. package/lib/front_end/core/platform/NumberUtilities.ts +80 -0
  64. package/lib/front_end/core/platform/StringUtilities.ts +588 -0
  65. package/lib/front_end/core/platform/Timing.ts +17 -0
  66. package/lib/front_end/core/platform/TypedArrayUtilities.ts +189 -0
  67. package/lib/front_end/core/platform/TypescriptUtilities.ts +86 -0
  68. package/lib/front_end/core/platform/UIString.ts +39 -0
  69. package/lib/front_end/core/platform/UserVisibleError.ts +28 -0
  70. package/lib/front_end/core/platform/platform.ts +45 -0
  71. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +26 -0
  72. package/lib/front_end/core/protocol_client/InspectorBackend.ts +1050 -0
  73. package/lib/front_end/core/protocol_client/NodeURL.ts +42 -0
  74. package/lib/front_end/core/protocol_client/protocol_client.ts +13 -0
  75. package/lib/front_end/core/root/Runtime.ts +609 -0
  76. package/lib/front_end/core/root/root.ts +6 -0
  77. package/lib/front_end/core/sdk/AccessibilityModel.ts +353 -0
  78. package/lib/front_end/core/sdk/AnimationModel.ts +1041 -0
  79. package/lib/front_end/core/sdk/AutofillModel.ts +184 -0
  80. package/lib/front_end/core/sdk/CPUProfilerModel.ts +148 -0
  81. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +282 -0
  82. package/lib/front_end/core/sdk/CSSContainerQuery.ts +139 -0
  83. package/lib/front_end/core/sdk/CSSFontFace.ts +40 -0
  84. package/lib/front_end/core/sdk/CSSLayer.ts +30 -0
  85. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +1646 -0
  86. package/lib/front_end/core/sdk/CSSMedia.ts +121 -0
  87. package/lib/front_end/core/sdk/CSSMetadata.ts +1647 -0
  88. package/lib/front_end/core/sdk/CSSModel.ts +1128 -0
  89. package/lib/front_end/core/sdk/CSSProperty.ts +384 -0
  90. package/lib/front_end/core/sdk/CSSPropertyParser.ts +681 -0
  91. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +1395 -0
  92. package/lib/front_end/core/sdk/CSSQuery.ts +72 -0
  93. package/lib/front_end/core/sdk/CSSRule.ts +465 -0
  94. package/lib/front_end/core/sdk/CSSScope.ts +30 -0
  95. package/lib/front_end/core/sdk/CSSStartingStyle.ts +29 -0
  96. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +313 -0
  97. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +196 -0
  98. package/lib/front_end/core/sdk/CSSSupports.ts +33 -0
  99. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +64 -0
  100. package/lib/front_end/core/sdk/ChildTargetManager.ts +314 -0
  101. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +62 -0
  102. package/lib/front_end/core/sdk/Connections.ts +293 -0
  103. package/lib/front_end/core/sdk/ConsoleModel.ts +808 -0
  104. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +15 -0
  105. package/lib/front_end/core/sdk/Cookie.ts +319 -0
  106. package/lib/front_end/core/sdk/CookieModel.ts +239 -0
  107. package/lib/front_end/core/sdk/CookieParser.ts +185 -0
  108. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +787 -0
  109. package/lib/front_end/core/sdk/DOMModel.ts +1961 -0
  110. package/lib/front_end/core/sdk/DebuggerModel.ts +1605 -0
  111. package/lib/front_end/core/sdk/EmulationModel.ts +648 -0
  112. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +515 -0
  113. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +183 -0
  114. package/lib/front_end/core/sdk/FrameAssociated.ts +11 -0
  115. package/lib/front_end/core/sdk/FrameManager.ts +259 -0
  116. package/lib/front_end/core/sdk/HeapProfilerModel.ts +225 -0
  117. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +77 -0
  118. package/lib/front_end/core/sdk/IOModel.ts +91 -0
  119. package/lib/front_end/core/sdk/IsolateManager.ts +257 -0
  120. package/lib/front_end/core/sdk/IssuesModel.ts +70 -0
  121. package/lib/front_end/core/sdk/LayerTreeBase.ts +169 -0
  122. package/lib/front_end/core/sdk/LogModel.ts +56 -0
  123. package/lib/front_end/core/sdk/NetworkManager.ts +2823 -0
  124. package/lib/front_end/core/sdk/NetworkRequest.ts +2253 -0
  125. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +52 -0
  126. package/lib/front_end/core/sdk/OverlayModel.ts +1011 -0
  127. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +522 -0
  128. package/lib/front_end/core/sdk/PageLoad.ts +35 -0
  129. package/lib/front_end/core/sdk/PageResourceLoader.ts +435 -0
  130. package/lib/front_end/core/sdk/PaintProfiler.ts +110 -0
  131. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +84 -0
  132. package/lib/front_end/core/sdk/PreloadingModel.ts +863 -0
  133. package/lib/front_end/core/sdk/RehydratingConnection.ts +386 -0
  134. package/lib/front_end/core/sdk/RehydratingObject.ts +66 -0
  135. package/lib/front_end/core/sdk/RemoteObject.ts +1160 -0
  136. package/lib/front_end/core/sdk/Resource.ts +232 -0
  137. package/lib/front_end/core/sdk/ResourceTreeModel.ts +1160 -0
  138. package/lib/front_end/core/sdk/RuntimeModel.ts +732 -0
  139. package/lib/front_end/core/sdk/SDKModel.ts +65 -0
  140. package/lib/front_end/core/sdk/ScopeTreeCache.ts +45 -0
  141. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +255 -0
  142. package/lib/front_end/core/sdk/Script.ts +534 -0
  143. package/lib/front_end/core/sdk/SecurityOriginManager.ts +76 -0
  144. package/lib/front_end/core/sdk/ServerSentEvents.ts +80 -0
  145. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +122 -0
  146. package/lib/front_end/core/sdk/ServerTiming.ts +260 -0
  147. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +377 -0
  148. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +605 -0
  149. package/lib/front_end/core/sdk/SourceMap.ts +867 -0
  150. package/lib/front_end/core/sdk/SourceMapCache.ts +54 -0
  151. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +156 -0
  152. package/lib/front_end/core/sdk/SourceMapManager.ts +239 -0
  153. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +189 -0
  154. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +508 -0
  155. package/lib/front_end/core/sdk/StorageBucketsModel.ts +204 -0
  156. package/lib/front_end/core/sdk/StorageKeyManager.ts +98 -0
  157. package/lib/front_end/core/sdk/Target.ts +332 -0
  158. package/lib/front_end/core/sdk/TargetManager.ts +453 -0
  159. package/lib/front_end/core/sdk/TraceObject.ts +61 -0
  160. package/lib/front_end/core/sdk/WebAuthnModel.ts +104 -0
  161. package/lib/front_end/core/sdk/sdk.ts +174 -0
  162. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +59 -0
  163. package/lib/front_end/generated/InspectorBackendCommands.js +1617 -0
  164. package/lib/front_end/generated/SupportedCSSProperties.js +7512 -0
  165. package/lib/front_end/generated/protocol-proxy-api.d.ts +5022 -0
  166. package/lib/front_end/generated/protocol.ts +22014 -0
  167. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +571 -0
  168. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +103 -0
  169. package/lib/front_end/models/cpu_profile/cpu_profile.ts +11 -0
  170. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +219 -0
  171. package/lib/front_end/models/formatter/ScriptFormatter.ts +112 -0
  172. package/lib/front_end/models/formatter/formatter.ts +8 -0
  173. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +37 -0
  174. package/lib/front_end/models/text_utils/ContentData.ts +199 -0
  175. package/lib/front_end/models/text_utils/ContentProvider.ts +68 -0
  176. package/lib/front_end/models/text_utils/StaticContentProvider.ts +49 -0
  177. package/lib/front_end/models/text_utils/StreamingContentData.ts +108 -0
  178. package/lib/front_end/models/text_utils/Text.ts +90 -0
  179. package/lib/front_end/models/text_utils/TextCursor.ts +44 -0
  180. package/lib/front_end/models/text_utils/TextRange.ts +266 -0
  181. package/lib/front_end/models/text_utils/TextUtils.ts +401 -0
  182. package/lib/front_end/models/text_utils/WasmDisassembly.ts +87 -0
  183. package/lib/front_end/models/text_utils/text_utils.ts +27 -0
  184. package/lib/front_end/models/trace/EntityMapper.ts +141 -0
  185. package/lib/front_end/models/trace/EventsSerializer.ts +101 -0
  186. package/lib/front_end/models/trace/LanternComputationData.ts +438 -0
  187. package/lib/front_end/models/trace/ModelImpl.ts +236 -0
  188. package/lib/front_end/models/trace/Name.ts +136 -0
  189. package/lib/front_end/models/trace/Processor.ts +652 -0
  190. package/lib/front_end/models/trace/Styles.ts +1138 -0
  191. package/lib/front_end/models/trace/extras/FilmStrip.ts +78 -0
  192. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +86 -0
  193. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +236 -0
  194. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +203 -0
  195. package/lib/front_end/models/trace/extras/ThirdParties.ts +164 -0
  196. package/lib/front_end/models/trace/extras/TraceFilter.ts +62 -0
  197. package/lib/front_end/models/trace/extras/TraceTree.ts +701 -0
  198. package/lib/front_end/models/trace/extras/extras.ts +11 -0
  199. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +128 -0
  200. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +36 -0
  201. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +239 -0
  202. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +183 -0
  203. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +31 -0
  204. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +306 -0
  205. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +175 -0
  206. package/lib/front_end/models/trace/handlers/FramesHandler.ts +571 -0
  207. package/lib/front_end/models/trace/handlers/GPUHandler.ts +50 -0
  208. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +183 -0
  209. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +193 -0
  210. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +168 -0
  211. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +109 -0
  212. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +35 -0
  213. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +123 -0
  214. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +573 -0
  215. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +31 -0
  216. package/lib/front_end/models/trace/handlers/MetaHandler.ts +525 -0
  217. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +34 -0
  218. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +672 -0
  219. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +52 -0
  220. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +460 -0
  221. package/lib/front_end/models/trace/handlers/RendererHandler.ts +428 -0
  222. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +271 -0
  223. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +122 -0
  224. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +336 -0
  225. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +110 -0
  226. package/lib/front_end/models/trace/handlers/Threads.ts +139 -0
  227. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +400 -0
  228. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +233 -0
  229. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +162 -0
  230. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +45 -0
  231. package/lib/front_end/models/trace/handlers/handlers.ts +8 -0
  232. package/lib/front_end/models/trace/handlers/helpers.ts +196 -0
  233. package/lib/front_end/models/trace/handlers/types.ts +75 -0
  234. package/lib/front_end/models/trace/helpers/Extensions.ts +54 -0
  235. package/lib/front_end/models/trace/helpers/Network.ts +129 -0
  236. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +544 -0
  237. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +87 -0
  238. package/lib/front_end/models/trace/helpers/Timing.ts +248 -0
  239. package/lib/front_end/models/trace/helpers/Trace.ts +928 -0
  240. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +320 -0
  241. package/lib/front_end/models/trace/helpers/helpers.ts +11 -0
  242. package/lib/front_end/models/trace/insights/CLSCulprits.ts +668 -0
  243. package/lib/front_end/models/trace/insights/Cache.ts +269 -0
  244. package/lib/front_end/models/trace/insights/Common.ts +453 -0
  245. package/lib/front_end/models/trace/insights/DOMSize.ts +223 -0
  246. package/lib/front_end/models/trace/insights/DocumentLatency.ts +319 -0
  247. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +126 -0
  248. package/lib/front_end/models/trace/insights/FontDisplay.ts +119 -0
  249. package/lib/front_end/models/trace/insights/ForcedReflow.ts +220 -0
  250. package/lib/front_end/models/trace/insights/INPBreakdown.ts +171 -0
  251. package/lib/front_end/models/trace/insights/ImageDelivery.ts +348 -0
  252. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +268 -0
  253. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +237 -0
  254. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +138 -0
  255. package/lib/front_end/models/trace/insights/Models.ts +22 -0
  256. package/lib/front_end/models/trace/insights/ModernHTTP.ts +257 -0
  257. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +726 -0
  258. package/lib/front_end/models/trace/insights/RenderBlocking.ts +257 -0
  259. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +175 -0
  260. package/lib/front_end/models/trace/insights/Statistics.ts +101 -0
  261. package/lib/front_end/models/trace/insights/ThirdParties.ts +130 -0
  262. package/lib/front_end/models/trace/insights/Viewport.ts +138 -0
  263. package/lib/front_end/models/trace/insights/insights.ts +10 -0
  264. package/lib/front_end/models/trace/insights/types.ts +157 -0
  265. package/lib/front_end/models/trace/lantern/core/LanternError.ts +7 -0
  266. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +619 -0
  267. package/lib/front_end/models/trace/lantern/core/core.ts +6 -0
  268. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +345 -0
  269. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +80 -0
  270. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +101 -0
  271. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +636 -0
  272. package/lib/front_end/models/trace/lantern/graph/graph.ts +8 -0
  273. package/lib/front_end/models/trace/lantern/lantern.ts +17 -0
  274. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +187 -0
  275. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +88 -0
  276. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +92 -0
  277. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +72 -0
  278. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +126 -0
  279. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +126 -0
  280. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +82 -0
  281. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +112 -0
  282. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +12 -0
  283. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +150 -0
  284. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +46 -0
  285. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +61 -0
  286. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +196 -0
  287. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +556 -0
  288. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +192 -0
  289. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +10 -0
  290. package/lib/front_end/models/trace/lantern/types/Lantern.ts +220 -0
  291. package/lib/front_end/models/trace/lantern/types/types.ts +5 -0
  292. package/lib/front_end/models/trace/trace.ts +33 -0
  293. package/lib/front_end/models/trace/types/Configuration.ts +110 -0
  294. package/lib/front_end/models/trace/types/Extensions.ts +136 -0
  295. package/lib/front_end/models/trace/types/File.ts +281 -0
  296. package/lib/front_end/models/trace/types/Overlays.ts +138 -0
  297. package/lib/front_end/models/trace/types/Timing.ts +30 -0
  298. package/lib/front_end/models/trace/types/TraceEvents.ts +3277 -0
  299. package/lib/front_end/models/trace/types/types.ts +10 -0
  300. package/lib/front_end/third_party/i18n/LICENSE +202 -0
  301. package/lib/front_end/third_party/i18n/README.chromium +15 -0
  302. package/lib/front_end/third_party/i18n/i18n-impl.ts +61 -0
  303. package/lib/front_end/third_party/i18n/i18n.ts +11 -0
  304. package/lib/front_end/third_party/i18n/localized-string-set.ts +129 -0
  305. package/lib/front_end/third_party/intl-messageformat/LICENSE +33 -0
  306. package/lib/front_end/third_party/intl-messageformat/README.chromium +24 -0
  307. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +16 -0
  308. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +6 -0
  309. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +33 -0
  310. package/lib/front_end/third_party/intl-messageformat/package/README.md +3 -0
  311. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +6 -0
  312. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +1 -0
  313. package/lib/front_end/third_party/intl-messageformat/package/index.js +13 -0
  314. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +5 -0
  315. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +1710 -0
  316. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +1815 -0
  317. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +6 -0
  318. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +1 -0
  319. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +10 -0
  320. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +34 -0
  321. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +1 -0
  322. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +229 -0
  323. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +28 -0
  324. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +1 -0
  325. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +48 -0
  326. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +34 -0
  327. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +1 -0
  328. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +179 -0
  329. package/lib/front_end/third_party/intl-messageformat/package/package.json +42 -0
  330. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +34 -0
  331. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +1 -0
  332. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +230 -0
  333. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +28 -0
  334. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +1 -0
  335. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +51 -0
  336. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +34 -0
  337. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +1 -0
  338. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +182 -0
  339. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +79 -0
  340. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +15 -0
  341. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +153 -0
  342. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +139 -0
  343. package/lib/front_end/third_party/legacy-javascript/LICENSE +202 -0
  344. package/lib/front_end/third_party/legacy-javascript/README.chromium +13 -0
  345. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +8 -0
  346. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +3 -0
  347. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +18 -0
  348. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +943 -0
  349. package/lib/front_end/third_party/legacy-javascript/package.json +8 -0
  350. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +9 -0
  351. package/lib/front_end/third_party/third-party-web/LICENSE +20 -0
  352. package/lib/front_end/third_party/third-party-web/README.chromium +13 -0
  353. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +2 -0
  354. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +149 -0
  355. package/lib/front_end/third_party/third-party-web/package/LICENSE +20 -0
  356. package/lib/front_end/third_party/third-party-web/package/README.md +929 -0
  357. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +1 -0
  358. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +1 -0
  359. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +1 -0
  360. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +1 -0
  361. package/lib/front_end/third_party/third-party-web/package/facades.md +46 -0
  362. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +1 -0
  363. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +1 -0
  364. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +1 -0
  365. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +1 -0
  366. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +1006 -0
  367. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +139 -0
  368. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +44 -0
  369. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +27 -0
  370. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +34 -0
  371. package/lib/front_end/third_party/third-party-web/package/lib/index.js +3 -0
  372. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +246 -0
  373. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +36 -0
  374. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +9 -0
  375. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +5 -0
  376. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +151 -0
  377. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +1 -0
  378. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +1 -0
  379. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +1 -0
  380. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +14 -0
  381. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +1 -0
  382. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +3 -0
  383. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +1 -0
  384. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +3 -0
  385. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +1 -0
  386. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +3 -0
  387. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +1 -0
  388. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +3 -0
  389. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +1 -0
  390. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +1 -0
  391. package/lib/front_end/third_party/third-party-web/package/package.json +46 -0
  392. package/lib/front_end/third_party/third-party-web/package.json +8 -0
  393. package/lib/front_end/third_party/third-party-web/rebuild.sh +13 -0
  394. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +8 -0
  395. package/lib/front_end/third_party/third-party-web/third-party-web.ts +3 -0
  396. package/package.json +24 -0
  397. package/patches/chrome-devtools-frontend+1.0.1533544.patch +187 -0
@@ -0,0 +1,556 @@
1
+ // Copyright 2024 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 Core from '../core/core.js';
6
+ import * as Graph from '../graph/graph.js';
7
+ import type * as Lantern from '../types/types.js';
8
+
9
+ import {ConnectionPool} from './ConnectionPool.js';
10
+ import {Constants} from './Constants.js';
11
+ import {DNSCache} from './DNSCache.js';
12
+ import {type CompleteNodeTiming, type ConnectionTiming, SimulatorTimingMap} from './SimulationTimingMap.js';
13
+ import {TCPConnection} from './TCPConnection.js';
14
+
15
+ export interface Result<T = Lantern.AnyNetworkObject> {
16
+ timeInMs: number;
17
+ nodeTimings: Map<Graph.Node<T>, Lantern.Simulation.NodeTiming>;
18
+ }
19
+
20
+ const defaultThrottling = Constants.throttling.mobileSlow4G;
21
+
22
+ // see https://cs.chromium.org/search/?q=kDefaultMaxNumDelayableRequestsPerClient&sq=package:chromium&type=cs
23
+ const DEFAULT_MAXIMUM_CONCURRENT_REQUESTS = 10;
24
+ // layout tasks tend to be less CPU-bound and do not experience the same increase in duration
25
+ const DEFAULT_LAYOUT_TASK_MULTIPLIER = 0.5;
26
+ // if a task takes more than 10 seconds it's usually a sign it isn't actually CPU bound and we're overestimating
27
+ const DEFAULT_MAXIMUM_CPU_TASK_DURATION = 10000;
28
+
29
+ const NodeState = {
30
+ NotReadyToStart: 0,
31
+ ReadyToStart: 1,
32
+ InProgress: 2,
33
+ Complete: 3,
34
+ };
35
+
36
+ const PriorityStartTimePenalty: Record<Lantern.ResourcePriority, number> = {
37
+ VeryHigh: 0,
38
+ High: 0.25,
39
+ Medium: 0.5,
40
+ Low: 1,
41
+ VeryLow: 2,
42
+ };
43
+
44
+ const ALL_SIMULATION_NODE_TIMINGS = new Map<string, Map<Graph.Node, CompleteNodeTiming>>();
45
+
46
+ class Simulator<T = Lantern.AnyNetworkObject> {
47
+ static createSimulator(settings: Lantern.Simulation.Settings): Simulator {
48
+ const {throttlingMethod, throttling, precomputedLanternData, networkAnalysis} = settings;
49
+
50
+ const options: Lantern.Simulation.Options = {
51
+ additionalRttByOrigin: networkAnalysis.additionalRttByOrigin,
52
+ serverResponseTimeByOrigin: networkAnalysis.serverResponseTimeByOrigin,
53
+ observedThroughput: networkAnalysis.throughput,
54
+ };
55
+
56
+ // If we have precomputed lantern data, overwrite our observed estimates and use precomputed instead
57
+ // for increased stability.
58
+ if (precomputedLanternData) {
59
+ options.additionalRttByOrigin = new Map(Object.entries(precomputedLanternData.additionalRttByOrigin));
60
+ options.serverResponseTimeByOrigin = new Map(Object.entries(precomputedLanternData.serverResponseTimeByOrigin));
61
+ }
62
+
63
+ switch (throttlingMethod) {
64
+ case 'provided':
65
+ options.rtt = networkAnalysis.rtt;
66
+ options.throughput = networkAnalysis.throughput;
67
+ options.cpuSlowdownMultiplier = 1;
68
+ options.layoutTaskMultiplier = 1;
69
+ break;
70
+ case 'devtools':
71
+ if (throttling) {
72
+ options.rtt = throttling.requestLatencyMs / Constants.throttling.DEVTOOLS_RTT_ADJUSTMENT_FACTOR;
73
+ options.throughput =
74
+ throttling.downloadThroughputKbps * 1024 / Constants.throttling.DEVTOOLS_THROUGHPUT_ADJUSTMENT_FACTOR;
75
+ }
76
+
77
+ options.cpuSlowdownMultiplier = 1;
78
+ options.layoutTaskMultiplier = 1;
79
+ break;
80
+ case 'simulate':
81
+ if (throttling) {
82
+ options.rtt = throttling.rttMs;
83
+ options.throughput = throttling.throughputKbps * 1024;
84
+ options.cpuSlowdownMultiplier = throttling.cpuSlowdownMultiplier;
85
+ }
86
+ break;
87
+ default:
88
+ // intentionally fallback to simulator defaults
89
+ break;
90
+ }
91
+
92
+ return new Simulator(options);
93
+ }
94
+
95
+ options: Required<Lantern.Simulation.Options>;
96
+ _rtt: number;
97
+ throughput: number;
98
+ maximumConcurrentRequests: number;
99
+ cpuSlowdownMultiplier: number;
100
+ layoutTaskMultiplier: number;
101
+ cachedNodeListByStartPosition: Graph.Node[];
102
+ nodeTimings: SimulatorTimingMap;
103
+ numberInProgressByType: Map<string, number>;
104
+ nodes: Record<number, Set<Graph.Node>>;
105
+ dns: DNSCache;
106
+ connectionPool: ConnectionPool;
107
+
108
+ constructor(options?: Lantern.Simulation.Options) {
109
+ this.options = Object.assign(
110
+ {
111
+ rtt: defaultThrottling.rttMs,
112
+ throughput: defaultThrottling.throughputKbps * 1024,
113
+ maximumConcurrentRequests: DEFAULT_MAXIMUM_CONCURRENT_REQUESTS,
114
+ cpuSlowdownMultiplier: defaultThrottling.cpuSlowdownMultiplier,
115
+ layoutTaskMultiplier: DEFAULT_LAYOUT_TASK_MULTIPLIER,
116
+ additionalRttByOrigin: new Map(),
117
+ serverResponseTimeByOrigin: new Map(),
118
+ },
119
+ options,
120
+ );
121
+
122
+ this._rtt = this.options.rtt;
123
+ this.throughput = this.options.throughput;
124
+ this.maximumConcurrentRequests = Math.max(
125
+ Math.min(
126
+ TCPConnection.maximumSaturatedConnections(this._rtt, this.throughput),
127
+ this.options.maximumConcurrentRequests,
128
+ ),
129
+ 1);
130
+ this.cpuSlowdownMultiplier = this.options.cpuSlowdownMultiplier;
131
+ this.layoutTaskMultiplier = this.cpuSlowdownMultiplier * this.options.layoutTaskMultiplier;
132
+ this.cachedNodeListByStartPosition = [];
133
+
134
+ // Properties reset on every `.simulate` call but duplicated here for type checking
135
+ this.nodeTimings = new SimulatorTimingMap();
136
+ this.numberInProgressByType = new Map<string, number>();
137
+ this.nodes = {};
138
+ this.dns = new DNSCache({rtt: this._rtt});
139
+ // @ts-expect-error
140
+ this.connectionPool = null;
141
+
142
+ if (!Number.isFinite(this._rtt)) {
143
+ throw new Core.LanternError(`Invalid rtt ${this._rtt}`);
144
+ }
145
+ if (!Number.isFinite(this.throughput)) {
146
+ throw new Core.LanternError(`Invalid throughput ${this.throughput}`);
147
+ }
148
+ }
149
+
150
+ get rtt(): number {
151
+ return this._rtt;
152
+ }
153
+
154
+ initializeConnectionPool(graph: Graph.Node): void {
155
+ const records: Lantern.NetworkRequest[] = [];
156
+ graph.getRootNode().traverse(node => {
157
+ if (node.type === Graph.BaseNode.types.NETWORK) {
158
+ records.push(node.request);
159
+ }
160
+ });
161
+
162
+ this.connectionPool = new ConnectionPool(records, this.options);
163
+ }
164
+
165
+ /**
166
+ * Initializes the various state data structures such _nodeTimings and the _node Sets by state.
167
+ */
168
+ initializeAuxiliaryData(): void {
169
+ this.nodeTimings = new SimulatorTimingMap();
170
+ this.numberInProgressByType = new Map();
171
+
172
+ this.nodes = {};
173
+ this.cachedNodeListByStartPosition = [];
174
+ // NOTE: We don't actually need *all* of these sets, but the clarity that each node progresses
175
+ // through the system is quite nice.
176
+ for (const state of Object.values(NodeState)) {
177
+ this.nodes[state] = new Set();
178
+ }
179
+ }
180
+
181
+ numberInProgress(type: string): number {
182
+ return this.numberInProgressByType.get(type) || 0;
183
+ }
184
+
185
+ markNodeAsReadyToStart(node: Graph.Node, queuedTime: number): void {
186
+ const nodeStartPosition = Simulator.computeNodeStartPosition(node);
187
+ const firstNodeIndexWithGreaterStartPosition = this.cachedNodeListByStartPosition.findIndex(
188
+ candidate => Simulator.computeNodeStartPosition(candidate) > nodeStartPosition);
189
+ const insertionIndex = firstNodeIndexWithGreaterStartPosition === -1 ? this.cachedNodeListByStartPosition.length :
190
+ firstNodeIndexWithGreaterStartPosition;
191
+ this.cachedNodeListByStartPosition.splice(insertionIndex, 0, node);
192
+
193
+ this.nodes[NodeState.ReadyToStart].add(node);
194
+ this.nodes[NodeState.NotReadyToStart].delete(node);
195
+ this.nodeTimings.setReadyToStart(node, {queuedTime});
196
+ }
197
+
198
+ markNodeAsInProgress(node: Graph.Node, startTime: number): void {
199
+ const indexOfNodeToStart = this.cachedNodeListByStartPosition.indexOf(node);
200
+ this.cachedNodeListByStartPosition.splice(indexOfNodeToStart, 1);
201
+
202
+ this.nodes[NodeState.InProgress].add(node);
203
+ this.nodes[NodeState.ReadyToStart].delete(node);
204
+ this.numberInProgressByType.set(node.type, this.numberInProgress(node.type) + 1);
205
+ this.nodeTimings.setInProgress(node, {startTime});
206
+ }
207
+
208
+ markNodeAsComplete(node: Graph.Node, endTime: number, connectionTiming?: ConnectionTiming): void {
209
+ this.nodes[NodeState.Complete].add(node);
210
+ this.nodes[NodeState.InProgress].delete(node);
211
+ this.numberInProgressByType.set(node.type, this.numberInProgress(node.type) - 1);
212
+ this.nodeTimings.setCompleted(node, {endTime, connectionTiming});
213
+
214
+ // Try to add all its dependents to the queue
215
+ for (const dependent of node.getDependents()) {
216
+ // Skip dependent node if one of its dependencies hasn't finished yet
217
+ const dependencies = dependent.getDependencies();
218
+ if (dependencies.some(dep => !this.nodes[NodeState.Complete].has(dep))) {
219
+ continue;
220
+ }
221
+
222
+ // Otherwise add it to the queue
223
+ this.markNodeAsReadyToStart(dependent, endTime);
224
+ }
225
+ }
226
+
227
+ acquireConnection(request: Lantern.NetworkRequest): TCPConnection|null {
228
+ return this.connectionPool.acquire(request);
229
+ }
230
+
231
+ getNodesSortedByStartPosition(): Graph.Node[] {
232
+ // Make a copy so we don't skip nodes due to concurrent modification
233
+ return Array.from(this.cachedNodeListByStartPosition);
234
+ }
235
+
236
+ startNodeIfPossible(node: Graph.Node, totalElapsedTime: number): void {
237
+ if (node.type === Graph.BaseNode.types.CPU) {
238
+ // Start a CPU task if there's no other CPU task in process
239
+ if (this.numberInProgress(node.type) === 0) {
240
+ this.markNodeAsInProgress(node, totalElapsedTime);
241
+ }
242
+
243
+ return;
244
+ }
245
+
246
+ if (node.type !== Graph.BaseNode.types.NETWORK) {
247
+ throw new Core.LanternError('Unsupported');
248
+ }
249
+
250
+ // If a network request is connectionless, we can always start it, so skip the connection checks
251
+ if (!node.isConnectionless) {
252
+ // Start a network request if we're not at max requests and a connection is available
253
+ const numberOfActiveRequests = this.numberInProgress(node.type);
254
+ if (numberOfActiveRequests >= this.maximumConcurrentRequests) {
255
+ return;
256
+ }
257
+ const connection = this.acquireConnection(node.request);
258
+ if (!connection) {
259
+ return;
260
+ }
261
+ }
262
+
263
+ this.markNodeAsInProgress(node, totalElapsedTime);
264
+ }
265
+
266
+ /**
267
+ * Updates each connection in use with the available throughput based on the number of network requests
268
+ * currently in flight.
269
+ */
270
+ updateNetworkCapacity(): void {
271
+ const inFlight = this.numberInProgress(Graph.BaseNode.types.NETWORK);
272
+ if (inFlight === 0) {
273
+ return;
274
+ }
275
+
276
+ for (const connection of this.connectionPool.connectionsInUse()) {
277
+ connection.setThroughput(this.throughput / inFlight);
278
+ }
279
+ }
280
+
281
+ /**
282
+ * Estimates the number of milliseconds remaining given current conditions before the node is complete.
283
+ */
284
+ estimateTimeRemaining(node: Graph.Node): number {
285
+ if (node.type === Graph.BaseNode.types.CPU) {
286
+ return this.estimateCPUTimeRemaining(node);
287
+ }
288
+ if (node.type === Graph.BaseNode.types.NETWORK) {
289
+ return this.estimateNetworkTimeRemaining(node);
290
+ }
291
+ throw new Core.LanternError('Unsupported');
292
+ }
293
+
294
+ estimateCPUTimeRemaining(cpuNode: Graph.CPUNode): number {
295
+ const timingData = this.nodeTimings.getCpuStarted(cpuNode);
296
+ const multiplier = cpuNode.didPerformLayout() ? this.layoutTaskMultiplier : this.cpuSlowdownMultiplier;
297
+ const totalDuration = Math.min(
298
+ Math.round(cpuNode.duration / 1000 * multiplier),
299
+ DEFAULT_MAXIMUM_CPU_TASK_DURATION,
300
+ );
301
+ const estimatedTimeElapsed = totalDuration - timingData.timeElapsed;
302
+ this.nodeTimings.setCpuEstimated(cpuNode, {estimatedTimeElapsed});
303
+ return estimatedTimeElapsed;
304
+ }
305
+
306
+ estimateNetworkTimeRemaining(networkNode: Graph.NetworkNode): number {
307
+ const request = networkNode.request;
308
+ const timingData = this.nodeTimings.getNetworkStarted(networkNode);
309
+
310
+ let timeElapsed = 0;
311
+ if (networkNode.fromDiskCache) {
312
+ // Rough access time for seeking to location on disk and reading sequentially.
313
+ // 8ms per seek + 20ms/MB
314
+ // @see http://norvig.com/21-days.html#answers
315
+ const sizeInMb = (request.resourceSize || 0) / 1024 / 1024;
316
+ timeElapsed = 8 + 20 * sizeInMb - timingData.timeElapsed;
317
+ } else if (networkNode.isNonNetworkProtocol) {
318
+ // Estimates for the overhead of a data URL in Chromium and the decoding time for base64-encoded data.
319
+ // 2ms per request + 10ms/MB
320
+ // @see traces on https://dopiaza.org/tools/datauri/examples/index.php
321
+ const sizeInMb = (request.resourceSize || 0) / 1024 / 1024;
322
+ timeElapsed = 2 + 10 * sizeInMb - timingData.timeElapsed;
323
+ } else {
324
+ const connection = this.connectionPool.acquireActiveConnectionFromRequest(request);
325
+ const dnsResolutionTime = this.dns.getTimeUntilResolution(request, {
326
+ requestedAt: timingData.startTime,
327
+ shouldUpdateCache: true,
328
+ });
329
+ const timeAlreadyElapsed = timingData.timeElapsed;
330
+ const calculation = connection.simulateDownloadUntil(
331
+ request.transferSize - timingData.bytesDownloaded,
332
+ {timeAlreadyElapsed, dnsResolutionTime, maximumTimeToElapse: Infinity},
333
+ );
334
+
335
+ timeElapsed = calculation.timeElapsed;
336
+ }
337
+
338
+ const estimatedTimeElapsed = timeElapsed + timingData.timeElapsedOvershoot;
339
+ this.nodeTimings.setNetworkEstimated(networkNode, {estimatedTimeElapsed});
340
+ return estimatedTimeElapsed;
341
+ }
342
+
343
+ /**
344
+ * Computes and returns the minimum estimated completion time of the nodes currently in progress.
345
+ */
346
+ findNextNodeCompletionTime(): number {
347
+ let minimumTime = Infinity;
348
+ for (const node of this.nodes[NodeState.InProgress]) {
349
+ minimumTime = Math.min(minimumTime, this.estimateTimeRemaining(node));
350
+ }
351
+
352
+ return minimumTime;
353
+ }
354
+
355
+ /**
356
+ * Given a time period, computes the progress toward completion that the node made during that time.
357
+ */
358
+ updateProgressMadeInTimePeriod(node: Graph.Node, timePeriodLength: number, totalElapsedTime: number): void {
359
+ const timingData = this.nodeTimings.getInProgress(node);
360
+ const isFinished = timingData.estimatedTimeElapsed === timePeriodLength;
361
+
362
+ if (node.type === Graph.BaseNode.types.CPU || node.isConnectionless) {
363
+ if (isFinished) {
364
+ this.markNodeAsComplete(node, totalElapsedTime);
365
+ } else {
366
+ timingData.timeElapsed += timePeriodLength;
367
+ }
368
+ return;
369
+ }
370
+
371
+ if (node.type !== Graph.BaseNode.types.NETWORK) {
372
+ throw new Core.LanternError('Unsupported');
373
+ }
374
+ if (!('bytesDownloaded' in timingData)) {
375
+ throw new Core.LanternError('Invalid timing data');
376
+ }
377
+
378
+ const request = node.request;
379
+ const connection = this.connectionPool.acquireActiveConnectionFromRequest(request);
380
+ const dnsResolutionTime = this.dns.getTimeUntilResolution(request, {
381
+ requestedAt: timingData.startTime,
382
+ shouldUpdateCache: true,
383
+ });
384
+ const calculation = connection.simulateDownloadUntil(
385
+ request.transferSize - timingData.bytesDownloaded,
386
+ {
387
+ dnsResolutionTime,
388
+ timeAlreadyElapsed: timingData.timeElapsed,
389
+ maximumTimeToElapse: timePeriodLength - timingData.timeElapsedOvershoot,
390
+ },
391
+ );
392
+
393
+ connection.setCongestionWindow(calculation.congestionWindow);
394
+ connection.setH2OverflowBytesDownloaded(calculation.extraBytesDownloaded);
395
+
396
+ if (isFinished) {
397
+ connection.setWarmed(true);
398
+ this.connectionPool.release(request);
399
+ this.markNodeAsComplete(node, totalElapsedTime, calculation.connectionTiming);
400
+ } else {
401
+ timingData.timeElapsed += calculation.timeElapsed;
402
+ timingData.timeElapsedOvershoot += calculation.timeElapsed - timePeriodLength;
403
+ timingData.bytesDownloaded += calculation.bytesDownloaded;
404
+ }
405
+ }
406
+
407
+ computeFinalNodeTimings(): {
408
+ nodeTimings: Map<Graph.Node, Lantern.Simulation.NodeTiming>,
409
+ completeNodeTimings: Map<Graph.Node, CompleteNodeTiming>,
410
+ } {
411
+ const completeNodeTimingEntries: Array<[Graph.Node, CompleteNodeTiming]> = this.nodeTimings.getNodes().map(node => {
412
+ return [node, this.nodeTimings.getCompleted(node)];
413
+ });
414
+
415
+ // Most consumers will want the entries sorted by startTime, so insert them in that order
416
+ completeNodeTimingEntries.sort((a, b) => a[1].startTime - b[1].startTime);
417
+
418
+ // Trimmed version of type `Lantern.Simulation.NodeTiming`.
419
+ const nodeTimingEntries: Array<[Graph.Node, Lantern.Simulation.NodeTiming]> =
420
+ completeNodeTimingEntries.map(([node, timing]) => {
421
+ return [
422
+ node,
423
+ {
424
+ startTime: timing.startTime,
425
+ endTime: timing.endTime,
426
+ duration: timing.endTime - timing.startTime,
427
+ },
428
+ ];
429
+ });
430
+
431
+ return {
432
+ nodeTimings: new Map(nodeTimingEntries),
433
+ completeNodeTimings: new Map(completeNodeTimingEntries),
434
+ };
435
+ }
436
+
437
+ getOptions(): Required<Lantern.Simulation.Options> {
438
+ return this.options;
439
+ }
440
+
441
+ /**
442
+ * Estimates the time taken to process all of the graph's nodes, returns the overall time along with
443
+ * each node annotated by start/end times.
444
+ *
445
+ * Simulator/connection pool are allowed to deviate from what was
446
+ * observed in the trace/devtoolsLog and start requests as soon as they are queued (i.e. do not
447
+ * wait around for a warm connection to be available if the original request was fetched on a warm
448
+ * connection).
449
+ */
450
+ simulate(graph: Graph.Node, options?: {label?: string}): Result<T> {
451
+ if (Graph.BaseNode.findCycle(graph)) {
452
+ throw new Core.LanternError('Cannot simulate graph with cycle');
453
+ }
454
+
455
+ options = Object.assign(
456
+ {
457
+ label: undefined,
458
+ },
459
+ options);
460
+
461
+ // initialize the necessary data containers
462
+ this.dns = new DNSCache({rtt: this._rtt});
463
+ this.initializeConnectionPool(graph);
464
+ this.initializeAuxiliaryData();
465
+
466
+ const nodesNotReadyToStart = this.nodes[NodeState.NotReadyToStart];
467
+ const nodesReadyToStart = this.nodes[NodeState.ReadyToStart];
468
+ const nodesInProgress = this.nodes[NodeState.InProgress];
469
+
470
+ const rootNode = graph.getRootNode();
471
+ rootNode.traverse(node => nodesNotReadyToStart.add(node));
472
+ let totalElapsedTime = 0;
473
+ let iteration = 0;
474
+
475
+ // root node is always ready to start
476
+ this.markNodeAsReadyToStart(rootNode, totalElapsedTime);
477
+
478
+ // loop as long as we have nodes in the queue or currently in progress
479
+ while (nodesReadyToStart.size || nodesInProgress.size) {
480
+ // move all possible queued nodes to in progress
481
+ for (const node of this.getNodesSortedByStartPosition()) {
482
+ this.startNodeIfPossible(node, totalElapsedTime);
483
+ }
484
+
485
+ if (!nodesInProgress.size) {
486
+ // Interplay between fromDiskCache and connectionReused can be incorrect,
487
+ // have to give up.
488
+ throw new Core.LanternError('Failed to start a node');
489
+ }
490
+
491
+ // set the available throughput for all connections based on # in-flight
492
+ this.updateNetworkCapacity();
493
+
494
+ // find the time that the next node will finish
495
+ const minimumTime = this.findNextNodeCompletionTime();
496
+ totalElapsedTime += minimumTime;
497
+
498
+ // While this is no longer strictly necessary, it's always better than hanging
499
+ if (!Number.isFinite(minimumTime) || iteration > 100000) {
500
+ throw new Core.LanternError('Simulation failed, depth exceeded');
501
+ }
502
+
503
+ iteration++;
504
+ // update how far each node will progress until that point
505
+ for (const node of nodesInProgress) {
506
+ this.updateProgressMadeInTimePeriod(node, minimumTime, totalElapsedTime);
507
+ }
508
+ }
509
+
510
+ // `nodeTimings` are used for simulator consumers, `completeNodeTimings` kept for debugging.
511
+ const {nodeTimings, completeNodeTimings} = this.computeFinalNodeTimings();
512
+ ALL_SIMULATION_NODE_TIMINGS.set(options.label || 'unlabeled', completeNodeTimings);
513
+
514
+ return {
515
+ timeInMs: totalElapsedTime,
516
+ nodeTimings,
517
+ };
518
+ }
519
+
520
+ computeWastedMsFromWastedBytes(wastedBytes: number): number {
521
+ const {throughput, observedThroughput} = this.options;
522
+
523
+ // https://github.com/GoogleChrome/lighthouse/pull/13323#issuecomment-962031709
524
+ // 0 throughput means the no (additional) throttling is expected.
525
+ // This is common for desktop + devtools throttling where throttling is additive and we don't want any additional.
526
+ const bitsPerSecond = throughput === 0 ? observedThroughput : throughput;
527
+ if (bitsPerSecond === 0) {
528
+ return 0;
529
+ }
530
+
531
+ const wastedBits = wastedBytes * 8;
532
+ const wastedMs = wastedBits / bitsPerSecond * 1000;
533
+
534
+ // This is an estimate of wasted time, so we won't be more precise than 10ms.
535
+ return Math.round(wastedMs / 10) * 10;
536
+ }
537
+
538
+ // Used by Lighthouse asset-saver
539
+ static get allNodeTimings(): Map<string, Map<Graph.Node, CompleteNodeTiming>> {
540
+ return ALL_SIMULATION_NODE_TIMINGS;
541
+ }
542
+
543
+ /**
544
+ * We attempt to start nodes by their observed start time using the request priority as a tie breaker.
545
+ * When simulating, just because a low priority image started 5ms before a high priority image doesn't mean
546
+ * it would have happened like that when the network was slower.
547
+ */
548
+ static computeNodeStartPosition(node: Graph.Node): number {
549
+ if (node.type === 'cpu') {
550
+ return node.startTime;
551
+ }
552
+ return node.startTime + (PriorityStartTimePenalty[node.request.priority] * 1000 * 1000 || 0);
553
+ }
554
+ }
555
+
556
+ export {Simulator};