devtools-tracing 1.1.1 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.local.json +14 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +28854 -0
- package/package.json +11 -8
- package/generate.ts +0 -649
- package/index.ts +0 -17
- package/lib/extension-api/ExtensionAPI.d.ts +0 -357
- package/lib/front_end/core/common/App.ts +0 -7
- package/lib/front_end/core/common/AppProvider.ts +0 -32
- package/lib/front_end/core/common/Base64.ts +0 -47
- package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
- package/lib/front_end/core/common/Color.ts +0 -2506
- package/lib/front_end/core/common/ColorConverter.ts +0 -402
- package/lib/front_end/core/common/ColorUtils.ts +0 -252
- package/lib/front_end/core/common/Console.ts +0 -114
- package/lib/front_end/core/common/Debouncer.ts +0 -15
- package/lib/front_end/core/common/EventTarget.ts +0 -52
- package/lib/front_end/core/common/Gzip.ts +0 -74
- package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
- package/lib/front_end/core/common/Lazy.ts +0 -31
- package/lib/front_end/core/common/Linkifier.ts +0 -55
- package/lib/front_end/core/common/MapWithDefault.ts +0 -26
- package/lib/front_end/core/common/Mutex.ts +0 -55
- package/lib/front_end/core/common/Object.ts +0 -145
- package/lib/front_end/core/common/ParsedURL.ts +0 -554
- package/lib/front_end/core/common/Progress.ts +0 -180
- package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
- package/lib/front_end/core/common/ResolverBase.ts +0 -85
- package/lib/front_end/core/common/ResourceType.ts +0 -588
- package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
- package/lib/front_end/core/common/Revealer.ts +0 -192
- package/lib/front_end/core/common/Runnable.ts +0 -41
- package/lib/front_end/core/common/SegmentedRange.ts +0 -87
- package/lib/front_end/core/common/SettingRegistration.ts +0 -339
- package/lib/front_end/core/common/Settings.ts +0 -1497
- package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
- package/lib/front_end/core/common/StringOutputStream.ts +0 -26
- package/lib/front_end/core/common/TextDictionary.ts +0 -48
- package/lib/front_end/core/common/Throttler.ts +0 -99
- package/lib/front_end/core/common/Trie.ts +0 -152
- package/lib/front_end/core/common/Worker.ts +0 -60
- package/lib/front_end/core/common/common.ts +0 -81
- package/lib/front_end/core/host/AidaClient.ts +0 -733
- package/lib/front_end/core/host/GdpClient.ts +0 -316
- package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
- package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
- package/lib/front_end/core/host/Platform.ts +0 -76
- package/lib/front_end/core/host/ResourceLoader.ts +0 -282
- package/lib/front_end/core/host/UserMetrics.ts +0 -1230
- package/lib/front_end/core/host/host.ts +0 -23
- package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
- package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
- package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
- package/lib/front_end/core/i18n/i18n.ts +0 -17
- package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
- package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
- package/lib/front_end/core/i18n/locales.js +0 -14
- package/lib/front_end/core/i18n/time-utilities.ts +0 -174
- package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
- package/lib/front_end/core/platform/Brand.ts +0 -23
- package/lib/front_end/core/platform/Constructor.ts +0 -10
- package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
- package/lib/front_end/core/platform/DateUtilities.ts +0 -15
- package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
- package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
- package/lib/front_end/core/platform/MapUtilities.ts +0 -95
- package/lib/front_end/core/platform/MimeType.ts +0 -175
- package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
- package/lib/front_end/core/platform/StringUtilities.ts +0 -588
- package/lib/front_end/core/platform/Timing.ts +0 -17
- package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
- package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
- package/lib/front_end/core/platform/UIString.ts +0 -39
- package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
- package/lib/front_end/core/platform/platform.ts +0 -45
- package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
- package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
- package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
- package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
- package/lib/front_end/core/root/Runtime.ts +0 -609
- package/lib/front_end/core/root/root.ts +0 -6
- package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
- package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
- package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
- package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
- package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
- package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
- package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
- package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
- package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
- package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
- package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
- package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
- package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
- package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
- package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
- package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
- package/lib/front_end/core/sdk/CSSRule.ts +0 -465
- package/lib/front_end/core/sdk/CSSScope.ts +0 -30
- package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
- package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
- package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
- package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
- package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
- package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
- package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
- package/lib/front_end/core/sdk/Connections.ts +0 -293
- package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
- package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
- package/lib/front_end/core/sdk/Cookie.ts +0 -319
- package/lib/front_end/core/sdk/CookieModel.ts +0 -239
- package/lib/front_end/core/sdk/CookieParser.ts +0 -185
- package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
- package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
- package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
- package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
- package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
- package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
- package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
- package/lib/front_end/core/sdk/FrameManager.ts +0 -259
- package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
- package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
- package/lib/front_end/core/sdk/IOModel.ts +0 -91
- package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
- package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
- package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
- package/lib/front_end/core/sdk/LogModel.ts +0 -56
- package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
- package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
- package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
- package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
- package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
- package/lib/front_end/core/sdk/PageLoad.ts +0 -35
- package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
- package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
- package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
- package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
- package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
- package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
- package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
- package/lib/front_end/core/sdk/Resource.ts +0 -232
- package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
- package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
- package/lib/front_end/core/sdk/SDKModel.ts +0 -65
- package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
- package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
- package/lib/front_end/core/sdk/Script.ts +0 -534
- package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
- package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
- package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
- package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
- package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
- package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
- package/lib/front_end/core/sdk/SourceMap.ts +0 -867
- package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
- package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
- package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
- package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
- package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
- package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
- package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
- package/lib/front_end/core/sdk/Target.ts +0 -332
- package/lib/front_end/core/sdk/TargetManager.ts +0 -453
- package/lib/front_end/core/sdk/TraceObject.ts +0 -61
- package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
- package/lib/front_end/core/sdk/sdk.ts +0 -174
- package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
- package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
- package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
- package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
- package/lib/front_end/generated/protocol.ts +0 -22014
- package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
- package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
- package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
- package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
- package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
- package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
- package/lib/front_end/models/bindings/FileUtils.ts +0 -228
- package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
- package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
- package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
- package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
- package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
- package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
- package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
- package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
- package/lib/front_end/models/bindings/TempFile.ts +0 -67
- package/lib/front_end/models/bindings/bindings.ts +0 -39
- package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
- package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
- package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
- package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
- package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
- package/lib/front_end/models/formatter/formatter.ts +0 -8
- package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
- package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
- package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
- package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
- package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
- package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
- package/lib/front_end/models/stack_trace/Trie.ts +0 -163
- package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
- package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
- package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
- package/lib/front_end/models/text_utils/ContentData.ts +0 -199
- package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
- package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
- package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
- package/lib/front_end/models/text_utils/Text.ts +0 -90
- package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
- package/lib/front_end/models/text_utils/TextRange.ts +0 -266
- package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
- package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
- package/lib/front_end/models/text_utils/text_utils.ts +0 -27
- package/lib/front_end/models/trace/EntityMapper.ts +0 -141
- package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
- package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
- package/lib/front_end/models/trace/ModelImpl.ts +0 -236
- package/lib/front_end/models/trace/Name.ts +0 -136
- package/lib/front_end/models/trace/Processor.ts +0 -652
- package/lib/front_end/models/trace/Styles.ts +0 -1138
- package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
- package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
- package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
- package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
- package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
- package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
- package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
- package/lib/front_end/models/trace/extras/extras.ts +0 -11
- package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
- package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
- package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
- package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
- package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
- package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
- package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
- package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
- package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
- package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
- package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
- package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
- package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
- package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
- package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
- package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
- package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
- package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
- package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
- package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
- package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
- package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
- package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
- package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
- package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
- package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
- package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
- package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
- package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
- package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
- package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
- package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
- package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
- package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
- package/lib/front_end/models/trace/handlers/types.ts +0 -75
- package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
- package/lib/front_end/models/trace/helpers/Network.ts +0 -129
- package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
- package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
- package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
- package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
- package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
- package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
- package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
- package/lib/front_end/models/trace/insights/Cache.ts +0 -269
- package/lib/front_end/models/trace/insights/Common.ts +0 -453
- package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
- package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
- package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
- package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
- package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
- package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
- package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
- package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
- package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
- package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
- package/lib/front_end/models/trace/insights/Models.ts +0 -22
- package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
- package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
- package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
- package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
- package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
- package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
- package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
- package/lib/front_end/models/trace/insights/insights.ts +0 -10
- package/lib/front_end/models/trace/insights/types.ts +0 -157
- package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
- package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
- package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
- package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
- package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
- package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
- package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
- package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
- package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
- package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
- package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
- package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
- package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
- package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
- package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
- package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
- package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
- package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
- package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
- package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
- package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
- package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
- package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
- package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
- package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
- package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
- package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
- package/lib/front_end/models/trace/trace.ts +0 -33
- package/lib/front_end/models/trace/types/Configuration.ts +0 -110
- package/lib/front_end/models/trace/types/Extensions.ts +0 -136
- package/lib/front_end/models/trace/types/File.ts +0 -281
- package/lib/front_end/models/trace/types/Overlays.ts +0 -138
- package/lib/front_end/models/trace/types/Timing.ts +0 -30
- package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
- package/lib/front_end/models/trace/types/types.ts +0 -10
- package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
- package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
- package/lib/front_end/models/workspace/FileManager.ts +0 -97
- package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
- package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
- package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
- package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
- package/lib/front_end/models/workspace/workspace.ts +0 -17
- package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
- package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
- package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
- package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
- package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
- package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
- package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
- package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
- package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
- package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
- package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/package.json +0 -43
- package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
- package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
- package/lib/front_end/third_party/i18n/LICENSE +0 -202
- package/lib/front_end/third_party/i18n/README.chromium +0 -15
- package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
- package/lib/front_end/third_party/i18n/i18n.ts +0 -11
- package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
- package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
- package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
- package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
- package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
- package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
- package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
- package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
- package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
- package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
- package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
- package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
- package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
- package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
- package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
- package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
- package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
- package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
- package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
- package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
- package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
- package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
- package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
- package/lib/front_end/third_party/third-party-web/package.json +0 -8
- package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
- package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
- package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
- package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
- package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
- package/patches/chrome-devtools-frontend+1.0.1533544.patch +0 -1716
|
@@ -1,319 +0,0 @@
|
|
|
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 i18n from '../../../core/i18n/i18n.js';
|
|
6
|
-
import type * as Handlers from '../handlers/handlers.js';
|
|
7
|
-
import * as Helpers from '../helpers/helpers.js';
|
|
8
|
-
import * as Types from '../types/types.js';
|
|
9
|
-
|
|
10
|
-
import {isRequestCompressed} from './Common.js';
|
|
11
|
-
import {
|
|
12
|
-
type Checklist,
|
|
13
|
-
InsightCategory,
|
|
14
|
-
InsightKeys,
|
|
15
|
-
type InsightModel,
|
|
16
|
-
type InsightSetContext,
|
|
17
|
-
InsightWarning,
|
|
18
|
-
type PartialInsightModel,
|
|
19
|
-
} from './types.js';
|
|
20
|
-
|
|
21
|
-
export const UIStrings = {
|
|
22
|
-
/**
|
|
23
|
-
* @description Title of an insight that provides a breakdown for how long it took to download the main document.
|
|
24
|
-
*/
|
|
25
|
-
title: 'Document request latency',
|
|
26
|
-
/**
|
|
27
|
-
* @description Description of an insight that provides a breakdown for how long it took to download the main document.
|
|
28
|
-
*/
|
|
29
|
-
description:
|
|
30
|
-
'Your first network request is the most important. [Reduce its latency](https://developer.chrome.com/docs/performance/insights/document-latency) by avoiding redirects, ensuring a fast server response, and enabling text compression.',
|
|
31
|
-
/**
|
|
32
|
-
* @description Text to tell the user that the document request does not have redirects.
|
|
33
|
-
*/
|
|
34
|
-
passingRedirects: 'Avoids redirects',
|
|
35
|
-
/**
|
|
36
|
-
* @description Text to tell the user that the document request had redirects.
|
|
37
|
-
* @example {3} PH1
|
|
38
|
-
* @example {1000 ms} PH2
|
|
39
|
-
*/
|
|
40
|
-
failedRedirects: 'Had redirects ({PH1} redirects, +{PH2})',
|
|
41
|
-
/**
|
|
42
|
-
* @description Text to tell the user that the time starting the document request to when the server started responding is acceptable.
|
|
43
|
-
* @example {600 ms} PH1
|
|
44
|
-
*/
|
|
45
|
-
passingServerResponseTime: 'Server responds quickly (observed {PH1})',
|
|
46
|
-
/**
|
|
47
|
-
* @description Text to tell the user that the time starting the document request to when the server started responding is not acceptable.
|
|
48
|
-
* @example {601 ms} PH1
|
|
49
|
-
*/
|
|
50
|
-
failedServerResponseTime: 'Server responded slowly (observed {PH1})',
|
|
51
|
-
/**
|
|
52
|
-
* @description Text to tell the user that text compression (like gzip) was applied.
|
|
53
|
-
*/
|
|
54
|
-
passingTextCompression: 'Applies text compression',
|
|
55
|
-
/**
|
|
56
|
-
* @description Text to tell the user that text compression (like gzip) was not applied.
|
|
57
|
-
*/
|
|
58
|
-
failedTextCompression: 'No compression applied',
|
|
59
|
-
/**
|
|
60
|
-
* @description Text for a label describing a network request event as having redirects.
|
|
61
|
-
*/
|
|
62
|
-
redirectsLabel: 'Redirects',
|
|
63
|
-
/**
|
|
64
|
-
* @description Text for a label describing a network request event as taking too long to start delivery by the server.
|
|
65
|
-
*/
|
|
66
|
-
serverResponseTimeLabel: 'Server response time',
|
|
67
|
-
/**
|
|
68
|
-
* @description Text for a label describing a network request event as taking longer to download because it wasn't compressed.
|
|
69
|
-
*/
|
|
70
|
-
uncompressedDownload: 'Uncompressed download',
|
|
71
|
-
} as const;
|
|
72
|
-
|
|
73
|
-
const str_ = i18n.i18n.registerUIStrings('models/trace/insights/DocumentLatency.ts', UIStrings);
|
|
74
|
-
export const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
|
|
75
|
-
|
|
76
|
-
// Due to the way that DevTools throttling works we cannot see if server response took less than ~570ms.
|
|
77
|
-
// We set our failure threshold to 600ms to avoid those false positives but we want devs to shoot for 100ms.
|
|
78
|
-
const TOO_SLOW_THRESHOLD_MS = 600;
|
|
79
|
-
const TARGET_MS = 100;
|
|
80
|
-
|
|
81
|
-
// Threshold for compression savings.
|
|
82
|
-
const IGNORE_THRESHOLD_IN_BYTES = 1400;
|
|
83
|
-
|
|
84
|
-
export function isDocumentLatencyInsight(x: InsightModel): x is DocumentLatencyInsightModel {
|
|
85
|
-
return x.insightKey === 'DocumentLatency';
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
export type DocumentLatencyInsightModel = InsightModel<typeof UIStrings, {
|
|
89
|
-
data?: {
|
|
90
|
-
serverResponseTime: Types.Timing.Milli,
|
|
91
|
-
redirectDuration: Types.Timing.Milli,
|
|
92
|
-
uncompressedResponseBytes: number,
|
|
93
|
-
checklist: Checklist<'noRedirects'|'serverResponseIsFast'|'usesCompression'>,
|
|
94
|
-
documentRequest?: Types.Events.SyntheticNetworkRequest,
|
|
95
|
-
},
|
|
96
|
-
}>;
|
|
97
|
-
|
|
98
|
-
function getServerResponseTime(request: Types.Events.SyntheticNetworkRequest): Types.Timing.Milli|null {
|
|
99
|
-
// For technical reasons, Lightrider does not have `sendEnd` timing values. The
|
|
100
|
-
// closest we can get to the server response time is from a header that Lightrider
|
|
101
|
-
// sets.
|
|
102
|
-
// @ts-expect-error
|
|
103
|
-
const isLightrider = globalThis.isLightrider;
|
|
104
|
-
if (isLightrider) {
|
|
105
|
-
return request.args.data.lrServerResponseTime ?? null;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
const timing = request.args.data.timing;
|
|
109
|
-
if (!timing) {
|
|
110
|
-
return null;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
const ms = Helpers.Timing.microToMilli(request.args.data.syntheticData.serverResponseTime);
|
|
114
|
-
return Math.round(ms) as Types.Timing.Milli;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
function getCompressionSavings(request: Types.Events.SyntheticNetworkRequest): number {
|
|
118
|
-
const isCompressed = isRequestCompressed(request);
|
|
119
|
-
if (isCompressed) {
|
|
120
|
-
return 0;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
// We don't know how many bytes this asset used on the network, but we can guess it was
|
|
124
|
-
// roughly the size of the content gzipped.
|
|
125
|
-
// See https://developers.google.com/web/fundamentals/performance/optimizing-content-efficiency/optimize-encoding-and-transfer for specific CSS/Script examples
|
|
126
|
-
// See https://discuss.httparchive.org/t/file-size-and-compression-savings/145 for fallback multipliers
|
|
127
|
-
// See https://letstalkaboutwebperf.com/en/gzip-brotli-server-config/ for MIME types to compress
|
|
128
|
-
const originalSize = request.args.data.decodedBodyLength;
|
|
129
|
-
let estimatedSavings = 0;
|
|
130
|
-
switch (request.args.data.mimeType) {
|
|
131
|
-
case 'text/css':
|
|
132
|
-
// Stylesheets tend to compress extremely well.
|
|
133
|
-
estimatedSavings = Math.round(originalSize * 0.8);
|
|
134
|
-
break;
|
|
135
|
-
case 'text/html':
|
|
136
|
-
case 'text/javascript':
|
|
137
|
-
// Scripts and HTML compress fairly well too.
|
|
138
|
-
estimatedSavings = Math.round(originalSize * 0.67);
|
|
139
|
-
break;
|
|
140
|
-
case 'text/plain':
|
|
141
|
-
case 'text/xml':
|
|
142
|
-
case 'text/x-component':
|
|
143
|
-
case 'application/javascript':
|
|
144
|
-
case 'application/json':
|
|
145
|
-
case 'application/manifest+json':
|
|
146
|
-
case 'application/vnd.api+json':
|
|
147
|
-
case 'application/xml':
|
|
148
|
-
case 'application/xhtml+xml':
|
|
149
|
-
case 'application/rss+xml':
|
|
150
|
-
case 'application/atom+xml':
|
|
151
|
-
case 'application/vnd.ms-fontobject':
|
|
152
|
-
case 'application/x-font-ttf':
|
|
153
|
-
case 'application/x-font-opentype':
|
|
154
|
-
case 'application/x-font-truetype':
|
|
155
|
-
case 'image/svg+xml':
|
|
156
|
-
case 'image/x-icon':
|
|
157
|
-
case 'image/vnd.microsoft.icon':
|
|
158
|
-
case 'font/ttf':
|
|
159
|
-
case 'font/eot':
|
|
160
|
-
case 'font/otf':
|
|
161
|
-
case 'font/opentype':
|
|
162
|
-
// Use the average savings in HTTPArchive.
|
|
163
|
-
estimatedSavings = Math.round(originalSize * 0.5);
|
|
164
|
-
break;
|
|
165
|
-
default: // Any other MIME types are likely already compressed.
|
|
166
|
-
}
|
|
167
|
-
// Check if the estimated savings are greater than the byte ignore threshold.
|
|
168
|
-
// Note that the estimated gzip savings are always more than 10%, so there is
|
|
169
|
-
// no percent threshold.
|
|
170
|
-
return estimatedSavings < IGNORE_THRESHOLD_IN_BYTES ? 0 : estimatedSavings;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
function finalize(partialModel: PartialInsightModel<DocumentLatencyInsightModel>): DocumentLatencyInsightModel {
|
|
174
|
-
let hasFailure = false;
|
|
175
|
-
if (partialModel.data) {
|
|
176
|
-
hasFailure = !partialModel.data.checklist.usesCompression.value ||
|
|
177
|
-
!partialModel.data.checklist.serverResponseIsFast.value || !partialModel.data.checklist.noRedirects.value;
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
return {
|
|
181
|
-
insightKey: InsightKeys.DOCUMENT_LATENCY,
|
|
182
|
-
strings: UIStrings,
|
|
183
|
-
title: i18nString(UIStrings.title),
|
|
184
|
-
description: i18nString(UIStrings.description),
|
|
185
|
-
docs: 'https://developer.chrome.com/docs/performance/insights/document-latency',
|
|
186
|
-
category: InsightCategory.ALL,
|
|
187
|
-
state: hasFailure ? 'fail' : 'pass',
|
|
188
|
-
...partialModel,
|
|
189
|
-
};
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
export function generateInsight(
|
|
193
|
-
data: Handlers.Types.HandlerData, context: InsightSetContext): DocumentLatencyInsightModel {
|
|
194
|
-
if (!context.navigation) {
|
|
195
|
-
return finalize({});
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
const millisToString = context.options.insightTimeFormatters?.milli ?? i18n.TimeUtilities.millisToString;
|
|
199
|
-
|
|
200
|
-
const documentRequest = data.NetworkRequests.byId.get(context.navigationId);
|
|
201
|
-
if (!documentRequest) {
|
|
202
|
-
return finalize({warnings: [InsightWarning.NO_DOCUMENT_REQUEST]});
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
const serverResponseTime = getServerResponseTime(documentRequest);
|
|
206
|
-
if (serverResponseTime === null) {
|
|
207
|
-
throw new Error('missing document request timing');
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
const serverResponseTooSlow = serverResponseTime > TOO_SLOW_THRESHOLD_MS;
|
|
211
|
-
|
|
212
|
-
let overallSavingsMs = 0;
|
|
213
|
-
if (serverResponseTime > TOO_SLOW_THRESHOLD_MS) {
|
|
214
|
-
overallSavingsMs = Math.max(serverResponseTime - TARGET_MS, 0);
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
const redirectDuration =
|
|
218
|
-
Math.round(documentRequest.args.data.syntheticData.redirectionDuration / 1000) as Types.Timing.Milli;
|
|
219
|
-
overallSavingsMs += redirectDuration;
|
|
220
|
-
|
|
221
|
-
const metricSavings = {
|
|
222
|
-
FCP: overallSavingsMs as Types.Timing.Milli,
|
|
223
|
-
LCP: overallSavingsMs as Types.Timing.Milli,
|
|
224
|
-
};
|
|
225
|
-
|
|
226
|
-
const uncompressedResponseBytes = getCompressionSavings(documentRequest);
|
|
227
|
-
|
|
228
|
-
const noRedirects = redirectDuration === 0;
|
|
229
|
-
const serverResponseIsFast = !serverResponseTooSlow;
|
|
230
|
-
const usesCompression = uncompressedResponseBytes === 0;
|
|
231
|
-
|
|
232
|
-
return finalize({
|
|
233
|
-
relatedEvents: [documentRequest],
|
|
234
|
-
data: {
|
|
235
|
-
serverResponseTime,
|
|
236
|
-
redirectDuration: Types.Timing.Milli(redirectDuration),
|
|
237
|
-
uncompressedResponseBytes,
|
|
238
|
-
documentRequest,
|
|
239
|
-
checklist: {
|
|
240
|
-
noRedirects: {
|
|
241
|
-
label: noRedirects ? i18nString(UIStrings.passingRedirects) : i18nString(UIStrings.failedRedirects, {
|
|
242
|
-
PH1: documentRequest.args.data.redirects.length,
|
|
243
|
-
PH2: millisToString(redirectDuration),
|
|
244
|
-
}),
|
|
245
|
-
value: noRedirects
|
|
246
|
-
},
|
|
247
|
-
serverResponseIsFast: {
|
|
248
|
-
label: serverResponseIsFast ?
|
|
249
|
-
i18nString(UIStrings.passingServerResponseTime, {PH1: millisToString(serverResponseTime)}) :
|
|
250
|
-
i18nString(UIStrings.failedServerResponseTime, {PH1: millisToString(serverResponseTime)}),
|
|
251
|
-
value: serverResponseIsFast
|
|
252
|
-
},
|
|
253
|
-
usesCompression: {
|
|
254
|
-
label: usesCompression ? i18nString(UIStrings.passingTextCompression) :
|
|
255
|
-
i18nString(UIStrings.failedTextCompression),
|
|
256
|
-
value: usesCompression
|
|
257
|
-
},
|
|
258
|
-
},
|
|
259
|
-
},
|
|
260
|
-
metricSavings,
|
|
261
|
-
wastedBytes: uncompressedResponseBytes,
|
|
262
|
-
});
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
export function createOverlays(model: DocumentLatencyInsightModel): Types.Overlays.Overlay[] {
|
|
266
|
-
if (!model.data?.documentRequest) {
|
|
267
|
-
return [];
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
const overlays: Types.Overlays.Overlay[] = [];
|
|
271
|
-
const event = model.data.documentRequest;
|
|
272
|
-
const redirectDurationMicro = Helpers.Timing.milliToMicro(model.data.redirectDuration);
|
|
273
|
-
|
|
274
|
-
const sections = [];
|
|
275
|
-
if (model.data.redirectDuration) {
|
|
276
|
-
const bounds = Helpers.Timing.traceWindowFromMicroSeconds(
|
|
277
|
-
event.ts,
|
|
278
|
-
(event.ts + redirectDurationMicro) as Types.Timing.Micro,
|
|
279
|
-
);
|
|
280
|
-
sections.push({bounds, label: i18nString(UIStrings.redirectsLabel), showDuration: true});
|
|
281
|
-
overlays.push({type: 'CANDY_STRIPED_TIME_RANGE', bounds, entry: event});
|
|
282
|
-
}
|
|
283
|
-
if (!model.data.checklist.serverResponseIsFast.value) {
|
|
284
|
-
const serverResponseTimeMicro = Helpers.Timing.milliToMicro(model.data.serverResponseTime);
|
|
285
|
-
// NOTE: NetworkRequestHandlers never makes a synthetic network request event if `timing` is missing.
|
|
286
|
-
const sendEnd = event.args.data.timing?.sendEnd ?? Types.Timing.Milli(0);
|
|
287
|
-
const sendEndMicro = Helpers.Timing.milliToMicro(sendEnd);
|
|
288
|
-
const bounds = Helpers.Timing.traceWindowFromMicroSeconds(
|
|
289
|
-
sendEndMicro,
|
|
290
|
-
(sendEndMicro + serverResponseTimeMicro) as Types.Timing.Micro,
|
|
291
|
-
);
|
|
292
|
-
sections.push({bounds, label: i18nString(UIStrings.serverResponseTimeLabel), showDuration: true});
|
|
293
|
-
}
|
|
294
|
-
if (model.data.uncompressedResponseBytes) {
|
|
295
|
-
const bounds = Helpers.Timing.traceWindowFromMicroSeconds(
|
|
296
|
-
event.args.data.syntheticData.downloadStart,
|
|
297
|
-
(event.args.data.syntheticData.downloadStart + event.args.data.syntheticData.download) as Types.Timing.Micro,
|
|
298
|
-
);
|
|
299
|
-
sections.push({bounds, label: i18nString(UIStrings.uncompressedDownload), showDuration: true});
|
|
300
|
-
overlays.push({type: 'CANDY_STRIPED_TIME_RANGE', bounds, entry: event});
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
if (sections.length) {
|
|
304
|
-
overlays.push({
|
|
305
|
-
type: 'TIMESPAN_BREAKDOWN',
|
|
306
|
-
sections,
|
|
307
|
-
entry: model.data.documentRequest,
|
|
308
|
-
// Always render below because the document request is guaranteed to be
|
|
309
|
-
// the first request in the network track.
|
|
310
|
-
renderLocation: 'BELOW_EVENT',
|
|
311
|
-
});
|
|
312
|
-
}
|
|
313
|
-
overlays.push({
|
|
314
|
-
type: 'ENTRY_SELECTED',
|
|
315
|
-
entry: model.data.documentRequest,
|
|
316
|
-
});
|
|
317
|
-
|
|
318
|
-
return overlays;
|
|
319
|
-
}
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
// Copyright 2025 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 i18n from '../../../core/i18n/i18n.js';
|
|
6
|
-
import * as Extras from '../extras/extras.js';
|
|
7
|
-
import type * as Handlers from '../handlers/handlers.js';
|
|
8
|
-
import * as Helpers from '../helpers/helpers.js';
|
|
9
|
-
import type * as Types from '../types/types.js';
|
|
10
|
-
|
|
11
|
-
import {estimateCompressionRatioForScript, metricSavingsForWastedBytes} from './Common.js';
|
|
12
|
-
import {
|
|
13
|
-
InsightCategory,
|
|
14
|
-
InsightKeys,
|
|
15
|
-
type InsightModel,
|
|
16
|
-
type InsightSetContext,
|
|
17
|
-
type PartialInsightModel,
|
|
18
|
-
} from './types.js';
|
|
19
|
-
|
|
20
|
-
export const UIStrings = {
|
|
21
|
-
/**
|
|
22
|
-
* @description Title of an insight that identifies multiple copies of the same JavaScript sources, and recommends removing the duplication.
|
|
23
|
-
*/
|
|
24
|
-
title: 'Duplicated JavaScript',
|
|
25
|
-
/**
|
|
26
|
-
* @description Description of an insight that identifies multiple copies of the same JavaScript sources, and recommends removing the duplication.
|
|
27
|
-
*/
|
|
28
|
-
description:
|
|
29
|
-
'Remove large, [duplicate JavaScript modules](https://developer.chrome.com/docs/performance/insights/duplicated-javascript) from bundles to reduce unnecessary bytes consumed by network activity.',
|
|
30
|
-
/** Label for a column in a data table; entries will be the locations of JavaScript or CSS code, e.g. the name of a Javascript package or module. */
|
|
31
|
-
columnSource: 'Source',
|
|
32
|
-
/** Label for a column in a data table; entries will be the number of wasted bytes due to duplication of a web resource. */
|
|
33
|
-
columnDuplicatedBytes: 'Duplicated bytes',
|
|
34
|
-
} as const;
|
|
35
|
-
|
|
36
|
-
const str_ = i18n.i18n.registerUIStrings('models/trace/insights/DuplicatedJavaScript.ts', UIStrings);
|
|
37
|
-
export const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
|
|
38
|
-
|
|
39
|
-
export type DuplicatedJavaScriptInsightModel = InsightModel<typeof UIStrings, {
|
|
40
|
-
duplication: Extras.ScriptDuplication.ScriptDuplication,
|
|
41
|
-
duplicationGroupedByNodeModules: Extras.ScriptDuplication.ScriptDuplication,
|
|
42
|
-
scriptsWithDuplication: Handlers.ModelHandlers.Scripts.Script[],
|
|
43
|
-
scripts: Handlers.ModelHandlers.Scripts.Script[],
|
|
44
|
-
mainDocumentUrl: string,
|
|
45
|
-
}>;
|
|
46
|
-
|
|
47
|
-
function finalize(partialModel: PartialInsightModel<DuplicatedJavaScriptInsightModel>):
|
|
48
|
-
DuplicatedJavaScriptInsightModel {
|
|
49
|
-
const requests = partialModel.scriptsWithDuplication.map(script => script.request).filter(e => !!e);
|
|
50
|
-
|
|
51
|
-
return {
|
|
52
|
-
insightKey: InsightKeys.DUPLICATE_JAVASCRIPT,
|
|
53
|
-
strings: UIStrings,
|
|
54
|
-
title: i18nString(UIStrings.title),
|
|
55
|
-
description: i18nString(UIStrings.description),
|
|
56
|
-
docs: 'https://developer.chrome.com/docs/performance/insights/duplicated-javascript',
|
|
57
|
-
category: InsightCategory.LCP,
|
|
58
|
-
state: Boolean(partialModel.duplication.values().next().value) ? 'fail' : 'pass',
|
|
59
|
-
relatedEvents: [...new Set(requests)],
|
|
60
|
-
...partialModel,
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
export function isDuplicatedJavaScriptInsight(model: InsightModel): model is DuplicatedJavaScriptInsightModel {
|
|
65
|
-
return model.insightKey === InsightKeys.DUPLICATE_JAVASCRIPT;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
export function generateInsight(
|
|
69
|
-
data: Handlers.Types.HandlerData, context: InsightSetContext): DuplicatedJavaScriptInsightModel {
|
|
70
|
-
const scripts = data.Scripts.scripts.filter(script => {
|
|
71
|
-
if (script.frame !== context.frameId) {
|
|
72
|
-
return false;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
if (script.url?.startsWith('chrome-extension://')) {
|
|
76
|
-
return false;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
return Helpers.Timing.timestampIsInBounds(context.bounds, script.ts);
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
const compressionRatios = new Map<string, number>();
|
|
83
|
-
for (const script of scripts) {
|
|
84
|
-
if (script.request) {
|
|
85
|
-
compressionRatios.set(script.request.args.data.requestId, estimateCompressionRatioForScript(script));
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
const {duplication, duplicationGroupedByNodeModules} =
|
|
90
|
-
Extras.ScriptDuplication.computeScriptDuplication({scripts}, compressionRatios);
|
|
91
|
-
const scriptsWithDuplication = [...duplication.values().flatMap(data => data.duplicates.map(d => d.script))];
|
|
92
|
-
|
|
93
|
-
const wastedBytesByRequestId = new Map<string, number>();
|
|
94
|
-
for (const {duplicates} of duplication.values()) {
|
|
95
|
-
for (let i = 1; i < duplicates.length; i++) {
|
|
96
|
-
const sourceData = duplicates[i];
|
|
97
|
-
if (!sourceData.script.request) {
|
|
98
|
-
continue;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
const transferSize = sourceData.attributedSize;
|
|
102
|
-
const requestId = sourceData.script.request.args.data.requestId;
|
|
103
|
-
wastedBytesByRequestId.set(requestId, (wastedBytesByRequestId.get(requestId) || 0) + transferSize);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
return finalize({
|
|
108
|
-
duplication,
|
|
109
|
-
duplicationGroupedByNodeModules,
|
|
110
|
-
scriptsWithDuplication: [...new Set(scriptsWithDuplication)],
|
|
111
|
-
scripts,
|
|
112
|
-
mainDocumentUrl: context.navigation?.args.data?.url ?? data.Meta.mainFrameURL,
|
|
113
|
-
metricSavings: metricSavingsForWastedBytes(wastedBytesByRequestId, context),
|
|
114
|
-
wastedBytes: wastedBytesByRequestId.values().reduce((acc, cur) => acc + cur, 0),
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
export function createOverlays(model: DuplicatedJavaScriptInsightModel): Types.Overlays.Overlay[] {
|
|
119
|
-
return model.scriptsWithDuplication.map(script => script.request).filter(e => !!e).map(request => {
|
|
120
|
-
return {
|
|
121
|
-
type: 'ENTRY_OUTLINE',
|
|
122
|
-
entry: request,
|
|
123
|
-
outlineReason: 'ERROR',
|
|
124
|
-
};
|
|
125
|
-
});
|
|
126
|
-
}
|
|
@@ -1,119 +0,0 @@
|
|
|
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 i18n from '../../../core/i18n/i18n.js';
|
|
6
|
-
import * as Platform from '../../../core/platform/platform.js';
|
|
7
|
-
import type * as Handlers from '../handlers/handlers.js';
|
|
8
|
-
import * as Helpers from '../helpers/helpers.js';
|
|
9
|
-
import * as Types from '../types/types.js';
|
|
10
|
-
|
|
11
|
-
import {
|
|
12
|
-
InsightCategory,
|
|
13
|
-
InsightKeys,
|
|
14
|
-
type InsightModel,
|
|
15
|
-
type InsightSetContext,
|
|
16
|
-
type PartialInsightModel,
|
|
17
|
-
} from './types.js';
|
|
18
|
-
|
|
19
|
-
export const UIStrings = {
|
|
20
|
-
/** Title of an insight that provides details about the fonts used on the page, and the value of their `font-display` properties. */
|
|
21
|
-
title: 'Font display',
|
|
22
|
-
/**
|
|
23
|
-
* @description Text to tell the user about the font-display CSS feature to help improve a the UX of a page.
|
|
24
|
-
*/
|
|
25
|
-
description:
|
|
26
|
-
'Consider setting [`font-display`](https://developer.chrome.com/docs/performance/insights/font-display) to `swap` or `optional` to ensure text is consistently visible. `swap` can be further optimized to mitigate layout shifts with [font metric overrides](https://developer.chrome.com/blog/font-fallbacks).',
|
|
27
|
-
/** Column for a font loaded by the page to render text. */
|
|
28
|
-
fontColumn: 'Font',
|
|
29
|
-
/** Column for the amount of time wasted. */
|
|
30
|
-
wastedTimeColumn: 'Wasted time',
|
|
31
|
-
} as const;
|
|
32
|
-
|
|
33
|
-
const str_ = i18n.i18n.registerUIStrings('models/trace/insights/FontDisplay.ts', UIStrings);
|
|
34
|
-
export const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
|
|
35
|
-
|
|
36
|
-
export interface RemoteFont {
|
|
37
|
-
name?: string;
|
|
38
|
-
request: Types.Events.SyntheticNetworkRequest;
|
|
39
|
-
display: string;
|
|
40
|
-
wastedTime: Types.Timing.Milli;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export type FontDisplayInsightModel = InsightModel<typeof UIStrings, {
|
|
44
|
-
fonts: RemoteFont[],
|
|
45
|
-
}>;
|
|
46
|
-
|
|
47
|
-
function finalize(partialModel: PartialInsightModel<FontDisplayInsightModel>): FontDisplayInsightModel {
|
|
48
|
-
return {
|
|
49
|
-
insightKey: InsightKeys.FONT_DISPLAY,
|
|
50
|
-
strings: UIStrings,
|
|
51
|
-
title: i18nString(UIStrings.title),
|
|
52
|
-
description: i18nString(UIStrings.description),
|
|
53
|
-
docs: 'https://developer.chrome.com/docs/performance/insights/font-display',
|
|
54
|
-
category: InsightCategory.INP,
|
|
55
|
-
state: partialModel.fonts.find(font => font.wastedTime > 0) ? 'fail' : 'pass',
|
|
56
|
-
...partialModel,
|
|
57
|
-
};
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
export function isFontDisplayInsight(model: InsightModel): model is FontDisplayInsightModel {
|
|
61
|
-
return model.insightKey === InsightKeys.FONT_DISPLAY;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
export function generateInsight(data: Handlers.Types.HandlerData, context: InsightSetContext): FontDisplayInsightModel {
|
|
65
|
-
const fonts: RemoteFont[] = [];
|
|
66
|
-
for (const remoteFont of data.LayoutShifts.remoteFonts) {
|
|
67
|
-
const event = remoteFont.beginRemoteFontLoadEvent;
|
|
68
|
-
if (!Helpers.Timing.eventIsInBounds(event, context.bounds)) {
|
|
69
|
-
continue;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
const requestId = `${event.pid}.${event.args.id}`;
|
|
73
|
-
const request = data.NetworkRequests.byId.get(requestId);
|
|
74
|
-
if (!request) {
|
|
75
|
-
continue;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
if (!/^(block|fallback|auto)$/.test(remoteFont.display)) {
|
|
79
|
-
continue;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
const wastedTimeMicro =
|
|
83
|
-
Types.Timing.Micro(request.args.data.syntheticData.finishTime - request.args.data.syntheticData.sendStartTime);
|
|
84
|
-
// TODO(crbug.com/352244504): should really end at the time of the next Commit trace event.
|
|
85
|
-
let wastedTime =
|
|
86
|
-
Platform.NumberUtilities.floor(Helpers.Timing.microToMilli(wastedTimeMicro), 1 / 5) as Types.Timing.Milli;
|
|
87
|
-
if (wastedTime === 0) {
|
|
88
|
-
continue;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// All browsers wait for no more than 3s.
|
|
92
|
-
wastedTime = Math.min(wastedTime, 3000) as Types.Timing.Milli;
|
|
93
|
-
|
|
94
|
-
fonts.push({
|
|
95
|
-
name: remoteFont.name,
|
|
96
|
-
request,
|
|
97
|
-
display: remoteFont.display,
|
|
98
|
-
wastedTime,
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
fonts.sort((a, b) => b.wastedTime - a.wastedTime);
|
|
103
|
-
|
|
104
|
-
const savings = Math.max(...fonts.map(f => f.wastedTime)) as Types.Timing.Milli;
|
|
105
|
-
|
|
106
|
-
return finalize({
|
|
107
|
-
relatedEvents: fonts.map(f => f.request),
|
|
108
|
-
fonts,
|
|
109
|
-
metricSavings: {FCP: savings},
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
export function createOverlays(model: FontDisplayInsightModel): Types.Overlays.Overlay[] {
|
|
114
|
-
return model.fonts.map(font => ({
|
|
115
|
-
type: 'ENTRY_OUTLINE',
|
|
116
|
-
entry: font.request,
|
|
117
|
-
outlineReason: font.wastedTime ? 'ERROR' : 'INFO',
|
|
118
|
-
}));
|
|
119
|
-
}
|