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,808 @@
1
+ // Copyright 2011 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 Protocol from '../../generated/protocol.js';
6
+ import * as Common from '../common/common.js';
7
+ import * as Host from '../host/host.js';
8
+ import * as i18n from '../i18n/i18n.js';
9
+ import * as Platform from '../platform/platform.js';
10
+
11
+ import {FrontendMessageType} from './ConsoleModelTypes.js';
12
+ import {CPUProfilerModel, type EventData, Events as CPUProfilerModelEvents} from './CPUProfilerModel.js';
13
+ import {
14
+ BreakpointType,
15
+ COND_BREAKPOINT_SOURCE_URL,
16
+ Events as DebuggerModelEvents,
17
+ type Location,
18
+ LOGPOINT_SOURCE_URL,
19
+ } from './DebuggerModel.js';
20
+ import {LogModel} from './LogModel.js';
21
+ import {RemoteObject} from './RemoteObject.js';
22
+ import {
23
+ Events as ResourceTreeModelEvents,
24
+ type PrimaryPageChangeType,
25
+ type ResourceTreeFrame,
26
+ ResourceTreeModel,
27
+ } from './ResourceTreeModel.js';
28
+ import {
29
+ type ConsoleAPICall,
30
+ Events as RuntimeModelEvents,
31
+ type ExceptionWithTimestamp,
32
+ type ExecutionContext,
33
+ type QueryObjectRequestedEvent,
34
+ RuntimeModel,
35
+ } from './RuntimeModel.js';
36
+ import {SDKModel} from './SDKModel.js';
37
+ import {Capability, type Target, Type} from './Target.js';
38
+ import {TargetManager} from './TargetManager.js';
39
+
40
+ export {FrontendMessageType} from './ConsoleModelTypes.js';
41
+
42
+ const UIStrings = {
43
+ /**
44
+ * @description Text shown when the main frame (page) of the website was navigated to a different URL.
45
+ * @example {https://example.com} PH1
46
+ */
47
+ navigatedToS: 'Navigated to {PH1}',
48
+ /**
49
+ * @description Text shown when the main frame (page) of the website was navigated to a different URL
50
+ * and the page was restored from back/forward cache (https://web.dev/bfcache/).
51
+ * @example {https://example.com} PH1
52
+ */
53
+ bfcacheNavigation: 'Navigation to {PH1} was restored from back/forward cache (see https://web.dev/bfcache/)',
54
+ /**
55
+ * @description Text shown in the console when a performance profile (with the given name) was started.
56
+ * @example {title} PH1
57
+ */
58
+ profileSStarted: 'Profile \'\'{PH1}\'\' started.',
59
+ /**
60
+ * @description Text shown in the console when a performance profile (with the given name) was stopped.
61
+ * @example {name} PH1
62
+ */
63
+ profileSFinished: 'Profile \'\'{PH1}\'\' finished.',
64
+ /**
65
+ * @description Error message shown in the console after the user tries to save a JavaScript value to a temporary variable.
66
+ */
67
+ failedToSaveToTempVariable: 'Failed to save to temp variable.',
68
+ } as const;
69
+
70
+ const str_ = i18n.i18n.registerUIStrings('core/sdk/ConsoleModel.ts', UIStrings);
71
+ const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
72
+
73
+ export class ConsoleModel extends SDKModel<EventTypes> {
74
+ #messages: ConsoleMessage[] = [];
75
+ readonly #messagesByTimestamp = new Platform.MapUtilities.Multimap<number, ConsoleMessage>();
76
+ readonly #messageByExceptionId = new Map<RuntimeModel, Map<number, ConsoleMessage>>();
77
+ #warnings = 0;
78
+ #errors = 0;
79
+ #violations = 0;
80
+ #pageLoadSequenceNumber = 0;
81
+ readonly #targetListeners = new WeakMap<Target, Common.EventTarget.EventDescriptor[]>();
82
+
83
+ constructor(target: Target) {
84
+ super(target);
85
+
86
+ const resourceTreeModel = target.model(ResourceTreeModel);
87
+ if (!resourceTreeModel || resourceTreeModel.cachedResourcesLoaded()) {
88
+ this.initTarget(target);
89
+ return;
90
+ }
91
+
92
+ const eventListener = resourceTreeModel.addEventListener(ResourceTreeModelEvents.CachedResourcesLoaded, () => {
93
+ Common.EventTarget.removeEventListeners([eventListener]);
94
+ this.initTarget(target);
95
+ });
96
+ }
97
+
98
+ private initTarget(target: Target): void {
99
+ const eventListeners = [];
100
+
101
+ const cpuProfilerModel = target.model(CPUProfilerModel);
102
+ if (cpuProfilerModel) {
103
+ eventListeners.push(cpuProfilerModel.addEventListener(
104
+ CPUProfilerModelEvents.CONSOLE_PROFILE_STARTED, this.consoleProfileStarted.bind(this, cpuProfilerModel)));
105
+ eventListeners.push(cpuProfilerModel.addEventListener(
106
+ CPUProfilerModelEvents.CONSOLE_PROFILE_FINISHED, this.consoleProfileFinished.bind(this, cpuProfilerModel)));
107
+ }
108
+
109
+ const resourceTreeModel = target.model(ResourceTreeModel);
110
+ if (resourceTreeModel && target.parentTarget()?.type() !== Type.FRAME) {
111
+ eventListeners.push(resourceTreeModel.addEventListener(
112
+ ResourceTreeModelEvents.PrimaryPageChanged, this.primaryPageChanged, this));
113
+ }
114
+
115
+ const runtimeModel = target.model(RuntimeModel);
116
+ if (runtimeModel) {
117
+ eventListeners.push(runtimeModel.addEventListener(
118
+ RuntimeModelEvents.ExceptionThrown, this.exceptionThrown.bind(this, runtimeModel)));
119
+ eventListeners.push(runtimeModel.addEventListener(
120
+ RuntimeModelEvents.ExceptionRevoked, this.exceptionRevoked.bind(this, runtimeModel)));
121
+ eventListeners.push(runtimeModel.addEventListener(
122
+ RuntimeModelEvents.ConsoleAPICalled, this.consoleAPICalled.bind(this, runtimeModel)));
123
+ if (target.parentTarget()?.type() !== Type.FRAME) {
124
+ eventListeners.push(runtimeModel.debuggerModel().addEventListener(
125
+ DebuggerModelEvents.GlobalObjectCleared, this.clearIfNecessary, this));
126
+ }
127
+ eventListeners.push(runtimeModel.addEventListener(
128
+ RuntimeModelEvents.QueryObjectRequested, this.queryObjectRequested.bind(this, runtimeModel)));
129
+ }
130
+
131
+ this.#targetListeners.set(target, eventListeners);
132
+ }
133
+
134
+ targetRemoved(target: Target): void {
135
+ const runtimeModel = target.model(RuntimeModel);
136
+ if (runtimeModel) {
137
+ this.#messageByExceptionId.delete(runtimeModel);
138
+ }
139
+ Common.EventTarget.removeEventListeners(this.#targetListeners.get(target) || []);
140
+ }
141
+
142
+ async evaluateCommandInConsole(
143
+ executionContext: ExecutionContext, originatingMessage: ConsoleMessage, expression: string,
144
+ useCommandLineAPI: boolean): Promise<void> {
145
+ const result = await executionContext.evaluate(
146
+ {
147
+ expression,
148
+ objectGroup: 'console',
149
+ includeCommandLineAPI: useCommandLineAPI,
150
+ silent: false,
151
+ returnByValue: false,
152
+ generatePreview: true,
153
+ replMode: true,
154
+ allowUnsafeEvalBlockedByCSP: false,
155
+ },
156
+ Common.Settings.Settings.instance().moduleSetting('console-user-activation-eval').get(),
157
+ /* awaitPromise */ false);
158
+ Host.userMetrics.actionTaken(Host.UserMetrics.Action.ConsoleEvaluated);
159
+ if ('error' in result) {
160
+ return;
161
+ }
162
+ await Common.Console.Console.instance().showPromise();
163
+ this.dispatchEventToListeners(
164
+ Events.CommandEvaluated,
165
+ {result: result.object, commandMessage: originatingMessage, exceptionDetails: result.exceptionDetails});
166
+ }
167
+
168
+ addCommandMessage(executionContext: ExecutionContext, text: string): ConsoleMessage {
169
+ const commandMessage = new ConsoleMessage(
170
+ executionContext.runtimeModel, Protocol.Log.LogEntrySource.Javascript, null, text,
171
+ {type: FrontendMessageType.Command});
172
+ commandMessage.setExecutionContextId(executionContext.id);
173
+ this.addMessage(commandMessage);
174
+ return commandMessage;
175
+ }
176
+
177
+ addMessage(msg: ConsoleMessage): void {
178
+ msg.setPageLoadSequenceNumber(this.#pageLoadSequenceNumber);
179
+ if (msg.source === Common.Console.FrontendMessageSource.ConsoleAPI &&
180
+ msg.type === Protocol.Runtime.ConsoleAPICalledEventType.Clear) {
181
+ this.clearIfNecessary();
182
+ }
183
+
184
+ this.#messages.push(msg);
185
+ this.#messagesByTimestamp.set(msg.timestamp, msg);
186
+ const runtimeModel = msg.runtimeModel();
187
+ const exceptionId = msg.getExceptionId();
188
+ if (exceptionId && runtimeModel) {
189
+ let modelMap = this.#messageByExceptionId.get(runtimeModel);
190
+ if (!modelMap) {
191
+ modelMap = new Map();
192
+ this.#messageByExceptionId.set(runtimeModel, modelMap);
193
+ }
194
+ modelMap.set(exceptionId, msg);
195
+ }
196
+ this.incrementErrorWarningCount(msg);
197
+ this.dispatchEventToListeners(Events.MessageAdded, msg);
198
+ }
199
+
200
+ private exceptionThrown(
201
+ runtimeModel: RuntimeModel, event: Common.EventTarget.EventTargetEvent<ExceptionWithTimestamp>): void {
202
+ const exceptionWithTimestamp = event.data;
203
+ const affectedResources = extractExceptionMetaData(exceptionWithTimestamp.details.exceptionMetaData);
204
+ const consoleMessage = ConsoleMessage.fromException(
205
+ runtimeModel, exceptionWithTimestamp.details, undefined, exceptionWithTimestamp.timestamp, undefined,
206
+ affectedResources);
207
+ consoleMessage.setExceptionId(exceptionWithTimestamp.details.exceptionId);
208
+ this.addMessage(consoleMessage);
209
+ }
210
+
211
+ private exceptionRevoked(runtimeModel: RuntimeModel, event: Common.EventTarget.EventTargetEvent<number>): void {
212
+ const exceptionId = event.data;
213
+ const modelMap = this.#messageByExceptionId.get(runtimeModel);
214
+ const exceptionMessage = modelMap ? modelMap.get(exceptionId) : null;
215
+ if (!exceptionMessage) {
216
+ return;
217
+ }
218
+ this.#errors--;
219
+ exceptionMessage.level = Protocol.Log.LogEntryLevel.Verbose;
220
+ this.dispatchEventToListeners(Events.MessageUpdated, exceptionMessage);
221
+ }
222
+
223
+ private consoleAPICalled(runtimeModel: RuntimeModel, event: Common.EventTarget.EventTargetEvent<ConsoleAPICall>):
224
+ void {
225
+ const call = event.data;
226
+ let level: Protocol.Log.LogEntryLevel = Protocol.Log.LogEntryLevel.Info;
227
+ if (call.type === Protocol.Runtime.ConsoleAPICalledEventType.Debug) {
228
+ level = Protocol.Log.LogEntryLevel.Verbose;
229
+ } else if (
230
+ call.type === Protocol.Runtime.ConsoleAPICalledEventType.Error ||
231
+ call.type === Protocol.Runtime.ConsoleAPICalledEventType.Assert) {
232
+ level = Protocol.Log.LogEntryLevel.Error;
233
+ } else if (call.type === Protocol.Runtime.ConsoleAPICalledEventType.Warning) {
234
+ level = Protocol.Log.LogEntryLevel.Warning;
235
+ } else if (
236
+ call.type === Protocol.Runtime.ConsoleAPICalledEventType.Info ||
237
+ call.type === Protocol.Runtime.ConsoleAPICalledEventType.Log) {
238
+ level = Protocol.Log.LogEntryLevel.Info;
239
+ }
240
+ let message = '';
241
+ if (call.args.length && call.args[0].unserializableValue) {
242
+ message = call.args[0].unserializableValue;
243
+ } else if (
244
+ call.args.length &&
245
+ ((typeof call.args[0].value !== 'object' && typeof call.args[0].value !== 'undefined') ||
246
+ call.args[0].value === null)) {
247
+ message = String(call.args[0].value);
248
+ } else if (call.args.length && call.args[0].description) {
249
+ message = call.args[0].description;
250
+ }
251
+ const callFrame = call.stackTrace?.callFrames.length ? call.stackTrace.callFrames[0] : null;
252
+ const details = {
253
+ type: call.type,
254
+ url: callFrame?.url as Platform.DevToolsPath.UrlString | undefined,
255
+ line: callFrame?.lineNumber,
256
+ column: callFrame?.columnNumber,
257
+ parameters: call.args,
258
+ stackTrace: call.stackTrace,
259
+ timestamp: call.timestamp,
260
+ executionContextId: call.executionContextId,
261
+ context: call.context,
262
+ };
263
+ const consoleMessage =
264
+ new ConsoleMessage(runtimeModel, Common.Console.FrontendMessageSource.ConsoleAPI, level, (message), details);
265
+ for (const msg of this.#messagesByTimestamp.get(consoleMessage.timestamp).values()) {
266
+ if (consoleMessage.isEqual(msg)) {
267
+ return;
268
+ }
269
+ }
270
+ this.addMessage(consoleMessage);
271
+ }
272
+
273
+ private queryObjectRequested(
274
+ runtimeModel: RuntimeModel, event: Common.EventTarget.EventTargetEvent<QueryObjectRequestedEvent>): void {
275
+ const {objects, executionContextId} = event.data;
276
+ const details = {
277
+ type: FrontendMessageType.QueryObjectResult,
278
+ parameters: [objects],
279
+ executionContextId,
280
+ };
281
+ const consoleMessage = new ConsoleMessage(
282
+ runtimeModel, Common.Console.FrontendMessageSource.ConsoleAPI, Protocol.Log.LogEntryLevel.Info, '', details);
283
+ this.addMessage(consoleMessage);
284
+ }
285
+
286
+ private clearIfNecessary(): void {
287
+ if (!Common.Settings.Settings.instance().moduleSetting('preserve-console-log').get()) {
288
+ this.clear();
289
+ }
290
+ ++this.#pageLoadSequenceNumber;
291
+ }
292
+
293
+ private primaryPageChanged(
294
+ event: Common.EventTarget.EventTargetEvent<{frame: ResourceTreeFrame, type: PrimaryPageChangeType}>): void {
295
+ if (Common.Settings.Settings.instance().moduleSetting('preserve-console-log').get()) {
296
+ const {frame} = event.data;
297
+ if (frame.backForwardCacheDetails.restoredFromCache) {
298
+ Common.Console.Console.instance().log(i18nString(UIStrings.bfcacheNavigation, {PH1: frame.url}));
299
+ } else {
300
+ Common.Console.Console.instance().log(i18nString(UIStrings.navigatedToS, {PH1: frame.url}));
301
+ }
302
+ }
303
+ }
304
+
305
+ private consoleProfileStarted(
306
+ cpuProfilerModel: CPUProfilerModel, event: Common.EventTarget.EventTargetEvent<EventData>): void {
307
+ const {data} = event;
308
+ this.addConsoleProfileMessage(
309
+ cpuProfilerModel, Protocol.Runtime.ConsoleAPICalledEventType.Profile, data.scriptLocation,
310
+ i18nString(UIStrings.profileSStarted, {PH1: data.title}));
311
+ }
312
+
313
+ private consoleProfileFinished(
314
+ cpuProfilerModel: CPUProfilerModel, event: Common.EventTarget.EventTargetEvent<EventData>): void {
315
+ const {data} = event;
316
+ this.addConsoleProfileMessage(
317
+ cpuProfilerModel, Protocol.Runtime.ConsoleAPICalledEventType.ProfileEnd, data.scriptLocation,
318
+ i18nString(UIStrings.profileSFinished, {PH1: data.title}));
319
+ }
320
+
321
+ private addConsoleProfileMessage(
322
+ cpuProfilerModel: CPUProfilerModel, type: MessageType, scriptLocation: Location, messageText: string): void {
323
+ const script = scriptLocation.script();
324
+ const callFrames = [{
325
+ functionName: '',
326
+ scriptId: scriptLocation.scriptId,
327
+ url: script ? script.contentURL() : '',
328
+ lineNumber: scriptLocation.lineNumber,
329
+ columnNumber: scriptLocation.columnNumber || 0,
330
+ }];
331
+ this.addMessage(new ConsoleMessage(
332
+ cpuProfilerModel.runtimeModel(), Common.Console.FrontendMessageSource.ConsoleAPI,
333
+ Protocol.Log.LogEntryLevel.Info, messageText, {type, stackTrace: {callFrames}}));
334
+ }
335
+
336
+ private incrementErrorWarningCount(msg: ConsoleMessage): void {
337
+ if (msg.source === Protocol.Log.LogEntrySource.Violation) {
338
+ this.#violations++;
339
+ return;
340
+ }
341
+ switch (msg.level) {
342
+ case Protocol.Log.LogEntryLevel.Warning:
343
+ this.#warnings++;
344
+ break;
345
+ case Protocol.Log.LogEntryLevel.Error:
346
+ this.#errors++;
347
+ break;
348
+ }
349
+ }
350
+
351
+ messages(): ConsoleMessage[] {
352
+ return this.#messages;
353
+ }
354
+
355
+ // messages[] are not ordered by timestamp.
356
+ static allMessagesUnordered(): ConsoleMessage[] {
357
+ const messages = [];
358
+ for (const target of TargetManager.instance().targets()) {
359
+ const targetMessages = target.model(ConsoleModel)?.messages() || [];
360
+ messages.push(...targetMessages);
361
+ }
362
+ return messages;
363
+ }
364
+
365
+ static requestClearMessages(): void {
366
+ for (const logModel of TargetManager.instance().models(LogModel)) {
367
+ logModel.requestClear();
368
+ }
369
+ for (const runtimeModel of TargetManager.instance().models(RuntimeModel)) {
370
+ runtimeModel.discardConsoleEntries();
371
+ // Runtime.discardConsoleEntries implies Runtime.releaseObjectGroup('console').
372
+ runtimeModel.releaseObjectGroup('live-expression');
373
+ }
374
+ for (const target of TargetManager.instance().targets()) {
375
+ target.model(ConsoleModel)?.clear();
376
+ }
377
+ }
378
+
379
+ private clear(): void {
380
+ this.#messages = [];
381
+ this.#messagesByTimestamp.clear();
382
+ this.#messageByExceptionId.clear();
383
+ this.#errors = 0;
384
+ this.#warnings = 0;
385
+ this.#violations = 0;
386
+ this.dispatchEventToListeners(Events.ConsoleCleared);
387
+ }
388
+
389
+ errors(): number {
390
+ return this.#errors;
391
+ }
392
+
393
+ static allErrors(): number {
394
+ let errors = 0;
395
+ for (const target of TargetManager.instance().targets()) {
396
+ errors += target.model(ConsoleModel)?.errors() || 0;
397
+ }
398
+ return errors;
399
+ }
400
+
401
+ warnings(): number {
402
+ return this.#warnings;
403
+ }
404
+
405
+ static allWarnings(): number {
406
+ let warnings = 0;
407
+ for (const target of TargetManager.instance().targets()) {
408
+ warnings += target.model(ConsoleModel)?.warnings() || 0;
409
+ }
410
+ return warnings;
411
+ }
412
+
413
+ violations(): number {
414
+ return this.#violations;
415
+ }
416
+
417
+ async saveToTempVariable(currentExecutionContext: ExecutionContext|null, remoteObject: RemoteObject|null):
418
+ Promise<void> {
419
+ if (!remoteObject || !currentExecutionContext) {
420
+ failedToSave(null);
421
+ return;
422
+ }
423
+ const executionContext = (currentExecutionContext);
424
+
425
+ const result = await executionContext.globalObject(/* objectGroup */ '', /* generatePreview */ false);
426
+ if ('error' in result || Boolean(result.exceptionDetails) || !result.object) {
427
+ failedToSave('object' in result && result.object || null);
428
+ return;
429
+ }
430
+
431
+ const globalObject = result.object;
432
+ const callFunctionResult =
433
+ await globalObject.callFunction(saveVariable, [RemoteObject.toCallArgument(remoteObject)]);
434
+ globalObject.release();
435
+ if (callFunctionResult.wasThrown || !callFunctionResult.object || callFunctionResult.object.type !== 'string') {
436
+ failedToSave(callFunctionResult.object || null);
437
+ } else {
438
+ const text = (callFunctionResult.object.value as string);
439
+ const message = this.addCommandMessage(executionContext, text);
440
+ void this.evaluateCommandInConsole(executionContext, message, text, /* useCommandLineAPI */ false);
441
+ }
442
+ if (callFunctionResult.object) {
443
+ callFunctionResult.object.release();
444
+ }
445
+
446
+ function saveVariable(this: Window, value: Protocol.Runtime.CallArgument): string {
447
+ const prefix = 'temp';
448
+ let index = 1;
449
+ while ((prefix + index) in this) {
450
+ ++index;
451
+ }
452
+ const name = prefix + index;
453
+ // @ts-expect-error Assignment to global object
454
+ this[name] = value;
455
+ return name;
456
+ }
457
+
458
+ function failedToSave(result: RemoteObject|null): void {
459
+ let message = i18nString(UIStrings.failedToSaveToTempVariable);
460
+ if (result) {
461
+ message = (message + ' ' + result.description as Common.UIString.LocalizedString);
462
+ }
463
+ Common.Console.Console.instance().error(message);
464
+ }
465
+ }
466
+ }
467
+
468
+ export enum Events {
469
+ /* eslint-disable @typescript-eslint/naming-convention -- Used by web_tests. */
470
+ ConsoleCleared = 'ConsoleCleared',
471
+ MessageAdded = 'MessageAdded',
472
+ MessageUpdated = 'MessageUpdated',
473
+ CommandEvaluated = 'CommandEvaluated',
474
+ /* eslint-enable @typescript-eslint/naming-convention */
475
+ }
476
+
477
+ export interface CommandEvaluatedEvent {
478
+ result: RemoteObject;
479
+ commandMessage: ConsoleMessage;
480
+ exceptionDetails?: Protocol.Runtime.ExceptionDetails|undefined;
481
+ }
482
+
483
+ export interface EventTypes {
484
+ [Events.ConsoleCleared]: void;
485
+ [Events.MessageAdded]: ConsoleMessage;
486
+ [Events.MessageUpdated]: ConsoleMessage;
487
+ [Events.CommandEvaluated]: CommandEvaluatedEvent;
488
+ }
489
+
490
+ export interface AffectedResources {
491
+ requestId?: Protocol.Network.RequestId;
492
+ issueId?: Protocol.Audits.IssueId;
493
+ }
494
+
495
+ function extractExceptionMetaData(metaData?: {
496
+ requestId?: Protocol.Network.RequestId,
497
+ issueId?: Protocol.Audits.IssueId,
498
+ }): AffectedResources|undefined {
499
+ if (!metaData) {
500
+ return undefined;
501
+ }
502
+ return {requestId: metaData.requestId || undefined, issueId: metaData.issueId || undefined};
503
+ }
504
+
505
+ function areAffectedResourcesEquivalent(a?: AffectedResources, b?: AffectedResources): boolean {
506
+ // Not considering issueId, as that would prevent de-duplication of console #messages.
507
+ return a?.requestId === b?.requestId;
508
+ }
509
+
510
+ function areStackTracesEquivalent(
511
+ stackTrace1?: Protocol.Runtime.StackTrace, stackTrace2?: Protocol.Runtime.StackTrace): boolean {
512
+ if (!stackTrace1 !== !stackTrace2) {
513
+ return false;
514
+ }
515
+ if (!stackTrace1 || !stackTrace2) {
516
+ return true;
517
+ }
518
+ const callFrames1 = stackTrace1.callFrames;
519
+ const callFrames2 = stackTrace2.callFrames;
520
+ if (callFrames1.length !== callFrames2.length) {
521
+ return false;
522
+ }
523
+ for (let i = 0, n = callFrames1.length; i < n; ++i) {
524
+ if (callFrames1[i].scriptId !== callFrames2[i].scriptId ||
525
+ callFrames1[i].functionName !== callFrames2[i].functionName ||
526
+ callFrames1[i].lineNumber !== callFrames2[i].lineNumber ||
527
+ callFrames1[i].columnNumber !== callFrames2[i].columnNumber) {
528
+ return false;
529
+ }
530
+ }
531
+ return areStackTracesEquivalent(stackTrace1.parent, stackTrace2.parent);
532
+ }
533
+
534
+ export interface ConsoleMessageDetails {
535
+ type?: MessageType;
536
+ url?: Platform.DevToolsPath.UrlString;
537
+ line?: number;
538
+ column?: number;
539
+ parameters?: Array<string|RemoteObject|Protocol.Runtime.RemoteObject>;
540
+ stackTrace?: Protocol.Runtime.StackTrace;
541
+ timestamp?: number;
542
+ executionContextId?: number;
543
+ scriptId?: Protocol.Runtime.ScriptId;
544
+ workerId?: string;
545
+ context?: string;
546
+ affectedResources?: AffectedResources;
547
+ category?: Protocol.Log.LogEntryCategory;
548
+ isCookieReportIssue?: boolean;
549
+ }
550
+
551
+ export class ConsoleMessage {
552
+ readonly #runtimeModel: RuntimeModel|null;
553
+ source: MessageSource;
554
+ level: Protocol.Log.LogEntryLevel|null;
555
+ messageText: string;
556
+ readonly type: MessageType;
557
+ url: Platform.DevToolsPath.UrlString|undefined;
558
+ line: number;
559
+ column: number;
560
+ parameters: Array<string|RemoteObject|Protocol.Runtime.RemoteObject>|undefined;
561
+ stackTrace: Protocol.Runtime.StackTrace|undefined;
562
+ timestamp: number;
563
+ #executionContextId: number;
564
+ scriptId?: Protocol.Runtime.ScriptId;
565
+ workerId?: string;
566
+ context?: string;
567
+ #originatingConsoleMessage: ConsoleMessage|null = null;
568
+ #pageLoadSequenceNumber?: number = undefined;
569
+ #exceptionId?: number = undefined;
570
+ #affectedResources?: AffectedResources;
571
+ category?: Protocol.Log.LogEntryCategory;
572
+ isCookieReportIssue = false;
573
+
574
+ /**
575
+ * The parent frame of the `console.log` call of logpoints or conditional breakpoints
576
+ * if they called `console.*` explicitly. The parent frame is where V8 paused
577
+ * and consequently where the logpoint is set.
578
+ *
579
+ * Is `null` for page console.logs, commands, command results, etc.
580
+ */
581
+ readonly stackFrameWithBreakpoint: Protocol.Runtime.CallFrame|null = null;
582
+ readonly #originatingBreakpointType: BreakpointType|null = null;
583
+
584
+ constructor(
585
+ runtimeModel: RuntimeModel|null, source: MessageSource, level: Protocol.Log.LogEntryLevel|null,
586
+ messageText: string, details?: ConsoleMessageDetails) {
587
+ this.#runtimeModel = runtimeModel;
588
+ this.source = source;
589
+ this.level = (level);
590
+ this.messageText = messageText;
591
+ this.type = details?.type || Protocol.Runtime.ConsoleAPICalledEventType.Log;
592
+ this.url = details?.url;
593
+ this.line = details?.line || 0;
594
+ this.column = details?.column || 0;
595
+ this.parameters = details?.parameters;
596
+ this.stackTrace = details?.stackTrace;
597
+ this.timestamp = details?.timestamp || Date.now();
598
+ this.#executionContextId = details?.executionContextId || 0;
599
+ this.scriptId = details?.scriptId;
600
+ this.workerId = details?.workerId;
601
+ this.#affectedResources = details?.affectedResources;
602
+ this.category = details?.category;
603
+ this.isCookieReportIssue = Boolean(details?.isCookieReportIssue);
604
+
605
+ if (!this.#executionContextId && this.#runtimeModel) {
606
+ if (this.scriptId) {
607
+ this.#executionContextId = this.#runtimeModel.executionContextIdForScriptId(this.scriptId);
608
+ } else if (this.stackTrace) {
609
+ this.#executionContextId = this.#runtimeModel.executionContextForStackTrace(this.stackTrace);
610
+ }
611
+ }
612
+
613
+ if (details?.context) {
614
+ const match = details?.context.match(/[^#]*/);
615
+ this.context = match?.[0];
616
+ }
617
+
618
+ if (this.stackTrace) {
619
+ const {callFrame, type} = ConsoleMessage.#stackFrameWithBreakpoint(this.stackTrace);
620
+ this.stackFrameWithBreakpoint = callFrame;
621
+ this.#originatingBreakpointType = type;
622
+ }
623
+ }
624
+
625
+ getAffectedResources(): AffectedResources|undefined {
626
+ return this.#affectedResources;
627
+ }
628
+
629
+ setPageLoadSequenceNumber(pageLoadSequenceNumber: number): void {
630
+ this.#pageLoadSequenceNumber = pageLoadSequenceNumber;
631
+ }
632
+
633
+ static fromException(
634
+ runtimeModel: RuntimeModel, exceptionDetails: Protocol.Runtime.ExceptionDetails,
635
+ messageType?: Protocol.Runtime.ConsoleAPICalledEventType|FrontendMessageType, timestamp?: number,
636
+ forceUrl?: Platform.DevToolsPath.UrlString, affectedResources?: AffectedResources): ConsoleMessage {
637
+ const details = {
638
+ type: messageType,
639
+ url: forceUrl || exceptionDetails.url as Platform.DevToolsPath.UrlString,
640
+ line: exceptionDetails.lineNumber,
641
+ column: exceptionDetails.columnNumber,
642
+ parameters: exceptionDetails.exception ?
643
+ [RemoteObject.fromLocalObject(exceptionDetails.text), exceptionDetails.exception] :
644
+ undefined,
645
+ stackTrace: exceptionDetails.stackTrace,
646
+ timestamp,
647
+ executionContextId: exceptionDetails.executionContextId,
648
+ scriptId: exceptionDetails.scriptId,
649
+ affectedResources,
650
+ };
651
+ return new ConsoleMessage(
652
+ runtimeModel, Protocol.Log.LogEntrySource.Javascript, Protocol.Log.LogEntryLevel.Error,
653
+ RuntimeModel.simpleTextFromException(exceptionDetails), details);
654
+ }
655
+
656
+ runtimeModel(): RuntimeModel|null {
657
+ return this.#runtimeModel;
658
+ }
659
+
660
+ target(): Target|null {
661
+ return this.#runtimeModel ? this.#runtimeModel.target() : null;
662
+ }
663
+
664
+ setOriginatingMessage(originatingMessage: ConsoleMessage): void {
665
+ this.#originatingConsoleMessage = originatingMessage;
666
+ this.#executionContextId = originatingMessage.#executionContextId;
667
+ }
668
+
669
+ originatingMessage(): ConsoleMessage|null {
670
+ return this.#originatingConsoleMessage;
671
+ }
672
+
673
+ setExecutionContextId(executionContextId: number): void {
674
+ this.#executionContextId = executionContextId;
675
+ }
676
+
677
+ getExecutionContextId(): number {
678
+ return this.#executionContextId;
679
+ }
680
+
681
+ getExceptionId(): number|undefined {
682
+ return this.#exceptionId;
683
+ }
684
+
685
+ setExceptionId(exceptionId: number): void {
686
+ this.#exceptionId = exceptionId;
687
+ }
688
+
689
+ isGroupMessage(): boolean {
690
+ return this.type === Protocol.Runtime.ConsoleAPICalledEventType.StartGroup ||
691
+ this.type === Protocol.Runtime.ConsoleAPICalledEventType.StartGroupCollapsed ||
692
+ this.type === Protocol.Runtime.ConsoleAPICalledEventType.EndGroup;
693
+ }
694
+
695
+ isGroupStartMessage(): boolean {
696
+ return this.type === Protocol.Runtime.ConsoleAPICalledEventType.StartGroup ||
697
+ this.type === Protocol.Runtime.ConsoleAPICalledEventType.StartGroupCollapsed;
698
+ }
699
+
700
+ isErrorOrWarning(): boolean {
701
+ return (this.level === Protocol.Log.LogEntryLevel.Warning || this.level === Protocol.Log.LogEntryLevel.Error);
702
+ }
703
+
704
+ isGroupable(): boolean {
705
+ const isUngroupableError = this.level === Protocol.Log.LogEntryLevel.Error &&
706
+ (this.source === Protocol.Log.LogEntrySource.Javascript || this.source === Protocol.Log.LogEntrySource.Network);
707
+ return (
708
+ this.source !== Common.Console.FrontendMessageSource.ConsoleAPI && this.type !== FrontendMessageType.Command &&
709
+ this.type !== FrontendMessageType.Result && this.type !== FrontendMessageType.System && !isUngroupableError);
710
+ }
711
+
712
+ groupCategoryKey(): string {
713
+ return [this.source, this.level, this.type, this.#pageLoadSequenceNumber].join(':');
714
+ }
715
+
716
+ isEqual(msg: ConsoleMessage|null): boolean {
717
+ if (!msg) {
718
+ return false;
719
+ }
720
+
721
+ if (this.parameters) {
722
+ if (!msg.parameters || this.parameters.length !== msg.parameters.length) {
723
+ return false;
724
+ }
725
+
726
+ for (let i = 0; i < msg.parameters.length; ++i) {
727
+ const msgParam = msg.parameters[i];
728
+ const param = this.parameters[i];
729
+ if (typeof msgParam === 'string' || typeof param === 'string') {
730
+ // TODO(chromium:1136435): Remove this case.
731
+ return false;
732
+ }
733
+ if (msgParam.type === 'object' && msgParam.subtype !== 'error') {
734
+ if (!msgParam.objectId || msgParam.objectId !== param.objectId || msg.timestamp !== this.timestamp) {
735
+ return false;
736
+ }
737
+ }
738
+ if (param.type !== msgParam.type || param.value !== msgParam.value ||
739
+ param.description !== msgParam.description) {
740
+ return false;
741
+ }
742
+ }
743
+ }
744
+
745
+ return (this.runtimeModel() === msg.runtimeModel()) && (this.source === msg.source) && (this.type === msg.type) &&
746
+ (this.level === msg.level) && (this.line === msg.line) && (this.url === msg.url) &&
747
+ (this.scriptId === msg.scriptId) && (this.messageText === msg.messageText) &&
748
+ (this.#executionContextId === msg.#executionContextId) &&
749
+ areAffectedResourcesEquivalent(this.#affectedResources, msg.#affectedResources) &&
750
+ areStackTracesEquivalent(this.stackTrace, msg.stackTrace);
751
+ }
752
+
753
+ get originatesFromLogpoint(): boolean {
754
+ return this.#originatingBreakpointType === BreakpointType.LOGPOINT;
755
+ }
756
+
757
+ /** @returns true, iff this was a console.* call in a conditional breakpoint */
758
+ get originatesFromConditionalBreakpoint(): boolean {
759
+ return this.#originatingBreakpointType === BreakpointType.CONDITIONAL_BREAKPOINT;
760
+ }
761
+
762
+ static #stackFrameWithBreakpoint({callFrames}: Protocol.Runtime.StackTrace):
763
+ {callFrame: Protocol.Runtime.CallFrame|null, type: BreakpointType|null} {
764
+ // Note that breakpoint condition code could in theory call into user JS and back into
765
+ // "condition-defined" functions. This means that the top-most
766
+ // stack frame is not necessarily the `console.log` call, but there could be other things
767
+ // on top. We want the LAST marker frame in the stack.
768
+ // We search FROM THE TOP for the last marked stack frame and
769
+ // return it's parent (successor).
770
+ const markerSourceUrls = [COND_BREAKPOINT_SOURCE_URL, LOGPOINT_SOURCE_URL];
771
+ const lastBreakpointFrameIndex = callFrames.findLastIndex(({url}) => markerSourceUrls.includes(url));
772
+ if (lastBreakpointFrameIndex === -1 || lastBreakpointFrameIndex === callFrames.length - 1) {
773
+ // We either didn't find any breakpoint or we didn't capture enough stack
774
+ // frames and the breakpoint condition is the bottom-most frame.
775
+ return {callFrame: null, type: null};
776
+ }
777
+
778
+ const type = callFrames[lastBreakpointFrameIndex].url === LOGPOINT_SOURCE_URL ?
779
+ BreakpointType.LOGPOINT :
780
+ BreakpointType.CONDITIONAL_BREAKPOINT;
781
+ return {callFrame: callFrames[lastBreakpointFrameIndex + 1], type};
782
+ }
783
+ }
784
+
785
+ SDKModel.register(ConsoleModel, {capabilities: Capability.JS, autostart: true});
786
+
787
+ export type MessageSource = Protocol.Log.LogEntrySource|Common.Console.FrontendMessageSource;
788
+ export type MessageLevel = Protocol.Log.LogEntryLevel;
789
+ export type MessageType = Protocol.Runtime.ConsoleAPICalledEventType|FrontendMessageType;
790
+
791
+ export const MessageSourceDisplayName = new Map<MessageSource, string>(([
792
+ [Protocol.Log.LogEntrySource.XML, 'xml'],
793
+ [Protocol.Log.LogEntrySource.Javascript, 'javascript'],
794
+ [Protocol.Log.LogEntrySource.Network, 'network'],
795
+ [Common.Console.FrontendMessageSource.ConsoleAPI, 'console-api'],
796
+ [Protocol.Log.LogEntrySource.Storage, 'storage'],
797
+ [Protocol.Log.LogEntrySource.Appcache, 'appcache'],
798
+ [Protocol.Log.LogEntrySource.Rendering, 'rendering'],
799
+ [Common.Console.FrontendMessageSource.CSS, 'css'],
800
+ [Protocol.Log.LogEntrySource.Security, 'security'],
801
+ [Protocol.Log.LogEntrySource.Deprecation, 'deprecation'],
802
+ [Protocol.Log.LogEntrySource.Worker, 'worker'],
803
+ [Protocol.Log.LogEntrySource.Violation, 'violation'],
804
+ [Protocol.Log.LogEntrySource.Intervention, 'intervention'],
805
+ [Protocol.Log.LogEntrySource.Recommendation, 'recommendation'],
806
+ [Protocol.Log.LogEntrySource.Other, 'other'],
807
+ [Common.Console.FrontendMessageSource.ISSUE_PANEL, 'issue-panel'],
808
+ ]));