Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

core(lantern): create network graph from trace (experimental) #16026

Merged
merged 65 commits into from
Jun 3, 2024
Merged
Show file tree
Hide file tree
Changes from 63 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
b4fa823
start on lantern from trace
connorjclark May 14, 2024
a487855
redirects
connorjclark Apr 25, 2024
acaa25c
timings
connorjclark Apr 25, 2024
5bde7b5
typescript
connorjclark Apr 25, 2024
aca1615
update
connorjclark Apr 25, 2024
6a50568
more redirect stuff
connorjclark Apr 25, 2024
171f7b7
update
connorjclark May 1, 2024
bc5ebbf
update
connorjclark May 1, 2024
318c6de
initiator call stack
connorjclark May 2, 2024
037e690
add a testing tool
connorjclark May 2, 2024
4e07d3a
xhr
connorjclark May 2, 2024
5a916b2
types
connorjclark May 2, 2024
9802496
fix timestamps
connorjclark May 13, 2024
f955dd6
fix test
connorjclark May 14, 2024
0c27d0b
update
connorjclark May 14, 2024
2b7d434
update
connorjclark May 14, 2024
53b713d
update te
connorjclark May 14, 2024
2b19b21
test: update interactive test trace
connorjclark May 14, 2024
0ccc87e
Merge branch 'inter-trace' into lantern-from-trace
connorjclark May 14, 2024
300ed78
update
connorjclark May 14, 2024
96d2ed7
fix timing
connorjclark May 14, 2024
9d8969e
Merge remote-tracking branch 'origin/main' into lantern-from-trace
connorjclark May 15, 2024
78e66e5
passing tests
connorjclark May 15, 2024
4166ca8
vary
connorjclark May 15, 2024
c2927c3
update
connorjclark May 15, 2024
552dda9
wip
connorjclark May 15, 2024
c0c75d0
move to lantern lib
connorjclark May 15, 2024
862cda9
wip
connorjclark May 15, 2024
32944ce
:wqerge remote-tracking branch 'origin/main' into lantern-from-trace
connorjclark May 15, 2024
d23acb0
wip
connorjclark May 15, 2024
dff6fe5
wip
connorjclark May 15, 2024
b5c0ec8
wip
connorjclark May 16, 2024
09ff562
wip
connorjclark May 17, 2024
8db8c7c
test
connorjclark May 20, 2024
bd244c7
wip
connorjclark May 20, 2024
b689180
wip
connorjclark May 20, 2024
ffc56e2
wip
connorjclark May 20, 2024
7d637a4
Merge remote-tracking branch 'origin/main' into lantern-from-trace
connorjclark May 30, 2024
e4196d8
update te
connorjclark May 30, 2024
11c0b5b
run lh tests using lantern with trace and cdt
connorjclark May 30, 2024
fc6b342
disable some tests that need more work
connorjclark May 30, 2024
841e534
remove dated comments
connorjclark May 30, 2024
61b52b7
update test
connorjclark May 30, 2024
84ef26a
tests: use new trace in metrics-test for pwa
connorjclark May 30, 2024
1644637
Merge branch 'test-update-metric-trace' into lantern-from-trace
connorjclark May 30, 2024
d6dd650
remove rounding thing that is not needed anymore
connorjclark May 30, 2024
c0e6226
only do lantern smoke for ToT
connorjclark May 30, 2024
40d0f2a
Merge remote-tracking branch 'origin/main' into lantern-from-trace
connorjclark May 30, 2024
183e50d
include audits in trace tests, and exclude many more
connorjclark May 30, 2024
9fdcbab
generate network revents in createTestTrace; fix redirect setup in ne…
connorjclark May 31, 2024
30460e7
work more on createTestTrace
connorjclark May 31, 2024
025fd52
decompose createGraphFromTrace into a few private methods
connorjclark May 31, 2024
8c938e4
comment
connorjclark May 31, 2024
976a91c
ts
connorjclark May 31, 2024
9811633
lint, fix a test
connorjclark May 31, 2024
20f72d0
fix minor things with createTestTrace, disabled tests
connorjclark May 31, 2024
6edccfe
network sizes
connorjclark May 31, 2024
a436e25
lint
connorjclark May 31, 2024
6b85157
more tweaks to redirect stuff
connorjclark May 31, 2024
6126b22
fix type
connorjclark May 31, 2024
b0a78af
fix wrong access for requestId in Lantern node
connorjclark May 31, 2024
007a6f7
account for all workers in our lookup
connorjclark Jun 3, 2024
34316d5
be more explicit
connorjclark Jun 3, 2024
bf7b5d2
pr
connorjclark Jun 3, 2024
df982f7
Merge remote-tracking branch 'origin/main' into lantern-from-trace
connorjclark Jun 3, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions .github/workflows/smoke.yml
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,14 @@ jobs:
yarn c8 yarn smoke --debug -j=2 --retries=2 --shard=${{ matrix.smoke-test-shard }}/$SHARD_TOTAL
yarn c8 report --reporter text-lcov > smoke-coverage.lcov

