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.
- package/generate.ts +643 -0
- package/index.ts +16 -0
- package/lib/front_end/core/common/App.ts +7 -0
- package/lib/front_end/core/common/AppProvider.ts +32 -0
- package/lib/front_end/core/common/Base64.ts +47 -0
- package/lib/front_end/core/common/CharacterIdMap.ts +30 -0
- package/lib/front_end/core/common/Color.ts +2506 -0
- package/lib/front_end/core/common/ColorConverter.ts +402 -0
- package/lib/front_end/core/common/ColorUtils.ts +252 -0
- package/lib/front_end/core/common/Console.ts +114 -0
- package/lib/front_end/core/common/Debouncer.ts +15 -0
- package/lib/front_end/core/common/EventTarget.ts +52 -0
- package/lib/front_end/core/common/Gzip.ts +74 -0
- package/lib/front_end/core/common/JavaScriptMetaData.ts +29 -0
- package/lib/front_end/core/common/Lazy.ts +31 -0
- package/lib/front_end/core/common/Linkifier.ts +55 -0
- package/lib/front_end/core/common/MapWithDefault.ts +26 -0
- package/lib/front_end/core/common/Mutex.ts +55 -0
- package/lib/front_end/core/common/Object.ts +145 -0
- package/lib/front_end/core/common/ParsedURL.ts +554 -0
- package/lib/front_end/core/common/Progress.ts +180 -0
- package/lib/front_end/core/common/QueryParamHandler.ts +7 -0
- package/lib/front_end/core/common/ResolverBase.ts +85 -0
- package/lib/front_end/core/common/ResourceType.ts +588 -0
- package/lib/front_end/core/common/ReturnToPanel.ts +17 -0
- package/lib/front_end/core/common/Revealer.ts +192 -0
- package/lib/front_end/core/common/Runnable.ts +41 -0
- package/lib/front_end/core/common/SegmentedRange.ts +87 -0
- package/lib/front_end/core/common/SettingRegistration.ts +339 -0
- package/lib/front_end/core/common/Settings.ts +1497 -0
- package/lib/front_end/core/common/SimpleHistoryManager.ts +124 -0
- package/lib/front_end/core/common/StringOutputStream.ts +26 -0
- package/lib/front_end/core/common/TextDictionary.ts +48 -0
- package/lib/front_end/core/common/Throttler.ts +99 -0
- package/lib/front_end/core/common/Trie.ts +152 -0
- package/lib/front_end/core/common/Worker.ts +60 -0
- package/lib/front_end/core/common/common.ts +81 -0
- package/lib/front_end/core/host/AidaClient.ts +733 -0
- package/lib/front_end/core/host/GdpClient.ts +316 -0
- package/lib/front_end/core/host/InspectorFrontendHost.ts +648 -0
- package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +551 -0
- package/lib/front_end/core/host/Platform.ts +76 -0
- package/lib/front_end/core/host/ResourceLoader.ts +282 -0
- package/lib/front_end/core/host/UserMetrics.ts +1230 -0
- package/lib/front_end/core/host/host.ts +23 -0
- package/lib/front_end/core/i18n/ByteUtilities.ts +82 -0
- package/lib/front_end/core/i18n/DevToolsLocale.ts +87 -0
- package/lib/front_end/core/i18n/NumberFormatter.ts +82 -0
- package/lib/front_end/core/i18n/i18n.ts +17 -0
- package/lib/front_end/core/i18n/i18nImpl.ts +204 -0
- package/lib/front_end/core/i18n/i18nTypes.ts +10 -0
- package/lib/front_end/core/i18n/locales.js +14 -0
- package/lib/front_end/core/i18n/time-utilities.ts +174 -0
- package/lib/front_end/core/platform/ArrayUtilities.ts +271 -0
- package/lib/front_end/core/platform/Brand.ts +23 -0
- package/lib/front_end/core/platform/Constructor.ts +10 -0
- package/lib/front_end/core/platform/DOMUtilities.ts +138 -0
- package/lib/front_end/core/platform/DateUtilities.ts +15 -0
- package/lib/front_end/core/platform/DevToolsPath.ts +53 -0
- package/lib/front_end/core/platform/KeyboardUtilities.ts +38 -0
- package/lib/front_end/core/platform/MapUtilities.ts +95 -0
- package/lib/front_end/core/platform/MimeType.ts +175 -0
- package/lib/front_end/core/platform/NumberUtilities.ts +80 -0
- package/lib/front_end/core/platform/StringUtilities.ts +588 -0
- package/lib/front_end/core/platform/Timing.ts +17 -0
- package/lib/front_end/core/platform/TypedArrayUtilities.ts +189 -0
- package/lib/front_end/core/platform/TypescriptUtilities.ts +86 -0
- package/lib/front_end/core/platform/UIString.ts +39 -0
- package/lib/front_end/core/platform/UserVisibleError.ts +28 -0
- package/lib/front_end/core/platform/platform.ts +45 -0
- package/lib/front_end/core/protocol_client/ConnectionTransport.ts +26 -0
- package/lib/front_end/core/protocol_client/InspectorBackend.ts +1050 -0
- package/lib/front_end/core/protocol_client/NodeURL.ts +42 -0
- package/lib/front_end/core/protocol_client/protocol_client.ts +13 -0
- package/lib/front_end/core/root/Runtime.ts +609 -0
- package/lib/front_end/core/root/root.ts +6 -0
- package/lib/front_end/core/sdk/AccessibilityModel.ts +353 -0
- package/lib/front_end/core/sdk/AnimationModel.ts +1041 -0
- package/lib/front_end/core/sdk/AutofillModel.ts +184 -0
- package/lib/front_end/core/sdk/CPUProfilerModel.ts +148 -0
- package/lib/front_end/core/sdk/CPUThrottlingManager.ts +282 -0
- package/lib/front_end/core/sdk/CSSContainerQuery.ts +139 -0
- package/lib/front_end/core/sdk/CSSFontFace.ts +40 -0
- package/lib/front_end/core/sdk/CSSLayer.ts +30 -0
- package/lib/front_end/core/sdk/CSSMatchedStyles.ts +1646 -0
- package/lib/front_end/core/sdk/CSSMedia.ts +121 -0
- package/lib/front_end/core/sdk/CSSMetadata.ts +1647 -0
- package/lib/front_end/core/sdk/CSSModel.ts +1128 -0
- package/lib/front_end/core/sdk/CSSProperty.ts +384 -0
- package/lib/front_end/core/sdk/CSSPropertyParser.ts +681 -0
- package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +1395 -0
- package/lib/front_end/core/sdk/CSSQuery.ts +72 -0
- package/lib/front_end/core/sdk/CSSRule.ts +465 -0
- package/lib/front_end/core/sdk/CSSScope.ts +30 -0
- package/lib/front_end/core/sdk/CSSStartingStyle.ts +29 -0
- package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +313 -0
- package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +196 -0
- package/lib/front_end/core/sdk/CSSSupports.ts +33 -0
- package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +64 -0
- package/lib/front_end/core/sdk/ChildTargetManager.ts +314 -0
- package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +62 -0
- package/lib/front_end/core/sdk/Connections.ts +293 -0
- package/lib/front_end/core/sdk/ConsoleModel.ts +808 -0
- package/lib/front_end/core/sdk/ConsoleModelTypes.ts +15 -0
- package/lib/front_end/core/sdk/Cookie.ts +319 -0
- package/lib/front_end/core/sdk/CookieModel.ts +239 -0
- package/lib/front_end/core/sdk/CookieParser.ts +185 -0
- package/lib/front_end/core/sdk/DOMDebuggerModel.ts +787 -0
- package/lib/front_end/core/sdk/DOMModel.ts +1961 -0
- package/lib/front_end/core/sdk/DebuggerModel.ts +1605 -0
- package/lib/front_end/core/sdk/EmulationModel.ts +648 -0
- package/lib/front_end/core/sdk/EnhancedTracesParser.ts +515 -0
- package/lib/front_end/core/sdk/EventBreakpointsModel.ts +183 -0
- package/lib/front_end/core/sdk/FrameAssociated.ts +11 -0
- package/lib/front_end/core/sdk/FrameManager.ts +259 -0
- package/lib/front_end/core/sdk/HeapProfilerModel.ts +225 -0
- package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +77 -0
- package/lib/front_end/core/sdk/IOModel.ts +91 -0
- package/lib/front_end/core/sdk/IsolateManager.ts +257 -0
- package/lib/front_end/core/sdk/IssuesModel.ts +70 -0
- package/lib/front_end/core/sdk/LayerTreeBase.ts +169 -0
- package/lib/front_end/core/sdk/LogModel.ts +56 -0
- package/lib/front_end/core/sdk/NetworkManager.ts +2823 -0
- package/lib/front_end/core/sdk/NetworkRequest.ts +2253 -0
- package/lib/front_end/core/sdk/OverlayColorGenerator.ts +52 -0
- package/lib/front_end/core/sdk/OverlayModel.ts +1011 -0
- package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +522 -0
- package/lib/front_end/core/sdk/PageLoad.ts +35 -0
- package/lib/front_end/core/sdk/PageResourceLoader.ts +435 -0
- package/lib/front_end/core/sdk/PaintProfiler.ts +110 -0
- package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +84 -0
- package/lib/front_end/core/sdk/PreloadingModel.ts +863 -0
- package/lib/front_end/core/sdk/RehydratingConnection.ts +386 -0
- package/lib/front_end/core/sdk/RehydratingObject.ts +66 -0
- package/lib/front_end/core/sdk/RemoteObject.ts +1160 -0
- package/lib/front_end/core/sdk/Resource.ts +232 -0
- package/lib/front_end/core/sdk/ResourceTreeModel.ts +1160 -0
- package/lib/front_end/core/sdk/RuntimeModel.ts +732 -0
- package/lib/front_end/core/sdk/SDKModel.ts +65 -0
- package/lib/front_end/core/sdk/ScopeTreeCache.ts +45 -0
- package/lib/front_end/core/sdk/ScreenCaptureModel.ts +255 -0
- package/lib/front_end/core/sdk/Script.ts +534 -0
- package/lib/front_end/core/sdk/SecurityOriginManager.ts +76 -0
- package/lib/front_end/core/sdk/ServerSentEvents.ts +80 -0
- package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +122 -0
- package/lib/front_end/core/sdk/ServerTiming.ts +260 -0
- package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +377 -0
- package/lib/front_end/core/sdk/ServiceWorkerManager.ts +605 -0
- package/lib/front_end/core/sdk/SourceMap.ts +867 -0
- package/lib/front_end/core/sdk/SourceMapCache.ts +54 -0
- package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +156 -0
- package/lib/front_end/core/sdk/SourceMapManager.ts +239 -0
- package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +189 -0
- package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +508 -0
- package/lib/front_end/core/sdk/StorageBucketsModel.ts +204 -0
- package/lib/front_end/core/sdk/StorageKeyManager.ts +98 -0
- package/lib/front_end/core/sdk/Target.ts +332 -0
- package/lib/front_end/core/sdk/TargetManager.ts +453 -0
- package/lib/front_end/core/sdk/TraceObject.ts +61 -0
- package/lib/front_end/core/sdk/WebAuthnModel.ts +104 -0
- package/lib/front_end/core/sdk/sdk.ts +174 -0
- package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +59 -0
- package/lib/front_end/generated/InspectorBackendCommands.js +1617 -0
- package/lib/front_end/generated/SupportedCSSProperties.js +7512 -0
- package/lib/front_end/generated/protocol-proxy-api.d.ts +5022 -0
- package/lib/front_end/generated/protocol.ts +22014 -0
- package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +571 -0
- package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +103 -0
- package/lib/front_end/models/cpu_profile/cpu_profile.ts +11 -0
- package/lib/front_end/models/formatter/FormatterWorkerPool.ts +219 -0
- package/lib/front_end/models/formatter/ScriptFormatter.ts +112 -0
- package/lib/front_end/models/formatter/formatter.ts +8 -0
- package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +37 -0
- package/lib/front_end/models/text_utils/ContentData.ts +199 -0
- package/lib/front_end/models/text_utils/ContentProvider.ts +68 -0
- package/lib/front_end/models/text_utils/StaticContentProvider.ts +49 -0
- package/lib/front_end/models/text_utils/StreamingContentData.ts +108 -0
- package/lib/front_end/models/text_utils/Text.ts +90 -0
- package/lib/front_end/models/text_utils/TextCursor.ts +44 -0
- package/lib/front_end/models/text_utils/TextRange.ts +266 -0
- package/lib/front_end/models/text_utils/TextUtils.ts +401 -0
- package/lib/front_end/models/text_utils/WasmDisassembly.ts +87 -0
- package/lib/front_end/models/text_utils/text_utils.ts +27 -0
- package/lib/front_end/models/trace/EntityMapper.ts +141 -0
- package/lib/front_end/models/trace/EventsSerializer.ts +101 -0
- package/lib/front_end/models/trace/LanternComputationData.ts +438 -0
- package/lib/front_end/models/trace/ModelImpl.ts +236 -0
- package/lib/front_end/models/trace/Name.ts +136 -0
- package/lib/front_end/models/trace/Processor.ts +652 -0
- package/lib/front_end/models/trace/Styles.ts +1138 -0
- package/lib/front_end/models/trace/extras/FilmStrip.ts +78 -0
- package/lib/front_end/models/trace/extras/MainThreadActivity.ts +86 -0
- package/lib/front_end/models/trace/extras/ScriptDuplication.ts +236 -0
- package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +203 -0
- package/lib/front_end/models/trace/extras/ThirdParties.ts +164 -0
- package/lib/front_end/models/trace/extras/TraceFilter.ts +62 -0
- package/lib/front_end/models/trace/extras/TraceTree.ts +701 -0
- package/lib/front_end/models/trace/extras/extras.ts +11 -0
- package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +128 -0
- package/lib/front_end/models/trace/handlers/AnimationHandler.ts +36 -0
- package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +239 -0
- package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +183 -0
- package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +31 -0
- package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +306 -0
- package/lib/front_end/models/trace/handlers/FlowsHandler.ts +175 -0
- package/lib/front_end/models/trace/handlers/FramesHandler.ts +571 -0
- package/lib/front_end/models/trace/handlers/GPUHandler.ts +50 -0
- package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +183 -0
- package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +193 -0
- package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +168 -0
- package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +109 -0
- package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +35 -0
- package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +123 -0
- package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +573 -0
- package/lib/front_end/models/trace/handlers/MemoryHandler.ts +31 -0
- package/lib/front_end/models/trace/handlers/MetaHandler.ts +525 -0
- package/lib/front_end/models/trace/handlers/ModelHandlers.ts +34 -0
- package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +672 -0
- package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +52 -0
- package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +460 -0
- package/lib/front_end/models/trace/handlers/RendererHandler.ts +428 -0
- package/lib/front_end/models/trace/handlers/SamplesHandler.ts +271 -0
- package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +122 -0
- package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +336 -0
- package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +110 -0
- package/lib/front_end/models/trace/handlers/Threads.ts +139 -0
- package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +400 -0
- package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +233 -0
- package/lib/front_end/models/trace/handlers/WarningsHandler.ts +162 -0
- package/lib/front_end/models/trace/handlers/WorkersHandler.ts +45 -0
- package/lib/front_end/models/trace/handlers/handlers.ts +8 -0
- package/lib/front_end/models/trace/handlers/helpers.ts +196 -0
- package/lib/front_end/models/trace/handlers/types.ts +75 -0
- package/lib/front_end/models/trace/helpers/Extensions.ts +54 -0
- package/lib/front_end/models/trace/helpers/Network.ts +129 -0
- package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +544 -0
- package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +87 -0
- package/lib/front_end/models/trace/helpers/Timing.ts +248 -0
- package/lib/front_end/models/trace/helpers/Trace.ts +928 -0
- package/lib/front_end/models/trace/helpers/TreeHelpers.ts +320 -0
- package/lib/front_end/models/trace/helpers/helpers.ts +11 -0
- package/lib/front_end/models/trace/insights/CLSCulprits.ts +668 -0
- package/lib/front_end/models/trace/insights/Cache.ts +269 -0
- package/lib/front_end/models/trace/insights/Common.ts +453 -0
- package/lib/front_end/models/trace/insights/DOMSize.ts +223 -0
- package/lib/front_end/models/trace/insights/DocumentLatency.ts +319 -0
- package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +126 -0
- package/lib/front_end/models/trace/insights/FontDisplay.ts +119 -0
- package/lib/front_end/models/trace/insights/ForcedReflow.ts +220 -0
- package/lib/front_end/models/trace/insights/INPBreakdown.ts +171 -0
- package/lib/front_end/models/trace/insights/ImageDelivery.ts +348 -0
- package/lib/front_end/models/trace/insights/LCPBreakdown.ts +268 -0
- package/lib/front_end/models/trace/insights/LCPDiscovery.ts +237 -0
- package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +138 -0
- package/lib/front_end/models/trace/insights/Models.ts +22 -0
- package/lib/front_end/models/trace/insights/ModernHTTP.ts +257 -0
- package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +726 -0
- package/lib/front_end/models/trace/insights/RenderBlocking.ts +257 -0
- package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +175 -0
- package/lib/front_end/models/trace/insights/Statistics.ts +101 -0
- package/lib/front_end/models/trace/insights/ThirdParties.ts +130 -0
- package/lib/front_end/models/trace/insights/Viewport.ts +138 -0
- package/lib/front_end/models/trace/insights/insights.ts +10 -0
- package/lib/front_end/models/trace/insights/types.ts +157 -0
- package/lib/front_end/models/trace/lantern/core/LanternError.ts +7 -0
- package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +619 -0
- package/lib/front_end/models/trace/lantern/core/core.ts +6 -0
- package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +345 -0
- package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +80 -0
- package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +101 -0
- package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +636 -0
- package/lib/front_end/models/trace/lantern/graph/graph.ts +8 -0
- package/lib/front_end/models/trace/lantern/lantern.ts +17 -0
- package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +187 -0
- package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +88 -0
- package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +92 -0
- package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +72 -0
- package/lib/front_end/models/trace/lantern/metrics/Metric.ts +126 -0
- package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +126 -0
- package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +82 -0
- package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +112 -0
- package/lib/front_end/models/trace/lantern/metrics/metrics.ts +12 -0
- package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +150 -0
- package/lib/front_end/models/trace/lantern/simulation/Constants.ts +46 -0
- package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +61 -0
- package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +196 -0
- package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +556 -0
- package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +192 -0
- package/lib/front_end/models/trace/lantern/simulation/simulation.ts +10 -0
- package/lib/front_end/models/trace/lantern/types/Lantern.ts +220 -0
- package/lib/front_end/models/trace/lantern/types/types.ts +5 -0
- package/lib/front_end/models/trace/trace.ts +33 -0
- package/lib/front_end/models/trace/types/Configuration.ts +110 -0
- package/lib/front_end/models/trace/types/Extensions.ts +136 -0
- package/lib/front_end/models/trace/types/File.ts +281 -0
- package/lib/front_end/models/trace/types/Overlays.ts +138 -0
- package/lib/front_end/models/trace/types/Timing.ts +30 -0
- package/lib/front_end/models/trace/types/TraceEvents.ts +3277 -0
- package/lib/front_end/models/trace/types/types.ts +10 -0
- package/lib/front_end/third_party/i18n/LICENSE +202 -0
- package/lib/front_end/third_party/i18n/README.chromium +15 -0
- package/lib/front_end/third_party/i18n/i18n-impl.ts +61 -0
- package/lib/front_end/third_party/i18n/i18n.ts +11 -0
- package/lib/front_end/third_party/i18n/localized-string-set.ts +129 -0
- package/lib/front_end/third_party/intl-messageformat/LICENSE +33 -0
- package/lib/front_end/third_party/intl-messageformat/README.chromium +24 -0
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +16 -0
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +6 -0
- package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +33 -0
- package/lib/front_end/third_party/intl-messageformat/package/README.md +3 -0
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +6 -0
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/index.js +13 -0
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +5 -0
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +1710 -0
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +1815 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +6 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +10 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +34 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +229 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +28 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +48 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +34 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +179 -0
- package/lib/front_end/third_party/intl-messageformat/package/package.json +42 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +34 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/core.js +230 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +28 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/error.js +51 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +34 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +1 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +182 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +79 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +15 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +153 -0
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +139 -0
- package/lib/front_end/third_party/legacy-javascript/LICENSE +202 -0
- package/lib/front_end/third_party/legacy-javascript/README.chromium +13 -0
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +8 -0
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +3 -0
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +18 -0
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +943 -0
- package/lib/front_end/third_party/legacy-javascript/package.json +8 -0
- package/lib/front_end/third_party/legacy-javascript/rebuild.sh +9 -0
- package/lib/front_end/third_party/third-party-web/LICENSE +20 -0
- package/lib/front_end/third_party/third-party-web/README.chromium +13 -0
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +2 -0
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +149 -0
- package/lib/front_end/third_party/third-party-web/package/LICENSE +20 -0
- package/lib/front_end/third_party/third-party-web/package/README.md +929 -0
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +1 -0
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +1 -0
- package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +1 -0
- package/lib/front_end/third_party/third-party-web/package/dist/entities.json +1 -0
- package/lib/front_end/third_party/third-party-web/package/facades.md +46 -0
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +1 -0
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +1 -0
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +1 -0
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +1006 -0
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +139 -0
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +44 -0
- package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +27 -0
- package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +34 -0
- package/lib/front_end/third_party/third-party-web/package/lib/index.js +3 -0
- package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +246 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +36 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +9 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +5 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +151 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +14 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +3 -0
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +3 -0
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +3 -0
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +1 -0
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +3 -0
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +1 -0
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +1 -0
- package/lib/front_end/third_party/third-party-web/package/package.json +46 -0
- package/lib/front_end/third_party/third-party-web/package.json +8 -0
- package/lib/front_end/third_party/third-party-web/rebuild.sh +13 -0
- package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +8 -0
- package/lib/front_end/third_party/third-party-web/third-party-web.ts +3 -0
- package/package.json +24 -0
- package/patches/chrome-devtools-frontend+1.0.1533544.patch +187 -0
|
@@ -0,0 +1,101 @@
|
|
|
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 Helpers from './helpers/helpers.js';
|
|
6
|
+
import type {ParsedTrace} from './ModelImpl.js';
|
|
7
|
+
import * as Types from './types/types.js';
|
|
8
|
+
|
|
9
|
+
export class EventsSerializer {
|
|
10
|
+
#modifiedProfileCallByKey = new Map<Types.File.ProfileCallKeyValues, Types.Events.SyntheticProfileCall>();
|
|
11
|
+
|
|
12
|
+
keyForEvent(event: Types.Events.Event): Types.File.SerializableKey|null {
|
|
13
|
+
if (Types.Events.isProfileCall(event)) {
|
|
14
|
+
return `${Types.File.EventKeyType.PROFILE_CALL}-${event.pid}-${event.tid}-${
|
|
15
|
+
Types.Events.SampleIndex(event.sampleIndex)}-${event.nodeId}`;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
if (Types.Events.isLegacyTimelineFrame(event)) {
|
|
19
|
+
return `${Types.File.EventKeyType.LEGACY_TIMELINE_FRAME}-${event.index}`;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const rawEvents = Helpers.SyntheticEvents.SyntheticEventsManager.getActiveManager().getRawTraceEvents();
|
|
23
|
+
const key: Types.File.SyntheticEventKey|Types.File.RawEventKey = Types.Events.isSyntheticBased(event) ?
|
|
24
|
+
`${Types.File.EventKeyType.SYNTHETIC_EVENT}-${rawEvents.indexOf(event.rawSourceEvent)}` :
|
|
25
|
+
`${Types.File.EventKeyType.RAW_EVENT}-${rawEvents.indexOf(event)}`;
|
|
26
|
+
if (key.length < 3) {
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
return key;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
eventForKey(key: Types.File.SerializableKey, parsedTrace: ParsedTrace): Types.Events.Event {
|
|
33
|
+
const eventValues = Types.File.traceEventKeyToValues(key);
|
|
34
|
+
|
|
35
|
+
if (EventsSerializer.isProfileCallKey(eventValues)) {
|
|
36
|
+
return this.#getModifiedProfileCallByKeyValues(eventValues, parsedTrace);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
if (EventsSerializer.isLegacyTimelineFrameKey(eventValues)) {
|
|
40
|
+
const event = parsedTrace.data.Frames.frames.at(eventValues.rawIndex);
|
|
41
|
+
if (!event) {
|
|
42
|
+
throw new Error(`Unknown trace event. Could not find frame with index ${eventValues.rawIndex}`);
|
|
43
|
+
}
|
|
44
|
+
return event;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
if (EventsSerializer.isSyntheticEventKey(eventValues)) {
|
|
48
|
+
const syntheticEvents = Helpers.SyntheticEvents.SyntheticEventsManager.getActiveManager().getSyntheticTraces();
|
|
49
|
+
const syntheticEvent = syntheticEvents.at(eventValues.rawIndex);
|
|
50
|
+
if (!syntheticEvent) {
|
|
51
|
+
throw new Error(`Unknown trace event. Attempted to get a synthetic event from an unknown raw event index: ${
|
|
52
|
+
eventValues.rawIndex}`);
|
|
53
|
+
}
|
|
54
|
+
return syntheticEvent;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
if (EventsSerializer.isRawEventKey(eventValues)) {
|
|
58
|
+
const rawEvents = Helpers.SyntheticEvents.SyntheticEventsManager.getActiveManager().getRawTraceEvents();
|
|
59
|
+
return rawEvents[eventValues.rawIndex];
|
|
60
|
+
}
|
|
61
|
+
throw new Error(`Unknown trace event. Serializable key values: ${(eventValues as unknown[]).join('-')}`);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
static isProfileCallKey(key: Types.File.SerializableKeyValues): key is Types.File.ProfileCallKeyValues {
|
|
65
|
+
return key.type === Types.File.EventKeyType.PROFILE_CALL;
|
|
66
|
+
}
|
|
67
|
+
static isLegacyTimelineFrameKey(key: Types.File.SerializableKeyValues):
|
|
68
|
+
key is Types.File.LegacyTimelineFrameKeyValues {
|
|
69
|
+
return key.type === Types.File.EventKeyType.LEGACY_TIMELINE_FRAME;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
static isRawEventKey(key: Types.File.SerializableKeyValues): key is Types.File.RawEventKeyValues {
|
|
73
|
+
return key.type === Types.File.EventKeyType.RAW_EVENT;
|
|
74
|
+
}
|
|
75
|
+
static isSyntheticEventKey(key: Types.File.SerializableKeyValues): key is Types.File.SyntheticEventKeyValues {
|
|
76
|
+
return key.type === Types.File.EventKeyType.SYNTHETIC_EVENT;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
#getModifiedProfileCallByKeyValues(key: Types.File.ProfileCallKeyValues, parsedTrace: ParsedTrace):
|
|
80
|
+
Types.Events.SyntheticProfileCall {
|
|
81
|
+
const cacheResult = this.#modifiedProfileCallByKey.get(key);
|
|
82
|
+
if (cacheResult) {
|
|
83
|
+
return cacheResult;
|
|
84
|
+
}
|
|
85
|
+
const profileCallsInThread =
|
|
86
|
+
parsedTrace.data.Renderer.processes.get(key.processID)?.threads.get(key.threadID)?.profileCalls;
|
|
87
|
+
if (!profileCallsInThread) {
|
|
88
|
+
throw new Error(`Unknown profile call serializable key: ${(key)}`);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
const match = profileCallsInThread?.find((e: Types.Events.SyntheticProfileCall) => {
|
|
92
|
+
return e.sampleIndex === key.sampleIndex && e.nodeId === key.protocol;
|
|
93
|
+
});
|
|
94
|
+
if (!match) {
|
|
95
|
+
throw new Error(`Unknown profile call serializable key: ${(JSON.stringify(key))}`);
|
|
96
|
+
}
|
|
97
|
+
// Cache to avoid looking up in subsequent calls.
|
|
98
|
+
this.#modifiedProfileCallByKey.set(key, match);
|
|
99
|
+
return match;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
@@ -0,0 +1,438 @@
|
|
|
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 Protocol from '../../generated/protocol.js';
|
|
6
|
+
|
|
7
|
+
import * as Handlers from './handlers/handlers.js';
|
|
8
|
+
import * as Lantern from './lantern/lantern.js';
|
|
9
|
+
import type * as Types from './types/types.js';
|
|
10
|
+
|
|
11
|
+
type NetworkRequest = Lantern.Types.NetworkRequest<Types.Events.SyntheticNetworkRequest>;
|
|
12
|
+
|
|
13
|
+
function createProcessedNavigation(data: Handlers.Types.HandlerData, frameId: string, navigationId: string):
|
|
14
|
+
Lantern.Types.Simulation.ProcessedNavigation {
|
|
15
|
+
const scoresByNav = data.PageLoadMetrics.metricScoresByFrameId.get(frameId);
|
|
16
|
+
if (!scoresByNav) {
|
|
17
|
+
throw new Lantern.Core.LanternError('missing metric scores for frame');
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const scores = scoresByNav.get(navigationId);
|
|
21
|
+
if (!scores) {
|
|
22
|
+
throw new Lantern.Core.LanternError('missing metric scores for specified navigation');
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const getTimestampOrUndefined =
|
|
26
|
+
(metric: Handlers.ModelHandlers.PageLoadMetrics.MetricName): Types.Timing.Micro|undefined => {
|
|
27
|
+
const metricScore = scores.get(metric);
|
|
28
|
+
if (!metricScore?.event) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
return metricScore.event.ts;
|
|
32
|
+
};
|
|
33
|
+
const getTimestamp = (metric: Handlers.ModelHandlers.PageLoadMetrics.MetricName): Types.Timing.Micro => {
|
|
34
|
+
const metricScore = scores.get(metric);
|
|
35
|
+
if (!metricScore?.event) {
|
|
36
|
+
throw new Lantern.Core.LanternError(`missing metric: ${metric}`);
|
|
37
|
+
}
|
|
38
|
+
return metricScore.event.ts;
|
|
39
|
+
};
|
|
40
|
+
return {
|
|
41
|
+
timestamps: {
|
|
42
|
+
firstContentfulPaint: getTimestamp(Handlers.ModelHandlers.PageLoadMetrics.MetricName.FCP),
|
|
43
|
+
largestContentfulPaint: getTimestampOrUndefined(Handlers.ModelHandlers.PageLoadMetrics.MetricName.LCP),
|
|
44
|
+
},
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function createParsedUrl(url: URL|string): Lantern.Types.ParsedURL {
|
|
49
|
+
if (typeof url === 'string') {
|
|
50
|
+
url = new URL(url);
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
scheme: url.protocol.split(':')[0],
|
|
54
|
+
// Intentional, DevTools uses different terminology
|
|
55
|
+
host: url.hostname,
|
|
56
|
+
securityOrigin: url.origin,
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Returns a map of `pid` -> `tid[]`.
|
|
62
|
+
*/
|
|
63
|
+
function findWorkerThreads(trace: Lantern.Types.Trace): Map<number, number[]> {
|
|
64
|
+
// TODO: WorkersHandler in Trace Engine needs to be updated to also include `pid` (only had `tid`).
|
|
65
|
+
const workerThreads = new Map();
|
|
66
|
+
const workerCreationEvents = ['ServiceWorker thread', 'DedicatedWorker thread'];
|
|
67
|
+
|
|
68
|
+
for (const event of trace.traceEvents) {
|
|
69
|
+
if (event.name !== 'thread_name' || !event.args.name) {
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
if (!workerCreationEvents.includes(event.args.name)) {
|
|
73
|
+
continue;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const tids = workerThreads.get(event.pid);
|
|
77
|
+
if (tids) {
|
|
78
|
+
tids.push(event.tid);
|
|
79
|
+
} else {
|
|
80
|
+
workerThreads.set(event.pid, [event.tid]);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
return workerThreads;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
function createLanternRequest(
|
|
88
|
+
parsedTrace: Readonly<Handlers.Types.HandlerData>, workerThreads: Map<number, number[]>,
|
|
89
|
+
request: Types.Events.SyntheticNetworkRequest): NetworkRequest|undefined {
|
|
90
|
+
if (request.args.data.hasResponse && request.args.data.connectionId === undefined) {
|
|
91
|
+
throw new Lantern.Core.LanternError('Trace is too old');
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
let url;
|
|
95
|
+
try {
|
|
96
|
+
url = new URL(request.args.data.url);
|
|
97
|
+
} catch {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const timing = request.args.data.timing ? {
|
|
102
|
+
// These two timings are not included in the trace.
|
|
103
|
+
workerFetchStart: -1,
|
|
104
|
+
workerRespondWithSettled: -1,
|
|
105
|
+
receiveHeadersStart: -1,
|
|
106
|
+
...request.args.data.timing,
|
|
107
|
+
} :
|
|
108
|
+
undefined;
|
|
109
|
+
|
|
110
|
+
const networkRequestTime = timing ? timing.requestTime * 1000 : request.args.data.syntheticData.downloadStart / 1000;
|
|
111
|
+
|
|
112
|
+
let fromWorker = false;
|
|
113
|
+
const tids = workerThreads.get(request.pid);
|
|
114
|
+
if (tids?.includes(request.tid)) {
|
|
115
|
+
fromWorker = true;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// Trace Engine collects worker thread ids in a different manner than `workerThreads` does.
|
|
119
|
+
// AFAIK these should be equivalent, but in case they are not let's also check this for now.
|
|
120
|
+
if (parsedTrace.Workers.workerIdByThread.has(request.tid)) {
|
|
121
|
+
fromWorker = true;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// `initiator` in the trace does not contain the stack trace for JS-initiated
|
|
125
|
+
// requests. Instead, that is stored in the `stackTrace` property of the SyntheticNetworkRequest.
|
|
126
|
+
// There are some minor differences in the fields, accounted for here.
|
|
127
|
+
// Most importantly, there seems to be fewer frames in the trace than the equivalent
|
|
128
|
+
// events over the CDP. This results in less accuracy in determining the initiator request,
|
|
129
|
+
// which means less edges in the graph, which mean worse results.
|
|
130
|
+
// TODO: Should fix in Chromium.
|
|
131
|
+
const initiator: Lantern.Types.NetworkRequest['initiator'] =
|
|
132
|
+
request.args.data.initiator ?? {type: Protocol.Network.InitiatorType.Other};
|
|
133
|
+
if (request.args.data.stackTrace) {
|
|
134
|
+
const callFrames = request.args.data.stackTrace.map(f => {
|
|
135
|
+
return {
|
|
136
|
+
scriptId: String(f.scriptId) as Protocol.Runtime.ScriptId,
|
|
137
|
+
url: f.url,
|
|
138
|
+
lineNumber: f.lineNumber - 1,
|
|
139
|
+
columnNumber: f.columnNumber - 1,
|
|
140
|
+
functionName: f.functionName,
|
|
141
|
+
};
|
|
142
|
+
});
|
|
143
|
+
initiator.stack = {callFrames};
|
|
144
|
+
// Note: there is no `parent` to set ...
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
let resourceType = request.args.data.resourceType;
|
|
148
|
+
if (request.args.data.initiator?.fetchType === 'xmlhttprequest') {
|
|
149
|
+
// @ts-expect-error yes XHR is a valid ResourceType. TypeScript const enums are so unhelpful.
|
|
150
|
+
resourceType = 'XHR';
|
|
151
|
+
} else if (request.args.data.initiator?.fetchType === 'fetch') {
|
|
152
|
+
// @ts-expect-error yes Fetch is a valid ResourceType. TypeScript const enums are so unhelpful.
|
|
153
|
+
resourceType = 'Fetch';
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// TODO: set decodedBodyLength for data urls in Trace Engine.
|
|
157
|
+
let resourceSize = request.args.data.decodedBodyLength ?? 0;
|
|
158
|
+
if (url.protocol === 'data:' && resourceSize === 0) {
|
|
159
|
+
const commaIndex = url.pathname.indexOf(',');
|
|
160
|
+
if (url.pathname.substring(0, commaIndex).includes(';base64')) {
|
|
161
|
+
resourceSize = atob(url.pathname.substring(commaIndex + 1)).length;
|
|
162
|
+
} else {
|
|
163
|
+
resourceSize = url.pathname.length - commaIndex - 1;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
return {
|
|
168
|
+
rawRequest: request,
|
|
169
|
+
requestId: request.args.data.requestId,
|
|
170
|
+
connectionId: request.args.data.connectionId ?? 0,
|
|
171
|
+
connectionReused: request.args.data.connectionReused ?? false,
|
|
172
|
+
url: request.args.data.url,
|
|
173
|
+
protocol: request.args.data.protocol,
|
|
174
|
+
parsedURL: createParsedUrl(url),
|
|
175
|
+
documentURL: request.args.data.requestingFrameUrl,
|
|
176
|
+
rendererStartTime: request.ts / 1000,
|
|
177
|
+
networkRequestTime,
|
|
178
|
+
responseHeadersEndTime: request.args.data.syntheticData.downloadStart / 1000,
|
|
179
|
+
networkEndTime: request.args.data.syntheticData.finishTime / 1000,
|
|
180
|
+
transferSize: request.args.data.encodedDataLength,
|
|
181
|
+
resourceSize,
|
|
182
|
+
fromDiskCache: request.args.data.syntheticData.isDiskCached,
|
|
183
|
+
fromMemoryCache: request.args.data.syntheticData.isMemoryCached,
|
|
184
|
+
isLinkPreload: request.args.data.isLinkPreload,
|
|
185
|
+
finished: request.args.data.finished,
|
|
186
|
+
failed: request.args.data.failed,
|
|
187
|
+
statusCode: request.args.data.statusCode,
|
|
188
|
+
initiator,
|
|
189
|
+
timing,
|
|
190
|
+
resourceType,
|
|
191
|
+
mimeType: request.args.data.mimeType,
|
|
192
|
+
priority: request.args.data.priority,
|
|
193
|
+
frameId: request.args.data.frame,
|
|
194
|
+
fromWorker,
|
|
195
|
+
serverResponseTime: request.args.data.lrServerResponseTime ?? undefined,
|
|
196
|
+
// Set later.
|
|
197
|
+
redirects: undefined,
|
|
198
|
+
redirectSource: undefined,
|
|
199
|
+
redirectDestination: undefined,
|
|
200
|
+
initiatorRequest: undefined,
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* @param request The request to find the initiator of
|
|
206
|
+
*/
|
|
207
|
+
function chooseInitiatorRequest(request: NetworkRequest, requestsByURL: Map<string, NetworkRequest[]>): NetworkRequest|
|
|
208
|
+
null {
|
|
209
|
+
if (request.redirectSource) {
|
|
210
|
+
return request.redirectSource;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
const initiatorURL = Lantern.Graph.PageDependencyGraph.getNetworkInitiators(request)[0];
|
|
214
|
+
let candidates = requestsByURL.get(initiatorURL) || [];
|
|
215
|
+
// The (valid) initiator must come before the initiated request.
|
|
216
|
+
candidates = candidates.filter(c => {
|
|
217
|
+
return c.responseHeadersEndTime <= request.rendererStartTime && c.finished && !c.failed;
|
|
218
|
+
});
|
|
219
|
+
if (candidates.length > 1) {
|
|
220
|
+
// Disambiguate based on prefetch. Prefetch requests have type 'Other' and cannot
|
|
221
|
+
// initiate requests, so we drop them here.
|
|
222
|
+
const nonPrefetchCandidates =
|
|
223
|
+
candidates.filter(cand => cand.resourceType !== Lantern.Types.NetworkRequestTypes.Other);
|
|
224
|
+
if (nonPrefetchCandidates.length) {
|
|
225
|
+
candidates = nonPrefetchCandidates;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
if (candidates.length > 1) {
|
|
229
|
+
// Disambiguate based on frame. It's likely that the initiator comes from the same frame.
|
|
230
|
+
const sameFrameCandidates = candidates.filter(cand => cand.frameId === request.frameId);
|
|
231
|
+
if (sameFrameCandidates.length) {
|
|
232
|
+
candidates = sameFrameCandidates;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
if (candidates.length > 1 && request.initiator.type === 'parser') {
|
|
236
|
+
// Filter to just Documents when initiator type is parser.
|
|
237
|
+
const documentCandidates =
|
|
238
|
+
candidates.filter(cand => cand.resourceType === Lantern.Types.NetworkRequestTypes.Document);
|
|
239
|
+
if (documentCandidates.length) {
|
|
240
|
+
candidates = documentCandidates;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
if (candidates.length > 1) {
|
|
244
|
+
// If all real loads came from successful preloads (url preloaded and
|
|
245
|
+
// loads came from the cache), filter to link rel=preload request(s).
|
|
246
|
+
const linkPreloadCandidates = candidates.filter(c => c.isLinkPreload);
|
|
247
|
+
if (linkPreloadCandidates.length) {
|
|
248
|
+
const nonPreloadCandidates = candidates.filter(c => !c.isLinkPreload);
|
|
249
|
+
const allPreloaded = nonPreloadCandidates.every(c => c.fromDiskCache || c.fromMemoryCache);
|
|
250
|
+
if (nonPreloadCandidates.length && allPreloaded) {
|
|
251
|
+
candidates = linkPreloadCandidates;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
// Only return an initiator if the result is unambiguous.
|
|
257
|
+
return candidates.length === 1 ? candidates[0] : null;
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
function linkInitiators(lanternRequests: NetworkRequest[]): void {
|
|
261
|
+
const requestsByURL = new Map<string, NetworkRequest[]>();
|
|
262
|
+
for (const request of lanternRequests) {
|
|
263
|
+
const requests = requestsByURL.get(request.url) || [];
|
|
264
|
+
requests.push(request);
|
|
265
|
+
requestsByURL.set(request.url, requests);
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
for (const request of lanternRequests) {
|
|
269
|
+
const initiatorRequest = chooseInitiatorRequest(request, requestsByURL);
|
|
270
|
+
if (initiatorRequest) {
|
|
271
|
+
request.initiatorRequest = initiatorRequest;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
function createNetworkRequests(
|
|
277
|
+
trace: Lantern.Types.Trace, data: Handlers.Types.HandlerData, startTime = 0,
|
|
278
|
+
endTime = Number.POSITIVE_INFINITY): NetworkRequest[] {
|
|
279
|
+
const workerThreads = findWorkerThreads(trace);
|
|
280
|
+
|
|
281
|
+
const lanternRequestsNoRedirects: NetworkRequest[] = [];
|
|
282
|
+
for (const request of data.NetworkRequests.byTime) {
|
|
283
|
+
if (request.ts >= startTime && request.ts < endTime) {
|
|
284
|
+
const lanternRequest = createLanternRequest(data, workerThreads, request);
|
|
285
|
+
if (lanternRequest) {
|
|
286
|
+
lanternRequestsNoRedirects.push(lanternRequest);
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
const lanternRequests: NetworkRequest[] = [];
|
|
292
|
+
|
|
293
|
+
// Trace Engine consolidates all redirects into a single request object, but lantern needs
|
|
294
|
+
// an entry for each redirected request.
|
|
295
|
+
for (const request of [...lanternRequestsNoRedirects]) {
|
|
296
|
+
if (!request.rawRequest) {
|
|
297
|
+
continue;
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
const redirects = request.rawRequest.args.data.redirects;
|
|
301
|
+
if (!redirects.length) {
|
|
302
|
+
lanternRequests.push(request);
|
|
303
|
+
continue;
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
const requestChain = [];
|
|
307
|
+
for (const redirect of redirects) {
|
|
308
|
+
const redirectedRequest = structuredClone(request);
|
|
309
|
+
|
|
310
|
+
redirectedRequest.networkRequestTime = redirect.ts / 1000;
|
|
311
|
+
redirectedRequest.rendererStartTime = redirectedRequest.networkRequestTime;
|
|
312
|
+
|
|
313
|
+
redirectedRequest.networkEndTime = (redirect.ts + redirect.dur) / 1000;
|
|
314
|
+
redirectedRequest.responseHeadersEndTime = redirectedRequest.networkEndTime;
|
|
315
|
+
|
|
316
|
+
redirectedRequest.timing = {
|
|
317
|
+
requestTime: redirectedRequest.networkRequestTime / 1000,
|
|
318
|
+
receiveHeadersStart: redirectedRequest.responseHeadersEndTime,
|
|
319
|
+
receiveHeadersEnd: redirectedRequest.responseHeadersEndTime,
|
|
320
|
+
proxyStart: -1,
|
|
321
|
+
proxyEnd: -1,
|
|
322
|
+
dnsStart: -1,
|
|
323
|
+
dnsEnd: -1,
|
|
324
|
+
connectStart: -1,
|
|
325
|
+
connectEnd: -1,
|
|
326
|
+
sslStart: -1,
|
|
327
|
+
sslEnd: -1,
|
|
328
|
+
sendStart: -1,
|
|
329
|
+
sendEnd: -1,
|
|
330
|
+
workerStart: -1,
|
|
331
|
+
workerReady: -1,
|
|
332
|
+
workerFetchStart: -1,
|
|
333
|
+
workerRespondWithSettled: -1,
|
|
334
|
+
pushStart: -1,
|
|
335
|
+
pushEnd: -1,
|
|
336
|
+
};
|
|
337
|
+
|
|
338
|
+
redirectedRequest.url = redirect.url;
|
|
339
|
+
redirectedRequest.parsedURL = createParsedUrl(redirect.url);
|
|
340
|
+
// TODO: Trace Engine is not retaining the actual status code.
|
|
341
|
+
redirectedRequest.statusCode = 302;
|
|
342
|
+
redirectedRequest.resourceType = undefined;
|
|
343
|
+
// TODO: Trace Engine is not retaining transfer size of redirected request.
|
|
344
|
+
redirectedRequest.transferSize = 400;
|
|
345
|
+
requestChain.push(redirectedRequest);
|
|
346
|
+
lanternRequests.push(redirectedRequest);
|
|
347
|
+
}
|
|
348
|
+
requestChain.push(request);
|
|
349
|
+
lanternRequests.push(request);
|
|
350
|
+
|
|
351
|
+
for (let i = 0; i < requestChain.length; i++) {
|
|
352
|
+
const request = requestChain[i];
|
|
353
|
+
if (i > 0) {
|
|
354
|
+
request.redirectSource = requestChain[i - 1];
|
|
355
|
+
request.redirects = requestChain.slice(0, i);
|
|
356
|
+
}
|
|
357
|
+
if (i !== requestChain.length - 1) {
|
|
358
|
+
request.redirectDestination = requestChain[i + 1];
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
// Apply the `:redirect` requestId convention: only redirects[0].requestId is the actual
|
|
363
|
+
// requestId, all the rest have n occurrences of `:redirect` as a suffix.
|
|
364
|
+
for (let i = 1; i < requestChain.length; i++) {
|
|
365
|
+
requestChain[i].requestId = `${requestChain[i - 1].requestId}:redirect`;
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
linkInitiators(lanternRequests);
|
|
370
|
+
|
|
371
|
+
return lanternRequests;
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
function collectMainThreadEvents(
|
|
375
|
+
trace: Lantern.Types.Trace, data: Handlers.Types.HandlerData): Lantern.Types.TraceEvent[] {
|
|
376
|
+
const Meta = data.Meta;
|
|
377
|
+
const mainFramePids = Meta.mainFrameNavigations.length ? new Set(Meta.mainFrameNavigations.map(nav => nav.pid)) :
|
|
378
|
+
Meta.topLevelRendererIds;
|
|
379
|
+
|
|
380
|
+
const rendererPidToTid = new Map();
|
|
381
|
+
for (const pid of mainFramePids) {
|
|
382
|
+
const threads = Meta.threadsInProcess.get(pid) ?? [];
|
|
383
|
+
|
|
384
|
+
let found = false;
|
|
385
|
+
for (const [tid, thread] of threads) {
|
|
386
|
+
if (thread.args.name === 'CrRendererMain') {
|
|
387
|
+
rendererPidToTid.set(pid, tid);
|
|
388
|
+
found = true;
|
|
389
|
+
break;
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
if (found) {
|
|
394
|
+
continue;
|
|
395
|
+
}
|
|
396
|
+
|
|
397
|
+
// `CrRendererMain` can be missing if chrome is launched with the `--single-process` flag.
|
|
398
|
+
// In this case, page tasks will be run in the browser thread.
|
|
399
|
+
for (const [tid, thread] of threads) {
|
|
400
|
+
if (thread.args.name === 'CrBrowserMain') {
|
|
401
|
+
rendererPidToTid.set(pid, tid);
|
|
402
|
+
found = true;
|
|
403
|
+
break;
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
return trace.traceEvents.filter(e => rendererPidToTid.get(e.pid) === e.tid);
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
function createGraph(
|
|
412
|
+
requests: Lantern.Types.NetworkRequest[], trace: Lantern.Types.Trace, data: Handlers.Types.HandlerData,
|
|
413
|
+
url?: Lantern.Types.Simulation.URL): Lantern.Graph.Node<Types.Events.SyntheticNetworkRequest> {
|
|
414
|
+
const mainThreadEvents = collectMainThreadEvents(trace, data);
|
|
415
|
+
|
|
416
|
+
// url defines the initial request that the Lantern graph starts at (the root node) and the
|
|
417
|
+
// main document request. These are equal if there are no redirects.
|
|
418
|
+
if (!url) {
|
|
419
|
+
url = {
|
|
420
|
+
requestedUrl: requests[0].url,
|
|
421
|
+
mainDocumentUrl: '',
|
|
422
|
+
};
|
|
423
|
+
|
|
424
|
+
let request = requests[0];
|
|
425
|
+
while (request.redirectDestination) {
|
|
426
|
+
request = request.redirectDestination;
|
|
427
|
+
}
|
|
428
|
+
url.mainDocumentUrl = request.url;
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
return Lantern.Graph.PageDependencyGraph.createGraph(mainThreadEvents, requests, url);
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
export {
|
|
435
|
+
createGraph,
|
|
436
|
+
createNetworkRequests,
|
|
437
|
+
createProcessedNavigation,
|
|
438
|
+
};
|