From 58b59bbcb5f3c59b04b806cb465a3b839cb6e90b Mon Sep 17 00:00:00 2001 From: Connor Clark Date: Tue, 21 Oct 2025 14:49:20 -0700 Subject: [PATCH 1/2] core: fix incorrect dpr used for responsive images advice (#16771) --- .../test-definitions/byte-efficiency.js | 2 +- .../test-definitions/dobetterweb.js | 14 +- core/audits/audit.js | 4 +- core/audits/bootup-time.js | 2 +- core/audits/byte-efficiency/unminified-css.js | 2 +- .../byte-efficiency/unminified-javascript.js | 2 +- .../byte-efficiency/unused-css-rules.js | 4 +- .../byte-efficiency/unused-javascript.js | 2 +- core/audits/insights/cache-insight.js | 2 +- core/audits/insights/cls-culprits-insight.js | 2 +- .../insights/document-latency-insight.js | 2 +- core/audits/insights/dom-size-insight.js | 2 +- .../insights/duplicated-javascript-insight.js | 2 +- core/audits/insights/font-display-insight.js | 2 +- core/audits/insights/forced-reflow-insight.js | 2 +- .../audits/insights/image-delivery-insight.js | 2 +- core/audits/insights/inp-breakdown-insight.js | 2 +- core/audits/insights/insight-audit.js | 5 +- core/audits/insights/lcp-breakdown-insight.js | 2 +- core/audits/insights/lcp-discovery-insight.js | 2 +- .../insights/legacy-javascript-insight.js | 2 +- core/audits/insights/modern-http-insight.js | 2 +- .../network-dependency-tree-insight.js | 2 +- .../insights/render-blocking-insight.js | 2 +- .../insights/slow-css-selector-insight.js | 2 +- core/audits/insights/third-parties-insight.js | 2 +- core/audits/insights/viewport-insight.js | 2 +- core/audits/layout-shifts.js | 6 +- core/audits/long-tasks.js | 6 +- core/audits/mainthread-work-breakdown.js | 2 +- core/audits/metrics.js | 6 +- core/audits/metrics/first-contentful-paint.js | 3 +- core/audits/metrics/interactive.js | 3 +- .../metrics/largest-contentful-paint.js | 3 +- core/audits/metrics/max-potential-fid.js | 3 +- core/audits/metrics/speed-index.js | 6 +- core/audits/metrics/total-blocking-time.js | 6 +- core/audits/predictive-perf.js | 6 +- core/audits/redirects.js | 6 +- core/audits/server-response-time.js | 7 +- .../first-contentful-paint-all-frames.js | 2 +- .../metrics/first-contentful-paint.js | 2 +- core/computed/metrics/interactive.js | 2 +- .../metrics/lantern-first-contentful-paint.js | 2 +- core/computed/metrics/lantern-interactive.js | 2 +- .../lantern-largest-contentful-paint.js | 2 +- .../metrics/lantern-max-potential-fid.js | 2 +- core/computed/metrics/lantern-speed-index.js | 2 +- .../metrics/lantern-total-blocking-time.js | 2 +- .../largest-contentful-paint-all-frames.js | 2 +- .../metrics/largest-contentful-paint.js | 2 +- core/computed/metrics/lcp-breakdown.js | 7 +- core/computed/metrics/max-potential-fid.js | 2 +- core/computed/metrics/metric.js | 1 + core/computed/metrics/speed-index.js | 2 +- core/computed/metrics/time-to-first-byte.js | 9 +- core/computed/metrics/timing-summary.js | 11 +- core/computed/metrics/total-blocking-time.js | 2 +- core/computed/navigation-insights.js | 8 +- core/computed/page-dependency-graph.js | 8 +- core/computed/tbt-impact-tasks.js | 2 +- core/computed/trace-engine-result.js | 11 +- core/gather/gatherers/trace-elements.js | 3 +- core/scripts/generate-insight-audits.js | 2 +- core/scripts/lantern/run-once.js | 1 + core/test/audits/bootup-time-test.js | 1 + .../byte-efficiency-audit-test.js | 7 +- core/test/audits/layout-shifts-test.js | 2 + core/test/audits/long-tasks-test.js | 8 + .../audits/mainthread-work-breakdown-test.js | 3 + core/test/audits/metrics-test.js | 9 + .../metrics/first-contentful-paint-test.js | 2 + core/test/audits/metrics/interactive-test.js | 2 + .../metrics/largest-contentful-paint-test.js | 1 + .../audits/metrics/max-potential-fid-test.js | 2 + core/test/audits/metrics/speed-index-test.js | 2 +- .../metrics/total-blocking-time-test.js | 1 + core/test/audits/predictive-perf-test.js | 1 + core/test/audits/redirects-test.js | 1 + core/test/audits/server-response-time-test.js | 4 + .../first-contentful-paint-all-frames-test.js | 6 +- .../metrics/first-contentful-paint-test.js | 7 +- .../test/computed/metrics/interactive-test.js | 6 +- ...argest-contentful-paint-all-frames-test.js | 8 +- .../metrics/largest-contentful-paint-test.js | 4 +- .../computed/metrics/lcp-breakdown-test.js | 3 + .../metrics/max-potential-fid-test.js | 10 +- .../test/computed/metrics/speed-index-test.js | 11 +- .../metrics/time-to-first-byte-test.js | 2 + .../computed/metrics/timing-summary-test.js | 2 +- .../metrics/total-blocking-time-test.js | 5 +- .../computed/page-dependency-graph-test.js | 1 + core/test/computed/tbt-impact-tasks-test.js | 3 + .../test/computed/trace-engine-result-test.js | 9 +- .../reports/sample-flow-result.json | 32168 +++++++--------- .../gather/gatherers/trace-elements-test.js | 4 + core/test/gather/mock-driver.js | 2 +- core/test/lib/minify-devtoolslog-test.js | 1 + core/test/results/artifacts/artifacts.json | 3 +- core/test/results/sample_v2.json | 56 +- types/artifacts.d.ts | 5 +- 101 files changed, 14271 insertions(+), 18318 deletions(-) diff --git a/cli/test/smokehouse/test-definitions/byte-efficiency.js b/cli/test/smokehouse/test-definitions/byte-efficiency.js index a2d20197f665..9561cd7bee0e 100644 --- a/cli/test/smokehouse/test-definitions/byte-efficiency.js +++ b/cli/test/smokehouse/test-definitions/byte-efficiency.js @@ -214,7 +214,7 @@ const expectations = { // }, // ], debugData: { - wastedBytes: '160000 +/- 10000', + wastedBytes: '132000 +/- 10000', }, }, }, diff --git a/cli/test/smokehouse/test-definitions/dobetterweb.js b/cli/test/smokehouse/test-definitions/dobetterweb.js index 9f17e5149934..6dba0d3b3264 100644 --- a/cli/test/smokehouse/test-definitions/dobetterweb.js +++ b/cli/test/smokehouse/test-definitions/dobetterweb.js @@ -351,42 +351,42 @@ const expectations = { score: '<0.5', metricSavings: {LCP: '>2000'}, details: { - debugData: {wastedBytes: '>1200000'}, + debugData: {wastedBytes: '>1100000'}, items: [ { url: 'http://localhost:10200/dobetterweb/lighthouse-rotating.gif', totalBytes: 934285, - wastedBytes: 682028, + wastedBytes: '682028 +/- 10000', subItems: {items: [{reason: /Using video formats instead of GIFs/}]}, }, { url: 'http://localhost:10200/dobetterweb/lighthouse-1024x680.jpg?iar1', // filename is a lie... totalBytes: 112710, - wastedBytes: 112418, + wastedBytes: '111815 +/- 10000', subItems: {items: [{reason: /This image file is larger than it needs to be \(1024x678\) for its displayed dimensions/}]}, }, { url: 'http://localhost:10200/dobetterweb/lighthouse-1024x680.jpg?isr2', totalBytes: 112710, - wastedBytes: 111152, + wastedBytes: '107937 +/- 10000', subItems: {items: [{reason: /This image file is larger than it needs to be \(1024x678\) for its displayed dimensions/}]}, }, { url: 'http://localhost:10200/dobetterweb/lighthouse-1024x680.jpg?iar2', totalBytes: 112710, - wastedBytes: 111152, + wastedBytes: '107937 +/- 10000', subItems: {items: [{reason: /This image file is larger than it needs to be \(1024x678\) for its displayed dimensions/}]}, }, { url: 'http://localhost:10200/dobetterweb/lighthouse-1024x680.jpg?isr3', totalBytes: 112710, - wastedBytes: 98684, + wastedBytes: '69754 +/- 30000', subItems: {items: [{reason: /This image file is larger than it needs to be \(1024x678\) for its displayed dimensions/}]}, }, { url: 'http://localhost:10200/dobetterweb/lighthouse-1024x680.jpg', totalBytes: 112710, - wastedBytes: 98684, + wastedBytes: '69754 +/- 30000', subItems: {items: [{reason: /This image file is larger than it needs to be \(1024x678\) for its displayed dimensions/}]}, }, ], diff --git a/core/audits/audit.js b/core/audits/audit.js index 68846bca822e..b0d075f880ba 100644 --- a/core/audits/audit.js +++ b/core/audits/audit.js @@ -496,9 +496,9 @@ class Audit { const trace = artifacts.Trace; const devtoolsLog = artifacts.DevtoolsLog; const gatherContext = artifacts.GatherContext; - const {URL, SourceMaps} = artifacts; + const {URL, HostDPR, SourceMaps} = artifacts; // eslint-disable-next-line max-len - return {trace, devtoolsLog, gatherContext, settings: context.settings, URL, SourceMaps, simulator: null}; + return {trace, devtoolsLog, gatherContext, settings: context.settings, URL, SourceMaps, HostDPR, simulator: null}; } } diff --git a/core/audits/bootup-time.js b/core/audits/bootup-time.js index 62638e708d5f..f016ee521b57 100644 --- a/core/audits/bootup-time.js +++ b/core/audits/bootup-time.js @@ -49,7 +49,7 @@ class BootupTime extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 1, - requiredArtifacts: ['Trace', 'DevtoolsLog', 'URL', 'GatherContext', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'URL', 'GatherContext', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/byte-efficiency/unminified-css.js b/core/audits/byte-efficiency/unminified-css.js index 7b5dfa8220db..ad46b049cfab 100644 --- a/core/audits/byte-efficiency/unminified-css.js +++ b/core/audits/byte-efficiency/unminified-css.js @@ -38,7 +38,7 @@ class UnminifiedCSS extends ByteEfficiencyAudit { scoreDisplayMode: ByteEfficiencyAudit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 3, requiredArtifacts: ['Stylesheets', 'DevtoolsLog', 'Trace', 'URL', 'GatherContext', - 'SourceMaps'], + 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/byte-efficiency/unminified-javascript.js b/core/audits/byte-efficiency/unminified-javascript.js index fef9c90b2ba3..2767e14123a5 100644 --- a/core/audits/byte-efficiency/unminified-javascript.js +++ b/core/audits/byte-efficiency/unminified-javascript.js @@ -45,7 +45,7 @@ class UnminifiedJavaScript extends ByteEfficiencyAudit { scoreDisplayMode: ByteEfficiencyAudit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 3, requiredArtifacts: ['Scripts', 'DevtoolsLog', 'Trace', 'GatherContext', 'URL', - 'SourceMaps'], + 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/byte-efficiency/unused-css-rules.js b/core/audits/byte-efficiency/unused-css-rules.js index ef3b425b8cf8..3b58785417ae 100644 --- a/core/audits/byte-efficiency/unused-css-rules.js +++ b/core/audits/byte-efficiency/unused-css-rules.js @@ -34,8 +34,8 @@ class UnusedCSSRules extends ByteEfficiencyAudit { description: str_(UIStrings.description), scoreDisplayMode: ByteEfficiencyAudit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 1, - requiredArtifacts: - ['Stylesheets', 'CSSUsage', 'URL', 'DevtoolsLog', 'Trace', 'GatherContext', 'SourceMaps'], + // eslint-disable-next-line max-len + requiredArtifacts: ['Stylesheets', 'CSSUsage', 'URL', 'DevtoolsLog', 'Trace', 'GatherContext', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/byte-efficiency/unused-javascript.js b/core/audits/byte-efficiency/unused-javascript.js index 712c91e7ec3d..db1f1ae91963 100644 --- a/core/audits/byte-efficiency/unused-javascript.js +++ b/core/audits/byte-efficiency/unused-javascript.js @@ -69,7 +69,7 @@ class UnusedJavaScript extends ByteEfficiencyAudit { scoreDisplayMode: ByteEfficiencyAudit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 1, requiredArtifacts: ['JsUsage', 'Scripts', 'SourceMaps', 'GatherContext', - 'DevtoolsLog', 'Trace', 'URL', 'SourceMaps'], + 'DevtoolsLog', 'Trace', 'URL', 'HostDPR'], }; } diff --git a/core/audits/insights/cache-insight.js b/core/audits/insights/cache-insight.js index 030f080b0d44..3bbcffb426ee 100644 --- a/core/audits/insights/cache-insight.js +++ b/core/audits/insights/cache-insight.js @@ -24,7 +24,7 @@ class CacheInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'SourceMaps'], + requiredArtifacts: ['Trace', 'SourceMaps', 'HostDPR'], replacesAudits: ['uses-long-cache-ttl'], }; } diff --git a/core/audits/insights/cls-culprits-insight.js b/core/audits/insights/cls-culprits-insight.js index 08bb183383bc..1c08b0d61d6e 100644 --- a/core/audits/insights/cls-culprits-insight.js +++ b/core/audits/insights/cls-culprits-insight.js @@ -37,7 +37,7 @@ class CLSCulpritsInsight extends Audit { failureTitle: insightStr_(InsightUIStrings.title), description: insightStr_(InsightUIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['layout-shifts'], }; } diff --git a/core/audits/insights/document-latency-insight.js b/core/audits/insights/document-latency-insight.js index e9be8cb02d15..c941902c384d 100644 --- a/core/audits/insights/document-latency-insight.js +++ b/core/audits/insights/document-latency-insight.js @@ -24,7 +24,7 @@ class DocumentLatencyInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['redirects', 'server-response-time', 'uses-text-compression'], }; } diff --git a/core/audits/insights/dom-size-insight.js b/core/audits/insights/dom-size-insight.js index 3c525ae7c643..eff90a0d003d 100644 --- a/core/audits/insights/dom-size-insight.js +++ b/core/audits/insights/dom-size-insight.js @@ -24,7 +24,7 @@ class DOMSizeInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['dom-size'], }; } diff --git a/core/audits/insights/duplicated-javascript-insight.js b/core/audits/insights/duplicated-javascript-insight.js index c95c24314c45..de5ab4bcada5 100644 --- a/core/audits/insights/duplicated-javascript-insight.js +++ b/core/audits/insights/duplicated-javascript-insight.js @@ -27,7 +27,7 @@ class DuplicatedJavaScriptInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 2, - requiredArtifacts: ['Trace', 'SourceMaps'], + requiredArtifacts: ['Trace', 'SourceMaps', 'HostDPR'], replacesAudits: ['duplicated-javascript'], }; } diff --git a/core/audits/insights/font-display-insight.js b/core/audits/insights/font-display-insight.js index 813269a212e4..b3efdb8d71cd 100644 --- a/core/audits/insights/font-display-insight.js +++ b/core/audits/insights/font-display-insight.js @@ -24,7 +24,7 @@ class FontDisplayInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['font-display'], }; } diff --git a/core/audits/insights/forced-reflow-insight.js b/core/audits/insights/forced-reflow-insight.js index 638e0f8d4da4..142cd072fdc7 100644 --- a/core/audits/insights/forced-reflow-insight.js +++ b/core/audits/insights/forced-reflow-insight.js @@ -24,7 +24,7 @@ class ForcedReflowInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/insights/image-delivery-insight.js b/core/audits/insights/image-delivery-insight.js index 42f6e04f1f86..b4c1884f2575 100644 --- a/core/audits/insights/image-delivery-insight.js +++ b/core/audits/insights/image-delivery-insight.js @@ -29,7 +29,7 @@ class ImageDeliveryInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: [ 'modern-image-formats', 'uses-optimized-images', diff --git a/core/audits/insights/inp-breakdown-insight.js b/core/audits/insights/inp-breakdown-insight.js index 5e7222809529..b55c5865d846 100644 --- a/core/audits/insights/inp-breakdown-insight.js +++ b/core/audits/insights/inp-breakdown-insight.js @@ -24,7 +24,7 @@ class INPBreakdownInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['work-during-interaction'], }; } diff --git a/core/audits/insights/insight-audit.js b/core/audits/insights/insight-audit.js index 087f02f4733e..4712406746c7 100644 --- a/core/audits/insights/insight-audit.js +++ b/core/audits/insights/insight-audit.js @@ -22,8 +22,9 @@ async function getInsightSet(artifacts, context) { const settings = context.settings; const trace = artifacts.Trace; const processedTrace = await ProcessedTrace.request(trace, context); - const SourceMaps = artifacts.SourceMaps; - const traceEngineResult = await TraceEngineResult.request({trace, settings, SourceMaps}, context); + const {SourceMaps, HostDPR} = artifacts; + const traceEngineResult = + await TraceEngineResult.request({trace, settings, SourceMaps, HostDPR}, context); const navigationId = processedTrace.timeOriginEvt.args.data?.navigationId; const key = navigationId ?? NO_NAVIGATION; diff --git a/core/audits/insights/lcp-breakdown-insight.js b/core/audits/insights/lcp-breakdown-insight.js index 2dedb9163fb4..aa1999c7e749 100644 --- a/core/audits/insights/lcp-breakdown-insight.js +++ b/core/audits/insights/lcp-breakdown-insight.js @@ -24,7 +24,7 @@ class LCPBreakdownInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['largest-contentful-paint-element'], }; } diff --git a/core/audits/insights/lcp-discovery-insight.js b/core/audits/insights/lcp-discovery-insight.js index c341f3980ee1..708622e8dc02 100644 --- a/core/audits/insights/lcp-discovery-insight.js +++ b/core/audits/insights/lcp-discovery-insight.js @@ -24,7 +24,7 @@ class LCPDiscoveryInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['prioritize-lcp-image', 'lcp-lazy-loaded'], }; } diff --git a/core/audits/insights/legacy-javascript-insight.js b/core/audits/insights/legacy-javascript-insight.js index 7cc27a27ce30..6638d7b7d3c3 100644 --- a/core/audits/insights/legacy-javascript-insight.js +++ b/core/audits/insights/legacy-javascript-insight.js @@ -28,7 +28,7 @@ class LegacyJavaScriptInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 2, - requiredArtifacts: ['Trace', 'Scripts', 'SourceMaps'], + requiredArtifacts: ['Trace', 'Scripts', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/insights/modern-http-insight.js b/core/audits/insights/modern-http-insight.js index d6814676e9bb..3d4ab5de3384 100644 --- a/core/audits/insights/modern-http-insight.js +++ b/core/audits/insights/modern-http-insight.js @@ -24,7 +24,7 @@ class ModernHTTPInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'SourceMaps'], + requiredArtifacts: ['Trace', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/insights/network-dependency-tree-insight.js b/core/audits/insights/network-dependency-tree-insight.js index 58c6f0eeb2ec..194bb1cfbe84 100644 --- a/core/audits/insights/network-dependency-tree-insight.js +++ b/core/audits/insights/network-dependency-tree-insight.js @@ -24,7 +24,7 @@ class NetworkDependencyTreeInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 1, - requiredArtifacts: ['Trace', 'SourceMaps', 'TraceElements'], + requiredArtifacts: ['Trace', 'SourceMaps', 'TraceElements', 'HostDPR'], replacesAudits: ['critical-request-chains', 'uses-rel-preconnect'], }; } diff --git a/core/audits/insights/render-blocking-insight.js b/core/audits/insights/render-blocking-insight.js index 40c30920a309..d7cd80f9399b 100644 --- a/core/audits/insights/render-blocking-insight.js +++ b/core/audits/insights/render-blocking-insight.js @@ -24,7 +24,7 @@ class RenderBlockingInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['render-blocking-resources'], }; } diff --git a/core/audits/insights/slow-css-selector-insight.js b/core/audits/insights/slow-css-selector-insight.js index a9db9aa65bdd..2f3055e63d94 100644 --- a/core/audits/insights/slow-css-selector-insight.js +++ b/core/audits/insights/slow-css-selector-insight.js @@ -28,7 +28,7 @@ class SlowCSSSelectorInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/insights/third-parties-insight.js b/core/audits/insights/third-parties-insight.js index 619cbb0af892..9febf7bba5e2 100644 --- a/core/audits/insights/third-parties-insight.js +++ b/core/audits/insights/third-parties-insight.js @@ -32,7 +32,7 @@ class ThirdPartiesInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['third-party-summary'], }; } diff --git a/core/audits/insights/viewport-insight.js b/core/audits/insights/viewport-insight.js index 76dcdb5c9c56..370a9a948a78 100644 --- a/core/audits/insights/viewport-insight.js +++ b/core/audits/insights/viewport-insight.js @@ -24,7 +24,7 @@ class ViewportInsight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], replacesAudits: ['viewport'], }; } diff --git a/core/audits/layout-shifts.js b/core/audits/layout-shifts.js index 3653ca255a69..dd5e2d981652 100644 --- a/core/audits/layout-shifts.js +++ b/core/audits/layout-shifts.js @@ -47,7 +47,7 @@ class LayoutShifts extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 2, - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], }; } @@ -59,9 +59,9 @@ class LayoutShifts extends Audit { static async audit(artifacts, context) { const settings = context.settings; const trace = artifacts.Trace; - const SourceMaps = artifacts.SourceMaps; + const {SourceMaps, HostDPR} = artifacts; const traceEngineResult = - await TraceEngineResult.request({trace, settings, SourceMaps}, context); + await TraceEngineResult.request({trace, settings, SourceMaps, HostDPR}, context); const clusters = traceEngineResult.data.LayoutShifts.clusters ?? []; const {cumulativeLayoutShift: clsSavings, impactByNodeId} = await CumulativeLayoutShiftComputed.request(trace, context); diff --git a/core/audits/long-tasks.js b/core/audits/long-tasks.js index 5be0ce472883..6fa73be43104 100644 --- a/core/audits/long-tasks.js +++ b/core/audits/long-tasks.js @@ -68,7 +68,7 @@ class LongTasks extends Audit { scoreDisplayMode: Audit.SCORING_MODES.INFORMATIVE, title: str_(UIStrings.title), description: str_(UIStrings.description), - requiredArtifacts: ['Trace', 'DevtoolsLog', 'URL', 'GatherContext', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'URL', 'GatherContext', 'SourceMaps', 'HostDPR'], guidanceLevel: 1, }; } @@ -176,7 +176,7 @@ class LongTasks extends Audit { */ static async audit(artifacts, context) { const settings = context.settings || {}; - const {URL, SourceMaps} = artifacts; + const {URL, HostDPR, SourceMaps} = artifacts; const trace = artifacts.Trace; const tasks = await MainThreadTasks.request(trace, context); const devtoolsLog = artifacts.DevtoolsLog; @@ -194,7 +194,7 @@ class LongTasks extends Audit { const simulatorOptions = {devtoolsLog, settings: context.settings}; const pageGraph = // eslint-disable-next-line max-len - await PageDependencyGraph.request({settings, trace, devtoolsLog, URL, SourceMaps, fromTrace: false}, context); + await PageDependencyGraph.request({settings, trace, devtoolsLog, URL, SourceMaps, HostDPR, fromTrace: false}, context); const simulator = await LoadSimulator.request(simulatorOptions, context); const simulation = simulator.simulate(pageGraph, {label: 'long-tasks-diagnostic'}); for (const [node, timing] of simulation.nodeTimings.entries()) { diff --git a/core/audits/mainthread-work-breakdown.js b/core/audits/mainthread-work-breakdown.js index 39e71a9098a9..304996f578a4 100644 --- a/core/audits/mainthread-work-breakdown.js +++ b/core/audits/mainthread-work-breakdown.js @@ -46,7 +46,7 @@ class MainThreadWorkBreakdown extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.METRIC_SAVINGS, guidanceLevel: 1, - requiredArtifacts: ['Trace', 'DevtoolsLog', 'URL', 'GatherContext', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'URL', 'GatherContext', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/audits/metrics.js b/core/audits/metrics.js index 0ddf8435c8dc..c30e73b28f38 100644 --- a/core/audits/metrics.js +++ b/core/audits/metrics.js @@ -26,7 +26,7 @@ class Metrics extends Audit { title: 'Metrics', description: 'Collects all available metrics.', supportedModes: ['navigation'], - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -40,9 +40,9 @@ class Metrics extends Audit { const gatherContext = artifacts.GatherContext; const trace = artifacts.Trace; const devtoolsLog = artifacts.DevtoolsLog; - const {URL, SourceMaps} = artifacts; + const {URL, HostDPR, SourceMaps} = artifacts; const summary = await TimingSummary - .request({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps}, context); + .request({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR}, context); const metrics = summary.metrics; const debugInfo = summary.debugInfo; diff --git a/core/audits/metrics/first-contentful-paint.js b/core/audits/metrics/first-contentful-paint.js index de10f1b122c3..a8be1b29fd9a 100644 --- a/core/audits/metrics/first-contentful-paint.js +++ b/core/audits/metrics/first-contentful-paint.js @@ -27,7 +27,7 @@ class FirstContentfulPaint extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, supportedModes: ['navigation'], - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -67,6 +67,7 @@ class FirstContentfulPaint extends Audit { const metricComputationData = {trace, devtoolsLog, gatherContext, settings: context.settings, URL: artifacts.URL, SourceMaps: artifacts.SourceMaps, simulator: null, + HostDPR: artifacts.HostDPR, }; const metricResult = await ComputedFcp.request(metricComputationData, context); const options = context.options[context.settings.formFactor]; diff --git a/core/audits/metrics/interactive.js b/core/audits/metrics/interactive.js index af297e39afc9..8747cc431f84 100644 --- a/core/audits/metrics/interactive.js +++ b/core/audits/metrics/interactive.js @@ -33,7 +33,7 @@ class InteractiveMetric extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, supportedModes: ['navigation'], - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -74,6 +74,7 @@ class InteractiveMetric extends Audit { trace, devtoolsLog, gatherContext, settings: context.settings, URL: artifacts.URL, SourceMaps: artifacts.SourceMaps, simulator: null, + HostDPR: artifacts.HostDPR, }; const metricResult = await Interactive.request(metricComputationData, context); const timeInMs = metricResult.timing; diff --git a/core/audits/metrics/largest-contentful-paint.js b/core/audits/metrics/largest-contentful-paint.js index 8c88d825942d..faac722e5382 100644 --- a/core/audits/metrics/largest-contentful-paint.js +++ b/core/audits/metrics/largest-contentful-paint.js @@ -28,7 +28,7 @@ class LargestContentfulPaint extends Audit { scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, supportedModes: ['navigation'], requiredArtifacts: ['HostUserAgent', 'Trace', 'DevtoolsLog', 'GatherContext', 'URL', - 'SourceMaps'], + 'SourceMaps', 'HostDPR'], }; } @@ -77,6 +77,7 @@ class LargestContentfulPaint extends Audit { trace, devtoolsLog, gatherContext, settings: context.settings, URL: artifacts.URL, SourceMaps: artifacts.SourceMaps, simulator: null, + HostDPR: artifacts.HostDPR, }; const metricResult = await ComputedLcp.request(metricComputationData, context); diff --git a/core/audits/metrics/max-potential-fid.js b/core/audits/metrics/max-potential-fid.js index cc5d5ae89d97..9564356a9d5d 100644 --- a/core/audits/metrics/max-potential-fid.js +++ b/core/audits/metrics/max-potential-fid.js @@ -43,7 +43,7 @@ class MaxPotentialFID extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, supportedModes: ['navigation'], - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -124,6 +124,7 @@ class MaxPotentialFID extends Audit { trace, devtoolsLog, gatherContext, settings: context.settings, URL: artifacts.URL, SourceMaps: artifacts.SourceMaps, simulator: null, + HostDPR: artifacts.HostDPR, }; const metricResult = await ComputedFid.request(metricComputationData, context); diff --git a/core/audits/metrics/speed-index.js b/core/audits/metrics/speed-index.js index 53c3884d65e1..09e16feac52c 100644 --- a/core/audits/metrics/speed-index.js +++ b/core/audits/metrics/speed-index.js @@ -27,7 +27,7 @@ class SpeedIndex extends Audit { description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, supportedModes: ['navigation'], - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -69,7 +69,9 @@ class SpeedIndex extends Audit { const metricComputationData = { trace, devtoolsLog, gatherContext, settings: context.settings, URL: artifacts.URL, - SourceMaps: artifacts.SourceMaps, simulator: null, + SourceMaps: artifacts.SourceMaps, + HostDPR: artifacts.HostDPR, + simulator: null, }; const metricResult = await ComputedSi.request(metricComputationData, context); const options = context.options[context.settings.formFactor]; diff --git a/core/audits/metrics/total-blocking-time.js b/core/audits/metrics/total-blocking-time.js index b738da7638ea..f68e6eb08f34 100644 --- a/core/audits/metrics/total-blocking-time.js +++ b/core/audits/metrics/total-blocking-time.js @@ -27,7 +27,7 @@ class TotalBlockingTime extends Audit { title: str_(i18n.UIStrings.totalBlockingTimeMetric), description: str_(UIStrings.description), scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -91,7 +91,9 @@ class TotalBlockingTime extends Audit { const metricComputationData = { trace, devtoolsLog, gatherContext, settings: context.settings, URL: artifacts.URL, - SourceMaps: artifacts.SourceMaps, simulator: null, + SourceMaps: artifacts.SourceMaps, + HostDPR: artifacts.HostDPR, + simulator: null, }; if ( gatherContext.gatherMode === 'timespan' && diff --git a/core/audits/predictive-perf.js b/core/audits/predictive-perf.js index 0f9beefca4fd..a2e0cb2fbedc 100644 --- a/core/audits/predictive-perf.js +++ b/core/audits/predictive-perf.js @@ -33,7 +33,7 @@ class PredictivePerf extends Audit { 'a cellular connection on a mobile device.', scoreDisplayMode: Audit.SCORING_MODES.NUMERIC, supportedModes: ['navigation'], - requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps'], + requiredArtifacts: ['Trace', 'DevtoolsLog', 'GatherContext', 'URL', 'SourceMaps', 'HostDPR'], }; } @@ -46,11 +46,11 @@ class PredictivePerf extends Audit { const gatherContext = artifacts.GatherContext; const trace = artifacts.Trace; const devtoolsLog = artifacts.DevtoolsLog; - const {URL, SourceMaps} = artifacts; + const {URL, HostDPR, SourceMaps} = artifacts; /** @type {LH.Config.Settings} */ const settings = JSON.parse(JSON.stringify(defaultSettings)); // Use default settings. const computationData = - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, simulator: null}; + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR, simulator: null}; const fcp = await LanternFirstContentfulPaint.request(computationData, context); const tti = await LanternInteractive.request(computationData, context); const si = await LanternSpeedIndex.request(computationData, context); diff --git a/core/audits/redirects.js b/core/audits/redirects.js index b93d98529232..5ba3dfca1e00 100644 --- a/core/audits/redirects.js +++ b/core/audits/redirects.js @@ -31,7 +31,7 @@ class Redirects extends Audit { scoreDisplayMode: Audit.SCORING_MODES.METRIC_SAVINGS, supportedModes: ['navigation'], guidanceLevel: 2, - requiredArtifacts: ['URL', 'GatherContext', 'DevtoolsLog', 'Trace', 'SourceMaps'], + requiredArtifacts: ['URL', 'GatherContext', 'DevtoolsLog', 'Trace', 'SourceMaps', 'HostDPR'], }; } @@ -87,14 +87,14 @@ class Redirects extends Audit { const trace = artifacts.Trace; const devtoolsLog = artifacts.DevtoolsLog; const gatherContext = artifacts.GatherContext; - const {URL, SourceMaps} = artifacts; + const {URL, HostDPR, SourceMaps} = artifacts; const processedTrace = await ProcessedTrace.request(trace, context); const networkRecords = await NetworkRecords.request(devtoolsLog, context); const documentRequests = Redirects.getDocumentRequestChain(networkRecords, processedTrace); const metricComputationData = - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, simulator: null}; + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR, simulator: null}; const metricResult = await LanternInteractive.request(metricComputationData, context); /** @type {Map} */ diff --git a/core/audits/server-response-time.js b/core/audits/server-response-time.js index 366ab0f0895f..e8e33a8ae270 100644 --- a/core/audits/server-response-time.js +++ b/core/audits/server-response-time.js @@ -35,7 +35,7 @@ class ServerResponseTime extends Audit { description: str_(UIStrings.description), supportedModes: ['navigation'], guidanceLevel: 1, - requiredArtifacts: ['Trace', 'SourceMaps'], + requiredArtifacts: ['Trace', 'SourceMaps', 'HostDPR'], scoreDisplayMode: Audit.SCORING_MODES.METRIC_SAVINGS, }; } @@ -48,8 +48,9 @@ class ServerResponseTime extends Audit { static async audit(artifacts, context) { const settings = context.settings; const trace = artifacts.Trace; - const SourceMaps = artifacts.SourceMaps; - const navInsights = await NavigationInsights.request({trace, settings, SourceMaps}, context); + const {SourceMaps, HostDPR} = artifacts; + const navInsights = + await NavigationInsights.request({trace, settings, SourceMaps, HostDPR}, context); const responseTime = navInsights.model.DocumentLatency.data?.serverResponseTime; const url = navInsights.model.DocumentLatency.data?.documentRequest?.args.data.url; diff --git a/core/computed/metrics/first-contentful-paint-all-frames.js b/core/computed/metrics/first-contentful-paint-all-frames.js index 34074390e1ed..9c00e835f30c 100644 --- a/core/computed/metrics/first-contentful-paint-all-frames.js +++ b/core/computed/metrics/first-contentful-paint-all-frames.js @@ -32,6 +32,6 @@ class FirstContentfulPaintAllFrames extends NavigationMetric { const FirstContentfulPaintAllFramesComputed = makeComputedArtifact( FirstContentfulPaintAllFrames, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {FirstContentfulPaintAllFramesComputed as FirstContentfulPaintAllFrames}; diff --git a/core/computed/metrics/first-contentful-paint.js b/core/computed/metrics/first-contentful-paint.js index 146554a1ef82..c8fa1f8c8cba 100644 --- a/core/computed/metrics/first-contentful-paint.js +++ b/core/computed/metrics/first-contentful-paint.js @@ -35,6 +35,6 @@ class FirstContentfulPaint extends NavigationMetric { const FirstContentfulPaintComputed = makeComputedArtifact( FirstContentfulPaint, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {FirstContentfulPaintComputed as FirstContentfulPaint}; diff --git a/core/computed/metrics/interactive.js b/core/computed/metrics/interactive.js index ec081e94acb6..bce752d69b01 100644 --- a/core/computed/metrics/interactive.js +++ b/core/computed/metrics/interactive.js @@ -181,7 +181,7 @@ class Interactive extends NavigationMetric { const InteractiveComputed = makeComputedArtifact( Interactive, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {InteractiveComputed as Interactive}; diff --git a/core/computed/metrics/lantern-first-contentful-paint.js b/core/computed/metrics/lantern-first-contentful-paint.js index c0d05f60f7cb..f6b64cb4f5a0 100644 --- a/core/computed/metrics/lantern-first-contentful-paint.js +++ b/core/computed/metrics/lantern-first-contentful-paint.js @@ -32,6 +32,6 @@ class LanternFirstContentfulPaint extends Lantern.Metrics.FirstContentfulPaint { const LanternFirstContentfulPaintComputed = makeComputedArtifact( LanternFirstContentfulPaint, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LanternFirstContentfulPaintComputed as LanternFirstContentfulPaint}; diff --git a/core/computed/metrics/lantern-interactive.js b/core/computed/metrics/lantern-interactive.js index 88d1c63c77a1..4da68c2866cb 100644 --- a/core/computed/metrics/lantern-interactive.js +++ b/core/computed/metrics/lantern-interactive.js @@ -34,6 +34,6 @@ class LanternInteractive extends Lantern.Metrics.Interactive { const LanternInteractiveComputed = makeComputedArtifact( LanternInteractive, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LanternInteractiveComputed as LanternInteractive}; diff --git a/core/computed/metrics/lantern-largest-contentful-paint.js b/core/computed/metrics/lantern-largest-contentful-paint.js index 85d7da93cb9a..a2eb51c048d4 100644 --- a/core/computed/metrics/lantern-largest-contentful-paint.js +++ b/core/computed/metrics/lantern-largest-contentful-paint.js @@ -34,6 +34,6 @@ class LanternLargestContentfulPaint extends Lantern.Metrics.LargestContentfulPai const LanternLargestContentfulPaintComputed = makeComputedArtifact( LanternLargestContentfulPaint, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LanternLargestContentfulPaintComputed as LanternLargestContentfulPaint}; diff --git a/core/computed/metrics/lantern-max-potential-fid.js b/core/computed/metrics/lantern-max-potential-fid.js index d0541977413e..9537b6cb4a7a 100644 --- a/core/computed/metrics/lantern-max-potential-fid.js +++ b/core/computed/metrics/lantern-max-potential-fid.js @@ -34,6 +34,6 @@ class LanternMaxPotentialFID extends Lantern.Metrics.MaxPotentialFID { const LanternMaxPotentialFIDComputed = makeComputedArtifact( LanternMaxPotentialFID, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LanternMaxPotentialFIDComputed as LanternMaxPotentialFID}; diff --git a/core/computed/metrics/lantern-speed-index.js b/core/computed/metrics/lantern-speed-index.js index 53b3a01458a2..c65a34da5749 100644 --- a/core/computed/metrics/lantern-speed-index.js +++ b/core/computed/metrics/lantern-speed-index.js @@ -40,6 +40,6 @@ class LanternSpeedIndex extends Lantern.Metrics.SpeedIndex { const LanternSpeedIndexComputed = makeComputedArtifact( LanternSpeedIndex, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LanternSpeedIndexComputed as LanternSpeedIndex}; diff --git a/core/computed/metrics/lantern-total-blocking-time.js b/core/computed/metrics/lantern-total-blocking-time.js index 2a942fd5663e..4b237286c0a1 100644 --- a/core/computed/metrics/lantern-total-blocking-time.js +++ b/core/computed/metrics/lantern-total-blocking-time.js @@ -35,6 +35,6 @@ class LanternTotalBlockingTime extends Lantern.Metrics.TotalBlockingTime { const LanternTotalBlockingTimeComputed = makeComputedArtifact( LanternTotalBlockingTime, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LanternTotalBlockingTimeComputed as LanternTotalBlockingTime}; diff --git a/core/computed/metrics/largest-contentful-paint-all-frames.js b/core/computed/metrics/largest-contentful-paint-all-frames.js index 45fe7b03e623..844a24cae901 100644 --- a/core/computed/metrics/largest-contentful-paint-all-frames.js +++ b/core/computed/metrics/largest-contentful-paint-all-frames.js @@ -40,6 +40,6 @@ class LargestContentfulPaintAllFrames extends NavigationMetric { const LargestContentfulPaintAllFramesComputed = makeComputedArtifact( LargestContentfulPaintAllFrames, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LargestContentfulPaintAllFramesComputed as LargestContentfulPaintAllFrames}; diff --git a/core/computed/metrics/largest-contentful-paint.js b/core/computed/metrics/largest-contentful-paint.js index 0da64d586f6b..f708e09463f7 100644 --- a/core/computed/metrics/largest-contentful-paint.js +++ b/core/computed/metrics/largest-contentful-paint.js @@ -47,6 +47,6 @@ class LargestContentfulPaint extends NavigationMetric { const LargestContentfulPaintComputed = makeComputedArtifact( LargestContentfulPaint, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LargestContentfulPaintComputed as LargestContentfulPaint}; diff --git a/core/computed/metrics/lcp-breakdown.js b/core/computed/metrics/lcp-breakdown.js index 73c6759d59df..5b6a20a826dc 100644 --- a/core/computed/metrics/lcp-breakdown.js +++ b/core/computed/metrics/lcp-breakdown.js @@ -54,8 +54,9 @@ class LCPBreakdown { }; } - const {trace, settings, SourceMaps} = data; - const navInsights = await NavigationInsights.request({trace, settings, SourceMaps}, context); + const {trace, settings, SourceMaps, HostDPR} = data; + const navInsights = + await NavigationInsights.request({trace, settings, SourceMaps, HostDPR}, context); const lcpBreakdown = navInsights.model.LCPBreakdown; if (lcpBreakdown instanceof Error) { throw new LighthouseError(LighthouseError.errors.NO_LCP, {}, {cause: lcpBreakdown}); @@ -80,7 +81,7 @@ class LCPBreakdown { const LCPBreakdownComputed = makeComputedArtifact( LCPBreakdown, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {LCPBreakdownComputed as LCPBreakdown}; diff --git a/core/computed/metrics/max-potential-fid.js b/core/computed/metrics/max-potential-fid.js index d24041ee06ac..429a8467eb4f 100644 --- a/core/computed/metrics/max-potential-fid.js +++ b/core/computed/metrics/max-potential-fid.js @@ -40,6 +40,6 @@ class MaxPotentialFID extends NavigationMetric { const MaxPotentialFIDComputed = makeComputedArtifact( MaxPotentialFID, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {MaxPotentialFIDComputed as MaxPotentialFID}; diff --git a/core/computed/metrics/metric.js b/core/computed/metrics/metric.js index d14df07ac236..cf188b3a389e 100644 --- a/core/computed/metrics/metric.js +++ b/core/computed/metrics/metric.js @@ -35,6 +35,7 @@ class Metric { settings: data.settings, URL: data.URL, SourceMaps: data.SourceMaps, + HostDPR: data.HostDPR, simulator: null, }; } diff --git a/core/computed/metrics/speed-index.js b/core/computed/metrics/speed-index.js index bdf552fab8f5..9ed2c28b342d 100644 --- a/core/computed/metrics/speed-index.js +++ b/core/computed/metrics/speed-index.js @@ -35,6 +35,6 @@ class SpeedIndex extends NavigationMetric { const SpeedIndexComputed = makeComputedArtifact( SpeedIndex, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {SpeedIndexComputed as SpeedIndex}; diff --git a/core/computed/metrics/time-to-first-byte.js b/core/computed/metrics/time-to-first-byte.js index 2f91b6bce21d..6d46bda8c32e 100644 --- a/core/computed/metrics/time-to-first-byte.js +++ b/core/computed/metrics/time-to-first-byte.js @@ -45,10 +45,11 @@ class TimeToFirstByte extends NavigationMetric { * @return {Promise} */ static async computeObservedMetric(data, context) { - const {trace, settings, SourceMaps} = data; + const {trace, settings, SourceMaps, HostDPR} = data; const traceEngineResult = - await TraceEngineResult.request({trace, settings, SourceMaps}, context); - const navInsights = await NavigationInsights.request({trace, settings, SourceMaps}, context); + await TraceEngineResult.request({trace, settings, SourceMaps, HostDPR}, context); + const navInsights = + await NavigationInsights.request({trace, settings, SourceMaps, HostDPR}, context); const lcpBreakdown = navInsights.model.LCPBreakdown; // Defer to LCP breakdown, but if there's no LCP fallback to manual calculation. @@ -81,6 +82,6 @@ class TimeToFirstByte extends NavigationMetric { const TimeToFirstByteComputed = makeComputedArtifact( TimeToFirstByte, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {TimeToFirstByteComputed as TimeToFirstByte}; diff --git a/core/computed/metrics/timing-summary.js b/core/computed/metrics/timing-summary.js index debf814a4021..9f2052331367 100644 --- a/core/computed/metrics/timing-summary.js +++ b/core/computed/metrics/timing-summary.js @@ -31,12 +31,14 @@ class TimingSummary { * @param {LH.Util.ImmutableObject} settings * @param {LH.Artifacts['URL']} URL * @param {LH.Artifacts['SourceMaps']} SourceMaps + * @param {LH.Artifacts['HostDPR']} HostDPR * @param {LH.Artifacts.ComputedContext} context * @return {Promise<{metrics: LH.Artifacts.TimingSummary, debugInfo: Record}>} */ - static async summarize(trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, context) { + // eslint-disable-next-line max-len + static async summarize(trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR, context) { const metricComputationData = - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, simulator: null}; + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR, simulator: null}; /** * @template TArtifacts @@ -147,7 +149,7 @@ class TimingSummary { return {metrics, debugInfo}; } /** - * @param {{trace: LH.Trace, devtoolsLog: LH.DevtoolsLog, gatherContext: LH.Artifacts['GatherContext']; settings: LH.Util.ImmutableObject, URL: LH.Artifacts['URL'], SourceMaps: LH.Artifacts['SourceMaps']}} data + * @param {{trace: LH.Trace, devtoolsLog: LH.DevtoolsLog, gatherContext: LH.Artifacts['GatherContext']; settings: LH.Util.ImmutableObject, URL: LH.Artifacts['URL'], SourceMaps: LH.Artifacts['SourceMaps'], HostDPR: LH.Artifacts['HostDPR']}} data * @param {LH.Artifacts.ComputedContext} context * @return {Promise<{metrics: LH.Artifacts.TimingSummary, debugInfo: Record}>} */ @@ -159,6 +161,7 @@ class TimingSummary { data.settings, data.URL, data.SourceMaps, + data.HostDPR, context ); } @@ -166,6 +169,6 @@ class TimingSummary { const TimingSummaryComputed = makeComputedArtifact( TimingSummary, - ['devtoolsLog', 'gatherContext', 'settings', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {TimingSummaryComputed as TimingSummary}; diff --git a/core/computed/metrics/total-blocking-time.js b/core/computed/metrics/total-blocking-time.js index 31a1d77fd504..1729305a60d8 100644 --- a/core/computed/metrics/total-blocking-time.js +++ b/core/computed/metrics/total-blocking-time.js @@ -71,6 +71,6 @@ class TotalBlockingTime extends ComputedMetric { const TotalBlockingTimeComputed = makeComputedArtifact( TotalBlockingTime, - ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps'] + ['devtoolsLog', 'gatherContext', 'settings', 'simulator', 'trace', 'URL', 'SourceMaps', 'HostDPR'] ); export {TotalBlockingTimeComputed as TotalBlockingTime}; diff --git a/core/computed/navigation-insights.js b/core/computed/navigation-insights.js index 94e938917eea..8d22394b5f4f 100644 --- a/core/computed/navigation-insights.js +++ b/core/computed/navigation-insights.js @@ -14,14 +14,14 @@ import {TraceEngineResult} from './trace-engine-result.js'; */ class NavigationInsights { /** - * @param {{trace: LH.Trace, settings: LH.Audit.Context['settings'], SourceMaps: LH.Artifacts['SourceMaps']}} data + * @param {{trace: LH.Trace, settings: LH.Audit.Context['settings'], SourceMaps: LH.Artifacts['SourceMaps'], HostDPR: LH.Artifacts['HostDPR']}} data * @param {LH.Artifacts.ComputedContext} context */ static async compute_(data, context) { - const {trace, settings, SourceMaps} = data; + const {trace, settings, SourceMaps, HostDPR} = data; const processedTrace = await ProcessedTrace.request(trace, context); const traceEngineResult = - await TraceEngineResult.request({trace, settings, SourceMaps}, context); + await TraceEngineResult.request({trace, settings, SourceMaps, HostDPR}, context); const navigationId = processedTrace.timeOriginEvt.args.data?.navigationId; if (!navigationId) throw new Error('No navigationId found'); @@ -34,5 +34,5 @@ class NavigationInsights { } const NavigationInsightsComputed = - makeComputedArtifact(NavigationInsights, ['trace', 'settings', 'SourceMaps']); + makeComputedArtifact(NavigationInsights, ['trace', 'settings', 'SourceMaps', 'HostDPR']); export {NavigationInsightsComputed as NavigationInsights}; diff --git a/core/computed/page-dependency-graph.js b/core/computed/page-dependency-graph.js index 157f5ffee2d0..fee4a2d25254 100644 --- a/core/computed/page-dependency-graph.js +++ b/core/computed/page-dependency-graph.js @@ -13,12 +13,12 @@ import {TraceEngineResult} from './trace-engine-result.js'; class PageDependencyGraph { /** - * @param {{trace: LH.Trace, devtoolsLog: LH.DevtoolsLog, settings: LH.Audit.Context['settings'], URL: LH.Artifacts['URL'], SourceMaps: LH.Artifacts['SourceMaps'], fromTrace: boolean}} data + * @param {{trace: LH.Trace, devtoolsLog: LH.DevtoolsLog, settings: LH.Audit.Context['settings'], URL: LH.Artifacts['URL'], SourceMaps: LH.Artifacts['SourceMaps'], HostDPR: LH.Artifacts['HostDPR'], fromTrace: boolean}} data * @param {LH.Artifacts.ComputedContext} context * @return {Promise} */ static async compute_(data, context) { - const {trace, settings, devtoolsLog, URL, SourceMaps} = data; + const {trace, settings, devtoolsLog, URL, SourceMaps, HostDPR} = data; const [{mainThreadEvents}, networkRecords] = await Promise.all([ ProcessedTrace.request(trace, context), NetworkRecords.request(devtoolsLog, context), @@ -26,7 +26,7 @@ class PageDependencyGraph { if (data.fromTrace) { const traceEngineResult = - await TraceEngineResult.request({trace, settings, SourceMaps}, context); + await TraceEngineResult.request({trace, settings, SourceMaps, HostDPR}, context); const parsedTrace = traceEngineResult.data; const requests = Lantern.TraceEngineComputationData.createNetworkRequests(trace, parsedTrace); @@ -46,5 +46,5 @@ class PageDependencyGraph { } const PageDependencyGraphComputed = makeComputedArtifact(PageDependencyGraph, - ['devtoolsLog', 'settings', 'trace', 'URL', 'SourceMaps', 'fromTrace']); + ['devtoolsLog', 'settings', 'trace', 'URL', 'SourceMaps', 'HostDPR', 'fromTrace']); export {PageDependencyGraphComputed as PageDependencyGraph}; diff --git a/core/computed/tbt-impact-tasks.js b/core/computed/tbt-impact-tasks.js index b12740cb090e..75e68573be1c 100644 --- a/core/computed/tbt-impact-tasks.js +++ b/core/computed/tbt-impact-tasks.js @@ -239,6 +239,6 @@ class TBTImpactTasks { const TBTImpactTasksComputed = makeComputedArtifact( TBTImpactTasks, - ['trace', 'devtoolsLog', 'URL', 'SourceMaps', 'gatherContext', 'settings', 'simulator'] + ['trace', 'devtoolsLog', 'URL', 'SourceMaps', 'gatherContext', 'settings', 'simulator', 'HostDPR'] ); export {TBTImpactTasksComputed as TBTImpactTasks}; diff --git a/core/computed/trace-engine-result.js b/core/computed/trace-engine-result.js index 730340222ce6..7ee12aac27ae 100644 --- a/core/computed/trace-engine-result.js +++ b/core/computed/trace-engine-result.js @@ -22,9 +22,10 @@ class TraceEngineResult { * @param {LH.TraceEvent[]} _traceEvents * @param {LH.Audit.Context['settings']} settings * @param {LH.Artifacts['SourceMaps']} SourceMaps + * @param {LH.Artifacts['HostDPR']} HostDPR * @return {Promise} */ - static async runTraceEngine(_traceEvents, settings, SourceMaps) { + static async runTraceEngine(_traceEvents, settings, SourceMaps, HostDPR) { const processor = new TraceEngine.TraceProcessor(TraceEngine.TraceHandlers); const traceEvents = /** @type {import('@paulirish/trace_engine').Types.Events.Event[]} */ (_traceEvents); @@ -51,6 +52,7 @@ class TraceEngineResult { }, }, lanternSettings, + metadata: {hostDPR: HostDPR}, async resolveSourceMap(params) { const sourceMap = SourceMaps.find(sm => sm.scriptId === params.scriptId); if (!sourceMap || !sourceMap.map) { @@ -220,7 +222,7 @@ class TraceEngineResult { } /** - * @param {{trace: LH.Trace, settings: LH.Audit.Context['settings'], SourceMaps: LH.Artifacts['SourceMaps']}} data + * @param {{trace: LH.Trace, settings: LH.Audit.Context['settings'], SourceMaps: LH.Artifacts['SourceMaps'], HostDPR: LH.Artifacts['HostDPR']}} data * @param {LH.Artifacts.ComputedContext} context * @return {Promise} */ @@ -251,11 +253,12 @@ class TraceEngineResult { } const result = - await TraceEngineResult.runTraceEngine(traceEvents, data.settings, data.SourceMaps); + await TraceEngineResult.runTraceEngine( + traceEvents, data.settings, data.SourceMaps, data.HostDPR); return result; } } const TraceEngineResultComputed = - makeComputedArtifact(TraceEngineResult, ['trace', 'settings', 'SourceMaps']); + makeComputedArtifact(TraceEngineResult, ['trace', 'settings', 'SourceMaps', 'HostDPR']); export {TraceEngineResultComputed as TraceEngineResult}; diff --git a/core/gather/gatherers/trace-elements.js b/core/gather/gatherers/trace-elements.js index 15fd31e7472e..6afa50029595 100644 --- a/core/gather/gatherers/trace-elements.js +++ b/core/gather/gatherers/trace-elements.js @@ -332,8 +332,9 @@ class TraceElements extends BaseGatherer { const trace = context.dependencies.Trace; const SourceMaps = context.dependencies.SourceMaps; const settings = context.settings; + const HostDPR = context.baseArtifacts.HostDPR; const traceEngineResult = - await TraceEngineResult.request({trace, settings, SourceMaps}, context); + await TraceEngineResult.request({trace, settings, SourceMaps, HostDPR}, context); const processedTrace = await ProcessedTrace.request(trace, context); const {mainThreadEvents} = processedTrace; diff --git a/core/scripts/generate-insight-audits.js b/core/scripts/generate-insight-audits.js index 1c35d0d23eb3..434fc2ff7925 100644 --- a/core/scripts/generate-insight-audits.js +++ b/core/scripts/generate-insight-audits.js @@ -71,7 +71,7 @@ class ${insightName}Insight extends Audit { failureTitle: str_(UIStrings.title), description: str_(UIStrings.description), guidanceLevel: 3, // TODO: confirm/change. - requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps'], + requiredArtifacts: ['Trace', 'TraceElements', 'SourceMaps', 'HostDPR'], }; } diff --git a/core/scripts/lantern/run-once.js b/core/scripts/lantern/run-once.js index 5aeb496f3385..31c96ceb40f3 100755 --- a/core/scripts/lantern/run-once.js +++ b/core/scripts/lantern/run-once.js @@ -31,6 +31,7 @@ async function run() { GatherContext: {gatherMode: 'navigation'}, URL, SourceMaps: [], + HostDPR: 1, }; // @ts-expect-error - We don't need the full artifacts or context. diff --git a/core/test/audits/bootup-time-test.js b/core/test/audits/bootup-time-test.js index ed4ba287e88d..a2f593de9aca 100644 --- a/core/test/audits/bootup-time-test.js +++ b/core/test/audits/bootup-time-test.js @@ -24,6 +24,7 @@ describe('Performance: bootup-time audit', () => { URL: getURLArtifactFromDevtoolsLog(acceptableDevtoolsLogs), GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }); const settings = JSON.parse(JSON.stringify(defaultSettings)); settings.throttlingMethod = 'devtools'; diff --git a/core/test/audits/byte-efficiency/byte-efficiency-audit-test.js b/core/test/audits/byte-efficiency/byte-efficiency-audit-test.js index 202e1dc8658a..6b2115325001 100644 --- a/core/test/audits/byte-efficiency/byte-efficiency-audit-test.js +++ b/core/test/audits/byte-efficiency/byte-efficiency-audit-test.js @@ -83,6 +83,7 @@ describe('Byte efficiency base audit', () => { settings: JSON.parse(JSON.stringify(defaultSettings)), simulator: null, SourceMaps: [], + HostDPR: 1, }; simulator = new Lantern.Simulation.Simulator({}); @@ -228,8 +229,9 @@ describe('Byte efficiency base audit', () => { ], }, simulator, - // eslint-disable-next-line max-len - {trace, devtoolsLog, URL, gatherContext: {gatherMode: 'navigation'}, settings, SourceMaps: [], simulator: null}, + + {trace, devtoolsLog, URL, gatherContext: {gatherMode: 'navigation'}, settings, SourceMaps: [], + HostDPR: 1, simulator: null}, {computedCache: new Map()} ); @@ -252,6 +254,7 @@ describe('Byte efficiency base audit', () => { DevtoolsLog: devtoolsLog, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], + HostDPR: 1, }; const computedCache = new Map(); diff --git a/core/test/audits/layout-shifts-test.js b/core/test/audits/layout-shifts-test.js index 0db242e780dd..063c9c925bfc 100644 --- a/core/test/audits/layout-shifts-test.js +++ b/core/test/audits/layout-shifts-test.js @@ -56,6 +56,7 @@ describe('Performance: layout-shifts audit', () => { }, }], SourceMaps: [], + HostDPR: 1, }; const auditResult = await LayoutShiftsAudit.audit(artifacts, { @@ -113,6 +114,7 @@ describe('Performance: layout-shifts audit', () => { Trace: trace, TraceElements: traceElements, SourceMaps: [], + HostDPR: 1, }; const auditResult = await LayoutShiftsAudit.audit(artifacts, { diff --git a/core/test/audits/long-tasks-test.js b/core/test/audits/long-tasks-test.js index d8512c0b586b..a96e43753da2 100644 --- a/core/test/audits/long-tasks-test.js +++ b/core/test/audits/long-tasks-test.js @@ -90,6 +90,7 @@ describe('Long tasks audit', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); expect(result.details.items).toHaveLength(0); @@ -106,6 +107,7 @@ describe('Long tasks audit', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); expect(result.details.items).toMatchObject([ @@ -138,6 +140,7 @@ describe('Long tasks audit', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); @@ -164,6 +167,7 @@ describe('Long tasks audit', () => { DevtoolsLog: networkRecordsToDevtoolsLog(networkRecords), GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = { computedCache: new Map(), @@ -201,6 +205,7 @@ describe('Long tasks audit', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); expect(result.details.items).toMatchObject([ @@ -232,6 +237,7 @@ describe('Long tasks audit', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); @@ -266,6 +272,7 @@ describe('Long tasks audit', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); @@ -300,6 +307,7 @@ describe('Long tasks audit', () => { DevtoolsLog: redirectDevtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const result = await LongTasks.audit(artifacts, context); diff --git a/core/test/audits/mainthread-work-breakdown-test.js b/core/test/audits/mainthread-work-breakdown-test.js index 51be7d707260..cfe455b5a06f 100644 --- a/core/test/audits/mainthread-work-breakdown-test.js +++ b/core/test/audits/mainthread-work-breakdown-test.js @@ -61,6 +61,7 @@ describe('Performance: page execution timings audit', () => { URL: getURLArtifactFromDevtoolsLog(acceptableDevtoolsLog), GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const output = await MainThreadWorkBreakdown.audit(artifacts, context); @@ -78,6 +79,7 @@ describe('Performance: page execution timings audit', () => { URL: getURLArtifactFromDevtoolsLog(acceptableDevtoolsLog), GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; context.settings.throttlingMethod = 'simulate'; @@ -109,6 +111,7 @@ describe('Performance: page execution timings audit', () => { URL: getURLArtifactFromDevtoolsLog(siteWithRedirectDevtoolsLog), GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; context.settings.throttlingMethod = 'provided'; diff --git a/core/test/audits/metrics-test.js b/core/test/audits/metrics-test.js index 86c06ab94998..5e90ee8900c8 100644 --- a/core/test/audits/metrics-test.js +++ b/core/test/audits/metrics-test.js @@ -35,6 +35,7 @@ describe('Performance: metrics', () => { Trace: pwaTrace, DevtoolsLog: pwaDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -53,6 +54,7 @@ describe('Performance: metrics', () => { Trace: pwaTrace, DevtoolsLog: pwaDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -76,6 +78,7 @@ describe('Performance: metrics', () => { Trace: lcpTrace, DevtoolsLog: lcpDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -94,6 +97,7 @@ describe('Performance: metrics', () => { Trace: lcpAllFramesTrace, DevtoolsLog: lcpAllFramesDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -117,6 +121,7 @@ describe('Performance: metrics', () => { Trace: lcpImageTrace, DevtoolsLog: lcpImageDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -135,6 +140,7 @@ describe('Performance: metrics', () => { Trace: lcpAllFramesTrace, DevtoolsLog: lcpAllFramesDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -156,6 +162,7 @@ describe('Performance: metrics', () => { Trace: clsAllFramesTrace, DevtoolsLog: clsAllFramesDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { @@ -178,6 +185,7 @@ describe('Performance: metrics', () => { Trace: pwaTrace, DevtoolsLog: pwaDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const mockTTIFn = jestMock.spyOn(Interactive, 'request'); @@ -198,6 +206,7 @@ describe('Performance: metrics', () => { Trace: jumpyClsTrace, DevtoolsLog: jumpyClsDevtoolsLog, SourceMaps: [], + HostDPR: 1, }; const context = { diff --git a/core/test/audits/metrics/first-contentful-paint-test.js b/core/test/audits/metrics/first-contentful-paint-test.js index a5fc31c8ed91..5b228fb64ca9 100644 --- a/core/test/audits/metrics/first-contentful-paint-test.js +++ b/core/test/audits/metrics/first-contentful-paint-test.js @@ -42,6 +42,7 @@ describe('Performance: first-contentful-paint audit', () => { DevtoolsLog: pwaDevtoolsLog, URL: getURLArtifactFromDevtoolsLog(pwaDevtoolsLog), SourceMaps: [], + HostDPR: 1, }; const context = getFakeContext({formFactor: 'mobile', throttlingMethod: 'provided'}); @@ -57,6 +58,7 @@ describe('Performance: first-contentful-paint audit', () => { DevtoolsLog: frameDevtoolsLog, URL: getURLArtifactFromDevtoolsLog(frameDevtoolsLog), SourceMaps: [], + HostDPR: 1, }; const context = getFakeContext({formFactor: 'mobile', throttlingMethod: 'provided'}); diff --git a/core/test/audits/metrics/interactive-test.js b/core/test/audits/metrics/interactive-test.js index a24238b5c424..378050c2a89d 100644 --- a/core/test/audits/metrics/interactive-test.js +++ b/core/test/audits/metrics/interactive-test.js @@ -40,6 +40,7 @@ describe('Performance: interactive audit', () => { DevtoolsLog: acceptableDevToolsLog, URL: getURLArtifactFromDevtoolsLog(acceptableDevToolsLog), SourceMaps: [], + HostDPR: 1, }; const context = getFakeContext({formFactor: 'mobile', throttlingMethod: 'provided'}); @@ -57,6 +58,7 @@ describe('Performance: interactive audit', () => { DevtoolsLog: redirectDevToolsLog, URL: getURLArtifactFromDevtoolsLog(redirectDevToolsLog), SourceMaps: [], + HostDPR: 1, }; const context = getFakeContext({formFactor: 'mobile', throttlingMethod: 'provided'}); diff --git a/core/test/audits/metrics/largest-contentful-paint-test.js b/core/test/audits/metrics/largest-contentful-paint-test.js index a8751cdac796..c28e2947f3d4 100644 --- a/core/test/audits/metrics/largest-contentful-paint-test.js +++ b/core/test/audits/metrics/largest-contentful-paint-test.js @@ -21,6 +21,7 @@ function generateArtifacts({trace, devtoolsLog, HostUserAgent}) { DevtoolsLog: devtoolsLog, HostUserAgent, SourceMaps: [], + HostDPR: 1, }; } diff --git a/core/test/audits/metrics/max-potential-fid-test.js b/core/test/audits/metrics/max-potential-fid-test.js index 28e7fd5d1916..66c686f6c5c0 100644 --- a/core/test/audits/metrics/max-potential-fid-test.js +++ b/core/test/audits/metrics/max-potential-fid-test.js @@ -74,6 +74,7 @@ describe('Max Potential FID', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = { settings: {throttlingMethod: 'devtools'}, @@ -138,6 +139,7 @@ describe('Max Potential FID', () => { DevtoolsLog: devtoolsLog, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = { settings: {throttlingMethod: 'devtools'}, diff --git a/core/test/audits/metrics/speed-index-test.js b/core/test/audits/metrics/speed-index-test.js index b0879ac8e5db..139befa7b256 100644 --- a/core/test/audits/metrics/speed-index-test.js +++ b/core/test/audits/metrics/speed-index-test.js @@ -31,7 +31,6 @@ const getFakeContext = ({formFactor, throttlingMethod}) => ({ }, }); - describe('Performance: speed-index audit', () => { it('works on a real trace', () => { const artifacts = { @@ -40,6 +39,7 @@ describe('Performance: speed-index audit', () => { DevtoolsLog: pwaDevtoolsLog, URL: getURLArtifactFromDevtoolsLog(pwaDevtoolsLog), SourceMaps: [], + HostDPR: 1, }; const context = getFakeContext({formFactor: 'mobile', throttlingMethod: 'provided'}); diff --git a/core/test/audits/metrics/total-blocking-time-test.js b/core/test/audits/metrics/total-blocking-time-test.js index a733344b8d06..f8348ce15297 100644 --- a/core/test/audits/metrics/total-blocking-time-test.js +++ b/core/test/audits/metrics/total-blocking-time-test.js @@ -22,6 +22,7 @@ function generateArtifacts({gatherMode = 'navigation', trace, devtoolsLog}) { DevtoolsLog: devtoolsLog, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], + HostDPR: 1, }; } diff --git a/core/test/audits/predictive-perf-test.js b/core/test/audits/predictive-perf-test.js index c11e5973b08b..6ac91e428fe8 100644 --- a/core/test/audits/predictive-perf-test.js +++ b/core/test/audits/predictive-perf-test.js @@ -23,6 +23,7 @@ describe('Performance: predictive performance audit', () => { Trace: acceptableTrace, DevtoolsLog: acceptableDevToolsLog, SourceMaps: [], + HostDPR: 1, }; const context = {computedCache: new Map(), settings: {locale: 'en'}}; diff --git a/core/test/audits/redirects-test.js b/core/test/audits/redirects-test.js index f6adc1eb7ec3..f742e484a430 100644 --- a/core/test/audits/redirects-test.js +++ b/core/test/audits/redirects-test.js @@ -161,6 +161,7 @@ describe('Performance: Redirects audit', () => { finalDisplayedUrl, }, SourceMaps: [], + HostDPR: 1, }; }; diff --git a/core/test/audits/server-response-time-test.js b/core/test/audits/server-response-time-test.js index 71aa4a18dc81..dadd23d6aff6 100644 --- a/core/test/audits/server-response-time-test.js +++ b/core/test/audits/server-response-time-test.js @@ -25,6 +25,7 @@ describe('Performance: server-response-time audit', () => { URL: {mainDocumentUrl: 'https://example.com/'}, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = {computedCache: new Map(), settings: {}}; @@ -56,6 +57,7 @@ describe('Performance: server-response-time audit', () => { URL: {mainDocumentUrl: 'https://example.com/'}, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = {computedCache: new Map(), settings: {}}; @@ -86,6 +88,7 @@ describe('Performance: server-response-time audit', () => { URL: {mainDocumentUrl: 'https://example.com/'}, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = {computedCache: new Map(), settings: {}}; @@ -108,6 +111,7 @@ describe('Performance: server-response-time audit', () => { URL: {mainDocumentUrl: 'https://example.com/'}, GatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, }; const context = {computedCache: new Map(), settings: {}}; diff --git a/core/test/computed/metrics/first-contentful-paint-all-frames-test.js b/core/test/computed/metrics/first-contentful-paint-all-frames-test.js index 5650ff00b70e..5dc2cb750978 100644 --- a/core/test/computed/metrics/first-contentful-paint-all-frames-test.js +++ b/core/test/computed/metrics/first-contentful-paint-all-frames-test.js @@ -19,7 +19,7 @@ describe('Metrics: FCP all frames', () => { const context = {settings, computedCache: new Map()}; const resultPromise = FirstContentfulPaintAllFrames.request( // eslint-disable-next-line max-len - {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], simulator: null}, + {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], HostDPR: 1, simulator: null}, context ); @@ -33,12 +33,12 @@ describe('Metrics: FCP all frames', () => { const result = await FirstContentfulPaintAllFrames.request( // eslint-disable-next-line max-len - {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], simulator: null}, + {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], HostDPR: 1, simulator: null}, context ); const mainFrameResult = await FirstContentfulPaint.request( // eslint-disable-next-line max-len - {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], simulator: null}, + {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], HostDPR: 1, simulator: null}, context ); diff --git a/core/test/computed/metrics/first-contentful-paint-test.js b/core/test/computed/metrics/first-contentful-paint-test.js index 34484c65ed96..3d558e992550 100644 --- a/core/test/computed/metrics/first-contentful-paint-test.js +++ b/core/test/computed/metrics/first-contentful-paint-test.js @@ -21,7 +21,8 @@ describe('Metrics: FCP', () => { const settings = {throttlingMethod: 'simulate'}; const context = {settings, computedCache: new Map()}; const result = await FirstContentfulPaint.request( - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, + // eslint-disable-next-line max-len + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); expect({ @@ -40,7 +41,7 @@ describe('Metrics: FCP', () => { const context = {settings, computedCache: new Map()}; const result = await FirstContentfulPaint.request( // eslint-disable-next-line max-len - {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], simulator: null}, + {trace, devtoolsLog, gatherContext, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], HostDPR: 1, simulator: null}, context); await expect(result).toMatchInlineSnapshot(` @@ -56,7 +57,7 @@ Object { const context = {settings, computedCache: new Map()}; const result = await FirstContentfulPaint.request( // eslint-disable-next-line max-len - {gatherContext, trace, devtoolsLog, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], simulator: null}, + {gatherContext, trace, devtoolsLog, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], HostDPR: 1, simulator: null}, context); await expect(result).toMatchInlineSnapshot(` diff --git a/core/test/computed/metrics/interactive-test.js b/core/test/computed/metrics/interactive-test.js index 00bebfe69578..f22c594f9aea 100644 --- a/core/test/computed/metrics/interactive-test.js +++ b/core/test/computed/metrics/interactive-test.js @@ -61,7 +61,7 @@ describe('Metrics: TTI', () => { ); const context = {settings, computedCache: new Map()}; // eslint-disable-next-line max-len - const result = await getResult({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, simulator: null}, context); + const result = await getResult({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR: 1, simulator: null}, context); expect({ timing: Math.round(result.timing), @@ -80,7 +80,7 @@ describe('Metrics: TTI', () => { ); const context = {settings, computedCache: new Map()}; // eslint-disable-next-line max-len - const result = await getResult({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, simulator: null}, context); + const result = await getResult({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR: 1, simulator: null}, context); assert.equal(Math.round(result.timing), 224); assert.equal(result.timestamp, 376406205074); @@ -92,7 +92,7 @@ describe('Metrics: TTI', () => { ); const context = {settings, computedCache: new Map()}; // eslint-disable-next-line max-len - const result = await getResult({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, simulator: null}, context); + const result = await getResult({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps, HostDPR: 1, simulator: null}, context); assert.equal(Math.round(result.timing), 224); assert.equal(result.timestamp, 376406205074); diff --git a/core/test/computed/metrics/largest-contentful-paint-all-frames-test.js b/core/test/computed/metrics/largest-contentful-paint-all-frames-test.js index 97e954d5833c..69144f5b31d6 100644 --- a/core/test/computed/metrics/largest-contentful-paint-all-frames-test.js +++ b/core/test/computed/metrics/largest-contentful-paint-all-frames-test.js @@ -24,7 +24,7 @@ describe('Metrics: LCP from all frames', () => { const context = {settings, computedCache: new Map()}; const resultPromise = LargestContentfulPaintAllFrames.request( // eslint-disable-next-line max-len - {gatherContext, trace: traceAllFrames, devtoolsLog: devtoolsLogAllFrames, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLogAllFrames), SourceMaps: [], simulator: null}, + {gatherContext, trace: traceAllFrames, devtoolsLog: devtoolsLogAllFrames, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLogAllFrames), SourceMaps: [], HostDPR: 1, simulator: null}, context); // TODO: Implement lantern solution for LCP all frames. @@ -36,7 +36,7 @@ describe('Metrics: LCP from all frames', () => { const context = {settings, computedCache: new Map()}; const result = await LargestContentfulPaintAllFrames.request( // eslint-disable-next-line max-len - {gatherContext, trace: traceAllFrames, devtoolsLog: devtoolsLogAllFrames, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLogAllFrames), SourceMaps: [], simulator: null}, + {gatherContext, trace: traceAllFrames, devtoolsLog: devtoolsLogAllFrames, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLogAllFrames), SourceMaps: [], HostDPR: 1, simulator: null}, context); assert.equal(Math.round(result.timing), 683); @@ -48,7 +48,7 @@ describe('Metrics: LCP from all frames', () => { const context = {settings, computedCache: new Map()}; const resultPromise = LargestContentfulPaintAllFrames.request( // eslint-disable-next-line max-len - {gatherContext, trace: invalidTrace, devtoolsLog: invalidDevtoolsLog, settings, URL: getURLArtifactFromDevtoolsLog(invalidDevtoolsLog), SourceMaps: [], simulator: null}, + {gatherContext, trace: invalidTrace, devtoolsLog: invalidDevtoolsLog, settings, URL: getURLArtifactFromDevtoolsLog(invalidDevtoolsLog), SourceMaps: [], HostDPR: 1, simulator: null}, context ); await expect(resultPromise).rejects.toThrow('NO_LCP_ALL_FRAMES'); @@ -59,7 +59,7 @@ describe('Metrics: LCP from all frames', () => { const context = {settings, computedCache: new Map()}; const result = await LargestContentfulPaintAllFrames.request( // eslint-disable-next-line max-len - {gatherContext, trace: traceMainFrame, devtoolsLog: devtoolsLogMainFrame, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLogMainFrame), SourceMaps: [], simulator: null}, + {gatherContext, trace: traceMainFrame, devtoolsLog: devtoolsLogMainFrame, settings, URL: getURLArtifactFromDevtoolsLog(devtoolsLogMainFrame), SourceMaps: [], HostDPR: 1, simulator: null}, context ); await expect(result).toMatchInlineSnapshot(` diff --git a/core/test/computed/metrics/largest-contentful-paint-test.js b/core/test/computed/metrics/largest-contentful-paint-test.js index bfcf8d7e93a2..7626287286f2 100644 --- a/core/test/computed/metrics/largest-contentful-paint-test.js +++ b/core/test/computed/metrics/largest-contentful-paint-test.js @@ -23,7 +23,7 @@ describe('Metrics: LCP', () => { const context = {settings, computedCache: new Map()}; const URL = getURLArtifactFromDevtoolsLog(devtoolsLog); const result = await LargestContentfulPaint.request({trace, devtoolsLog, gatherContext, - settings, URL, SourceMaps: [], simulator: null}, context); + settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); expect({ timing: Math.round(result.timing), @@ -43,7 +43,7 @@ Object { const context = {settings, computedCache: new Map()}; const URL = getURLArtifactFromDevtoolsLog(devtoolsLog); const result = await LargestContentfulPaint.request({trace, devtoolsLog, gatherContext, - settings, URL, SourceMaps: [], simulator: null}, context); + settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); await expect(result).toMatchInlineSnapshot(` Object { diff --git a/core/test/computed/metrics/lcp-breakdown-test.js b/core/test/computed/metrics/lcp-breakdown-test.js index 05821a37bcce..70332d789151 100644 --- a/core/test/computed/metrics/lcp-breakdown-test.js +++ b/core/test/computed/metrics/lcp-breakdown-test.js @@ -38,6 +38,7 @@ function mockData(networkRecords) { gatherContext: {gatherMode: 'navigation'}, simulator: null, SourceMaps: [], + HostDPR: 1, }; } @@ -101,6 +102,7 @@ describe('LCPBreakdown', () => { devtoolsLog: imageLcpDevtoolsLog, URL: getURLArtifactFromDevtoolsLog(imageLcpDevtoolsLog), SourceMaps: [], + HostDPR: 1, gatherContext: {gatherMode: 'navigation'}, simulator: null, }; @@ -125,6 +127,7 @@ describe('LCPBreakdown', () => { devtoolsLog: textLcpDevtoolsLog, URL: getURLArtifactFromDevtoolsLog(textLcpDevtoolsLog), SourceMaps: [], + HostDPR: 1, gatherContext: {gatherMode: 'navigation'}, simulator: null, }; diff --git a/core/test/computed/metrics/max-potential-fid-test.js b/core/test/computed/metrics/max-potential-fid-test.js index 2a4153b9d483..44c9aee1e97c 100644 --- a/core/test/computed/metrics/max-potential-fid-test.js +++ b/core/test/computed/metrics/max-potential-fid-test.js @@ -18,8 +18,9 @@ describe('Metrics: Max Potential FID', () => { it('should compute a simulated value', async () => { const settings = {throttlingMethod: 'simulate'}; const context = {settings, computedCache: new Map()}; - const result = await MaxPotentialFID.request({ - trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, context); + const result = + // eslint-disable-next-line max-len + await MaxPotentialFID.request({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); expect({ timing: Math.round(result.timing), @@ -31,8 +32,9 @@ describe('Metrics: Max Potential FID', () => { it('should compute an observed value', async () => { const settings = {throttlingMethod: 'provided'}; const context = {settings, computedCache: new Map()}; - const result = await MaxPotentialFID.request({ - trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, context); + const result = + // eslint-disable-next-line max-len + await MaxPotentialFID.request({trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); await expect(result).toMatchInlineSnapshot(` Object { diff --git a/core/test/computed/metrics/speed-index-test.js b/core/test/computed/metrics/speed-index-test.js index 174ebbcb48e3..b45156c1ed61 100644 --- a/core/test/computed/metrics/speed-index-test.js +++ b/core/test/computed/metrics/speed-index-test.js @@ -20,7 +20,8 @@ describe('Metrics: Speed Index', () => { const context = {settings, computedCache: new Map()}; const URL = getURLArtifactFromDevtoolsLog(devtoolsLog); const result = await SpeedIndex.request( - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, + // eslint-disable-next-line max-len + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); expect({ @@ -54,7 +55,7 @@ Object { devtoolsLog: devtoolsLog1msLayout, settings, URL, - SourceMaps: [], + SourceMaps: [], HostDPR: 1, simulator: null, }, context @@ -78,7 +79,8 @@ Object { const context = {settings, computedCache: new Map()}; const URL = getURLArtifactFromDevtoolsLog(devtoolsLog); const result = await SpeedIndex.request( - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, + // eslint-disable-next-line max-len + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); await expect(result).toMatchInlineSnapshot(` @@ -95,7 +97,8 @@ Object { const URL = getURLArtifactFromDevtoolsLog(devtoolsLog); const result = await SpeedIndex.request( - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, + // eslint-disable-next-line max-len + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context); await expect(result).toMatchInlineSnapshot(` diff --git a/core/test/computed/metrics/time-to-first-byte-test.js b/core/test/computed/metrics/time-to-first-byte-test.js index 7cb764b566a1..34544875ce02 100644 --- a/core/test/computed/metrics/time-to-first-byte-test.js +++ b/core/test/computed/metrics/time-to-first-byte-test.js @@ -32,6 +32,7 @@ function mockData(networkRecords) { }, gatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, simulator: null, }; } @@ -80,6 +81,7 @@ describe('Metrics: TTFB', () => { URL: getURLArtifactFromDevtoolsLog(devtoolsLog), gatherContext: {gatherMode: 'navigation'}, SourceMaps: [], + HostDPR: 1, simulator: null, }; diff --git a/core/test/computed/metrics/timing-summary-test.js b/core/test/computed/metrics/timing-summary-test.js index 84143eaa171a..7cf169120680 100644 --- a/core/test/computed/metrics/timing-summary-test.js +++ b/core/test/computed/metrics/timing-summary-test.js @@ -17,7 +17,7 @@ describe('Timing summary', () => { const URL = getURLArtifactFromDevtoolsLog(devtoolsLog); const artifacts = // eslint-disable-next-line max-len - {URL, settings: {throttlingMethod: 'devtools'}, trace, devtoolsLog, SourceMaps: [], gatherContext}; + {URL, settings: {throttlingMethod: 'devtools'}, trace, devtoolsLog, SourceMaps: [], HostDPR: 1, gatherContext}; const result = await TimingSummary.request(artifacts, context); expect(result.metrics).toMatchInlineSnapshot(` diff --git a/core/test/computed/metrics/total-blocking-time-test.js b/core/test/computed/metrics/total-blocking-time-test.js index 2e2c7c8e9d8d..cf09f9ffdf08 100644 --- a/core/test/computed/metrics/total-blocking-time-test.js +++ b/core/test/computed/metrics/total-blocking-time-test.js @@ -21,7 +21,8 @@ describe('Metrics: TotalBlockingTime', () => { const settings = {throttlingMethod: 'simulate'}; const context = {settings, computedCache: new Map()}; const result = await TotalBlockingTime.request( - {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, + // eslint-disable-next-line max-len + {trace, devtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context ); @@ -43,7 +44,7 @@ describe('Metrics: TotalBlockingTime', () => { const context = {settings, computedCache: new Map()}; const result = await TotalBlockingTime.request( // eslint-disable-next-line max-len - {trace: cnnTrace, devtoolsLog: cnnDevtoolsLog, gatherContext, settings, URL, SourceMaps: [], simulator: null}, + {trace: cnnTrace, devtoolsLog: cnnDevtoolsLog, gatherContext, settings, URL, SourceMaps: [], HostDPR: 1, simulator: null}, context ); expect(result.timing).toBeCloseTo(400, 1); diff --git a/core/test/computed/page-dependency-graph-test.js b/core/test/computed/page-dependency-graph-test.js index 45fdfab74d26..55f1a0fef0a0 100644 --- a/core/test/computed/page-dependency-graph-test.js +++ b/core/test/computed/page-dependency-graph-test.js @@ -22,6 +22,7 @@ describe('PageDependencyGraph computed artifact', () => { devtoolsLog: sampleDevtoolsLog, URL: getURLArtifactFromDevtoolsLog(sampleDevtoolsLog), SourceMaps: [], + HostDPR: 1, settings: {}, fromTrace: false, }, context); diff --git a/core/test/computed/tbt-impact-tasks-test.js b/core/test/computed/tbt-impact-tasks-test.js index 84bb5ecea81c..9bc1b5bc2354 100644 --- a/core/test/computed/tbt-impact-tasks-test.js +++ b/core/test/computed/tbt-impact-tasks-test.js @@ -57,6 +57,7 @@ describe('TBTImpactTasks', () => { finalDisplayedUrl: mainDocumentUrl, }, SourceMaps: [], + HostDPR: 1, gatherContext: {gatherMode: 'navigation'}, settings, simulator: null, @@ -246,6 +247,7 @@ describe('TBTImpactTasks', () => { devtoolsLog, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], + HostDPR: 1, gatherContext: {gatherMode: 'navigation'}, settings, simulator: null, @@ -297,6 +299,7 @@ describe('TBTImpactTasks', () => { devtoolsLog, URL: getURLArtifactFromDevtoolsLog(devtoolsLog), SourceMaps: [], + HostDPR: 1, gatherContext: {gatherMode: 'navigation'}, settings, simulator: null, diff --git a/core/test/computed/trace-engine-result-test.js b/core/test/computed/trace-engine-result-test.js index cb16dfee5aa1..fc7a77c9030e 100644 --- a/core/test/computed/trace-engine-result-test.js +++ b/core/test/computed/trace-engine-result-test.js @@ -27,7 +27,7 @@ describe('TraceEngineResult', () => { describe('compute_', () => { it('works on a basic trace', async () => { const result = await TraceEngineResult.request( - {trace: basicTrace, SourceMaps: [], settings}, + {trace: basicTrace, SourceMaps: [], HostDPR: 1, settings}, context ); assert.ok(result.insights); @@ -69,9 +69,10 @@ describe('TraceEngineResult', () => { bigTrace.traceEvents.push(...measureEvents); - result = await TraceEngineResult.request({trace: bigTrace, SourceMaps: [], settings}, - context - ); + result = + await TraceEngineResult.request({trace: bigTrace, SourceMaps: [], HostDPR: 1, settings}, + context + ); }); diff --git a/core/test/fixtures/user-flows/reports/sample-flow-result.json b/core/test/fixtures/user-flows/reports/sample-flow-result.json index 65ac9609391a..c98db9c0c424 100644 --- a/core/test/fixtures/user-flows/reports/sample-flow-result.json +++ b/core/test/fixtures/user-flows/reports/sample-flow-result.json @@ -54,43 +54,28 @@ "id": "first-contentful-paint", "title": "First Contentful Paint", "description": "First Contentful Paint marks the time at which the first text or image is painted. [Learn more about the First Contentful Paint metric](https://developer.chrome.com/docs/lighthouse/performance/first-contentful-paint/).", - "score": 0.7, - "scoreDisplayMode": "numeric", - "numericValue": 2413.8750000000005, - "numericUnit": "millisecond", - "displayValue": "2.4 s", - "scoringOptions": { - "p10": 1800, - "median": 3000 - } + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "largest-contentful-paint": { "id": "largest-contentful-paint", "title": "Largest Contentful Paint", "description": "Largest Contentful Paint marks the time at which the largest text or image is painted. [Learn more about the Largest Contentful Paint metric](https://developer.chrome.com/docs/lighthouse/performance/lighthouse-largest-contentful-paint/)", - "score": 0.48, - "scoreDisplayMode": "numeric", - "numericValue": 4073.5785, - "numericUnit": "millisecond", - "displayValue": "4.1 s", - "scoringOptions": { - "p10": 2500, - "median": 4000 - } + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "speed-index": { "id": "speed-index", "title": "Speed Index", "description": "Speed Index shows how quickly the contents of a page are visibly populated. [Learn more about the Speed Index metric](https://developer.chrome.com/docs/lighthouse/performance/speed-index/).", - "score": 0.54, - "scoreDisplayMode": "numeric", - "numericValue": 5523.9135999679565, - "numericUnit": "millisecond", - "displayValue": "5.5 s", - "scoringOptions": { - "p10": 3387, - "median": 5800 - } + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "screenshot-thumbnails": { "id": "screenshot-thumbnails", @@ -162,25 +147,19 @@ "id": "total-blocking-time", "title": "Total Blocking Time", "description": "Sum of all time periods between FCP and Time to Interactive, when task length exceeded 50ms, expressed in milliseconds. [Learn more about the Total Blocking Time metric](https://developer.chrome.com/docs/lighthouse/performance/lighthouse-total-blocking-time/).", - "score": 1, - "scoreDisplayMode": "numeric", - "numericValue": 6, - "numericUnit": "millisecond", - "displayValue": "10 ms", - "scoringOptions": { - "p10": 200, - "median": 600 - } + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "max-potential-fid": { "id": "max-potential-fid", "title": "Max Potential First Input Delay", "description": "The maximum potential First Input Delay that your users could experience is the duration of the longest task. [Learn more about the Maximum Potential First Input Delay metric](https://developer.chrome.com/docs/lighthouse/performance/lighthouse-max-potential-fid/).", - "score": 0.98, - "scoreDisplayMode": "numeric", - "numericValue": 87, - "numericUnit": "millisecond", - "displayValue": "90 ms" + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "cumulative-layout-shift": { "id": "cumulative-layout-shift", @@ -236,48 +215,20 @@ "id": "server-response-time", "title": "Initial server response time was short", "description": "Keep the server response time for the main document short because all other requests depend on it. [Learn more about the Time to First Byte metric](https://developer.chrome.com/docs/lighthouse/performance/time-to-first-byte/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 22, - "numericUnit": "millisecond", - "displayValue": "Root document took 20 ms", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "opportunity", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "responseTime", - "valueType": "timespanMs", - "label": "Time Spent" - } - ], - "items": [ - { - "url": "https://www.mikescerealshack.co/", - "responseTime": 22 - } - ], - "overallSavingsMs": 0 - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "interactive": { "id": "interactive", "title": "Time to Interactive", "description": "Time to Interactive is the amount of time it takes for the page to become fully interactive. [Learn more about the Time to Interactive metric](https://developer.chrome.com/docs/lighthouse/performance/interactive/).", - "score": 0.87, - "scoreDisplayMode": "numeric", - "numericValue": 4073.5785000000005, - "numericUnit": "millisecond", - "displayValue": "4.1 s" + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "user-timings": { "id": "user-timings", @@ -363,21 +314,10 @@ "id": "redirects", "title": "Avoid multiple page redirects", "description": "Redirects introduce additional delays before the page can be loaded. [Learn how to avoid page redirects](https://developer.chrome.com/docs/lighthouse/performance/redirects/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 0, - "numericUnit": "millisecond", - "displayValue": "", - "metricSavings": { - "LCP": 0, - "FCP": 0 - }, - "details": { - "type": "opportunity", - "headings": [], - "items": [], - "overallSavingsMs": 0 - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 2 }, "image-aspect-ratio": { @@ -501,139 +441,20 @@ "id": "mainthread-work-breakdown", "title": "Minimizes main-thread work", "description": "Consider reducing the time spent parsing, compiling and executing JS. You may find delivering smaller JS payloads helps with this. [Learn how to minimize main-thread work](https://developer.chrome.com/docs/lighthouse/performance/mainthread-work-breakdown/)", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 519.2439999999993, - "numericUnit": "millisecond", - "displayValue": "0.5 s", - "metricSavings": { - "TBT": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "groupLabel", - "valueType": "text", - "label": "Category" - }, - { - "key": "duration", - "valueType": "ms", - "granularity": 1, - "label": "Time Spent" - } - ], - "items": [ - { - "group": "scriptEvaluation", - "groupLabel": "Script Evaluation", - "duration": 244.14799999999934 - }, - { - "group": "other", - "groupLabel": "Other", - "duration": 140.64800000000008 - }, - { - "group": "styleLayout", - "groupLabel": "Style & Layout", - "duration": 76.15199999999997 - }, - { - "group": "scriptParseCompile", - "groupLabel": "Script Parsing & Compilation", - "duration": 34.976000000000006 - }, - { - "group": "paintCompositeRender", - "groupLabel": "Rendering", - "duration": 13.823999999999998 - }, - { - "group": "parseHTML", - "groupLabel": "Parse HTML & CSS", - "duration": 9.495999999999954 - } - ], - "sortedBy": [ - "duration" - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "bootup-time": { "id": "bootup-time", "title": "JavaScript execution time", "description": "Consider reducing the time spent parsing, compiling, and executing JS. You may find delivering smaller JS payloads helps with this. [Learn how to reduce Javascript execution time](https://developer.chrome.com/docs/lighthouse/performance/bootup-time/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 244.4120000000013, - "numericUnit": "millisecond", - "displayValue": "0.2 s", - "metricSavings": { - "TBT": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "total", - "granularity": 1, - "valueType": "ms", - "label": "Total CPU Time" - }, - { - "key": "scripting", - "granularity": 1, - "valueType": "ms", - "label": "Script Evaluation" - }, - { - "key": "scriptParseCompile", - "granularity": 1, - "valueType": "ms", - "label": "Script Parse" - } - ], - "items": [ - { - "url": "https://www.googletagmanager.com/gtag/js?id=G-RTW9M3W5HC", - "total": 125.53600000000097, - "scripting": 106.43200000000095, - "scriptParseCompile": 17.308 - }, - { - "url": "https://www.mikescerealshack.co/", - "total": 125.52399999999994, - "scripting": 5.747999999999998, - "scriptParseCompile": 1.196 - }, - { - "url": "Unattributable", - "total": 114.11600000000003, - "scripting": 7.171999999999999, - "scriptParseCompile": 0 - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/framework.9d524150d48315f49e80.js", - "total": 111.60800000000036, - "scripting": 99.16400000000037, - "scriptParseCompile": 7.3919999999999995 - } - ], - "summary": { - "wastedMs": 244.4120000000013 - }, - "sortedBy": [ - "total" - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "diagnostics": { @@ -1414,59 +1235,10 @@ "id": "metrics", "title": "Metrics", "description": "Collects all available metrics.", - "score": 1, - "scoreDisplayMode": "informative", - "numericValue": 4074, - "numericUnit": "millisecond", - "details": { - "type": "debugdata", - "items": [ - { - "firstContentfulPaint": 2414, - "largestContentfulPaint": 4074, - "interactive": 4074, - "speedIndex": 5524, - "totalBlockingTime": 6, - "maxPotentialFID": 87, - "cumulativeLayoutShift": 0, - "cumulativeLayoutShiftMainFrame": 0, - "lcpLoadDelay": 626, - "lcpLoadDuration": 626, - "timeToFirstByte": 626, - "observedTimeOrigin": 0, - "observedTimeOriginTs": 282954562981, - "observedNavigationStart": 0, - "observedNavigationStartTs": 282954562981, - "observedFirstPaint": 3266, - "observedFirstPaintTs": 282957828639, - "observedFirstContentfulPaint": 3266, - "observedFirstContentfulPaintTs": 282957828639, - "observedFirstContentfulPaintAllFrames": 3266, - "observedFirstContentfulPaintAllFramesTs": 282957828639, - "observedLargestContentfulPaint": 3266, - "observedLargestContentfulPaintTs": 282957828639, - "observedLargestContentfulPaintAllFrames": 3266, - "observedLargestContentfulPaintAllFramesTs": 282957828639, - "observedTraceEnd": 5578, - "observedTraceEndTs": 282960140650, - "observedLoad": 428, - "observedLoadTs": 282954990904, - "observedDomContentLoaded": 174, - "observedDomContentLoadedTs": 282954737292, - "observedCumulativeLayoutShift": 0, - "observedCumulativeLayoutShiftMainFrame": 0, - "observedFirstVisualChange": 3255, - "observedFirstVisualChangeTs": 282957817981, - "observedLastVisualChange": 3255, - "observedLastVisualChangeTs": 282957817981, - "observedSpeedIndex": 3256, - "observedSpeedIndexTs": 282957818955 - }, - { - "lcpInvalidated": false - } - ] - } + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js" }, "resource-summary": { "id": "resource-summary", @@ -1556,109 +1328,19 @@ "title": "Avoid large layout shifts", "description": "These are the largest layout shifts observed on the page. Each table item represents a single layout shift, and shows the element that shifted the most. Below each item are possible root causes that led to the layout shift. Some of these layout shifts may not be included in the CLS metric value due to [windowing](https://web.dev/articles/cls#what_is_cls). [Learn how to improve CLS](https://web.dev/articles/optimize-cls)", "score": null, - "scoreDisplayMode": "notApplicable", - "metricSavings": { - "CLS": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "node", - "valueType": "node", - "subItemsHeading": { - "key": "extra" - }, - "label": "Element" - }, - { - "key": "score", - "valueType": "numeric", - "subItemsHeading": { - "key": "cause", - "valueType": "text" - }, - "granularity": 0.001, - "label": "Layout shift score" - } - ], - "items": [] - }, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 2 }, "long-tasks": { "id": "long-tasks", "title": "Avoid long main-thread tasks", "description": "Lists the longest tasks on the main thread, useful for identifying worst contributors to input delay. [Learn how to avoid long main-thread tasks](https://web.dev/articles/optimize-long-tasks)", - "score": 1, - "scoreDisplayMode": "informative", - "displayValue": "2 long tasks found", - "metricSavings": { - "TBT": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "startTime", - "valueType": "ms", - "granularity": 1, - "label": "Start Time" - }, - { - "key": "duration", - "valueType": "ms", - "granularity": 1, - "label": "Duration" - } - ], - "items": [ - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/framework.9d524150d48315f49e80.js", - "duration": 87, - "startTime": 2338.271 - }, - { - "url": "https://www.googletagmanager.com/gtag/js?id=G-RTW9M3W5HC", - "duration": 56, - "startTime": 3205.556 - } - ], - "sortedBy": [ - "duration" - ], - "skipSumming": [ - "startTime" - ], - "debugData": { - "type": "debugdata", - "urls": [ - "https://www.mikescerealshack.co/_next/static/chunks/framework.9d524150d48315f49e80.js", - "https://www.googletagmanager.com/gtag/js?id=G-RTW9M3W5HC" - ], - "tasks": [ - { - "urlIndex": 0, - "startTime": 2338.3, - "duration": 87, - "other": 87, - "scriptEvaluation": 0 - }, - { - "urlIndex": 1, - "startTime": 3205.6, - "duration": 56, - "other": 56, - "scriptEvaluation": 0 - } - ] - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "non-composited-animations": { @@ -3036,162 +2718,40 @@ "id": "unminified-css", "title": "Minify CSS", "description": "Minifying CSS files can reduce network payload sizes. [Learn how to minify CSS](https://developer.chrome.com/docs/lighthouse/performance/unminified-css/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 0, - "numericUnit": "millisecond", - "displayValue": "", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "opportunity", - "headings": [], - "items": [], - "overallSavingsMs": 0, - "overallSavingsBytes": 0, - "sortedBy": [ - "wastedBytes" - ], - "debugData": { - "type": "debugdata", - "metricSavings": { - "FCP": 0, - "LCP": 0 - } - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "unminified-javascript": { "id": "unminified-javascript", "title": "Minify JavaScript", "description": "Minifying JavaScript files can reduce payload sizes and script parse time. [Learn how to minify JavaScript](https://developer.chrome.com/docs/lighthouse/performance/unminified-javascript/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 0, - "numericUnit": "millisecond", - "displayValue": "", - "warnings": [], - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "opportunity", - "headings": [], - "items": [], - "overallSavingsMs": 0, - "overallSavingsBytes": 0, - "sortedBy": [ - "wastedBytes" - ], - "debugData": { - "type": "debugdata", - "metricSavings": { - "FCP": 0, - "LCP": 0 - } - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "unused-css-rules": { "id": "unused-css-rules", "title": "Reduce unused CSS", "description": "Reduce unused rules from stylesheets and defer CSS not used for above-the-fold content to decrease bytes consumed by network activity. [Learn how to reduce unused CSS](https://developer.chrome.com/docs/lighthouse/performance/unused-css-rules/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 0, - "numericUnit": "millisecond", - "displayValue": "", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "opportunity", - "headings": [], - "items": [], - "overallSavingsMs": 0, - "overallSavingsBytes": 0, - "sortedBy": [ - "wastedBytes" - ], - "debugData": { - "type": "debugdata", - "metricSavings": { - "FCP": 0, - "LCP": 0 - } - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "unused-javascript": { "id": "unused-javascript", "title": "Reduce unused JavaScript", "description": "Reduce unused JavaScript and defer loading scripts until they are required to decrease bytes consumed by network activity. [Learn how to reduce unused JavaScript](https://developer.chrome.com/docs/lighthouse/performance/unused-javascript/).", - "score": 0, - "scoreDisplayMode": "metricSavings", - "numericValue": 330, - "numericUnit": "millisecond", - "displayValue": "Est savings of 43 KiB", - "metricSavings": { - "FCP": 0, - "LCP": 350 - }, - "details": { - "type": "opportunity", - "headings": [ - { - "key": "url", - "valueType": "url", - "subItemsHeading": { - "key": "source", - "valueType": "code" - }, - "label": "URL" - }, - { - "key": "totalBytes", - "valueType": "bytes", - "subItemsHeading": { - "key": "sourceBytes" - }, - "label": "Transfer Size" - }, - { - "key": "wastedBytes", - "valueType": "bytes", - "subItemsHeading": { - "key": "sourceWastedBytes" - }, - "label": "Est Savings" - } - ], - "items": [ - { - "url": "https://www.googletagmanager.com/gtag/js?id=G-RTW9M3W5HC", - "totalBytes": 111958, - "wastedBytes": 44164, - "wastedPercent": 39.44726092184847 - } - ], - "overallSavingsMs": 330, - "overallSavingsBytes": 44164, - "sortedBy": [ - "wastedBytes" - ], - "debugData": { - "type": "debugdata", - "metricSavings": { - "FCP": 0, - "LCP": 330 - } - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "doctype": { @@ -3645,306 +3205,80 @@ "id": "cache-insight", "title": "Use efficient cache lifetimes", "description": "A long cache lifetime can speed up repeat visits to your page. [Learn more about caching](https://developer.chrome.com/docs/performance/insights/cache).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "Request" - }, - { - "key": "cacheLifetimeMs", - "valueType": "ms", - "label": "Cache TTL", - "displayUnit": "duration" - }, - { - "key": "totalBytes", - "valueType": "bytes", - "label": "Transfer Size", - "displayUnit": "kb", - "granularity": 1 - } - ], - "items": [], - "debugData": { - "type": "debugdata", - "wastedBytes": 0 - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "cls-culprits-insight": { "id": "cls-culprits-insight", "title": "Layout shift culprits", "description": "Layout shifts occur when elements move absent any user interaction. [Investigate the causes of layout shifts](https://developer.chrome.com/docs/performance/insights/cls-culprit), such as elements being added, removed, or their fonts changing as the page loads.", - "score": 1, - "scoreDisplayMode": "numeric", - "metricSavings": { - "CLS": 0 - }, - "details": { - "type": "list", - "items": [] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "document-latency-insight": { "id": "document-latency-insight", "title": "Document request latency", "description": "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.", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "checklist", - "items": { - "noRedirects": { - "label": "Avoids redirects", - "value": true - }, - "serverResponseIsFast": { - "label": "Server responds quickly (observed 22 ms)", - "value": true - }, - "usesCompression": { - "label": "Applies text compression", - "value": true - } - }, - "debugData": { - "type": "debugdata", - "redirectDuration": 0, - "serverResponseTime": 22, - "uncompressedResponseBytes": 0, - "wastedBytes": 0 - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "dom-size-insight": { "id": "dom-size-insight", "title": "Optimize DOM size", "description": "A large DOM can increase the duration of style calculations and layout reflows, impacting page responsiveness. A large DOM will also increase memory usage. [Learn how to avoid an excessive DOM size](https://developer.chrome.com/docs/performance/insights/dom-size).", - "score": 1, - "scoreDisplayMode": "numeric", - "numericValue": 72, - "numericUnit": "element", - "metricSavings": { - "INP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "statistic", - "valueType": "text", - "label": "Statistic" - }, - { - "key": "node", - "valueType": "node", - "label": "Element" - }, - { - "key": "value", - "valueType": "numeric", - "label": "Value" - } - ], - "items": [ - { - "statistic": "Total elements", - "value": { - "type": "numeric", - "granularity": 1, - "value": 72 - } - }, - { - "statistic": "DOM depth", - "value": { - "type": "numeric", - "granularity": 1, - "value": 9 - } - }, - { - "statistic": "Most children", - "value": { - "type": "numeric", - "granularity": 1, - "value": 14 - } - } - ], - "debugData": { - "type": "debugdata", - "totalElements": 72, - "maxChildren": 14, - "maxDepth": 9 - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "duplicated-javascript-insight": { "id": "duplicated-javascript-insight", "title": "Duplicated JavaScript", "description": "Remove large, [duplicate JavaScript modules](https://developer.chrome.com/docs/performance/insights/duplicated-javascript) from bundles to reduce unnecessary bytes consumed by network activity.", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "source", - "valueType": "code", - "subItemsHeading": { - "key": "url", - "valueType": "url" - }, - "label": "Source" - }, - { - "key": "wastedBytes", - "valueType": "bytes", - "subItemsHeading": { - "key": "sourceTransferBytes" - }, - "granularity": 10, - "label": "Duplicated bytes" - } - ], - "items": [], - "debugData": { - "type": "debugdata", - "wastedBytes": 0 - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 2 }, "font-display-insight": { "id": "font-display-insight", "title": "Font display", "description": "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).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "INP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "wastedMs", - "valueType": "ms", - "label": "Est Savings" - } - ], - "items": [], - "skipSumming": [ - "wastedMs" - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "forced-reflow-insight": { "id": "forced-reflow-insight", "title": "Forced reflow", "description": "A forced reflow occurs when JavaScript queries geometric properties (such as offsetWidth) after styles have been invalidated by a change to the DOM state. This can result in poor performance. Learn more about [forced reflows](https://developer.chrome.com/docs/performance/insights/forced-reflow) and possible mitigations.", - "score": 1, - "scoreDisplayMode": "numeric", - "details": { - "type": "list", - "items": [ - { - "type": "table", - "headings": [ - { - "key": "source", - "valueType": "source-location", - "label": "Source" - }, - { - "key": "reflowTime", - "valueType": "ms", - "granularity": 1, - "label": "Total reflow time" - } - ], - "items": [] - } - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "image-delivery-insight": { "id": "image-delivery-insight", "title": "Improve image delivery", "description": "Reducing the download time of images can improve the perceived load time of the page and LCP. [Learn more about optimizing image size](https://developer.chrome.com/docs/performance/insights/image-delivery)", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "node", - "valueType": "node", - "label": "" - }, - { - "key": "url", - "valueType": "url", - "label": "URL", - "subItemsHeading": { - "key": "reason", - "valueType": "text" - } - }, - { - "key": "totalBytes", - "valueType": "bytes", - "label": "Resource Size" - }, - { - "key": "wastedBytes", - "valueType": "bytes", - "label": "Est Savings", - "subItemsHeading": { - "key": "wastedBytes", - "valueType": "bytes" - } - } - ], - "items": [], - "debugData": { - "type": "debugdata", - "wastedBytes": 0 - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "inp-breakdown-insight": { @@ -3952,366 +3286,79 @@ "title": "INP breakdown", "description": "Start investigating [how to improve INP](https://developer.chrome.com/docs/performance/insights/inp-breakdown) by looking at the longest subpart.", "score": null, - "scoreDisplayMode": "notApplicable", + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "lcp-breakdown-insight": { "id": "lcp-breakdown-insight", "title": "LCP breakdown", "description": "Each [subpart has specific improvement strategies](https://developer.chrome.com/docs/performance/insights/lcp-breakdown). Ideally, most of the LCP time should be spent on loading the resources, not within delays.", - "score": 0, - "scoreDisplayMode": "numeric", - "metricSavings": { - "LCP": 0 - }, - "details": { - "type": "list", - "items": [ - { - "type": "table", - "headings": [ - { - "key": "label", - "valueType": "text", - "label": "Subpart" - }, - { - "key": "duration", - "valueType": "ms", - "label": "Duration" - } - ], - "items": [ - { - "subpart": "timeToFirstByte", - "label": "Time to first byte", - "duration": 145.333 - }, - { - "subpart": "resourceLoadDelay", - "label": "Resource load delay", - "duration": 24.98 - }, - { - "subpart": "resourceLoadDuration", - "label": "Resource load duration", - "duration": 63.87 - }, - { - "subpart": "elementRenderDelay", - "label": "Element render delay", - "duration": 3031.475 - } - ] - } - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "lcp-discovery-insight": { "id": "lcp-discovery-insight", "title": "LCP request discovery", "description": "[Optimize LCP](https://developer.chrome.com/docs/performance/insights/lcp-discovery) by making the LCP image discoverable from the HTML immediately, and avoiding lazy-loading", - "score": 0, - "scoreDisplayMode": "numeric", - "metricSavings": { - "LCP": 0 - }, - "details": { - "type": "list", - "items": [ - { - "type": "checklist", - "items": { - "priorityHinted": { - "label": "fetchpriority=high should be applied", - "value": false - }, - "requestDiscoverable": { - "label": "Request is discoverable in initial document", - "value": true - }, - "eagerlyLoaded": { - "label": "lazy load not applied", - "value": true - } - } - } - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "legacy-javascript-insight": { "id": "legacy-javascript-insight", "title": "Legacy JavaScript", "description": "Polyfills and transforms enable older browsers to use new JavaScript features. However, many aren't necessary for modern browsers. Consider modifying your JavaScript build process to not transpile [Baseline](https://web.dev/articles/baseline-and-polyfills) features, unless you know you must support older browsers. [Learn why most sites can deploy ES6+ code without transpiling](https://developer.chrome.com/docs/performance/insights/legacy-javascript)", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "subItemsHeading": { - "key": "location", - "valueType": "source-location" - }, - "label": "URL" - }, - { - "key": null, - "valueType": "code", - "subItemsHeading": { - "key": "signal" - }, - "label": "" - }, - { - "key": "wastedBytes", - "valueType": "bytes", - "label": "Wasted bytes" - } - ], - "items": [], - "debugData": { - "type": "debugdata", - "wastedBytes": 0 - } - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 2 }, "network-dependency-tree-insight": { "id": "network-dependency-tree-insight", "title": "Network dependency tree", "description": "[Avoid chaining critical requests](https://developer.chrome.com/docs/performance/insights/network-dependency-tree) by reducing the length of chains, reducing the download size of resources, or deferring the download of unnecessary resources to improve page load.", - "score": 1, - "scoreDisplayMode": "numeric", - "metricSavings": { - "LCP": 0 - }, - "details": { - "type": "list", - "items": [ - { - "type": "list-section", - "value": { - "type": "network-tree", - "chains": { - "9E726BF73EE3F17B3D0E9C4779BDDEF7": { - "url": "https://www.mikescerealshack.co/", - "navStartToEndTime": 173, - "transferSize": 3632, - "isLongest": true, - "children": {} - } - }, - "longestChain": { - "duration": 173 - } - } - }, - { - "type": "list-section", - "title": "Preconnected origins", - "description": "[preconnect](https://developer.chrome.com/docs/lighthouse/performance/uses-rel-preconnect/) hints help the browser establish a connection earlier in the page load, saving time when the first request for that origin is made. The following are the origins that the page preconnected to.", - "value": { - "type": "text", - "value": "no origins were preconnected" - } - }, - { - "type": "list-section", - "title": "Preconnect candidates", - "description": "Add [preconnect](https://developer.chrome.com/docs/lighthouse/performance/uses-rel-preconnect/) hints to your most important origins, but try to use no more than 4.", - "value": { - "type": "table", - "headings": [ - { - "key": "origin", - "valueType": "text", - "label": "Origin" - }, - { - "key": "wastedMs", - "valueType": "ms", - "label": "Est LCP savings" - } - ], - "items": [ - { - "origin": "https://www.google-analytics.com", - "wastedMs": 300 - } - ] - } - } - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 1 }, "render-blocking-insight": { "id": "render-blocking-insight", "title": "Render blocking requests", "description": "Requests are blocking the page's initial render, which may delay LCP. [Deferring or inlining](https://developer.chrome.com/docs/performance/insights/render-blocking) can move these network requests out of the critical path.", - "score": 1, - "scoreDisplayMode": "metricSavings", - "metricSavings": { - "FCP": 0, - "LCP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "totalBytes", - "valueType": "bytes", - "label": "Transfer Size" - }, - { - "key": "wastedMs", - "valueType": "timespanMs", - "label": "Duration" - } - ], - "items": [] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "third-parties-insight": { "id": "third-parties-insight", "title": "3rd parties", "description": "3rd party code can significantly impact load performance. [Reduce and defer loading of 3rd party code](https://developer.chrome.com/docs/performance/insights/third-parties) to prioritize your page's content.", - "score": 1, - "scoreDisplayMode": "informative", - "details": { - "type": "table", - "headings": [ - { - "key": "entity", - "valueType": "text", - "label": "3rd party", - "subItemsHeading": { - "key": "url", - "valueType": "url" - } - }, - { - "key": "transferSize", - "granularity": 1, - "valueType": "bytes", - "label": "Transfer size", - "subItemsHeading": { - "key": "transferSize" - } - }, - { - "key": "mainThreadTime", - "granularity": 1, - "valueType": "ms", - "label": "Main thread time", - "subItemsHeading": { - "key": "mainThreadTime" - } - } - ], - "items": [ - { - "entity": "Google Tag Manager", - "mainThreadTime": 30.73799991607666, - "transferSize": 112588, - "subItems": { - "type": "subitems", - "items": [ - { - "url": "https://www.googletagmanager.com/gtag/js?id=G-RTW9M3W5HC", - "mainThreadTime": 30.73799991607666, - "transferSize": 112588 - } - ] - } - }, - { - "entity": "Google Fonts", - "mainThreadTime": 0, - "transferSize": 16723, - "subItems": { - "type": "subitems", - "items": [ - { - "url": "https://fonts.gstatic.com/s/poppins/v22/pxiEyp8kv8JHgFVrJJfecnFHGPc.woff2", - "mainThreadTime": 0, - "transferSize": 7927 - }, - { - "url": "https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLCz7Z1xlFd2JQEk.woff2", - "mainThreadTime": 0, - "transferSize": 7875 - }, - { - "url": "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;700&display=swap", - "mainThreadTime": 0, - "transferSize": 921 - } - ] - } - }, - { - "entity": "Google Analytics", - "mainThreadTime": 0, - "transferSize": 599, - "subItems": { - "type": "subitems", - "items": [ - { - "url": "https://www.google-analytics.com/g/collect?v=2&tid=G-RTW9M3W5HC>m=45je5230v9102781914za200&_p=1738719102855&gcd=13l3l3l3l1l1&npa=0&dma=0&tag_exp=102067808~102081485~102123608~102482432~102539968~102558064&cid=974257356.1738719103&ul=en-us&sr=412x823&uaa=&uab=64&uafvl=Chromium%3B134.0.6998.0%7CNot%253AA-Brand%3B24.0.0.0%7CGoogle%2520Chrome%3B134.0.6998.0&uamb=1&uam=moto%20g%20power%20(2022)&uap=Android&uapv=11.0&uaw=0&are=1&frm=0&pscdl=noapi&_s=1&sid=1738719103&sct=1&seg=0&dl=https%3A%2F%2Fwww.mikescerealshack.co%2F&dt=Search%20-%20Mike%27s%20Cereal%20Shack%3A%20The%20Office%20Search%20Engine&en=page_view&_fv=1&_nsi=1&_ss=1&_ee=1&tfd=427", - "mainThreadTime": 0, - "transferSize": 551 - }, - { - "url": "https://www.google-analytics.com/g/collect?v=2&tid=G-RTW9M3W5HC>m=45je5230v9102781914za200&_p=1738719102855&gcd=13l3l3l3l1l1&npa=0&dma=0&tag_exp=102067808~102081485~102123608~102482432~102539968~102558064&cid=974257356.1738719103&ul=en-us&sr=412x823&uaa=&uab=64&uafvl=Chromium%3B134.0.6998.0%7CNot%253AA-Brand%3B24.0.0.0%7CGoogle%2520Chrome%3B134.0.6998.0&uamb=1&uam=moto%20g%20power%20(2022)&uap=Android&uapv=11.0&uaw=0&are=1&frm=0&pscdl=noapi&_eu=AEA&_s=2&sid=1738719103&sct=1&seg=0&dl=https%3A%2F%2Fwww.mikescerealshack.co%2F&dt=Search%20-%20Mike%27s%20Cereal%20Shack%3A%20The%20Office%20Search%20Engine&en=scroll&epn.percent_scrolled=90&tfd=5436", - "mainThreadTime": 0, - "transferSize": 48 - } - ] - } - } - ], - "isEntityGrouped": true - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 }, "viewport-insight": { "id": "viewport-insight", "title": "Optimize viewport for mobile", "description": "Tap interactions may be [delayed by up to 300 ms](https://developer.chrome.com/docs/performance/insights/viewport) if the viewport is not optimized for mobile.", - "score": 1, - "scoreDisplayMode": "numeric", - "metricSavings": { - "INP": 0 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "node", - "valueType": "node", - "label": "" - } - ], - "items": [ - {} - ] - }, + "score": null, + "scoreDisplayMode": "error", + "errorMessage": "Required HostDPR gatherer did not run.", + "errorStack": "LighthouseError: MISSING_REQUIRED_ARTIFACT\n at Runner._runAudit (file:///core/runner.js)\n at Runner._runAudits (file:///core/runner.js)\n at async Runner.audit (file:///core/runner.js)\n at async auditGatherSteps (file:///core/user-flow.js)\n at async Module.auditFlowArtifacts (file:///core/index.js)\n at async generateFlowResult (file:///core/scripts/update-flow-fixtures.js)\n at async file:///core/scripts/update-flow-fixtures.js", "guidanceLevel": 3 } }, @@ -4625,7 +3672,7 @@ } ], "id": "performance", - "score": 0.79 + "score": null }, "accessibility": { "title": "Accessibility", @@ -6146,12542 +5193,1056 @@ }, { "startTime": 58, - "name": "lh:computed:FirstContentfulPaint", + "name": "lh:audit:largest-contentful-paint", "duration": 1, "entryType": "measure" }, { "startTime": 59, - "name": "lh:computed:ProcessedTrace", + "name": "lh:audit:speed-index", "duration": 1, "entryType": "measure" }, { "startTime": 60, - "name": "lh:computed:ProcessedNavigation", + "name": "lh:audit:screenshot-thumbnails", "duration": 1, "entryType": "measure" }, { "startTime": 61, - "name": "lh:computed:LanternFirstContentfulPaint", + "name": "lh:computed:Speedline", "duration": 1, "entryType": "measure" }, { "startTime": 62, - "name": "lh:computed:PageDependencyGraph", + "name": "lh:computed:ProcessedTrace", "duration": 1, "entryType": "measure" }, { "startTime": 63, - "name": "lh:computed:LoadSimulator", + "name": "lh:audit:final-screenshot", "duration": 1, "entryType": "measure" }, { "startTime": 64, - "name": "lh:computed:NetworkAnalysis", + "name": "lh:computed:Screenshots", "duration": 1, "entryType": "measure" }, { "startTime": 65, - "name": "lh:audit:largest-contentful-paint", + "name": "lh:audit:total-blocking-time", "duration": 1, "entryType": "measure" }, { "startTime": 66, - "name": "lh:computed:LargestContentfulPaint", + "name": "lh:audit:max-potential-fid", "duration": 1, "entryType": "measure" }, { "startTime": 67, - "name": "lh:computed:LanternLargestContentfulPaint", + "name": "lh:audit:cumulative-layout-shift", "duration": 1, "entryType": "measure" }, { "startTime": 68, - "name": "lh:audit:speed-index", + "name": "lh:computed:CumulativeLayoutShift", "duration": 1, "entryType": "measure" }, { "startTime": 69, - "name": "lh:computed:SpeedIndex", + "name": "lh:audit:errors-in-console", "duration": 1, "entryType": "measure" }, { "startTime": 70, - "name": "lh:computed:LanternSpeedIndex", + "name": "lh:computed:JSBundles", "duration": 1, "entryType": "measure" }, { "startTime": 71, - "name": "lh:computed:Speedline", + "name": "lh:audit:server-response-time", "duration": 1, "entryType": "measure" }, { "startTime": 72, - "name": "lh:audit:screenshot-thumbnails", + "name": "lh:audit:interactive", "duration": 1, "entryType": "measure" }, { "startTime": 73, - "name": "lh:audit:final-screenshot", + "name": "lh:audit:user-timings", "duration": 1, "entryType": "measure" }, { "startTime": 74, - "name": "lh:computed:Screenshots", + "name": "lh:computed:UserTimings", "duration": 1, "entryType": "measure" }, { "startTime": 75, - "name": "lh:audit:total-blocking-time", + "name": "lh:audit:redirects", "duration": 1, "entryType": "measure" }, { "startTime": 76, - "name": "lh:computed:TotalBlockingTime", + "name": "lh:audit:image-aspect-ratio", "duration": 1, "entryType": "measure" }, { "startTime": 77, - "name": "lh:computed:LanternTotalBlockingTime", + "name": "lh:audit:image-size-responsive", "duration": 1, "entryType": "measure" }, { "startTime": 78, - "name": "lh:computed:LanternInteractive", + "name": "lh:computed:ImageRecords", "duration": 1, "entryType": "measure" }, { "startTime": 79, - "name": "lh:audit:max-potential-fid", + "name": "lh:audit:deprecations", "duration": 1, "entryType": "measure" }, { "startTime": 80, - "name": "lh:computed:MaxPotentialFID", + "name": "lh:audit:third-party-cookies", "duration": 1, "entryType": "measure" }, { "startTime": 81, - "name": "lh:computed:LanternMaxPotentialFID", + "name": "lh:audit:mainthread-work-breakdown", "duration": 1, "entryType": "measure" }, { "startTime": 82, - "name": "lh:audit:cumulative-layout-shift", + "name": "lh:audit:bootup-time", "duration": 1, "entryType": "measure" }, { "startTime": 83, - "name": "lh:computed:CumulativeLayoutShift", + "name": "lh:audit:diagnostics", "duration": 1, "entryType": "measure" }, { "startTime": 84, - "name": "lh:audit:errors-in-console", + "name": "lh:computed:MainThreadTasks", "duration": 1, "entryType": "measure" }, { "startTime": 85, - "name": "lh:computed:JSBundles", + "name": "lh:computed:NetworkAnalysis", "duration": 1, "entryType": "measure" }, { "startTime": 86, - "name": "lh:audit:server-response-time", + "name": "lh:computed:MainResource", "duration": 1, "entryType": "measure" }, { "startTime": 87, - "name": "lh:computed:NavigationInsights", + "name": "lh:audit:network-requests", "duration": 1, "entryType": "measure" }, { "startTime": 88, - "name": "lh:computed:TraceEngineResult", + "name": "lh:computed:EntityClassification", "duration": 1, "entryType": "measure" }, { "startTime": 89, - "name": "lh:computed:TraceEngineResult:total", + "name": "lh:audit:network-rtt", "duration": 1, "entryType": "measure" }, { "startTime": 90, - "name": "lh:computed:TraceEngineResult:parse", + "name": "lh:audit:network-server-latency", "duration": 1, "entryType": "measure" }, { "startTime": 91, - "name": "lh:computed:TraceEngineResult:parse:handleEvent", + "name": "lh:audit:main-thread-tasks", "duration": 1, "entryType": "measure" }, { "startTime": 92, - "name": "lh:computed:TraceEngineResult:parse:Meta:finalize", + "name": "lh:audit:metrics", "duration": 1, "entryType": "measure" }, { "startTime": 93, - "name": "lh:computed:TraceEngineResult:parse:AnimationFrames:finalize", + "name": "lh:audit:resource-summary", "duration": 1, "entryType": "measure" }, { "startTime": 94, - "name": "lh:computed:TraceEngineResult:parse:Animations:finalize", + "name": "lh:computed:ResourceSummary", "duration": 1, "entryType": "measure" }, { "startTime": 95, - "name": "lh:computed:TraceEngineResult:parse:Samples:finalize", + "name": "lh:audit:layout-shifts", "duration": 1, "entryType": "measure" }, { "startTime": 96, - "name": "lh:computed:TraceEngineResult:parse:AuctionWorklets:finalize", + "name": "lh:audit:long-tasks", "duration": 1, "entryType": "measure" }, { "startTime": 97, - "name": "lh:computed:TraceEngineResult:parse:NetworkRequests:finalize", + "name": "lh:audit:non-composited-animations", "duration": 1, "entryType": "measure" }, { "startTime": 98, - "name": "lh:computed:TraceEngineResult:parse:Renderer:finalize", + "name": "lh:audit:unsized-images", "duration": 1, "entryType": "measure" }, { "startTime": 99, - "name": "lh:computed:TraceEngineResult:parse:Flows:finalize", + "name": "lh:audit:valid-source-maps", "duration": 1, "entryType": "measure" }, { "startTime": 100, - "name": "lh:computed:TraceEngineResult:parse:AsyncJSCalls:finalize", + "name": "lh:audit:csp-xss", "duration": 1, "entryType": "measure" }, { "startTime": 101, - "name": "lh:computed:TraceEngineResult:parse:DOMStats:finalize", + "name": "lh:audit:has-hsts", "duration": 1, "entryType": "measure" }, { "startTime": 102, - "name": "lh:computed:TraceEngineResult:parse:UserTimings:finalize", + "name": "lh:audit:origin-isolation", "duration": 1, "entryType": "measure" }, { "startTime": 103, - "name": "lh:computed:TraceEngineResult:parse:ExtensionTraceData:finalize", + "name": "lh:audit:clickjacking-mitigation", "duration": 1, "entryType": "measure" }, { "startTime": 104, - "name": "lh:computed:TraceEngineResult:parse:LayerTree:finalize", + "name": "lh:audit:trusted-types-xss", "duration": 1, "entryType": "measure" }, { "startTime": 105, - "name": "lh:computed:TraceEngineResult:parse:Frames:finalize", + "name": "lh:audit:script-treemap-data", "duration": 1, "entryType": "measure" }, { "startTime": 106, - "name": "lh:computed:TraceEngineResult:parse:GPU:finalize", + "name": "lh:computed:ModuleDuplication", "duration": 1, "entryType": "measure" }, { "startTime": 107, - "name": "lh:computed:TraceEngineResult:parse:ImagePainting:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 108, - "name": "lh:computed:TraceEngineResult:parse:Initiators:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 109, - "name": "lh:computed:TraceEngineResult:parse:Invalidations:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 110, - "name": "lh:computed:TraceEngineResult:parse:PageLoadMetrics:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 111, - "name": "lh:computed:TraceEngineResult:parse:LargestImagePaint:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 112, - "name": "lh:computed:TraceEngineResult:parse:LargestTextPaint:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 113, - "name": "lh:computed:TraceEngineResult:parse:Screenshots:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 114, - "name": "lh:computed:TraceEngineResult:parse:LayoutShifts:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 115, - "name": "lh:computed:TraceEngineResult:parse:Memory:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 116, - "name": "lh:computed:TraceEngineResult:parse:PageFrames:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 117, - "name": "lh:computed:TraceEngineResult:parse:Scripts:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 118, - "name": "lh:computed:TraceEngineResult:parse:SelectorStats:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 119, - "name": "lh:computed:TraceEngineResult:parse:UserInteractions:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 120, - "name": "lh:computed:TraceEngineResult:parse:Workers:finalize", + "name": "lh:computed:UnusedJavascriptSummary", "duration": 1, "entryType": "measure" }, { "startTime": 121, - "name": "lh:computed:TraceEngineResult:parse:Warnings:finalize", + "name": "lh:audit:accesskeys", "duration": 1, "entryType": "measure" }, { "startTime": 122, - "name": "lh:computed:TraceEngineResult:parse:handler.data()", + "name": "lh:audit:aria-allowed-attr", "duration": 1, "entryType": "measure" }, { "startTime": 123, - "name": "lh:computed:TraceEngineResult:insights", + "name": "lh:audit:aria-allowed-role", "duration": 1, "entryType": "measure" }, { "startTime": 124, - "name": "lh:computed:TraceEngineResult:insights:CLSCulprits", + "name": "lh:audit:aria-command-name", "duration": 1, "entryType": "measure" }, { "startTime": 125, - "name": "lh:computed:TraceEngineResult:insights:Cache", + "name": "lh:audit:aria-conditional-attr", "duration": 1, "entryType": "measure" }, { "startTime": 126, - "name": "lh:computed:TraceEngineResult:insights:DOMSize", + "name": "lh:audit:aria-deprecated-role", "duration": 1, "entryType": "measure" }, { "startTime": 127, - "name": "lh:computed:TraceEngineResult:insights:DocumentLatency", + "name": "lh:audit:aria-dialog-name", "duration": 1, "entryType": "measure" }, { "startTime": 128, - "name": "lh:computed:TraceEngineResult:insights:DuplicatedJavaScript", + "name": "lh:audit:aria-hidden-body", "duration": 1, "entryType": "measure" }, { "startTime": 129, - "name": "lh:computed:TraceEngineResult:insights:FontDisplay", + "name": "lh:audit:aria-hidden-focus", "duration": 1, "entryType": "measure" }, { "startTime": 130, - "name": "lh:computed:TraceEngineResult:insights:ForcedReflow", + "name": "lh:audit:aria-input-field-name", "duration": 1, "entryType": "measure" }, { "startTime": 131, - "name": "lh:computed:TraceEngineResult:insights:INPBreakdown", + "name": "lh:audit:aria-meter-name", "duration": 1, "entryType": "measure" }, { "startTime": 132, - "name": "lh:computed:TraceEngineResult:insights:ImageDelivery", + "name": "lh:audit:aria-progressbar-name", "duration": 1, "entryType": "measure" }, { "startTime": 133, - "name": "lh:computed:TraceEngineResult:insights:LCPBreakdown", + "name": "lh:audit:aria-prohibited-attr", "duration": 1, "entryType": "measure" }, { "startTime": 134, - "name": "lh:computed:TraceEngineResult:insights:LCPDiscovery", + "name": "lh:audit:aria-required-attr", "duration": 1, "entryType": "measure" }, { "startTime": 135, - "name": "lh:computed:TraceEngineResult:insights:LegacyJavaScript", + "name": "lh:audit:aria-required-children", "duration": 1, "entryType": "measure" }, { "startTime": 136, - "name": "lh:computed:TraceEngineResult:insights:ModernHTTP", + "name": "lh:audit:aria-required-parent", "duration": 1, "entryType": "measure" }, { "startTime": 137, - "name": "lh:computed:TraceEngineResult:insights:NetworkDependencyTree", + "name": "lh:audit:aria-roles", "duration": 1, "entryType": "measure" }, { "startTime": 138, - "name": "lh:computed:TraceEngineResult:insights:RenderBlocking", + "name": "lh:audit:aria-text", "duration": 1, "entryType": "measure" }, { "startTime": 139, - "name": "lh:computed:TraceEngineResult:insights:SlowCSSSelector", + "name": "lh:audit:aria-toggle-field-name", "duration": 1, "entryType": "measure" }, { "startTime": 140, - "name": "lh:computed:TraceEngineResult:insights:ThirdParties", + "name": "lh:audit:aria-tooltip-name", "duration": 1, "entryType": "measure" }, { "startTime": 141, - "name": "lh:computed:TraceEngineResult:insights:Viewport", + "name": "lh:audit:aria-treeitem-name", "duration": 1, "entryType": "measure" }, { "startTime": 142, - "name": "lh:computed:TraceEngineResult:insights:createLanternContext", + "name": "lh:audit:aria-valid-attr-value", "duration": 1, "entryType": "measure" }, { "startTime": 143, - "name": "lh:computed:TraceEngineResult:insights:CLSCulprits", + "name": "lh:audit:aria-valid-attr", "duration": 1, "entryType": "measure" }, { "startTime": 144, - "name": "lh:computed:TraceEngineResult:insights:Cache", + "name": "lh:audit:button-name", "duration": 1, "entryType": "measure" }, { "startTime": 145, - "name": "lh:computed:TraceEngineResult:insights:DOMSize", + "name": "lh:audit:bypass", "duration": 1, "entryType": "measure" }, { "startTime": 146, - "name": "lh:computed:TraceEngineResult:insights:DocumentLatency", + "name": "lh:audit:color-contrast", "duration": 1, "entryType": "measure" }, { "startTime": 147, - "name": "lh:computed:TraceEngineResult:insights:DuplicatedJavaScript", + "name": "lh:audit:definition-list", "duration": 1, "entryType": "measure" }, { "startTime": 148, - "name": "lh:computed:TraceEngineResult:insights:FontDisplay", + "name": "lh:audit:dlitem", "duration": 1, "entryType": "measure" }, { "startTime": 149, - "name": "lh:computed:TraceEngineResult:insights:ForcedReflow", + "name": "lh:audit:document-title", "duration": 1, "entryType": "measure" }, { "startTime": 150, - "name": "lh:computed:TraceEngineResult:insights:INPBreakdown", + "name": "lh:audit:duplicate-id-aria", "duration": 1, "entryType": "measure" }, { "startTime": 151, - "name": "lh:computed:TraceEngineResult:insights:ImageDelivery", + "name": "lh:audit:empty-heading", "duration": 1, "entryType": "measure" }, { "startTime": 152, - "name": "lh:computed:TraceEngineResult:insights:LCPBreakdown", + "name": "lh:audit:form-field-multiple-labels", "duration": 1, "entryType": "measure" }, { "startTime": 153, - "name": "lh:computed:TraceEngineResult:insights:LCPDiscovery", + "name": "lh:audit:frame-title", "duration": 1, "entryType": "measure" }, { "startTime": 154, - "name": "lh:computed:TraceEngineResult:insights:LegacyJavaScript", + "name": "lh:audit:heading-order", "duration": 1, "entryType": "measure" }, { "startTime": 155, - "name": "lh:computed:TraceEngineResult:insights:ModernHTTP", + "name": "lh:audit:html-has-lang", "duration": 1, "entryType": "measure" }, { "startTime": 156, - "name": "lh:computed:TraceEngineResult:insights:NetworkDependencyTree", + "name": "lh:audit:html-lang-valid", "duration": 1, "entryType": "measure" }, { "startTime": 157, - "name": "lh:computed:TraceEngineResult:insights:RenderBlocking", + "name": "lh:audit:html-xml-lang-mismatch", "duration": 1, "entryType": "measure" }, { "startTime": 158, - "name": "lh:computed:TraceEngineResult:insights:SlowCSSSelector", + "name": "lh:audit:identical-links-same-purpose", "duration": 1, "entryType": "measure" }, { "startTime": 159, - "name": "lh:computed:TraceEngineResult:insights:ThirdParties", + "name": "lh:audit:image-alt", "duration": 1, "entryType": "measure" }, { "startTime": 160, - "name": "lh:computed:TraceEngineResult:insights:Viewport", + "name": "lh:audit:image-redundant-alt", "duration": 1, "entryType": "measure" }, { "startTime": 161, - "name": "lh:audit:interactive", + "name": "lh:audit:input-button-name", "duration": 1, "entryType": "measure" }, { "startTime": 162, - "name": "lh:computed:Interactive", + "name": "lh:audit:input-image-alt", "duration": 1, "entryType": "measure" }, { "startTime": 163, - "name": "lh:audit:user-timings", + "name": "lh:audit:label-content-name-mismatch", "duration": 1, "entryType": "measure" }, { "startTime": 164, - "name": "lh:computed:UserTimings", + "name": "lh:audit:label", "duration": 1, "entryType": "measure" }, { "startTime": 165, - "name": "lh:audit:redirects", + "name": "lh:audit:landmark-one-main", "duration": 1, "entryType": "measure" }, { "startTime": 166, - "name": "lh:audit:image-aspect-ratio", + "name": "lh:audit:link-name", "duration": 1, "entryType": "measure" }, { "startTime": 167, - "name": "lh:audit:image-size-responsive", + "name": "lh:audit:link-in-text-block", "duration": 1, "entryType": "measure" }, { "startTime": 168, - "name": "lh:computed:ImageRecords", + "name": "lh:audit:list", "duration": 1, "entryType": "measure" }, { "startTime": 169, - "name": "lh:audit:deprecations", + "name": "lh:audit:listitem", "duration": 1, "entryType": "measure" }, { "startTime": 170, - "name": "lh:audit:third-party-cookies", + "name": "lh:audit:meta-refresh", "duration": 1, "entryType": "measure" }, { "startTime": 171, - "name": "lh:audit:mainthread-work-breakdown", + "name": "lh:audit:meta-viewport", "duration": 1, "entryType": "measure" }, { "startTime": 172, - "name": "lh:computed:MainThreadTasks", + "name": "lh:audit:object-alt", "duration": 1, "entryType": "measure" }, { "startTime": 173, - "name": "lh:audit:bootup-time", + "name": "lh:audit:select-name", "duration": 1, "entryType": "measure" }, { "startTime": 174, - "name": "lh:computed:TBTImpactTasks", + "name": "lh:audit:skip-link", "duration": 1, "entryType": "measure" }, { "startTime": 175, - "name": "lh:audit:diagnostics", + "name": "lh:audit:tabindex", "duration": 1, "entryType": "measure" }, { "startTime": 176, - "name": "lh:computed:MainResource", + "name": "lh:audit:table-duplicate-name", "duration": 1, "entryType": "measure" }, { "startTime": 177, - "name": "lh:audit:network-requests", + "name": "lh:audit:table-fake-caption", "duration": 1, "entryType": "measure" }, { "startTime": 178, - "name": "lh:computed:EntityClassification", + "name": "lh:audit:target-size", "duration": 1, "entryType": "measure" }, { "startTime": 179, - "name": "lh:audit:network-rtt", + "name": "lh:audit:td-has-header", "duration": 1, "entryType": "measure" }, { "startTime": 180, - "name": "lh:audit:network-server-latency", + "name": "lh:audit:td-headers-attr", "duration": 1, "entryType": "measure" }, { "startTime": 181, - "name": "lh:audit:main-thread-tasks", + "name": "lh:audit:th-has-data-cells", "duration": 1, "entryType": "measure" }, { "startTime": 182, - "name": "lh:audit:metrics", + "name": "lh:audit:valid-lang", "duration": 1, "entryType": "measure" }, { "startTime": 183, - "name": "lh:computed:TimingSummary", + "name": "lh:audit:video-caption", "duration": 1, "entryType": "measure" }, { "startTime": 184, - "name": "lh:computed:FirstContentfulPaintAllFrames", + "name": "lh:audit:custom-controls-labels", "duration": 1, "entryType": "measure" }, { "startTime": 185, - "name": "lh:computed:LargestContentfulPaintAllFrames", + "name": "lh:audit:custom-controls-roles", "duration": 1, "entryType": "measure" }, { "startTime": 186, - "name": "lh:computed:LCPBreakdown", + "name": "lh:audit:focus-traps", "duration": 1, "entryType": "measure" }, { "startTime": 187, - "name": "lh:computed:TimeToFirstByte", + "name": "lh:audit:focusable-controls", "duration": 1, "entryType": "measure" }, { "startTime": 188, - "name": "lh:computed:LCPImageRecord", + "name": "lh:audit:interactive-element-affordance", "duration": 1, "entryType": "measure" }, { "startTime": 189, - "name": "lh:audit:resource-summary", + "name": "lh:audit:logical-tab-order", "duration": 1, "entryType": "measure" }, { "startTime": 190, - "name": "lh:computed:ResourceSummary", + "name": "lh:audit:managed-focus", "duration": 1, "entryType": "measure" }, { "startTime": 191, - "name": "lh:audit:layout-shifts", + "name": "lh:audit:offscreen-content-hidden", "duration": 1, "entryType": "measure" }, { "startTime": 192, - "name": "lh:audit:long-tasks", + "name": "lh:audit:use-landmarks", "duration": 1, "entryType": "measure" }, { "startTime": 193, - "name": "lh:audit:non-composited-animations", + "name": "lh:audit:visual-order-follows-dom", "duration": 1, "entryType": "measure" }, { "startTime": 194, - "name": "lh:audit:unsized-images", + "name": "lh:audit:total-byte-weight", "duration": 1, "entryType": "measure" }, { "startTime": 195, - "name": "lh:audit:valid-source-maps", + "name": "lh:audit:unminified-css", "duration": 1, "entryType": "measure" }, { "startTime": 196, - "name": "lh:audit:csp-xss", + "name": "lh:audit:unminified-javascript", "duration": 1, "entryType": "measure" }, { "startTime": 197, - "name": "lh:audit:has-hsts", + "name": "lh:audit:unused-css-rules", "duration": 1, "entryType": "measure" }, { "startTime": 198, - "name": "lh:audit:origin-isolation", + "name": "lh:audit:unused-javascript", "duration": 1, "entryType": "measure" }, { "startTime": 199, - "name": "lh:audit:clickjacking-mitigation", + "name": "lh:audit:doctype", "duration": 1, "entryType": "measure" }, { "startTime": 200, - "name": "lh:audit:trusted-types-xss", + "name": "lh:audit:charset", "duration": 1, "entryType": "measure" }, { "startTime": 201, - "name": "lh:audit:script-treemap-data", + "name": "lh:audit:geolocation-on-start", "duration": 1, "entryType": "measure" }, { "startTime": 202, - "name": "lh:computed:ModuleDuplication", + "name": "lh:audit:inspector-issues", "duration": 1, "entryType": "measure" }, { "startTime": 203, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:js-libraries", "duration": 1, "entryType": "measure" }, { "startTime": 204, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:notification-on-start", "duration": 1, "entryType": "measure" }, { "startTime": 205, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:paste-preventing-inputs", "duration": 1, "entryType": "measure" }, { "startTime": 206, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:meta-description", "duration": 1, "entryType": "measure" }, { "startTime": 207, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:http-status-code", "duration": 1, "entryType": "measure" }, { "startTime": 208, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:link-text", "duration": 1, "entryType": "measure" }, { "startTime": 209, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:crawlable-anchors", "duration": 1, "entryType": "measure" }, { "startTime": 210, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:is-crawlable", "duration": 1, "entryType": "measure" }, { "startTime": 211, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:robots-txt", "duration": 1, "entryType": "measure" }, { "startTime": 212, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:hreflang", "duration": 1, "entryType": "measure" }, { "startTime": 213, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:canonical", "duration": 1, "entryType": "measure" }, { "startTime": 214, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:structured-data", "duration": 1, "entryType": "measure" }, { "startTime": 215, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:bf-cache", "duration": 1, "entryType": "measure" }, { "startTime": 216, - "name": "lh:computed:UnusedJavascriptSummary", + "name": "lh:audit:cache-insight", "duration": 1, "entryType": "measure" }, { "startTime": 217, - "name": "lh:audit:accesskeys", + "name": "lh:audit:cls-culprits-insight", "duration": 1, "entryType": "measure" }, { "startTime": 218, - "name": "lh:audit:aria-allowed-attr", + "name": "lh:audit:document-latency-insight", "duration": 1, "entryType": "measure" }, { "startTime": 219, - "name": "lh:audit:aria-allowed-role", + "name": "lh:audit:dom-size-insight", "duration": 1, "entryType": "measure" }, { "startTime": 220, - "name": "lh:audit:aria-command-name", + "name": "lh:audit:duplicated-javascript-insight", "duration": 1, "entryType": "measure" }, { "startTime": 221, - "name": "lh:audit:aria-conditional-attr", + "name": "lh:audit:font-display-insight", "duration": 1, "entryType": "measure" }, { "startTime": 222, - "name": "lh:audit:aria-deprecated-role", + "name": "lh:audit:forced-reflow-insight", "duration": 1, "entryType": "measure" }, { "startTime": 223, - "name": "lh:audit:aria-dialog-name", + "name": "lh:audit:image-delivery-insight", "duration": 1, "entryType": "measure" }, { "startTime": 224, - "name": "lh:audit:aria-hidden-body", + "name": "lh:audit:inp-breakdown-insight", "duration": 1, "entryType": "measure" }, { "startTime": 225, - "name": "lh:audit:aria-hidden-focus", + "name": "lh:audit:lcp-breakdown-insight", "duration": 1, "entryType": "measure" }, { "startTime": 226, - "name": "lh:audit:aria-input-field-name", + "name": "lh:audit:lcp-discovery-insight", "duration": 1, "entryType": "measure" }, { "startTime": 227, - "name": "lh:audit:aria-meter-name", + "name": "lh:audit:legacy-javascript-insight", "duration": 1, "entryType": "measure" }, { "startTime": 228, - "name": "lh:audit:aria-progressbar-name", + "name": "lh:audit:network-dependency-tree-insight", "duration": 1, "entryType": "measure" }, { "startTime": 229, - "name": "lh:audit:aria-prohibited-attr", + "name": "lh:audit:render-blocking-insight", "duration": 1, "entryType": "measure" }, { "startTime": 230, - "name": "lh:audit:aria-required-attr", + "name": "lh:audit:third-parties-insight", "duration": 1, "entryType": "measure" }, { "startTime": 231, - "name": "lh:audit:aria-required-children", + "name": "lh:audit:viewport-insight", "duration": 1, "entryType": "measure" }, { "startTime": 232, - "name": "lh:audit:aria-required-parent", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 233, - "name": "lh:audit:aria-roles", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 234, - "name": "lh:audit:aria-text", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 235, - "name": "lh:audit:aria-toggle-field-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 236, - "name": "lh:audit:aria-tooltip-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 237, - "name": "lh:audit:aria-treeitem-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 238, - "name": "lh:audit:aria-valid-attr-value", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 239, - "name": "lh:audit:aria-valid-attr", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 240, - "name": "lh:audit:button-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 241, - "name": "lh:audit:bypass", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 242, - "name": "lh:audit:color-contrast", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 243, - "name": "lh:audit:definition-list", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 244, - "name": "lh:audit:dlitem", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 245, - "name": "lh:audit:document-title", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 246, - "name": "lh:audit:duplicate-id-aria", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 247, - "name": "lh:audit:empty-heading", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 248, - "name": "lh:audit:form-field-multiple-labels", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 249, - "name": "lh:audit:frame-title", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 250, - "name": "lh:audit:heading-order", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 251, - "name": "lh:audit:html-has-lang", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 252, - "name": "lh:audit:html-lang-valid", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 253, - "name": "lh:audit:html-xml-lang-mismatch", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 254, - "name": "lh:audit:identical-links-same-purpose", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 255, - "name": "lh:audit:image-alt", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 256, - "name": "lh:audit:image-redundant-alt", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 257, - "name": "lh:audit:input-button-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 258, - "name": "lh:audit:input-image-alt", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 259, - "name": "lh:audit:label-content-name-mismatch", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 260, - "name": "lh:audit:label", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 261, - "name": "lh:audit:landmark-one-main", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 262, - "name": "lh:audit:link-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 263, - "name": "lh:audit:link-in-text-block", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 264, - "name": "lh:audit:list", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 265, - "name": "lh:audit:listitem", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 266, - "name": "lh:audit:meta-refresh", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 267, - "name": "lh:audit:meta-viewport", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 268, - "name": "lh:audit:object-alt", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 269, - "name": "lh:audit:select-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 270, - "name": "lh:audit:skip-link", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 271, - "name": "lh:audit:tabindex", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 272, - "name": "lh:audit:table-duplicate-name", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 273, - "name": "lh:audit:table-fake-caption", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 274, - "name": "lh:audit:target-size", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 275, - "name": "lh:audit:td-has-header", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 276, - "name": "lh:audit:td-headers-attr", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 277, - "name": "lh:audit:th-has-data-cells", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 278, - "name": "lh:audit:valid-lang", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 279, - "name": "lh:audit:video-caption", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 280, - "name": "lh:audit:custom-controls-labels", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 281, - "name": "lh:audit:custom-controls-roles", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 282, - "name": "lh:audit:focus-traps", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 283, - "name": "lh:audit:focusable-controls", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 284, - "name": "lh:audit:interactive-element-affordance", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 285, - "name": "lh:audit:logical-tab-order", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 286, - "name": "lh:audit:managed-focus", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 287, - "name": "lh:audit:offscreen-content-hidden", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 288, - "name": "lh:audit:use-landmarks", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 289, - "name": "lh:audit:visual-order-follows-dom", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 290, - "name": "lh:audit:total-byte-weight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 291, - "name": "lh:audit:unminified-css", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 292, - "name": "lh:audit:unminified-javascript", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 293, - "name": "lh:audit:unused-css-rules", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 294, - "name": "lh:computed:UnusedCSS", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 295, - "name": "lh:audit:unused-javascript", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 296, - "name": "lh:audit:doctype", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 297, - "name": "lh:audit:charset", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 298, - "name": "lh:audit:geolocation-on-start", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 299, - "name": "lh:audit:inspector-issues", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 300, - "name": "lh:audit:js-libraries", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 301, - "name": "lh:audit:notification-on-start", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 302, - "name": "lh:audit:paste-preventing-inputs", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 303, - "name": "lh:audit:meta-description", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 304, - "name": "lh:audit:http-status-code", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 305, - "name": "lh:audit:link-text", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 306, - "name": "lh:audit:crawlable-anchors", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 307, - "name": "lh:audit:is-crawlable", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 308, - "name": "lh:audit:robots-txt", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 309, - "name": "lh:audit:hreflang", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 310, - "name": "lh:audit:canonical", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 311, - "name": "lh:audit:structured-data", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 312, - "name": "lh:audit:bf-cache", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 313, - "name": "lh:audit:cache-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 314, - "name": "lh:audit:cls-culprits-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 315, - "name": "lh:audit:document-latency-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 316, - "name": "lh:audit:dom-size-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 317, - "name": "lh:audit:duplicated-javascript-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 318, - "name": "lh:audit:font-display-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 319, - "name": "lh:audit:forced-reflow-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 320, - "name": "lh:audit:image-delivery-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 321, - "name": "lh:audit:inp-breakdown-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 322, - "name": "lh:audit:lcp-breakdown-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 323, - "name": "lh:audit:lcp-discovery-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 324, - "name": "lh:audit:legacy-javascript-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 325, - "name": "lh:audit:network-dependency-tree-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 326, - "name": "lh:audit:render-blocking-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 327, - "name": "lh:audit:third-parties-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 328, - "name": "lh:audit:viewport-insight", - "duration": 1, - "entryType": "measure" - }, - { - "startTime": 329, - "name": "lh:runner:generate", - "duration": 1, - "entryType": "measure" - } - ], - "total": 330 - }, - "i18n": { - "rendererFormattedStrings": { - "calculatorLink": "See calculator.", - "collapseView": "Collapse view", - "crcInitialNavigation": "Initial Navigation", - "crcLongestDurationLabel": "Maximum critical path latency:", - "dropdownCopyJSON": "Copy JSON", - "dropdownDarkTheme": "Toggle Dark Theme", - "dropdownPrintExpanded": "Print Expanded", - "dropdownPrintSummary": "Print Summary", - "dropdownSaveGist": "Save as Gist", - "dropdownSaveHTML": "Save as HTML", - "dropdownSaveJSON": "Save as JSON", - "dropdownViewUnthrottledTrace": "View Unthrottled Trace", - "dropdownViewer": "Open in Viewer", - "errorLabel": "Error!", - "errorMissingAuditInfo": "Report error: no audit information", - "expandView": "Expand view", - "firstPartyChipLabel": "1st party", - "footerIssue": "File an issue", - "hide": "Hide", - "labDataTitle": "Lab Data", - "lsPerformanceCategoryDescription": "[Lighthouse](https://developers.google.com/web/tools/lighthouse/) analysis of the current page on an emulated mobile network. Values are estimated and may vary.", - "manualAuditsGroupTitle": "Additional items to manually check", - "notApplicableAuditsGroupTitle": "Not applicable", - "openInANewTabTooltip": "Open in a new tab", - "opportunityResourceColumnLabel": "Opportunity", - "opportunitySavingsColumnLabel": "Estimated Savings", - "passedAuditsGroupTitle": "Passed audits", - "runtimeAnalysisWindow": "Initial page load", - "runtimeAnalysisWindowSnapshot": "Point-in-time snapshot", - "runtimeAnalysisWindowTimespan": "User interactions timespan", - "runtimeCustom": "Custom throttling", - "runtimeDesktopEmulation": "Emulated Desktop", - "runtimeMobileEmulation": "Emulated Moto G Power", - "runtimeNoEmulation": "No emulation", - "runtimeSettingsAxeVersion": "Axe version", - "runtimeSettingsBenchmark": "Unthrottled CPU/Memory Power", - "runtimeSettingsCPUThrottling": "CPU throttling", - "runtimeSettingsDevice": "Device", - "runtimeSettingsNetworkThrottling": "Network throttling", - "runtimeSettingsScreenEmulation": "Screen emulation", - "runtimeSettingsUANetwork": "User agent (network)", - "runtimeSingleLoad": "Single page session", - "runtimeSingleLoadTooltip": "This data is taken from a single page session, as opposed to field data summarizing many sessions.", - "runtimeSlow4g": "Slow 4G throttling", - "runtimeUnknown": "Unknown", - "show": "Show", - "showRelevantAudits": "Show audits relevant to:", - "snippetCollapseButtonLabel": "Collapse snippet", - "snippetExpandButtonLabel": "Expand snippet", - "thirdPartyResourcesLabel": "Show 3rd-party resources", - "throttlingProvided": "Provided by environment", - "toplevelWarningsMessage": "There were issues affecting this run of Lighthouse:", - "unattributable": "Unattributable", - "unscoredLabel": "Unscored", - "unscoredTitle": "This audit does not contribute to the overall category score.", - "varianceDisclaimer": "Values are estimated and may vary. The [performance score is calculated](https://developer.chrome.com/docs/lighthouse/performance/performance-scoring/) directly from these metrics.", - "viewTraceLabel": "View Trace", - "viewTreemapLabel": "View Treemap", - "warningAuditsGroupTitle": "Passed audits but with warnings", - "warningHeader": "Warnings: " - }, - "icuMessagePaths": { - "core/audits/is-on-https.js | title": [ - "audits[is-on-https].title" - ], - "core/audits/is-on-https.js | description": [ - "audits[is-on-https].description" - ], - "core/audits/is-on-https.js | columnInsecureURL": [ - "audits[is-on-https].details.headings[0].label" - ], - "core/audits/is-on-https.js | columnResolution": [ - "audits[is-on-https].details.headings[1].label" - ], - "core/audits/redirects-http.js | title": [ - "audits[redirects-http].title" - ], - "core/audits/redirects-http.js | description": [ - "audits[redirects-http].description" - ], - "core/lib/i18n/i18n.js | firstContentfulPaintMetric": [ - "audits[first-contentful-paint].title" - ], - "core/audits/metrics/first-contentful-paint.js | description": [ - "audits[first-contentful-paint].description" - ], - "core/lib/i18n/i18n.js | seconds": [ - { - "values": { - "timeInMs": 2413.8750000000005 - }, - "path": "audits[first-contentful-paint].displayValue" - }, - { - "values": { - "timeInMs": 4073.5785 - }, - "path": "audits[largest-contentful-paint].displayValue" - }, - { - "values": { - "timeInMs": 5523.9135999679565 - }, - "path": "audits[speed-index].displayValue" - }, - { - "values": { - "timeInMs": 4073.5785000000005 - }, - "path": "audits.interactive.displayValue" - }, - { - "values": { - "timeInMs": 519.2439999999993 - }, - "path": "audits[mainthread-work-breakdown].displayValue" - }, - { - "values": { - "timeInMs": 244.4120000000013 - }, - "path": "audits[bootup-time].displayValue" - } - ], - "core/lib/i18n/i18n.js | largestContentfulPaintMetric": [ - "audits[largest-contentful-paint].title" - ], - "core/audits/metrics/largest-contentful-paint.js | description": [ - "audits[largest-contentful-paint].description" - ], - "core/lib/i18n/i18n.js | speedIndexMetric": [ - "audits[speed-index].title" - ], - "core/audits/metrics/speed-index.js | description": [ - "audits[speed-index].description" - ], - "core/lib/i18n/i18n.js | totalBlockingTimeMetric": [ - "audits[total-blocking-time].title" - ], - "core/audits/metrics/total-blocking-time.js | description": [ - "audits[total-blocking-time].description" - ], - "core/lib/i18n/i18n.js | ms": [ - { - "values": { - "timeInMs": 6 - }, - "path": "audits[total-blocking-time].displayValue" - }, - { - "values": { - "timeInMs": 87 - }, - "path": "audits[max-potential-fid].displayValue" - }, - { - "values": { - "timeInMs": 17.661 - }, - "path": "audits[network-rtt].displayValue" - }, - { - "values": { - "timeInMs": 26.339 - }, - "path": "audits[network-server-latency].displayValue" - } - ], - "core/lib/i18n/i18n.js | maxPotentialFIDMetric": [ - "audits[max-potential-fid].title" - ], - "core/audits/metrics/max-potential-fid.js | description": [ - "audits[max-potential-fid].description" - ], - "core/lib/i18n/i18n.js | cumulativeLayoutShiftMetric": [ - "audits[cumulative-layout-shift].title" - ], - "core/audits/metrics/cumulative-layout-shift.js | description": [ - "audits[cumulative-layout-shift].description" - ], - "core/audits/errors-in-console.js | title": [ - "audits[errors-in-console].title" - ], - "core/audits/errors-in-console.js | description": [ - "audits[errors-in-console].description" - ], - "core/lib/i18n/i18n.js | columnSource": [ - "audits[errors-in-console].details.headings[0].label", - "audits.deprecations.details.headings[1].label", - "audits[geolocation-on-start].details.headings[0].label", - "audits[notification-on-start].details.headings[0].label", - "audits[forced-reflow-insight].details.items[0].headings[0].label" - ], - "core/lib/i18n/i18n.js | columnDescription": [ - "audits[errors-in-console].details.headings[1].label", - "audits[csp-xss].details.headings[0].label", - "audits[has-hsts].details.headings[0].label", - "audits[origin-isolation].details.headings[0].label", - "audits[clickjacking-mitigation].details.headings[0].label", - "audits[trusted-types-xss].details.headings[0].label" - ], - "core/audits/server-response-time.js | title": [ - "audits[server-response-time].title" - ], - "core/audits/server-response-time.js | description": [ - "audits[server-response-time].description" - ], - "core/audits/server-response-time.js | displayValue": [ - { - "values": { - "timeInMs": 22 - }, - "path": "audits[server-response-time].displayValue" - } - ], - "core/lib/i18n/i18n.js | columnURL": [ - "audits[server-response-time].details.headings[0].label", - "audits[image-aspect-ratio].details.headings[1].label", - "audits[image-size-responsive].details.headings[1].label", - "audits[third-party-cookies].details.headings[1].label", - "audits[bootup-time].details.headings[0].label", - "audits[network-rtt].details.headings[0].label", - "audits[network-server-latency].details.headings[0].label", - "audits[long-tasks].details.headings[0].label", - "audits[unsized-images].details.headings[1].label", - "audits[valid-source-maps].details.headings[0].label", - "audits[total-byte-weight].details.headings[0].label", - "audits[unused-javascript].details.headings[0].label", - "audits[font-display-insight].details.headings[0].label", - "audits[image-delivery-insight].details.headings[1].label", - "audits[legacy-javascript-insight].details.headings[0].label", - "audits[render-blocking-insight].details.headings[0].label" - ], - "core/lib/i18n/i18n.js | columnTimeSpent": [ - "audits[server-response-time].details.headings[1].label", - "audits[mainthread-work-breakdown].details.headings[1].label", - "audits[network-rtt].details.headings[1].label", - "audits[network-server-latency].details.headings[1].label" - ], - "core/lib/i18n/i18n.js | interactiveMetric": [ - "audits.interactive.title" - ], - "core/audits/metrics/interactive.js | description": [ - "audits.interactive.description" - ], - "core/audits/user-timings.js | title": [ - "audits[user-timings].title" - ], - "core/audits/user-timings.js | description": [ - "audits[user-timings].description" - ], - "core/audits/user-timings.js | displayValue": [ - { - "values": { - "itemCount": 8 - }, - "path": "audits[user-timings].displayValue" - } - ], - "core/lib/i18n/i18n.js | columnName": [ - "audits[user-timings].details.headings[0].label", - "audits[third-party-cookies].details.headings[0].label", - "audits[js-libraries].details.headings[0].label" - ], - "core/audits/user-timings.js | columnType": [ - "audits[user-timings].details.headings[1].label" - ], - "core/lib/i18n/i18n.js | columnStartTime": [ - "audits[user-timings].details.headings[2].label", - "audits[long-tasks].details.headings[1].label" - ], - "core/lib/i18n/i18n.js | columnDuration": [ - "audits[user-timings].details.headings[3].label", - "audits[long-tasks].details.headings[2].label", - "audits[lcp-breakdown-insight].details.items[0].headings[1].label", - "audits[render-blocking-insight].details.headings[2].label" - ], - "core/audits/redirects.js | title": [ - "audits.redirects.title" - ], - "core/audits/redirects.js | description": [ - "audits.redirects.description" - ], - "core/audits/image-aspect-ratio.js | title": [ - "audits[image-aspect-ratio].title" - ], - "core/audits/image-aspect-ratio.js | description": [ - "audits[image-aspect-ratio].description" - ], - "core/audits/image-aspect-ratio.js | columnDisplayed": [ - "audits[image-aspect-ratio].details.headings[2].label" - ], - "core/audits/image-aspect-ratio.js | columnActual": [ - "audits[image-aspect-ratio].details.headings[3].label" - ], - "core/audits/image-size-responsive.js | title": [ - "audits[image-size-responsive].title" - ], - "core/audits/image-size-responsive.js | description": [ - "audits[image-size-responsive].description" - ], - "core/audits/image-size-responsive.js | columnDisplayed": [ - "audits[image-size-responsive].details.headings[2].label" - ], - "core/audits/image-size-responsive.js | columnActual": [ - "audits[image-size-responsive].details.headings[3].label" - ], - "core/audits/image-size-responsive.js | columnExpected": [ - "audits[image-size-responsive].details.headings[4].label" - ], - "core/audits/deprecations.js | title": [ - "audits.deprecations.title" - ], - "core/audits/deprecations.js | description": [ - "audits.deprecations.description" - ], - "core/audits/deprecations.js | columnDeprecate": [ - "audits.deprecations.details.headings[0].label" - ], - "core/audits/third-party-cookies.js | title": [ - "audits[third-party-cookies].title" - ], - "core/audits/third-party-cookies.js | description": [ - "audits[third-party-cookies].description" - ], - "core/audits/mainthread-work-breakdown.js | title": [ - "audits[mainthread-work-breakdown].title" - ], - "core/audits/mainthread-work-breakdown.js | description": [ - "audits[mainthread-work-breakdown].description" - ], - "core/audits/mainthread-work-breakdown.js | columnCategory": [ - "audits[mainthread-work-breakdown].details.headings[0].label" - ], - "core/audits/bootup-time.js | title": [ - "audits[bootup-time].title" - ], - "core/audits/bootup-time.js | description": [ - "audits[bootup-time].description" - ], - "core/audits/bootup-time.js | columnTotal": [ - "audits[bootup-time].details.headings[1].label" - ], - "core/audits/bootup-time.js | columnScriptEval": [ - "audits[bootup-time].details.headings[2].label" - ], - "core/audits/bootup-time.js | columnScriptParse": [ - "audits[bootup-time].details.headings[3].label" - ], - "core/audits/network-rtt.js | title": [ - "audits[network-rtt].title" - ], - "core/audits/network-rtt.js | description": [ - "audits[network-rtt].description" - ], - "core/audits/network-server-latency.js | title": [ - "audits[network-server-latency].title" - ], - "core/audits/network-server-latency.js | description": [ - "audits[network-server-latency].description" - ], - "core/lib/i18n/i18n.js | columnResourceType": [ - "audits[resource-summary].details.headings[0].label" - ], - "core/lib/i18n/i18n.js | columnRequests": [ - "audits[resource-summary].details.headings[1].label" - ], - "core/lib/i18n/i18n.js | columnTransferSize": [ - "audits[resource-summary].details.headings[2].label", - "audits[total-byte-weight].details.headings[1].label", - "audits[unused-javascript].details.headings[1].label", - "audits[cache-insight].details.headings[2].label", - "audits[render-blocking-insight].details.headings[1].label" - ], - "core/lib/i18n/i18n.js | total": [ - "audits[resource-summary].details.items[0].label" - ], - "core/lib/i18n/i18n.js | scriptResourceType": [ - "audits[resource-summary].details.items[1].label" - ], - "core/lib/i18n/i18n.js | fontResourceType": [ - "audits[resource-summary].details.items[2].label" - ], - "core/lib/i18n/i18n.js | imageResourceType": [ - "audits[resource-summary].details.items[3].label" - ], - "core/lib/i18n/i18n.js | otherResourceType": [ - "audits[resource-summary].details.items[4].label" - ], - "core/lib/i18n/i18n.js | stylesheetResourceType": [ - "audits[resource-summary].details.items[5].label" - ], - "core/lib/i18n/i18n.js | documentResourceType": [ - "audits[resource-summary].details.items[6].label" - ], - "core/lib/i18n/i18n.js | mediaResourceType": [ - "audits[resource-summary].details.items[7].label" - ], - "core/lib/i18n/i18n.js | thirdPartyResourceType": [ - "audits[resource-summary].details.items[8].label" - ], - "core/audits/layout-shifts.js | title": [ - "audits[layout-shifts].title" - ], - "core/audits/layout-shifts.js | description": [ - "audits[layout-shifts].description" - ], - "core/lib/i18n/i18n.js | columnElement": [ - "audits[layout-shifts].details.headings[0].label", - "audits[non-composited-animations].details.headings[0].label", - "audits[dom-size-insight].details.headings[1].label" - ], - "core/audits/layout-shifts.js | columnScore": [ - "audits[layout-shifts].details.headings[1].label" - ], - "core/audits/long-tasks.js | title": [ - "audits[long-tasks].title" - ], - "core/audits/long-tasks.js | description": [ - "audits[long-tasks].description" - ], - "core/audits/long-tasks.js | displayValue": [ - { - "values": { - "itemCount": 2 - }, - "path": "audits[long-tasks].displayValue" - } - ], - "core/audits/non-composited-animations.js | title": [ - "audits[non-composited-animations].title" - ], - "core/audits/non-composited-animations.js | description": [ - "audits[non-composited-animations].description" - ], - "core/audits/unsized-images.js | failureTitle": [ - "audits[unsized-images].title" - ], - "core/audits/unsized-images.js | description": [ - "audits[unsized-images].description" - ], - "core/audits/valid-source-maps.js | title": [ - "audits[valid-source-maps].title" - ], - "core/audits/valid-source-maps.js | description": [ - "audits[valid-source-maps].description" - ], - "core/audits/valid-source-maps.js | columnMapURL": [ - "audits[valid-source-maps].details.headings[1].label" - ], - "core/audits/csp-xss.js | title": [ - "audits[csp-xss].title" - ], - "core/audits/csp-xss.js | description": [ - "audits[csp-xss].description" - ], - "core/audits/csp-xss.js | columnDirective": [ - "audits[csp-xss].details.headings[1].label" - ], - "core/audits/csp-xss.js | columnSeverity": [ - "audits[csp-xss].details.headings[2].label" - ], - "core/lib/i18n/i18n.js | itemSeverityHigh": [ - "audits[csp-xss].details.items[0].severity", - "audits[origin-isolation].details.items[0].severity", - "audits[clickjacking-mitigation].details.items[0].severity", - "audits[trusted-types-xss].details.items[0].severity" - ], - "core/audits/csp-xss.js | noCsp": [ - "audits[csp-xss].details.items[0].description" - ], - "core/audits/has-hsts.js | title": [ - "audits[has-hsts].title" - ], - "core/audits/has-hsts.js | description": [ - "audits[has-hsts].description" - ], - "core/audits/has-hsts.js | columnDirective": [ - "audits[has-hsts].details.headings[1].label" - ], - "core/audits/has-hsts.js | columnSeverity": [ - "audits[has-hsts].details.headings[2].label" - ], - "core/audits/has-hsts.js | noSubdomain": [ - "audits[has-hsts].details.items[0].description" - ], - "core/lib/i18n/i18n.js | itemSeverityMedium": [ - "audits[has-hsts].details.items[0].severity", - "audits[has-hsts].details.items[1].severity" - ], - "core/audits/has-hsts.js | noPreload": [ - "audits[has-hsts].details.items[1].description" - ], - "core/audits/origin-isolation.js | title": [ - "audits[origin-isolation].title" - ], - "core/audits/origin-isolation.js | description": [ - "audits[origin-isolation].description" - ], - "core/audits/origin-isolation.js | columnDirective": [ - "audits[origin-isolation].details.headings[1].label" - ], - "core/audits/origin-isolation.js | columnSeverity": [ - "audits[origin-isolation].details.headings[2].label" - ], - "core/audits/origin-isolation.js | noCoop": [ - "audits[origin-isolation].details.items[0].description" - ], - "core/audits/clickjacking-mitigation.js | title": [ - "audits[clickjacking-mitigation].title" - ], - "core/audits/clickjacking-mitigation.js | description": [ - "audits[clickjacking-mitigation].description" - ], - "core/audits/clickjacking-mitigation.js | columnSeverity": [ - "audits[clickjacking-mitigation].details.headings[1].label" - ], - "core/audits/clickjacking-mitigation.js | noClickjackingMitigation": [ - "audits[clickjacking-mitigation].details.items[0].description" - ], - "core/audits/trusted-types-xss.js | title": [ - "audits[trusted-types-xss].title" - ], - "core/audits/trusted-types-xss.js | description": [ - "audits[trusted-types-xss].description" - ], - "core/audits/trusted-types-xss.js | columnSeverity": [ - "audits[trusted-types-xss].details.headings[1].label" - ], - "core/audits/trusted-types-xss.js | noTrustedTypesToMitigateXss": [ - "audits[trusted-types-xss].details.items[0].description" - ], - "core/audits/accessibility/accesskeys.js | title": [ - "audits.accesskeys.title" - ], - "core/audits/accessibility/accesskeys.js | description": [ - "audits.accesskeys.description" - ], - "core/audits/accessibility/aria-allowed-attr.js | title": [ - "audits[aria-allowed-attr].title" - ], - "core/audits/accessibility/aria-allowed-attr.js | description": [ - "audits[aria-allowed-attr].description" - ], - "core/lib/i18n/i18n.js | columnFailingElem": [ - "audits[aria-allowed-attr].details.headings[0].label", - "audits[aria-conditional-attr].details.headings[0].label", - "audits[aria-deprecated-role].details.headings[0].label", - "audits[aria-hidden-body].details.headings[0].label", - "audits[aria-hidden-focus].details.headings[0].label", - "audits[aria-prohibited-attr].details.headings[0].label", - "audits[aria-required-attr].details.headings[0].label", - "audits[aria-roles].details.headings[0].label", - "audits[aria-valid-attr-value].details.headings[0].label", - "audits[aria-valid-attr].details.headings[0].label", - "audits[button-name].details.headings[0].label", - "audits[color-contrast].details.headings[0].label", - "audits[document-title].details.headings[0].label", - "audits[heading-order].details.headings[0].label", - "audits[html-has-lang].details.headings[0].label", - "audits[html-lang-valid].details.headings[0].label", - "audits[image-alt].details.headings[0].label", - "audits.label.details.headings[0].label", - "audits[landmark-one-main].details.headings[0].label", - "audits[link-name].details.headings[0].label", - "audits.list.details.headings[0].label", - "audits.listitem.details.headings[0].label", - "audits[meta-viewport].details.headings[0].label", - "audits[target-size].details.headings[0].label", - "audits[paste-preventing-inputs].details.headings[0].label" - ], - "core/audits/accessibility/aria-allowed-role.js | title": [ - "audits[aria-allowed-role].title" - ], - "core/audits/accessibility/aria-allowed-role.js | description": [ - "audits[aria-allowed-role].description" - ], - "core/audits/accessibility/aria-command-name.js | title": [ - "audits[aria-command-name].title" - ], - "core/audits/accessibility/aria-command-name.js | description": [ - "audits[aria-command-name].description" - ], - "core/audits/accessibility/aria-conditional-attr.js | title": [ - "audits[aria-conditional-attr].title" - ], - "core/audits/accessibility/aria-conditional-attr.js | description": [ - "audits[aria-conditional-attr].description" - ], - "core/audits/accessibility/aria-deprecated-role.js | title": [ - "audits[aria-deprecated-role].title" - ], - "core/audits/accessibility/aria-deprecated-role.js | description": [ - "audits[aria-deprecated-role].description" - ], - "core/audits/accessibility/aria-dialog-name.js | title": [ - "audits[aria-dialog-name].title" - ], - "core/audits/accessibility/aria-dialog-name.js | description": [ - "audits[aria-dialog-name].description" - ], - "core/audits/accessibility/aria-hidden-body.js | title": [ - "audits[aria-hidden-body].title" - ], - "core/audits/accessibility/aria-hidden-body.js | description": [ - "audits[aria-hidden-body].description" - ], - "core/audits/accessibility/aria-hidden-focus.js | title": [ - "audits[aria-hidden-focus].title" - ], - "core/audits/accessibility/aria-hidden-focus.js | description": [ - "audits[aria-hidden-focus].description" - ], - "core/audits/accessibility/aria-input-field-name.js | title": [ - "audits[aria-input-field-name].title" - ], - "core/audits/accessibility/aria-input-field-name.js | description": [ - "audits[aria-input-field-name].description" - ], - "core/audits/accessibility/aria-meter-name.js | title": [ - "audits[aria-meter-name].title" - ], - "core/audits/accessibility/aria-meter-name.js | description": [ - "audits[aria-meter-name].description" - ], - "core/audits/accessibility/aria-progressbar-name.js | title": [ - "audits[aria-progressbar-name].title" - ], - "core/audits/accessibility/aria-progressbar-name.js | description": [ - "audits[aria-progressbar-name].description" - ], - "core/audits/accessibility/aria-prohibited-attr.js | title": [ - "audits[aria-prohibited-attr].title" - ], - "core/audits/accessibility/aria-prohibited-attr.js | description": [ - "audits[aria-prohibited-attr].description" - ], - "core/audits/accessibility/aria-required-attr.js | title": [ - "audits[aria-required-attr].title" - ], - "core/audits/accessibility/aria-required-attr.js | description": [ - "audits[aria-required-attr].description" - ], - "core/audits/accessibility/aria-required-children.js | title": [ - "audits[aria-required-children].title" - ], - "core/audits/accessibility/aria-required-children.js | description": [ - "audits[aria-required-children].description" - ], - "core/audits/accessibility/aria-required-parent.js | title": [ - "audits[aria-required-parent].title" - ], - "core/audits/accessibility/aria-required-parent.js | description": [ - "audits[aria-required-parent].description" - ], - "core/audits/accessibility/aria-roles.js | title": [ - "audits[aria-roles].title" - ], - "core/audits/accessibility/aria-roles.js | description": [ - "audits[aria-roles].description" - ], - "core/audits/accessibility/aria-text.js | title": [ - "audits[aria-text].title" - ], - "core/audits/accessibility/aria-text.js | description": [ - "audits[aria-text].description" - ], - "core/audits/accessibility/aria-toggle-field-name.js | title": [ - "audits[aria-toggle-field-name].title" - ], - "core/audits/accessibility/aria-toggle-field-name.js | description": [ - "audits[aria-toggle-field-name].description" - ], - "core/audits/accessibility/aria-tooltip-name.js | title": [ - "audits[aria-tooltip-name].title" - ], - "core/audits/accessibility/aria-tooltip-name.js | description": [ - "audits[aria-tooltip-name].description" - ], - "core/audits/accessibility/aria-treeitem-name.js | title": [ - "audits[aria-treeitem-name].title" - ], - "core/audits/accessibility/aria-treeitem-name.js | description": [ - "audits[aria-treeitem-name].description" - ], - "core/audits/accessibility/aria-valid-attr-value.js | title": [ - "audits[aria-valid-attr-value].title" - ], - "core/audits/accessibility/aria-valid-attr-value.js | description": [ - "audits[aria-valid-attr-value].description" - ], - "core/audits/accessibility/aria-valid-attr.js | title": [ - "audits[aria-valid-attr].title" - ], - "core/audits/accessibility/aria-valid-attr.js | description": [ - "audits[aria-valid-attr].description" - ], - "core/audits/accessibility/button-name.js | title": [ - "audits[button-name].title" - ], - "core/audits/accessibility/button-name.js | description": [ - "audits[button-name].description" - ], - "core/audits/accessibility/bypass.js | title": [ - "audits.bypass.title" - ], - "core/audits/accessibility/bypass.js | description": [ - "audits.bypass.description" - ], - "core/audits/accessibility/color-contrast.js | title": [ - "audits[color-contrast].title" - ], - "core/audits/accessibility/color-contrast.js | description": [ - "audits[color-contrast].description" - ], - "core/audits/accessibility/definition-list.js | title": [ - "audits[definition-list].title" - ], - "core/audits/accessibility/definition-list.js | description": [ - "audits[definition-list].description" - ], - "core/audits/accessibility/dlitem.js | title": [ - "audits.dlitem.title" - ], - "core/audits/accessibility/dlitem.js | description": [ - "audits.dlitem.description" - ], - "core/audits/accessibility/document-title.js | title": [ - "audits[document-title].title" - ], - "core/audits/accessibility/document-title.js | description": [ - "audits[document-title].description" - ], - "core/audits/accessibility/duplicate-id-aria.js | title": [ - "audits[duplicate-id-aria].title" - ], - "core/audits/accessibility/duplicate-id-aria.js | description": [ - "audits[duplicate-id-aria].description" - ], - "core/audits/accessibility/empty-heading.js | title": [ - "audits[empty-heading].title" - ], - "core/audits/accessibility/empty-heading.js | description": [ - "audits[empty-heading].description" - ], - "core/audits/accessibility/form-field-multiple-labels.js | title": [ - "audits[form-field-multiple-labels].title" - ], - "core/audits/accessibility/form-field-multiple-labels.js | description": [ - "audits[form-field-multiple-labels].description" - ], - "core/audits/accessibility/frame-title.js | title": [ - "audits[frame-title].title" - ], - "core/audits/accessibility/frame-title.js | description": [ - "audits[frame-title].description" - ], - "core/audits/accessibility/heading-order.js | title": [ - "audits[heading-order].title" - ], - "core/audits/accessibility/heading-order.js | description": [ - "audits[heading-order].description" - ], - "core/audits/accessibility/html-has-lang.js | title": [ - "audits[html-has-lang].title" - ], - "core/audits/accessibility/html-has-lang.js | description": [ - "audits[html-has-lang].description" - ], - "core/audits/accessibility/html-lang-valid.js | title": [ - "audits[html-lang-valid].title" - ], - "core/audits/accessibility/html-lang-valid.js | description": [ - "audits[html-lang-valid].description" - ], - "core/audits/accessibility/html-xml-lang-mismatch.js | title": [ - "audits[html-xml-lang-mismatch].title" - ], - "core/audits/accessibility/html-xml-lang-mismatch.js | description": [ - "audits[html-xml-lang-mismatch].description" - ], - "core/audits/accessibility/identical-links-same-purpose.js | title": [ - "audits[identical-links-same-purpose].title" - ], - "core/audits/accessibility/identical-links-same-purpose.js | description": [ - "audits[identical-links-same-purpose].description" - ], - "core/audits/accessibility/image-alt.js | title": [ - "audits[image-alt].title" - ], - "core/audits/accessibility/image-alt.js | description": [ - "audits[image-alt].description" - ], - "core/audits/accessibility/image-redundant-alt.js | title": [ - "audits[image-redundant-alt].title" - ], - "core/audits/accessibility/image-redundant-alt.js | description": [ - "audits[image-redundant-alt].description" - ], - "core/audits/accessibility/input-button-name.js | title": [ - "audits[input-button-name].title" - ], - "core/audits/accessibility/input-button-name.js | description": [ - "audits[input-button-name].description" - ], - "core/audits/accessibility/input-image-alt.js | title": [ - "audits[input-image-alt].title" - ], - "core/audits/accessibility/input-image-alt.js | description": [ - "audits[input-image-alt].description" - ], - "core/audits/accessibility/label-content-name-mismatch.js | title": [ - "audits[label-content-name-mismatch].title" - ], - "core/audits/accessibility/label-content-name-mismatch.js | description": [ - "audits[label-content-name-mismatch].description" - ], - "core/audits/accessibility/label.js | title": [ - "audits.label.title" - ], - "core/audits/accessibility/label.js | description": [ - "audits.label.description" - ], - "core/audits/accessibility/landmark-one-main.js | failureTitle": [ - "audits[landmark-one-main].title" - ], - "core/audits/accessibility/landmark-one-main.js | description": [ - "audits[landmark-one-main].description" - ], - "core/audits/accessibility/link-name.js | title": [ - "audits[link-name].title" - ], - "core/audits/accessibility/link-name.js | description": [ - "audits[link-name].description" - ], - "core/audits/accessibility/link-in-text-block.js | title": [ - "audits[link-in-text-block].title" - ], - "core/audits/accessibility/link-in-text-block.js | description": [ - "audits[link-in-text-block].description" - ], - "core/audits/accessibility/list.js | title": [ - "audits.list.title" - ], - "core/audits/accessibility/list.js | description": [ - "audits.list.description" - ], - "core/audits/accessibility/listitem.js | title": [ - "audits.listitem.title" - ], - "core/audits/accessibility/listitem.js | description": [ - "audits.listitem.description" - ], - "core/audits/accessibility/meta-refresh.js | title": [ - "audits[meta-refresh].title" - ], - "core/audits/accessibility/meta-refresh.js | description": [ - "audits[meta-refresh].description" - ], - "core/audits/accessibility/meta-viewport.js | title": [ - "audits[meta-viewport].title" - ], - "core/audits/accessibility/meta-viewport.js | description": [ - "audits[meta-viewport].description" - ], - "core/audits/accessibility/object-alt.js | title": [ - "audits[object-alt].title" - ], - "core/audits/accessibility/object-alt.js | description": [ - "audits[object-alt].description" - ], - "core/audits/accessibility/select-name.js | title": [ - "audits[select-name].title" - ], - "core/audits/accessibility/select-name.js | description": [ - "audits[select-name].description" - ], - "core/audits/accessibility/skip-link.js | title": [ - "audits[skip-link].title" - ], - "core/audits/accessibility/skip-link.js | description": [ - "audits[skip-link].description" - ], - "core/audits/accessibility/tabindex.js | title": [ - "audits.tabindex.title" - ], - "core/audits/accessibility/tabindex.js | description": [ - "audits.tabindex.description" - ], - "core/audits/accessibility/table-duplicate-name.js | title": [ - "audits[table-duplicate-name].title" - ], - "core/audits/accessibility/table-duplicate-name.js | description": [ - "audits[table-duplicate-name].description" - ], - "core/audits/accessibility/table-fake-caption.js | title": [ - "audits[table-fake-caption].title" - ], - "core/audits/accessibility/table-fake-caption.js | description": [ - "audits[table-fake-caption].description" - ], - "core/audits/accessibility/target-size.js | title": [ - "audits[target-size].title" - ], - "core/audits/accessibility/target-size.js | description": [ - "audits[target-size].description" - ], - "core/audits/accessibility/td-has-header.js | title": [ - "audits[td-has-header].title" - ], - "core/audits/accessibility/td-has-header.js | description": [ - "audits[td-has-header].description" - ], - "core/audits/accessibility/td-headers-attr.js | title": [ - "audits[td-headers-attr].title" - ], - "core/audits/accessibility/td-headers-attr.js | description": [ - "audits[td-headers-attr].description" - ], - "core/audits/accessibility/th-has-data-cells.js | title": [ - "audits[th-has-data-cells].title" - ], - "core/audits/accessibility/th-has-data-cells.js | description": [ - "audits[th-has-data-cells].description" - ], - "core/audits/accessibility/valid-lang.js | title": [ - "audits[valid-lang].title" - ], - "core/audits/accessibility/valid-lang.js | description": [ - "audits[valid-lang].description" - ], - "core/audits/accessibility/video-caption.js | title": [ - "audits[video-caption].title" - ], - "core/audits/accessibility/video-caption.js | description": [ - "audits[video-caption].description" - ], - "core/audits/byte-efficiency/total-byte-weight.js | title": [ - "audits[total-byte-weight].title" - ], - "core/audits/byte-efficiency/total-byte-weight.js | description": [ - "audits[total-byte-weight].description" - ], - "core/audits/byte-efficiency/total-byte-weight.js | displayValue": [ - { - "values": { - "totalBytes": 294647 - }, - "path": "audits[total-byte-weight].displayValue" - } - ], - "core/audits/byte-efficiency/unminified-css.js | title": [ - "audits[unminified-css].title" - ], - "core/audits/byte-efficiency/unminified-css.js | description": [ - "audits[unminified-css].description" - ], - "core/audits/byte-efficiency/unminified-javascript.js | title": [ - "audits[unminified-javascript].title" - ], - "core/audits/byte-efficiency/unminified-javascript.js | description": [ - "audits[unminified-javascript].description" - ], - "core/audits/byte-efficiency/unused-css-rules.js | title": [ - "audits[unused-css-rules].title" - ], - "core/audits/byte-efficiency/unused-css-rules.js | description": [ - "audits[unused-css-rules].description" - ], - "core/audits/byte-efficiency/unused-javascript.js | title": [ - "audits[unused-javascript].title" - ], - "core/audits/byte-efficiency/unused-javascript.js | description": [ - "audits[unused-javascript].description" - ], - "core/lib/i18n/i18n.js | displayValueByteSavings": [ - { - "values": { - "wastedBytes": 44164 - }, - "path": "audits[unused-javascript].displayValue" - } - ], - "core/lib/i18n/i18n.js | columnWastedBytes": [ - "audits[unused-javascript].details.headings[2].label", - "audits[font-display-insight].details.headings[1].label", - "audits[image-delivery-insight].details.headings[3].label" - ], - "core/audits/dobetterweb/doctype.js | title": [ - "audits.doctype.title" - ], - "core/audits/dobetterweb/doctype.js | description": [ - "audits.doctype.description" - ], - "core/audits/dobetterweb/charset.js | title": [ - "audits.charset.title" - ], - "core/audits/dobetterweb/charset.js | description": [ - "audits.charset.description" - ], - "core/audits/dobetterweb/geolocation-on-start.js | title": [ - "audits[geolocation-on-start].title" - ], - "core/audits/dobetterweb/geolocation-on-start.js | description": [ - "audits[geolocation-on-start].description" - ], - "core/audits/dobetterweb/inspector-issues.js | title": [ - "audits[inspector-issues].title" - ], - "core/audits/dobetterweb/inspector-issues.js | description": [ - "audits[inspector-issues].description" - ], - "core/audits/dobetterweb/inspector-issues.js | columnIssueType": [ - "audits[inspector-issues].details.headings[0].label" - ], - "core/audits/dobetterweb/js-libraries.js | title": [ - "audits[js-libraries].title" - ], - "core/audits/dobetterweb/js-libraries.js | description": [ - "audits[js-libraries].description" - ], - "core/audits/dobetterweb/js-libraries.js | columnVersion": [ - "audits[js-libraries].details.headings[1].label" - ], - "core/audits/dobetterweb/notification-on-start.js | title": [ - "audits[notification-on-start].title" - ], - "core/audits/dobetterweb/notification-on-start.js | description": [ - "audits[notification-on-start].description" - ], - "core/audits/dobetterweb/paste-preventing-inputs.js | title": [ - "audits[paste-preventing-inputs].title" - ], - "core/audits/dobetterweb/paste-preventing-inputs.js | description": [ - "audits[paste-preventing-inputs].description" - ], - "core/audits/seo/meta-description.js | title": [ - "audits[meta-description].title" - ], - "core/audits/seo/meta-description.js | description": [ - "audits[meta-description].description" - ], - "core/audits/seo/http-status-code.js | title": [ - "audits[http-status-code].title" - ], - "core/audits/seo/http-status-code.js | description": [ - "audits[http-status-code].description" - ], - "core/audits/seo/link-text.js | title": [ - "audits[link-text].title" - ], - "core/audits/seo/link-text.js | description": [ - "audits[link-text].description" - ], - "core/audits/seo/crawlable-anchors.js | failureTitle": [ - "audits[crawlable-anchors].title" - ], - "core/audits/seo/crawlable-anchors.js | description": [ - "audits[crawlable-anchors].description" - ], - "core/audits/seo/crawlable-anchors.js | columnFailingLink": [ - "audits[crawlable-anchors].details.headings[0].label" - ], - "core/audits/seo/is-crawlable.js | title": [ - "audits[is-crawlable].title" - ], - "core/audits/seo/is-crawlable.js | description": [ - "audits[is-crawlable].description" - ], - "core/audits/seo/robots-txt.js | title": [ - "audits[robots-txt].title" - ], - "core/audits/seo/robots-txt.js | description": [ - "audits[robots-txt].description" - ], - "core/audits/seo/hreflang.js | title": [ - "audits.hreflang.title" - ], - "core/audits/seo/hreflang.js | description": [ - "audits.hreflang.description" - ], - "core/audits/seo/canonical.js | title": [ - "audits.canonical.title" - ], - "core/audits/seo/canonical.js | description": [ - "audits.canonical.description" - ], - "core/audits/seo/manual/structured-data.js | title": [ - "audits[structured-data].title" - ], - "core/audits/seo/manual/structured-data.js | description": [ - "audits[structured-data].description" - ], - "core/audits/bf-cache.js | title": [ - "audits[bf-cache].title" - ], - "core/audits/bf-cache.js | description": [ - "audits[bf-cache].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/Cache.js | title": [ - "audits[cache-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/Cache.js | description": [ - "audits[cache-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/Cache.js | requestColumn": [ - "audits[cache-insight].details.headings[0].label" - ], - "core/lib/i18n/i18n.js | columnCacheTTL": [ - "audits[cache-insight].details.headings[1].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/CLSCulprits.js | title": [ - "audits[cls-culprits-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/CLSCulprits.js | description": [ - "audits[cls-culprits-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DocumentLatency.js | title": [ - "audits[document-latency-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DocumentLatency.js | description": [ - "audits[document-latency-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DocumentLatency.js | passingRedirects": [ - "audits[document-latency-insight].details.items.noRedirects.label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DocumentLatency.js | passingServerResponseTime": [ - { - "values": { - "PH1": "22 ms" - }, - "path": "audits[document-latency-insight].details.items.serverResponseIsFast.label" - } - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DocumentLatency.js | passingTextCompression": [ - "audits[document-latency-insight].details.items.usesCompression.label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | title": [ - "audits[dom-size-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | description": [ - "audits[dom-size-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | statistic": [ - "audits[dom-size-insight].details.headings[0].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | value": [ - "audits[dom-size-insight].details.headings[2].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | totalElements": [ - "audits[dom-size-insight].details.items[0].statistic" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | maxDOMDepth": [ - "audits[dom-size-insight].details.items[1].statistic" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DOMSize.js | maxChildren": [ - "audits[dom-size-insight].details.items[2].statistic" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DuplicatedJavaScript.js | title": [ - "audits[duplicated-javascript-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DuplicatedJavaScript.js | description": [ - "audits[duplicated-javascript-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DuplicatedJavaScript.js | columnSource": [ - "audits[duplicated-javascript-insight].details.headings[0].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/DuplicatedJavaScript.js | columnDuplicatedBytes": [ - "audits[duplicated-javascript-insight].details.headings[1].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/FontDisplay.js | title": [ - "audits[font-display-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/FontDisplay.js | description": [ - "audits[font-display-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ForcedReflow.js | title": [ - "audits[forced-reflow-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ForcedReflow.js | description": [ - "audits[forced-reflow-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ForcedReflow.js | totalReflowTime": [ - "audits[forced-reflow-insight].details.items[0].headings[1].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ImageDelivery.js | title": [ - "audits[image-delivery-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ImageDelivery.js | description": [ - "audits[image-delivery-insight].description" - ], - "core/lib/i18n/i18n.js | columnResourceSize": [ - "audits[image-delivery-insight].details.headings[2].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/INPBreakdown.js | title": [ - "audits[inp-breakdown-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/INPBreakdown.js | description": [ - "audits[inp-breakdown-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | title": [ - "audits[lcp-breakdown-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | description": [ - "audits[lcp-breakdown-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | subpart": [ - "audits[lcp-breakdown-insight].details.items[0].headings[0].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | timeToFirstByte": [ - "audits[lcp-breakdown-insight].details.items[0].items[0].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | resourceLoadDelay": [ - "audits[lcp-breakdown-insight].details.items[0].items[1].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | resourceLoadDuration": [ - "audits[lcp-breakdown-insight].details.items[0].items[2].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPBreakdown.js | elementRenderDelay": [ - "audits[lcp-breakdown-insight].details.items[0].items[3].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPDiscovery.js | title": [ - "audits[lcp-discovery-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPDiscovery.js | description": [ - "audits[lcp-discovery-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPDiscovery.js | fetchPriorityShouldBeApplied": [ - "audits[lcp-discovery-insight].details.items[0].items.priorityHinted.label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPDiscovery.js | requestDiscoverable": [ - "audits[lcp-discovery-insight].details.items[0].items.requestDiscoverable.label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LCPDiscovery.js | lazyLoadNotApplied": [ - "audits[lcp-discovery-insight].details.items[0].items.eagerlyLoaded.label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LegacyJavaScript.js | title": [ - "audits[legacy-javascript-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LegacyJavaScript.js | description": [ - "audits[legacy-javascript-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/LegacyJavaScript.js | columnWastedBytes": [ - "audits[legacy-javascript-insight].details.headings[2].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | title": [ - "audits[network-dependency-tree-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | description": [ - "audits[network-dependency-tree-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | preconnectOriginsTableTitle": [ - "audits[network-dependency-tree-insight].details.items[1].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | preconnectOriginsTableDescription": [ - "audits[network-dependency-tree-insight].details.items[1].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | noPreconnectOrigins": [ - "audits[network-dependency-tree-insight].details.items[1].value.value" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | estSavingTableTitle": [ - "audits[network-dependency-tree-insight].details.items[2].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | estSavingTableDescription": [ - "audits[network-dependency-tree-insight].details.items[2].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | columnOrigin": [ - "audits[network-dependency-tree-insight].details.items[2].value.headings[0].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/NetworkDependencyTree.js | columnWastedMs": [ - "audits[network-dependency-tree-insight].details.items[2].value.headings[1].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/RenderBlocking.js | title": [ - "audits[render-blocking-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/RenderBlocking.js | description": [ - "audits[render-blocking-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ThirdParties.js | title": [ - "audits[third-parties-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ThirdParties.js | description": [ - "audits[third-parties-insight].description" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ThirdParties.js | columnThirdParty": [ - "audits[third-parties-insight].details.headings[0].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ThirdParties.js | columnTransferSize": [ - "audits[third-parties-insight].details.headings[1].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/ThirdParties.js | columnMainThreadTime": [ - "audits[third-parties-insight].details.headings[2].label" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/Viewport.js | title": [ - "audits[viewport-insight].title" - ], - "node_modules/@paulirish/trace_engine/models/trace/insights/Viewport.js | description": [ - "audits[viewport-insight].description" - ], - "core/config/default-config.js | performanceCategoryTitle": [ - "categories.performance.title" - ], - "core/config/default-config.js | a11yCategoryTitle": [ - "categories.accessibility.title" - ], - "core/config/default-config.js | a11yCategoryDescription": [ - "categories.accessibility.description" - ], - "core/config/default-config.js | a11yCategoryManualDescription": [ - "categories.accessibility.manualDescription" - ], - "core/config/default-config.js | bestPracticesCategoryTitle": [ - "categories[best-practices].title" - ], - "core/config/default-config.js | seoCategoryTitle": [ - "categories.seo.title" - ], - "core/config/default-config.js | seoCategoryDescription": [ - "categories.seo.description" - ], - "core/config/default-config.js | seoCategoryManualDescription": [ - "categories.seo.manualDescription" - ], - "core/config/default-config.js | metricGroupTitle": [ - "categoryGroups.metrics.title" - ], - "core/config/default-config.js | insightsGroupTitle": [ - "categoryGroups.insights.title" - ], - "core/config/default-config.js | insightsGroupDescription": [ - "categoryGroups.insights.description" - ], - "core/config/default-config.js | diagnosticsGroupTitle": [ - "categoryGroups.diagnostics.title" - ], - "core/config/default-config.js | diagnosticsGroupDescription": [ - "categoryGroups.diagnostics.description" - ], - "core/config/default-config.js | a11yBestPracticesGroupTitle": [ - "categoryGroups[a11y-best-practices].title" - ], - "core/config/default-config.js | a11yBestPracticesGroupDescription": [ - "categoryGroups[a11y-best-practices].description" - ], - "core/config/default-config.js | a11yColorContrastGroupTitle": [ - "categoryGroups[a11y-color-contrast].title" - ], - "core/config/default-config.js | a11yColorContrastGroupDescription": [ - "categoryGroups[a11y-color-contrast].description" - ], - "core/config/default-config.js | a11yNamesLabelsGroupTitle": [ - "categoryGroups[a11y-names-labels].title" - ], - "core/config/default-config.js | a11yNamesLabelsGroupDescription": [ - "categoryGroups[a11y-names-labels].description" - ], - "core/config/default-config.js | a11yNavigationGroupTitle": [ - "categoryGroups[a11y-navigation].title" - ], - "core/config/default-config.js | a11yNavigationGroupDescription": [ - "categoryGroups[a11y-navigation].description" - ], - "core/config/default-config.js | a11yAriaGroupTitle": [ - "categoryGroups[a11y-aria].title" - ], - "core/config/default-config.js | a11yAriaGroupDescription": [ - "categoryGroups[a11y-aria].description" - ], - "core/config/default-config.js | a11yLanguageGroupTitle": [ - "categoryGroups[a11y-language].title" - ], - "core/config/default-config.js | a11yLanguageGroupDescription": [ - "categoryGroups[a11y-language].description" - ], - "core/config/default-config.js | a11yAudioVideoGroupTitle": [ - "categoryGroups[a11y-audio-video].title" - ], - "core/config/default-config.js | a11yAudioVideoGroupDescription": [ - "categoryGroups[a11y-audio-video].description" - ], - "core/config/default-config.js | a11yTablesListsVideoGroupTitle": [ - "categoryGroups[a11y-tables-lists].title" - ], - "core/config/default-config.js | a11yTablesListsVideoGroupDescription": [ - "categoryGroups[a11y-tables-lists].description" - ], - "core/config/default-config.js | seoMobileGroupTitle": [ - "categoryGroups[seo-mobile].title" - ], - "core/config/default-config.js | seoMobileGroupDescription": [ - "categoryGroups[seo-mobile].description" - ], - "core/config/default-config.js | seoContentGroupTitle": [ - "categoryGroups[seo-content].title" - ], - "core/config/default-config.js | seoContentGroupDescription": [ - "categoryGroups[seo-content].description" - ], - "core/config/default-config.js | seoCrawlingGroupTitle": [ - "categoryGroups[seo-crawl].title" - ], - "core/config/default-config.js | seoCrawlingGroupDescription": [ - "categoryGroups[seo-crawl].description" - ], - "core/config/default-config.js | bestPracticesTrustSafetyGroupTitle": [ - "categoryGroups[best-practices-trust-safety].title" - ], - "core/config/default-config.js | bestPracticesUXGroupTitle": [ - "categoryGroups[best-practices-ux].title" - ], - "core/config/default-config.js | bestPracticesBrowserCompatGroupTitle": [ - "categoryGroups[best-practices-browser-compat].title" - ], - "core/config/default-config.js | bestPracticesGeneralGroupTitle": [ - "categoryGroups[best-practices-general].title" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | unused-css-rules": [ - "stackPacks[0].descriptions[unused-css-rules]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | modern-image-formats": [ - "stackPacks[0].descriptions[modern-image-formats]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | offscreen-images": [ - "stackPacks[0].descriptions[offscreen-images]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | render-blocking-resources": [ - "stackPacks[0].descriptions[render-blocking-resources]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | unused-javascript": [ - "stackPacks[0].descriptions[unused-javascript]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | uses-long-cache-ttl": [ - "stackPacks[0].descriptions[uses-long-cache-ttl]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | uses-optimized-images": [ - "stackPacks[0].descriptions[uses-optimized-images]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | uses-text-compression": [ - "stackPacks[0].descriptions[uses-text-compression]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | uses-responsive-images": [ - "stackPacks[0].descriptions[uses-responsive-images]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | user-timings": [ - "stackPacks[0].descriptions[user-timings]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | prioritize-lcp-image": [ - "stackPacks[0].descriptions[prioritize-lcp-image]" - ], - "node_modules/lighthouse-stack-packs/packs/next.js.js | unsized-images": [ - "stackPacks[0].descriptions[unsized-images]" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | unminified-css": [ - "stackPacks[1].descriptions[unminified-css]" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | unminified-javascript": [ - "stackPacks[1].descriptions[unminified-javascript]" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | unused-javascript": [ - "stackPacks[1].descriptions[unused-javascript]" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | server-response-time": [ - "stackPacks[1].descriptions[server-response-time]" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | redirects": [ - "stackPacks[1].descriptions.redirects" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | user-timings": [ - "stackPacks[1].descriptions[user-timings]" - ], - "node_modules/lighthouse-stack-packs/packs/react.js | dom-size": [ - "stackPacks[1].descriptions[dom-size]" - ] - } - } - }, - "name": "Navigation report (www.mikescerealshack.co/)" - }, - { - "lhr": { - "lighthouseVersion": "13.0.0", - "finalDisplayedUrl": "https://www.mikescerealshack.co/search?q=call+of+duty", - "fetchTime": "2025-02-05T01:31:50.141Z", - "gatherMode": "timespan", - "runWarnings": [], - "userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36", - "environment": { - "networkUserAgent": "Mozilla/5.0 (Linux; Android 11; moto g power (2022)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Mobile Safari/537.36", - "hostUserAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/134.0.0.0 Safari/537.36", - "benchmarkIndex": 3004.5, - "credits": {} - }, - "audits": { - "is-on-https": { - "id": "is-on-https", - "title": "Uses HTTPS", - "description": "All sites should be protected with HTTPS, even ones that don't handle sensitive data. This includes avoiding [mixed content](https://developers.google.com/web/fundamentals/security/prevent-mixed-content/what-is-mixed-content), where some resources are loaded over HTTP despite the initial request being served over HTTPS. HTTPS prevents intruders from tampering with or passively listening in on the communications between your app and your users, and is a prerequisite for HTTP/2 and many new web platform APIs. [Learn more about HTTPS](https://developer.chrome.com/docs/lighthouse/pwa/is-on-https/).", - "score": 1, - "scoreDisplayMode": "binary", - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "Insecure URL" - }, - { - "key": "resolution", - "valueType": "text", - "label": "Request Resolution" - } - ], - "items": [] - } - }, - "screenshot-thumbnails": { - "id": "screenshot-thumbnails", - "title": "Screenshot Thumbnails", - "description": "This is what the load of your site looked like.", - "score": 1, - "scoreDisplayMode": "informative", - "details": { - "type": "filmstrip", - "scale": 5388, - "items": [ - { - "timing": 674, - "timestamp": 282962948315, - "data": "" - }, - { - "timing": 1347, - "timestamp": 282963621815, - "data": "" - }, - { - "timing": 2021, - "timestamp": 282964295315, - "data": "" - }, - { - "timing": 2694, - "timestamp": 282964968815, - "data": "" - }, - { - "timing": 3368, - "timestamp": 282965642315, - "data": "" - }, - { - "timing": 4041, - "timestamp": 282966315815, - "data": "" - }, - { - "timing": 4715, - "timestamp": 282966989315, - "data": "" - }, - { - "timing": 5388, - "timestamp": 282967662815, - "data": "" - } - ] - } - }, - "final-screenshot": { - "id": "final-screenshot", - "title": "Final Screenshot", - "description": "The last screenshot captured of the pageload.", - "score": 1, - "scoreDisplayMode": "informative", - "details": { - "type": "screenshot", - "timing": 7389, - "timestamp": 282969663620, - "data": "" - } - }, - "total-blocking-time": { - "id": "total-blocking-time", - "title": "Total Blocking Time", - "description": "Sum of all time periods between FCP and Time to Interactive, when task length exceeded 50ms, expressed in milliseconds. [Learn more about the Total Blocking Time metric](https://developer.chrome.com/docs/lighthouse/performance/lighthouse-total-blocking-time/).", - "score": 0.99, - "scoreDisplayMode": "numeric", - "numericValue": 75.78700000000003, - "numericUnit": "millisecond", - "displayValue": "80 ms", - "scoringOptions": { - "p10": 200, - "median": 600 - } - }, - "cumulative-layout-shift": { - "id": "cumulative-layout-shift", - "title": "Cumulative Layout Shift", - "description": "Cumulative Layout Shift measures the movement of visible elements within the viewport. [Learn more about the Cumulative Layout Shift metric](https://web.dev/articles/cls).", - "score": 0.89, - "scoreDisplayMode": "numeric", - "numericValue": 0.10206561360874848, - "numericUnit": "unitless", - "displayValue": "0.102", - "scoringOptions": { - "p10": 0.1, - "median": 0.25 - }, - "details": { - "type": "debugdata", - "items": [ - { - "cumulativeLayoutShiftMainFrame": 0.10206561360874848, - "newEngineResult": { - "cumulativeLayoutShift": 0.10206561360874848, - "cumulativeLayoutShiftMainFrame": 0.10206561360874848 - }, - "newEngineResultDiffered": false - } - ] - } - }, - "interaction-to-next-paint": { - "id": "interaction-to-next-paint", - "title": "Interaction to Next Paint", - "description": "Interaction to Next Paint measures page responsiveness, how long it takes the page to visibly respond to user input. [Learn more about the Interaction to Next Paint metric](https://web.dev/articles/inp).", - "score": 1, - "scoreDisplayMode": "numeric", - "numericValue": 41.019, - "numericUnit": "millisecond", - "displayValue": "40 ms" - }, - "errors-in-console": { - "id": "errors-in-console", - "title": "No browser errors logged to the console", - "description": "Errors logged to the console indicate unresolved problems. They can come from network request failures and other browser concerns. [Learn more about this errors in console diagnostic audit](https://developer.chrome.com/docs/lighthouse/best-practices/errors-in-console/)", - "score": 1, - "scoreDisplayMode": "binary", - "details": { - "type": "table", - "headings": [ - { - "key": "sourceLocation", - "valueType": "source-location", - "label": "Source" - }, - { - "key": "description", - "valueType": "code", - "label": "Description" - } - ], - "items": [] - } - }, - "user-timings": { - "id": "user-timings", - "title": "User Timing marks and measures", - "description": "Consider instrumenting your app with the User Timing API to measure your app's real-world performance during key user experiences. [Learn more about User Timing marks](https://developer.chrome.com/docs/lighthouse/performance/user-timings/).", - "score": 1, - "scoreDisplayMode": "informative", - "displayValue": "11 user timings", - "details": { - "type": "table", - "headings": [ - { - "key": "name", - "valueType": "text", - "label": "Name" - }, - { - "key": "timingType", - "valueType": "text", - "label": "Type" - }, - { - "key": "startTime", - "valueType": "ms", - "granularity": 0.01, - "label": "Start Time" - }, - { - "key": "duration", - "valueType": "ms", - "granularity": 0.01, - "label": "Duration" - } - ], - "items": [ - { - "name": "Next.js-route-change-to-render", - "startTime": 136.812, - "duration": 600.924, - "timingType": "Measure" - }, - { - "name": "Next.js-render", - "startTime": 737.736, - "duration": 23.572, - "timingType": "Measure" - }, - { - "name": "routeChange", - "startTime": 136.812, - "timingType": "Mark" - }, - { - "name": "beforeRender", - "startTime": 737.736, - "timingType": "Mark" - }, - { - "name": "afterRender", - "startTime": 761.308, - "timingType": "Mark" - }, - { - "name": "clearMarks", - "startTime": 761.363, - "timingType": "Mark" - }, - { - "name": "clearMarks", - "startTime": 761.364, - "timingType": "Mark" - }, - { - "name": "clearMarks", - "startTime": 761.365, - "timingType": "Mark" - }, - { - "name": "clearMarks", - "startTime": 761.366, - "timingType": "Mark" - }, - { - "name": "clearMeasures", - "startTime": 761.372, - "timingType": "Mark" - }, - { - "name": "clearMeasures", - "startTime": 761.373, - "timingType": "Mark" - } - ] - }, - "guidanceLevel": 2 - }, - "image-aspect-ratio": { - "id": "image-aspect-ratio", - "title": "Displays images with correct aspect ratio", - "description": "Image display dimensions should match natural aspect ratio. [Learn more about image aspect ratio](https://developer.chrome.com/docs/lighthouse/best-practices/image-aspect-ratio/).", - "score": 1, - "scoreDisplayMode": "binary", - "details": { - "type": "table", - "headings": [ - { - "key": "node", - "valueType": "node", - "label": "" - }, - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "displayedAspectRatio", - "valueType": "text", - "label": "Aspect Ratio (Displayed)" - }, - { - "key": "actualAspectRatio", - "valueType": "text", - "label": "Aspect Ratio (Actual)" - } - ], - "items": [] - } - }, - "image-size-responsive": { - "id": "image-size-responsive", - "title": "Serves images with appropriate resolution", - "description": "Image natural dimensions should be proportional to the display size and the pixel ratio to maximize image clarity. [Learn how to provide responsive images](https://web.dev/articles/serve-responsive-images).", - "score": 1, - "scoreDisplayMode": "binary", - "details": { - "type": "table", - "headings": [ - { - "key": "node", - "valueType": "node", - "label": "" - }, - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "displayedSize", - "valueType": "text", - "label": "Displayed size" - }, - { - "key": "actualSize", - "valueType": "text", - "label": "Actual size" - }, - { - "key": "expectedSize", - "valueType": "text", - "label": "Expected size" - } - ], - "items": [] - } - }, - "deprecations": { - "id": "deprecations", - "title": "Avoids deprecated APIs", - "description": "Deprecated APIs will eventually be removed from the browser. [Learn more about deprecated APIs](https://developer.chrome.com/docs/lighthouse/best-practices/deprecations/).", - "score": 1, - "scoreDisplayMode": "binary", - "details": { - "type": "table", - "headings": [ - { - "key": "value", - "valueType": "text", - "label": "Deprecation / Warning" - }, - { - "key": "source", - "valueType": "source-location", - "label": "Source" - } - ], - "items": [] - } - }, - "third-party-cookies": { - "id": "third-party-cookies", - "title": "Avoids third-party cookies", - "description": "Third-party cookies may be blocked in some contexts. [Learn more about preparing for third-party cookie restrictions](https://privacysandbox.google.com/cookies/prepare/overview).", - "score": 1, - "scoreDisplayMode": "binary", - "details": { - "type": "table", - "headings": [ - { - "key": "name", - "valueType": "text", - "label": "Name" - }, - { - "key": "url", - "valueType": "url", - "label": "URL" - } - ], - "items": [] - } - }, - "mainthread-work-breakdown": { - "id": "mainthread-work-breakdown", - "title": "Minimizes main-thread work", - "description": "Consider reducing the time spent parsing, compiling and executing JS. You may find delivering smaller JS payloads helps with this. [Learn how to minimize main-thread work](https://developer.chrome.com/docs/lighthouse/performance/mainthread-work-breakdown/)", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 493.4830000000002, - "numericUnit": "millisecond", - "displayValue": "0.5 s", - "metricSavings": { - "TBT": 100 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "groupLabel", - "valueType": "text", - "label": "Category" - }, - { - "key": "duration", - "valueType": "ms", - "granularity": 1, - "label": "Time Spent" - } - ], - "items": [ - { - "group": "scriptEvaluation", - "groupLabel": "Script Evaluation", - "duration": 236.0269999999999 - }, - { - "group": "other", - "groupLabel": "Other", - "duration": 143.23000000000027 - }, - { - "group": "styleLayout", - "groupLabel": "Style & Layout", - "duration": 74.75299999999997 - }, - { - "group": "paintCompositeRender", - "groupLabel": "Rendering", - "duration": 34.74599999999997 - }, - { - "group": "parseHTML", - "groupLabel": "Parse HTML & CSS", - "duration": 3.667999999999996 - }, - { - "group": "scriptParseCompile", - "groupLabel": "Script Parsing & Compilation", - "duration": 1.059 - } - ], - "sortedBy": [ - "duration" - ] - }, - "guidanceLevel": 1 - }, - "bootup-time": { - "id": "bootup-time", - "title": "JavaScript execution time", - "description": "Consider reducing the time spent parsing, compiling, and executing JS. You may find delivering smaller JS payloads helps with this. [Learn how to reduce Javascript execution time](https://developer.chrome.com/docs/lighthouse/performance/bootup-time/).", - "score": 1, - "scoreDisplayMode": "metricSavings", - "numericValue": 153.74500000000052, - "numericUnit": "millisecond", - "displayValue": "0.2 s", - "metricSavings": { - "TBT": 50 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "total", - "granularity": 1, - "valueType": "ms", - "label": "Total CPU Time" - }, - { - "key": "scripting", - "granularity": 1, - "valueType": "ms", - "label": "Script Evaluation" - }, - { - "key": "scriptParseCompile", - "granularity": 1, - "valueType": "ms", - "label": "Script Parse" - } - ], - "items": [ - { - "url": "https://www.mikescerealshack.co/", - "total": 256.98100000000056, - "scripting": 84.1010000000005, - "scriptParseCompile": 0 - }, - { - "url": "Unattributable", - "total": 80.7540000000001, - "scripting": 8.267999999999994, - "scriptParseCompile": 0 - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/framework.9d524150d48315f49e80.js", - "total": 68.43200000000003, - "scripting": 61.37600000000003, - "scriptParseCompile": 0 - } - ], - "summary": { - "wastedMs": 153.74500000000052 - }, - "sortedBy": [ - "total" - ] - }, - "guidanceLevel": 1 - }, - "network-requests": { - "id": "network-requests", - "title": "Network Requests", - "description": "Lists the network requests that were made during page load.", - "score": 1, - "scoreDisplayMode": "informative", - "details": { - "type": "table", - "headings": [ - { - "key": "url", - "valueType": "url", - "label": "URL" - }, - { - "key": "protocol", - "valueType": "text", - "label": "Protocol" - }, - { - "key": "networkRequestTime", - "valueType": "ms", - "granularity": 1, - "label": "Network Request Time" - }, - { - "key": "networkEndTime", - "valueType": "ms", - "granularity": 1, - "label": "Network End Time" - }, - { - "key": "transferSize", - "valueType": "bytes", - "displayUnit": "kb", - "granularity": 1, - "label": "Transfer Size" - }, - { - "key": "resourceSize", - "valueType": "bytes", - "displayUnit": "kb", - "granularity": 1, - "label": "Resource Size" - }, - { - "key": "statusCode", - "valueType": "text", - "label": "Status Code" - }, - { - "key": "mimeType", - "valueType": "text", - "label": "MIME Type" - }, - { - "key": "resourceType", - "valueType": "text", - "label": "Resource Type" - } - ], - "items": [ - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/pages/search-61667db69725d88755b4.js", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 0, - "networkRequestTime": 0.8429999947547913, - "networkEndTime": 591.1629999876022, - "finished": true, - "transferSize": 3324, - "resourceSize": 6631, - "statusCode": 200, - "mimeType": "application/javascript", - "resourceType": "Script", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.mikescerealshack.co/logo-text.svg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 623.5130000114441, - "networkRequestTime": 624.1660000085831, - "networkEndTime": 1194.1800000071526, - "finished": true, - "transferSize": 103, - "resourceSize": 53947, - "statusCode": 200, - "mimeType": "image/svg+xml", - "resourceType": "Image", - "priority": "High", - "entity": "mikescerealshack.co" - }, - { - "url": "https://mnl4bjjsnz-dsn.algolia.net/1/indexes/dev_OFFICE_SCENES/query", - "sessionTargetType": "page", - "protocol": "http/1.1", - "rendererStartTime": 637.8479999899864, - "networkRequestTime": 899.0799999833107, - "networkEndTime": 1615.5600000023842, - "finished": true, - "transferSize": 25319, - "resourceSize": 131537, - "statusCode": 200, - "mimeType": "application/json", - "resourceType": "Fetch", - "priority": "High", - "entity": "Algolia" - }, - { - "url": "https://mnl4bjjsnz-dsn.algolia.net/1/indexes/dev_OFFICE_SCENES/query", - "sessionTargetType": "page", - "protocol": "http/1.1", - "rendererStartTime": 645.0170000195503, - "networkRequestTime": 639.4819999933243, - "networkEndTime": 898.9919999837875, - "finished": true, - "transferSize": 0, - "resourceSize": 0, - "statusCode": 200, - "mimeType": "text/plain", - "resourceType": "Preflight", - "priority": "High", - "entity": "Algolia" - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/pages/index-b332e80eef0e3820d9a6.js", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 642.930999994278, - "networkRequestTime": 644.3409999608994, - "networkEndTime": 644.7469999790192, - "finished": true, - "transferSize": 0, - "resourceSize": 0, - "statusCode": 200, - "mimeType": "application/javascript", - "resourceType": "Other", - "priority": "VeryLow", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/pages/terms-0236318e86139dd7d7f2.js", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 643.4589999914169, - "networkRequestTime": 645.1650000214577, - "networkEndTime": 1242.2760000228882, - "finished": true, - "transferSize": 4941, - "resourceSize": 0, - "statusCode": 200, - "mimeType": "application/javascript", - "resourceType": "Other", - "priority": "VeryLow", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/pages/privacy-864d3895f3c3722acef2.js", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 649.0839999914169, - "networkRequestTime": 649.4490000009537, - "networkEndTime": 1226.1189999580383, - "finished": true, - "transferSize": 890, - "resourceSize": 0, - "statusCode": 200, - "mimeType": "application/javascript", - "resourceType": "Other", - "priority": "VeryLow", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/pages/privacy-864d3895f3c3722acef2.js", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1437.460000038147, - "networkRequestTime": 1438.1240000128746, - "networkEndTime": 1438.5580000281334, - "finished": true, - "transferSize": 0, - "resourceSize": 720, - "statusCode": 200, - "mimeType": "application/javascript", - "resourceType": "Script", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.mikescerealshack.co/_next/static/chunks/pages/terms-0236318e86139dd7d7f2.js", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1438.7879999876022, - "networkRequestTime": 1439.6789999604225, - "networkEndTime": 1439.960000038147, - "finished": true, - "transferSize": 0, - "resourceSize": 11002, - "statusCode": 200, - "mimeType": "application/javascript", - "resourceType": "Script", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.google-analytics.com/g/collect?v=2&tid=G-RTW9M3W5HC>m=45je5230v9102781914za200&_p=1738719102855&gcd=13l3l3l3l1l1&npa=0&dma=0&tag_exp=102067808~102081485~102123608~102482432~102539968~102558064&cid=974257356.1738719103&ul=en-us&sr=412x823&uaa=&uab=64&uafvl=Chromium%3B134.0.6998.0%7CNot%253AA-Brand%3B24.0.0.0%7CGoogle%2520Chrome%3B134.0.6998.0&uamb=1&uam=moto%20g%20power%20(2022)&uap=Android&uapv=11.0&uaw=0&are=1&frm=0&pscdl=noapi&_eu=AEE&_s=3&sid=1738719103&sct=1&seg=0&dl=https%3A%2F%2Fwww.mikescerealshack.co%2F&dt=Search%20-%20Mike%27s%20Cereal%20Shack%3A%20The%20Office%20Search%20Engine&en=form_start&ep.form_id=&ep.form_name=&ep.form_destination=https%3A%2F%2Fwww.mikescerealshack.co%2F&epn.form_length=2&ep.first_field_id=&ep.first_field_name=q&ep.first_field_type=text&epn.first_field_position=1&_et=127&tfd=9457", - "sessionTargetType": "page", - "protocol": "h3", - "rendererStartTime": 1606.7529999613762, - "networkRequestTime": 1608.5419999957085, - "networkEndTime": 2181.291000008583, - "finished": true, - "transferSize": 20, - "resourceSize": 0, - "statusCode": 204, - "mimeType": "text/plain", - "resourceType": "Fetch", - "priority": "High", - "entity": "Google Analytics" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s8/e13/128w/81d89db1bf3d43b5b21f813d2f2a9777.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1741.1729999780655, - "networkRequestTime": 1741.4399999976158, - "networkEndTime": 2553.4729999899864, - "finished": true, - "transferSize": 3019, - "resourceSize": 2379, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s3/e3/128w/9b3031eb3988ba363fe946929a79e016.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1742.1039999723434, - "networkRequestTime": 1742.2770000100136, - "networkEndTime": 2561.3180000185966, - "finished": true, - "transferSize": 3495, - "resourceSize": 2865, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s3/e3/128w/793a408ca63a660b5d7aa1a41ac126ca.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1742.1499999761581, - "networkRequestTime": 1742.4350000023842, - "networkEndTime": 2506.6270000338554, - "finished": true, - "transferSize": 2663, - "resourceSize": 1758, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s7/e11/128w/5d1df07b1741f4c3e66ed20ef00265f5.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1742.1860000491142, - "networkRequestTime": 1742.5649999976158, - "networkEndTime": 2537.9950000047684, - "finished": true, - "transferSize": 3886, - "resourceSize": 3267, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s8/e13/128w/b997cdb40263ff124e2a245c5e86a9a3.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1742.2240000367165, - "networkRequestTime": 1742.75, - "networkEndTime": 2528.4669999480247, - "finished": true, - "transferSize": 3598, - "resourceSize": 2596, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s8/e3/128w/08b3049589ca7ae688b0f771f9730caf.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1743.1800000071526, - "networkRequestTime": 1743.3759999871254, - "networkEndTime": 2545.5040000081062, - "finished": true, - "transferSize": 3744, - "resourceSize": 3110, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s8/e13/128w/f5c5012a2afa2ac6b190dcd68306dbac.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1743.2229999899864, - "networkRequestTime": 2179.2229999899864, - "networkEndTime": 2822.3079999685287, - "finished": true, - "transferSize": 4708, - "resourceSize": 3806, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s9/e9/128w/5fbc916d0fffb01af1225d4ec2ab001d.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1743.2689999938011, - "networkRequestTime": 2179.725000023842, - "networkEndTime": 2815.901999950409, - "finished": true, - "transferSize": 3635, - "resourceSize": 3032, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://cdn.mikescerealshack.co/frames/s9/e9/128w/558dc2f7d9c947e5445fb3f1838cb62c.jpg", - "sessionTargetType": "page", - "protocol": "h2", - "rendererStartTime": 1743.3100000023842, - "networkRequestTime": 2179.7789999842644, - "networkEndTime": 2808.1759999990463, - "finished": true, - "transferSize": 3957, - "resourceSize": 3324, - "statusCode": 200, - "mimeType": "image/jpeg", - "resourceType": "Image", - "priority": "Low", - "entity": "mikescerealshack.co" - }, - { - "url": "https://www.google-analytics.com/g/collect?v=2&tid=G-RTW9M3W5HC>m=45je5230v9102781914za200&_p=1738719102855&gcd=13l3l3l3l1l1&npa=0&dma=0&tag_exp=102067808~102081485~102123608~102482432~102539968~102558064&cid=974257356.1738719103&ul=en-us&sr=412x823&uaa=&uab=64&uafvl=Chromium%3B134.0.6998.0%7CNot%253AA-Brand%3B24.0.0.0%7CGoogle%2520Chrome%3B134.0.6998.0&uamb=1&uam=moto%20g%20power%20(2022)&uap=Android&uapv=11.0&uaw=0&are=1&frm=0&pscdl=noapi&_eu=AEA&_s=4&dl=https%3A%2F%2Fwww.mikescerealshack.co%2Fsearch%3Fq%3Dcall%2Bof%2Bduty&dr=https%3A%2F%2Fwww.mikescerealshack.co%2F&sid=1738719103&sct=1&seg=1&dt=%22call%20of%20duty%22%20Results%20-%20Mike%27s%20Cereal%20Shack%3A%20The%20Office%20Search%20Engine&en=page_view&_et=1590&tfd=14460", - "sessionTargetType": "page", - "protocol": "h3", - "rendererStartTime": 6609.106000006199, - "networkRequestTime": 6610.670000016689, - "networkEndTime": 7179.296000003815, - "finished": true, - "transferSize": 20, - "resourceSize": 0, - "statusCode": 204, - "mimeType": "text/plain", - "resourceType": "Fetch", - "priority": "High", - "entity": "Google Analytics" - } - ], - "debugData": { - "type": "debugdata", - "networkStartTimeTs": 282962413440, - "initiators": [ - { - "type": "preflight", - "url": "https://mnl4bjjsnz-dsn.algolia.net/1/indexes/dev_OFFICE_SCENES/query" - } - ] - } - } - }, - "network-rtt": { - "id": "network-rtt", - "title": "Network Round Trip Times", - "description": "Network round trip times (RTT) have a large impact on performance. If the RTT to an origin is high, it's an indication that servers closer to the user could improve performance. [Learn more about the Round Trip Time](https://hpbn.co/primer-on-latency-and-bandwidth/).", - "score": 1, - "scoreDisplayMode": "informative", - "numericValue": 21.025999999999996, - "numericUnit": "millisecond", - "displayValue": "20 ms", - "details": { - "type": "table", - "headings": [ - { - "key": "origin", - "valueType": "text", - "label": "URL" - }, - { - "key": "rtt", - "valueType": "ms", - "granularity": 1, - "label": "Time Spent" - } - ], - "items": [ - { - "origin": "https://cdn.mikescerealshack.co", - "rtt": 21.025999999999996 - }, - { - "origin": "https://mnl4bjjsnz-dsn.algolia.net", - "rtt": 17.63733000000001 - }, - { - "origin": "https://www.mikescerealshack.co", - "rtt": 0.023899999999999998 - }, - { - "origin": "https://www.google-analytics.com", - "rtt": 0 - } - ], - "sortedBy": [ - "rtt" - ] - } - }, - "network-server-latency": { - "id": "network-server-latency", - "title": "Server Backend Latencies", - "description": "Server latencies can impact web performance. If the server latency of an origin is high, it's an indication the server is overloaded or has poor backend performance. [Learn more about server response time](https://hpbn.co/primer-on-web-performance/#analyzing-the-resource-waterfall).", - "score": 1, - "scoreDisplayMode": "informative", - "numericValue": 568.1725, - "numericUnit": "millisecond", - "displayValue": "570 ms", - "details": { - "type": "table", - "headings": [ - { - "key": "origin", - "valueType": "text", - "label": "URL" - }, - { - "key": "serverResponseTime", - "valueType": "ms", - "granularity": 1, - "label": "Time Spent" - } - ], - "items": [ - { - "origin": "https://www.google-analytics.com", - "serverResponseTime": 568.1725 - }, - { - "origin": "https://cdn.mikescerealshack.co", - "serverResponseTime": 566.152 - }, - { - "origin": "https://www.mikescerealshack.co", - "serverResponseTime": 563.5710999999999 - }, - { - "origin": "https://mnl4bjjsnz-dsn.algolia.net", - "serverResponseTime": 303.44616999999994 - } - ], - "sortedBy": [ - "serverResponseTime" - ] - } - }, - "main-thread-tasks": { - "id": "main-thread-tasks", - "title": "Tasks", - "description": "Lists the toplevel main thread tasks that executed during page load.", - "score": 1, - "scoreDisplayMode": "informative", - "details": { - "type": "table", - "headings": [ - { - "key": "startTime", - "valueType": "ms", - "granularity": 1, - "label": "Start Time" - }, - { - "key": "duration", - "valueType": "ms", - "granularity": 1, - "label": "End Time" - } - ], - "items": [ - { - "duration": 16.541, - "startTime": 18.038 - }, - { - "duration": 5.296, - "startTime": 41.477 - }, - { - "duration": 5.535, - "startTime": 48.581 - }, - { - "duration": 13.026, - "startTime": 128.889 - }, - { - "duration": 10.717, - "startTime": 143.934 - }, - { - "duration": 35.353, - "startTime": 731.44 - }, - { - "duration": 7.582, - "startTime": 766.802 - }, - { - "duration": 7.761, - "startTime": 1332.669 - }, - { - "duration": 11.693, - "startTime": 1737.281 - }, - { - "duration": 125.787, - "startTime": 1757.73 - }, - { - "duration": 8.204, - "startTime": 1883.54 - } - ] - } - }, - "resource-summary": { - "id": "resource-summary", - "title": "Resources Summary", - "description": "Aggregates all network requests and groups them by type", - "score": 1, - "scoreDisplayMode": "informative", - "details": { - "type": "table", - "headings": [ - { - "key": "label", - "valueType": "text", - "label": "Resource Type" - }, - { - "key": "requestCount", - "valueType": "numeric", - "label": "Requests" - }, - { - "key": "transferSize", - "valueType": "bytes", - "label": "Transfer Size" - } - ], - "items": [ - { - "resourceType": "total", - "label": "Total", - "requestCount": 20, - "transferSize": 67322 - }, - { - "resourceType": "image", - "label": "Image", - "requestCount": 10, - "transferSize": 32808 - }, - { - "resourceType": "other", - "label": "Other", - "requestCount": 7, - "transferSize": 31190 - }, - { - "resourceType": "script", - "label": "Script", - "requestCount": 3, - "transferSize": 3324 - }, - { - "resourceType": "stylesheet", - "label": "Stylesheet", - "requestCount": 0, - "transferSize": 0 - }, - { - "resourceType": "media", - "label": "Media", - "requestCount": 0, - "transferSize": 0 - }, - { - "resourceType": "font", - "label": "Font", - "requestCount": 0, - "transferSize": 0 - }, - { - "resourceType": "document", - "label": "Document", - "requestCount": 0, - "transferSize": 0 - }, - { - "resourceType": "third-party", - "label": "Third-party", - "requestCount": 4, - "transferSize": 25359 - } - ] - } - }, - "layout-shifts": { - "id": "layout-shifts", - "title": "Avoid large layout shifts", - "description": "These are the largest layout shifts observed on the page. Each table item represents a single layout shift, and shows the element that shifted the most. Below each item are possible root causes that led to the layout shift. Some of these layout shifts may not be included in the CLS metric value due to [windowing](https://web.dev/articles/cls#what_is_cls). [Learn how to improve CLS](https://web.dev/articles/optimize-cls)", - "score": 0, - "scoreDisplayMode": "metricSavings", - "displayValue": "1 layout shift found", - "metricSavings": { - "CLS": 0.10200000000000001 - }, - "details": { - "type": "table", - "headings": [ - { - "key": "node", - "valueType": "node", - "subItemsHeading": { - "key": "extra" - }, - "label": "Element" - }, - { - "key": "score", - "valueType": "numeric", - "subItemsHeading": { - "key": "cause", - "valueType": "text" - }, - "granularity": 0.001, - "label": "Layout shift score" - } - ], - "items": [ - { - "node": { - "type": "node", - "lhId": "page-1-FOOTER", - "path": "1,HTML,1,BODY,0,DIV,0,DIV,5,FOOTER", - "selector": "body > div#__next > div.flex > footer.w-full", - "boundingRect": { - "top": 1580, - "bottom": 1664, - "left": 0, - "right": 412, - "width": 412, - "height": 84 - }, - "snippet": "