# TODO(15841): remove when using trace by default, and we want to remove CDT graph impl.
- name: Run smoke tests (lantern + trace)
if: matrix.smoke-test-shard == 1 && matrix.chrome-channel == 'ToT'
run: |
yarn smoke --debug -j=2 --retries=2 lantern
env:
INTERNAL_LANTERN_USE_TRACE: 1

- name: Upload test coverage to Codecov
if: matrix.chrome-channel == 'ToT'
uses: codecov/codecov-action@eaaf4bedf32dbdc6b720b63067d99c4d77d6047d
Expand Down
2 changes: 1 addition & 1 deletion core/audits/byte-efficiency/render-blocking-resources.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ function getNodesAndTimingByRequestId(nodeTimings) {
for (const [node, nodeTiming] of nodeTimings) {
if (node.type !== 'network') continue;

requestIdToNode.set(node.record.requestId, {node, nodeTiming});
requestIdToNode.set(node.request.requestId, {node, nodeTiming});
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yay! i so appreciate this rename. :) thanks

}

return requestIdToNode;
Expand Down
4 changes: 2 additions & 2 deletions core/audits/dobetterweb/uses-http2.js
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ class UsesHTTP2Audit extends Audit {
if (node.type !== 'network') return;
if (!urlsToChange.has(node.record.url)) return;

originalProtocols.set(node.record.requestId, node.record.protocol);
originalProtocols.set(node.request.requestId, node.record.protocol);
node.request.protocol = 'h2';
});

Expand All @@ -98,7 +98,7 @@ class UsesHTTP2Audit extends Audit {
// Restore the original protocol after we've done our simulation
graph.traverse(node => {
if (node.type !== 'network') return;
const originalProtocol = originalProtocols.get(node.record.requestId);
const originalProtocol = originalProtocols.get(node.request.requestId);
if (originalProtocol === undefined) return;
node.request.protocol = originalProtocol;
});
Expand Down
2 changes: 1 addition & 1 deletion core/audits/prioritize-lcp-image.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ class PrioritizeLcpImage extends Audit {
static findLCPNode(graph, lcpRecord) {
for (const {node} of graph.traverseGenerator()) {
if (node.type !== 'network') continue;
if (node.record.requestId === lcpRecord.requestId) {
if (node.request.requestId === lcpRecord.requestId) {
return node;
}
}
Expand Down
2 changes: 1 addition & 1 deletion core/audits/redirects.js
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ class Redirects extends Audit {
const nodeTimingsById = new Map();
for (const [node, timing] of metricResult.pessimisticEstimate.nodeTimings.entries()) {
if (node.type === 'network') {
nodeTimingsById.set(node.record.requestId, timing);
nodeTimingsById.set(node.request.requestId, timing);
}
}

Expand Down
53 changes: 51 additions & 2 deletions core/computed/metrics/lantern-metric.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,20 @@
*/

import {LanternError} from '../../lib/lantern/lantern-error.js';
import {PageDependencyGraph as LanternPageDependencyGraph} from '../../lib/lantern/page-dependency-graph.js';
import {LighthouseError} from '../../lib/lh-error.js';
import {LoadSimulator} from '../load-simulator.js';
import {PageDependencyGraph} from '../page-dependency-graph.js';
import {ProcessedNavigation} from '../processed-navigation.js';
import {ProcessedTrace} from '../processed-trace.js';
import {TraceEngineResult} from '../trace-engine-result.js';
import {PageDependencyGraph} from '../page-dependency-graph.js';

// TODO: we need to update all test traces (that use lantern) before this can be removed
/**
* @param {LH.Artifacts.MetricComputationDataInput} data
* @param {LH.Artifacts.ComputedContext} context
*/
async function getComputationDataParams(data, context) {
async function getComputationDataParamsFromDevtoolsLog(data, context) {
if (data.gatherContext.gatherMode !== 'navigation') {
throw new Error(`Lantern metrics can only be computed on navigations`);
}
Expand All @@ -26,6 +30,35 @@ async function getComputationDataParams(data, context) {
return {simulator, graph, processedNavigation};
}

/**
* @param {LH.Artifacts.URL} theURL
* @param {LH.Trace} trace
* @param {LH.Artifacts.ComputedContext} context
*/
async function createGraphFromTrace(theURL, trace, context) {
const {mainThreadEvents} = await ProcessedTrace.request(trace, context);
const traceEngineResult = await TraceEngineResult.request({trace}, context);
return LanternPageDependencyGraph.createGraphFromTrace(
mainThreadEvents, trace, traceEngineResult, theURL);
}

/**
* @param {LH.Artifacts.MetricComputationDataInput} data
* @param {LH.Artifacts.ComputedContext} context
*/
async function getComputationDataParamsFromTrace(data, context) {
if (data.gatherContext.gatherMode !== 'navigation') {
throw new Error(`Lantern metrics can only be computed on navigations`);
}

const {trace, URL} = data;
const {graph} = await createGraphFromTrace(URL, trace, context);
const processedNavigation = await ProcessedNavigation.request(data.trace, context);
const simulator = data.simulator || (await LoadSimulator.request(data, context));

return {simulator, graph, processedNavigation};
}

/**
* @param {unknown} err
* @return {never}
Expand All @@ -43,7 +76,23 @@ function lanternErrorAdapter(err) {
throw err;
}

/**
* @param {LH.Artifacts.MetricComputationDataInput} data
* @param {LH.Artifacts.ComputedContext} context
*/
function getComputationDataParams(data, context) {
// TODO(15841): remove when all tests use the trace, and we want to remove CDT graph impl.
if (process.env.INTERNAL_LANTERN_USE_TRACE !== undefined) {
return getComputationDataParamsFromTrace(data, context);
} else {
// This is the default behavior.
return getComputationDataParamsFromDevtoolsLog(data, context);
}
}

export {
getComputationDataParamsFromTrace,
getComputationDataParamsFromDevtoolsLog,
getComputationDataParams,
lanternErrorAdapter,
};
1 change: 1 addition & 0 deletions core/computed/trace-engine-result.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ const ENABLED_HANDLERS = {
Samples: TraceEngine.TraceHandlers.Samples,
Screenshots: TraceEngine.TraceHandlers.Screenshots,
PageLoadMetrics: TraceEngine.TraceHandlers.PageLoadMetrics,
Workers: TraceEngine.TraceHandlers.Workers,
};

/**
Expand Down
6 changes: 3 additions & 3 deletions core/lib/lantern/metric.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

import * as Lantern from './types/lantern.js';
import {BaseNode} from '../../lib/lantern/base-node.js';
import {NetworkRequest} from '../../lib/network-request.js';
import {RESOURCE_TYPES} from '../../lib/network-request.js';

/** @typedef {import('./base-node.js').Node} Node */
/** @typedef {import('./network-node.js').NetworkNode} NetworkNode */
Expand All @@ -33,9 +33,9 @@ class Metric {

dependencyGraph.traverse(node => {
if (node.type !== BaseNode.TYPES.NETWORK) return;
if (node.record.resourceType !== NetworkRequest.TYPES.Script) return;
if (node.request.resourceType !== RESOURCE_TYPES.Script) return;
if (treatNodeAsRenderBlocking?.(node)) {
scriptUrls.add(node.record.url);
scriptUrls.add(node.request.url);
}
});

Expand Down
2 changes: 1 addition & 1 deletion core/lib/lantern/metrics/first-contentful-paint.js
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ class FirstContentfulPaint extends Metric {
const endedAfterPaint = node.endTime > cutoffTimestamp || node.startTime > cutoffTimestamp;
if (endedAfterPaint && !node.isMainDocument()) return false;

const url = node.record.url;
const url = node.request.url;
// If the URL definitely wasn't render-blocking then we filter it out.
if (definitelyNotRenderBlockingScriptUrls.has(url)) {
return false;
Expand Down
8 changes: 4 additions & 4 deletions core/lib/lantern/metrics/interactive.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,13 +41,13 @@ class Interactive extends Metric {
}

// Include all scripts and high priority requests, exclude all images
const isImage = node.record.resourceType === NetworkRequestTypes.Image;
const isScript = node.record.resourceType === NetworkRequestTypes.Script;
const isImage = node.request.resourceType === NetworkRequestTypes.Image;
const isScript = node.request.resourceType === NetworkRequestTypes.Script;
return (
!isImage &&
(isScript ||
node.record.priority === 'High' ||
node.record.priority === 'VeryHigh')
node.request.priority === 'High' ||
node.request.priority === 'VeryHigh')
);
});
}
Expand Down
4 changes: 2 additions & 2 deletions core/lib/lantern/metrics/largest-contentful-paint.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,8 @@ class LargestContentfulPaint extends Metric {
*/
static isNotLowPriorityImageNode(node) {
if (node.type !== 'network') return true;
const isImage = node.record.resourceType === 'Image';
const isLowPriority = node.record.priority === 'Low' || node.record.priority === 'VeryLow';
const isImage = node.request.resourceType === 'Image';
const isLowPriority = node.request.priority === 'Low' || node.request.priority === 'VeryLow';
return !isImage || !isLowPriority;
}

Expand Down
Loading
Loading