@paulirish/trace_engine 0.0.24 → 0.0.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/platform/TypedArrayUtilities.d.ts +7 -0
- package/core/platform/TypedArrayUtilities.js +41 -0
- package/core/platform/TypedArrayUtilities.js.map +1 -1
- package/core/platform/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/core/platform/platform-tsconfig.json +0 -1
- package/generated/protocol.d.ts +73 -18
- package/models/cpu_profile/cpu_profile-tsconfig.json +0 -1
- package/models/cpu_profile/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/LanternComputationData.d.ts +8 -0
- package/models/trace/LanternComputationData.js +368 -0
- package/models/trace/LanternComputationData.js.map +1 -0
- package/models/trace/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/extras/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/extras/extras-tsconfig.json +0 -1
- package/models/trace/handlers/AuctionWorkletsHandler.js +1 -1
- package/models/trace/handlers/AuctionWorkletsHandler.js.map +1 -1
- package/models/trace/handlers/EnhancedTracesHandler.d.ts +46 -0
- package/models/trace/handlers/EnhancedTracesHandler.js +137 -0
- package/models/trace/handlers/EnhancedTracesHandler.js.map +1 -0
- package/models/trace/handlers/LayoutShiftsHandler.d.ts +1 -1
- package/models/trace/handlers/LayoutShiftsHandler.js +3 -3
- package/models/trace/handlers/LayoutShiftsHandler.js.map +1 -1
- package/models/trace/handlers/MetaHandler.js +39 -13
- package/models/trace/handlers/MetaHandler.js.map +1 -1
- package/models/trace/handlers/ModelHandlers.d.ts +1 -0
- package/models/trace/handlers/ModelHandlers.js +1 -0
- package/models/trace/handlers/ModelHandlers.js.map +1 -1
- package/models/trace/handlers/NetworkRequestsHandler.js +2 -2
- package/models/trace/handlers/NetworkRequestsHandler.js.map +1 -1
- package/models/trace/handlers/PageLoadMetricsHandler.d.ts +1 -2
- package/models/trace/handlers/PageLoadMetricsHandler.js +2 -35
- package/models/trace/handlers/PageLoadMetricsHandler.js.map +1 -1
- package/models/trace/handlers/ScreenshotsHandler.js +1 -2
- package/models/trace/handlers/ScreenshotsHandler.js.map +1 -1
- package/models/trace/handlers/UserInteractionsHandler.d.ts +6 -0
- package/models/trace/handlers/UserInteractionsHandler.js +17 -2
- package/models/trace/handlers/UserInteractionsHandler.js.map +1 -1
- package/models/trace/handlers/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/handlers/handlers-tsconfig.json +1 -1
- package/models/trace/helpers/SyntheticEvents.d.ts +1 -0
- package/models/trace/helpers/SyntheticEvents.js +12 -0
- package/models/trace/helpers/SyntheticEvents.js.map +1 -1
- package/models/trace/helpers/Timing.d.ts +17 -6
- package/models/trace/helpers/Timing.js +17 -76
- package/models/trace/helpers/Timing.js.map +1 -1
- package/models/trace/helpers/Trace.js +1 -2
- package/models/trace/helpers/Trace.js.map +1 -1
- package/models/trace/helpers/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/helpers/helpers-tsconfig.json +0 -1
- package/models/trace/insights/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/insights/insights-tsconfig.json +0 -1
- package/models/trace/lantern/BaseNode.d.ts +91 -0
- package/models/trace/lantern/BaseNode.js +268 -0
- package/models/trace/lantern/BaseNode.js.map +1 -0
- package/models/trace/lantern/CPUNode.d.ts +24 -0
- package/models/trace/lantern/CPUNode.js +64 -0
- package/models/trace/lantern/CPUNode.js.map +1 -0
- package/models/trace/lantern/LanternError.d.ts +3 -0
- package/models/trace/lantern/LanternError.js +7 -0
- package/models/trace/lantern/LanternError.js.map +1 -0
- package/models/trace/lantern/MetricsModule.d.ts +11 -0
- package/models/trace/lantern/MetricsModule.js +14 -0
- package/models/trace/lantern/MetricsModule.js.map +1 -0
- package/models/trace/lantern/NetworkNode.d.ts +22 -0
- package/models/trace/lantern/NetworkNode.js +83 -0
- package/models/trace/lantern/NetworkNode.js.map +1 -0
- package/models/trace/lantern/PageDependencyGraph.d.ts +43 -0
- package/models/trace/lantern/PageDependencyGraph.js +509 -0
- package/models/trace/lantern/PageDependencyGraph.js.map +1 -0
- package/models/trace/lantern/SimulationModule.d.ts +17 -0
- package/models/trace/lantern/SimulationModule.js +13 -0
- package/models/trace/lantern/SimulationModule.js.map +1 -0
- package/models/trace/lantern/bundle-tsconfig.json +1 -0
- package/models/trace/lantern/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
- package/models/trace/lantern/lantern-tsconfig.json +64 -0
- package/models/trace/lantern/lantern.d.ts +29 -0
- package/models/trace/lantern/lantern.js +33 -0
- package/models/trace/lantern/lantern.js.map +1 -0
- package/models/trace/lantern/metrics/FirstContentfulPaint.d.ts +42 -0
- package/models/trace/lantern/metrics/FirstContentfulPaint.js +137 -0
- package/models/trace/lantern/metrics/FirstContentfulPaint.js.map +1 -0
- package/models/trace/lantern/metrics/Interactive.d.ts +12 -0
- package/models/trace/lantern/metrics/Interactive.js +68 -0
- package/models/trace/lantern/metrics/Interactive.js.map +1 -0
- package/models/trace/lantern/metrics/LargestContentfulPaint.d.ts +16 -0
- package/models/trace/lantern/metrics/LargestContentfulPaint.js +70 -0
- package/models/trace/lantern/metrics/LargestContentfulPaint.js.map +1 -0
- package/models/trace/lantern/metrics/MaxPotentialFID.d.ts +14 -0
- package/models/trace/lantern/metrics/MaxPotentialFID.js +49 -0
- package/models/trace/lantern/metrics/MaxPotentialFID.js.map +1 -0
- package/models/trace/lantern/metrics/Metric.d.ts +26 -0
- package/models/trace/lantern/metrics/Metric.js +71 -0
- package/models/trace/lantern/metrics/Metric.js.map +1 -0
- package/models/trace/lantern/metrics/SpeedIndex.d.ts +25 -0
- package/models/trace/lantern/metrics/SpeedIndex.js +102 -0
- package/models/trace/lantern/metrics/SpeedIndex.js.map +1 -0
- package/models/trace/lantern/metrics/TBTUtils.d.ts +31 -0
- package/models/trace/lantern/metrics/TBTUtils.js +65 -0
- package/models/trace/lantern/metrics/TBTUtils.js.map +1 -0
- package/models/trace/lantern/metrics/TotalBlockingTime.d.ts +16 -0
- package/models/trace/lantern/metrics/TotalBlockingTime.js +79 -0
- package/models/trace/lantern/metrics/TotalBlockingTime.js.map +1 -0
- package/models/trace/lantern/metrics/metrics.d.ts +15 -0
- package/models/trace/lantern/metrics/metrics.js +12 -0
- package/models/trace/lantern/metrics/metrics.js.map +1 -0
- package/models/trace/lantern/simulation/ConnectionPool.d.ts +26 -0
- package/models/trace/lantern/simulation/ConnectionPool.js +116 -0
- package/models/trace/lantern/simulation/ConnectionPool.js.map +1 -0
- package/models/trace/lantern/simulation/Constants.d.ts +31 -0
- package/models/trace/lantern/simulation/Constants.js +43 -0
- package/models/trace/lantern/simulation/Constants.js.map +1 -0
- package/models/trace/lantern/simulation/DNSCache.d.ts +22 -0
- package/models/trace/lantern/simulation/DNSCache.js +48 -0
- package/models/trace/lantern/simulation/DNSCache.js.map +1 -0
- package/models/trace/lantern/simulation/NetworkAnalyzer.d.ts +112 -0
- package/models/trace/lantern/simulation/NetworkAnalyzer.js +486 -0
- package/models/trace/lantern/simulation/NetworkAnalyzer.js.map +1 -0
- package/models/trace/lantern/simulation/SimulationTimingMap.d.ts +71 -0
- package/models/trace/lantern/simulation/SimulationTimingMap.js +134 -0
- package/models/trace/lantern/simulation/SimulationTimingMap.js.map +1 -0
- package/models/trace/lantern/simulation/Simulator.d.ts +82 -0
- package/models/trace/lantern/simulation/Simulator.js +449 -0
- package/models/trace/lantern/simulation/Simulator.js.map +1 -0
- package/models/trace/lantern/simulation/TCPConnection.d.ts +48 -0
- package/models/trace/lantern/simulation/TCPConnection.js +158 -0
- package/models/trace/lantern/simulation/TCPConnection.js.map +1 -0
- package/models/trace/lantern/simulation/simulation.d.ts +21 -0
- package/models/trace/lantern/simulation/simulation.js +11 -0
- package/models/trace/lantern/simulation/simulation.js.map +1 -0
- package/models/trace/lantern/types/lantern.d.ts +205 -0
- package/models/trace/lantern/types/lantern.js +5 -0
- package/models/trace/lantern/types/lantern.js.map +1 -0
- package/models/trace/root-causes/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/root-causes/root-causes-tsconfig.json +0 -1
- package/models/trace/trace-tsconfig.json +4 -1
- package/models/trace/trace.d.ts +3 -1
- package/models/trace/trace.js +3 -1
- package/models/trace/trace.js.map +1 -1
- package/models/trace/types/Extensions.d.ts +2 -3
- package/models/trace/types/Extensions.js +2 -11
- package/models/trace/types/Extensions.js.map +1 -1
- package/models/trace/types/File.d.ts +28 -5
- package/models/trace/types/File.js +36 -1
- package/models/trace/types/File.js.map +1 -1
- package/models/trace/types/TraceEvents.d.ts +50 -0
- package/models/trace/types/TraceEvents.js +33 -0
- package/models/trace/types/TraceEvents.js.map +1 -1
- package/models/trace/types/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
- package/models/trace/types/types-tsconfig.json +0 -1
- package/package.json +1 -1
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
// Copyright 2024 The Chromium Authors. All rights reserved.
|
|
2
|
+
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
+
// found in the LICENSE file.
|
|
4
|
+
/**
|
|
5
|
+
* @fileoverview
|
|
6
|
+
*
|
|
7
|
+
* This class encapsulates the type-related validation logic for moving timing information for nodes
|
|
8
|
+
* through the different simulation phases. Methods here ensure that the invariants of simulation hold
|
|
9
|
+
* as nodes are queued, partially simulated, and completed.
|
|
10
|
+
*/
|
|
11
|
+
import { BaseNode } from '../BaseNode.js';
|
|
12
|
+
class SimulatorTimingMap {
|
|
13
|
+
_nodeTimings;
|
|
14
|
+
constructor() {
|
|
15
|
+
this._nodeTimings = new Map();
|
|
16
|
+
}
|
|
17
|
+
getNodes() {
|
|
18
|
+
return Array.from(this._nodeTimings.keys());
|
|
19
|
+
}
|
|
20
|
+
setReadyToStart(node, values) {
|
|
21
|
+
this._nodeTimings.set(node, values);
|
|
22
|
+
}
|
|
23
|
+
setInProgress(node, values) {
|
|
24
|
+
const nodeTiming = {
|
|
25
|
+
...this.getQueued(node),
|
|
26
|
+
startTime: values.startTime,
|
|
27
|
+
timeElapsed: 0,
|
|
28
|
+
};
|
|
29
|
+
this._nodeTimings.set(node, node.type === BaseNode.types.NETWORK ? { ...nodeTiming, timeElapsedOvershoot: 0, bytesDownloaded: 0 } :
|
|
30
|
+
nodeTiming);
|
|
31
|
+
}
|
|
32
|
+
setCompleted(node, values) {
|
|
33
|
+
const nodeTiming = {
|
|
34
|
+
...this.getInProgress(node),
|
|
35
|
+
endTime: values.endTime,
|
|
36
|
+
connectionTiming: values.connectionTiming,
|
|
37
|
+
};
|
|
38
|
+
this._nodeTimings.set(node, nodeTiming);
|
|
39
|
+
}
|
|
40
|
+
setCpu(node, values) {
|
|
41
|
+
const nodeTiming = {
|
|
42
|
+
...this.getCpuStarted(node),
|
|
43
|
+
timeElapsed: values.timeElapsed,
|
|
44
|
+
};
|
|
45
|
+
this._nodeTimings.set(node, nodeTiming);
|
|
46
|
+
}
|
|
47
|
+
setCpuEstimated(node, values) {
|
|
48
|
+
const nodeTiming = {
|
|
49
|
+
...this.getCpuStarted(node),
|
|
50
|
+
estimatedTimeElapsed: values.estimatedTimeElapsed,
|
|
51
|
+
};
|
|
52
|
+
this._nodeTimings.set(node, nodeTiming);
|
|
53
|
+
}
|
|
54
|
+
setNetwork(node, values) {
|
|
55
|
+
const nodeTiming = {
|
|
56
|
+
...this.getNetworkStarted(node),
|
|
57
|
+
timeElapsed: values.timeElapsed,
|
|
58
|
+
timeElapsedOvershoot: values.timeElapsedOvershoot,
|
|
59
|
+
bytesDownloaded: values.bytesDownloaded,
|
|
60
|
+
};
|
|
61
|
+
this._nodeTimings.set(node, nodeTiming);
|
|
62
|
+
}
|
|
63
|
+
setNetworkEstimated(node, values) {
|
|
64
|
+
const nodeTiming = {
|
|
65
|
+
...this.getNetworkStarted(node),
|
|
66
|
+
estimatedTimeElapsed: values.estimatedTimeElapsed,
|
|
67
|
+
};
|
|
68
|
+
this._nodeTimings.set(node, nodeTiming);
|
|
69
|
+
}
|
|
70
|
+
getQueued(node) {
|
|
71
|
+
const timing = this._nodeTimings.get(node);
|
|
72
|
+
if (!timing) {
|
|
73
|
+
throw new Error(`Node ${node.id} not yet queued`);
|
|
74
|
+
}
|
|
75
|
+
return timing;
|
|
76
|
+
}
|
|
77
|
+
getCpuStarted(node) {
|
|
78
|
+
const timing = this._nodeTimings.get(node);
|
|
79
|
+
if (!timing) {
|
|
80
|
+
throw new Error(`Node ${node.id} not yet queued`);
|
|
81
|
+
}
|
|
82
|
+
if (!('startTime' in timing)) {
|
|
83
|
+
throw new Error(`Node ${node.id} not yet started`);
|
|
84
|
+
}
|
|
85
|
+
if ('bytesDownloaded' in timing) {
|
|
86
|
+
throw new Error(`Node ${node.id} timing not valid`);
|
|
87
|
+
}
|
|
88
|
+
return timing;
|
|
89
|
+
}
|
|
90
|
+
getNetworkStarted(node) {
|
|
91
|
+
const timing = this._nodeTimings.get(node);
|
|
92
|
+
if (!timing) {
|
|
93
|
+
throw new Error(`Node ${node.id} not yet queued`);
|
|
94
|
+
}
|
|
95
|
+
if (!('startTime' in timing)) {
|
|
96
|
+
throw new Error(`Node ${node.id} not yet started`);
|
|
97
|
+
}
|
|
98
|
+
if (!('bytesDownloaded' in timing)) {
|
|
99
|
+
throw new Error(`Node ${node.id} timing not valid`);
|
|
100
|
+
}
|
|
101
|
+
return timing;
|
|
102
|
+
}
|
|
103
|
+
getInProgress(node) {
|
|
104
|
+
const timing = this._nodeTimings.get(node);
|
|
105
|
+
if (!timing) {
|
|
106
|
+
throw new Error(`Node ${node.id} not yet queued`);
|
|
107
|
+
}
|
|
108
|
+
if (!('startTime' in timing)) {
|
|
109
|
+
throw new Error(`Node ${node.id} not yet started`);
|
|
110
|
+
}
|
|
111
|
+
if (!('estimatedTimeElapsed' in timing)) {
|
|
112
|
+
throw new Error(`Node ${node.id} not yet in progress`);
|
|
113
|
+
}
|
|
114
|
+
return timing;
|
|
115
|
+
}
|
|
116
|
+
getCompleted(node) {
|
|
117
|
+
const timing = this._nodeTimings.get(node);
|
|
118
|
+
if (!timing) {
|
|
119
|
+
throw new Error(`Node ${node.id} not yet queued`);
|
|
120
|
+
}
|
|
121
|
+
if (!('startTime' in timing)) {
|
|
122
|
+
throw new Error(`Node ${node.id} not yet started`);
|
|
123
|
+
}
|
|
124
|
+
if (!('estimatedTimeElapsed' in timing)) {
|
|
125
|
+
throw new Error(`Node ${node.id} not yet in progress`);
|
|
126
|
+
}
|
|
127
|
+
if (!('endTime' in timing)) {
|
|
128
|
+
throw new Error(`Node ${node.id} not yet completed`);
|
|
129
|
+
}
|
|
130
|
+
return timing;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
export { SimulatorTimingMap };
|
|
134
|
+
//# sourceMappingURL=SimulationTimingMap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SimulationTimingMap.js","sourceRoot":"","sources":["../../../../../../../../front_end/models/trace/lantern/simulation/SimulationTimingMap.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2024 The Chromium Authors. All rights reserved.\n// Use of this source code is governed by a BSD-style license that can be\n// found in the LICENSE file.\n\n/**\n * @fileoverview\n *\n * This class encapsulates the type-related validation logic for moving timing information for nodes\n * through the different simulation phases. Methods here ensure that the invariants of simulation hold\n * as nodes are queued, partially simulated, and completed.\n */\n\nimport {BaseNode, type Node} from '../BaseNode.js';\nimport {type CPUNode} from '../CPUNode.js';\nimport {type NetworkNode} from '../NetworkNode.js';\n\ninterface NodeTimingComplete {\n startTime: number;\n endTime: number;\n queuedTime: number;\n estimatedTimeElapsed: number;\n timeElapsed: number;\n timeElapsedOvershoot: number;\n bytesDownloaded: number;\n}\n\ntype NodeTimingQueued = Pick<NodeTimingComplete, 'queuedTime'>;\n\ntype CpuNodeTimingStarted = NodeTimingQueued&Pick<NodeTimingComplete, 'startTime'|'timeElapsed'>;\ntype NetworkNodeTimingStarted = CpuNodeTimingStarted&Pick<NodeTimingComplete, 'timeElapsedOvershoot'|'bytesDownloaded'>;\n\ntype CpuNodeTimingInProgress = CpuNodeTimingStarted&Pick<NodeTimingComplete, 'estimatedTimeElapsed'>;\ntype NetworkNodeTimingInProgress = NetworkNodeTimingStarted&Pick<NodeTimingComplete, 'estimatedTimeElapsed'>;\n\nexport type CpuNodeTimingComplete = CpuNodeTimingInProgress&Pick<NodeTimingComplete, 'endTime'>;\nexport type NetworkNodeTimingComplete =\n NetworkNodeTimingInProgress&Pick<NodeTimingComplete, 'endTime'>&{connectionTiming: ConnectionTiming};\nexport type CompleteNodeTiming = CpuNodeTimingComplete|NetworkNodeTimingComplete;\n\ntype NodeTimingData = NodeTimingQueued|CpuNodeTimingStarted|NetworkNodeTimingStarted|CpuNodeTimingInProgress|\n NetworkNodeTimingInProgress|CpuNodeTimingComplete|NetworkNodeTimingComplete;\n\nexport interface ConnectionTiming {\n dnsResolutionTime?: number;\n connectionTime?: number;\n sslTime?: number;\n timeToFirstByte: number;\n}\n\nclass SimulatorTimingMap {\n _nodeTimings: Map<Node, NodeTimingData>;\n\n constructor() {\n this._nodeTimings = new Map<Node, NodeTimingData>();\n }\n\n getNodes(): Node[] {\n return Array.from(this._nodeTimings.keys());\n }\n\n setReadyToStart(node: Node, values: {queuedTime: number}): void {\n this._nodeTimings.set(node, values);\n }\n\n setInProgress(node: Node, values: {startTime: number}): void {\n const nodeTiming = {\n ...this.getQueued(node),\n startTime: values.startTime,\n timeElapsed: 0,\n };\n\n this._nodeTimings.set(\n node,\n node.type === BaseNode.types.NETWORK ? {...nodeTiming, timeElapsedOvershoot: 0, bytesDownloaded: 0} :\n nodeTiming,\n );\n }\n\n setCompleted(node: Node, values: {endTime: number, connectionTiming?: ConnectionTiming}): void {\n const nodeTiming = {\n ...this.getInProgress(node),\n endTime: values.endTime,\n connectionTiming: values.connectionTiming,\n };\n\n this._nodeTimings.set(node, nodeTiming);\n }\n\n setCpu(node: CPUNode, values: {timeElapsed: number}): void {\n const nodeTiming = {\n ...this.getCpuStarted(node),\n timeElapsed: values.timeElapsed,\n };\n\n this._nodeTimings.set(node, nodeTiming);\n }\n\n setCpuEstimated(node: CPUNode, values: {estimatedTimeElapsed: number}): void {\n const nodeTiming = {\n ...this.getCpuStarted(node),\n estimatedTimeElapsed: values.estimatedTimeElapsed,\n };\n\n this._nodeTimings.set(node, nodeTiming);\n }\n\n setNetwork(node: NetworkNode, values: {timeElapsed: number, timeElapsedOvershoot: number, bytesDownloaded: number}):\n void {\n const nodeTiming = {\n ...this.getNetworkStarted(node),\n timeElapsed: values.timeElapsed,\n timeElapsedOvershoot: values.timeElapsedOvershoot,\n bytesDownloaded: values.bytesDownloaded,\n };\n\n this._nodeTimings.set(node, nodeTiming);\n }\n\n setNetworkEstimated(node: NetworkNode, values: {estimatedTimeElapsed: number}): void {\n const nodeTiming = {\n ...this.getNetworkStarted(node),\n estimatedTimeElapsed: values.estimatedTimeElapsed,\n };\n\n this._nodeTimings.set(node, nodeTiming);\n }\n\n getQueued(node: Node): NodeTimingData {\n const timing = this._nodeTimings.get(node);\n if (!timing) {\n throw new Error(`Node ${node.id} not yet queued`);\n }\n return timing;\n }\n\n getCpuStarted(node: CPUNode): CpuNodeTimingStarted {\n const timing = this._nodeTimings.get(node);\n if (!timing) {\n throw new Error(`Node ${node.id} not yet queued`);\n }\n if (!('startTime' in timing)) {\n throw new Error(`Node ${node.id} not yet started`);\n }\n if ('bytesDownloaded' in timing) {\n throw new Error(`Node ${node.id} timing not valid`);\n }\n return timing;\n }\n\n getNetworkStarted(node: NetworkNode): NetworkNodeTimingStarted {\n const timing = this._nodeTimings.get(node);\n if (!timing) {\n throw new Error(`Node ${node.id} not yet queued`);\n }\n if (!('startTime' in timing)) {\n throw new Error(`Node ${node.id} not yet started`);\n }\n if (!('bytesDownloaded' in timing)) {\n throw new Error(`Node ${node.id} timing not valid`);\n }\n return timing;\n }\n\n getInProgress(node: Node): CpuNodeTimingInProgress|NetworkNodeTimingInProgress {\n const timing = this._nodeTimings.get(node);\n if (!timing) {\n throw new Error(`Node ${node.id} not yet queued`);\n }\n if (!('startTime' in timing)) {\n throw new Error(`Node ${node.id} not yet started`);\n }\n if (!('estimatedTimeElapsed' in timing)) {\n throw new Error(`Node ${node.id} not yet in progress`);\n }\n return timing;\n }\n\n getCompleted(node: Node): CpuNodeTimingComplete|NetworkNodeTimingComplete {\n const timing = this._nodeTimings.get(node);\n if (!timing) {\n throw new Error(`Node ${node.id} not yet queued`);\n }\n if (!('startTime' in timing)) {\n throw new Error(`Node ${node.id} not yet started`);\n }\n if (!('estimatedTimeElapsed' in timing)) {\n throw new Error(`Node ${node.id} not yet in progress`);\n }\n if (!('endTime' in timing)) {\n throw new Error(`Node ${node.id} not yet completed`);\n }\n return timing;\n }\n}\n\nexport {SimulatorTimingMap};\n"]}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { type Node } from '../BaseNode.js';
|
|
2
|
+
import { type CPUNode } from '../CPUNode.js';
|
|
3
|
+
import { type NetworkNode } from '../NetworkNode.js';
|
|
4
|
+
import type * as Lantern from '../types/lantern.js';
|
|
5
|
+
import { ConnectionPool } from './ConnectionPool.js';
|
|
6
|
+
import { DNSCache } from './DNSCache.js';
|
|
7
|
+
import { type CompleteNodeTiming, type ConnectionTiming, SimulatorTimingMap } from './SimulationTimingMap.js';
|
|
8
|
+
import { TCPConnection } from './TCPConnection.js';
|
|
9
|
+
declare class Simulator<T = Lantern.AnyNetworkObject> {
|
|
10
|
+
static createSimulator(settings: Lantern.Simulation.Settings): Simulator;
|
|
11
|
+
_options: Required<Lantern.Simulation.Options>;
|
|
12
|
+
_rtt: number;
|
|
13
|
+
_throughput: number;
|
|
14
|
+
_maximumConcurrentRequests: number;
|
|
15
|
+
_cpuSlowdownMultiplier: number;
|
|
16
|
+
_layoutTaskMultiplier: number;
|
|
17
|
+
_cachedNodeListByStartPosition: Node[];
|
|
18
|
+
_nodeTimings: SimulatorTimingMap;
|
|
19
|
+
_numberInProgressByType: Map<string, number>;
|
|
20
|
+
_nodes: Record<number, Set<Node>>;
|
|
21
|
+
_dns: DNSCache;
|
|
22
|
+
_connectionPool: ConnectionPool;
|
|
23
|
+
constructor(options?: Lantern.Simulation.Options);
|
|
24
|
+
get rtt(): number;
|
|
25
|
+
_initializeConnectionPool(graph: Node): void;
|
|
26
|
+
/**
|
|
27
|
+
* Initializes the various state data structures such _nodeTimings and the _node Sets by state.
|
|
28
|
+
*/
|
|
29
|
+
_initializeAuxiliaryData(): void;
|
|
30
|
+
_numberInProgress(type: string): number;
|
|
31
|
+
_markNodeAsReadyToStart(node: Node, queuedTime: number): void;
|
|
32
|
+
_markNodeAsInProgress(node: Node, startTime: number): void;
|
|
33
|
+
_markNodeAsComplete(node: Node, endTime: number, connectionTiming?: ConnectionTiming): void;
|
|
34
|
+
_acquireConnection(request: Lantern.NetworkRequest): TCPConnection | null;
|
|
35
|
+
_getNodesSortedByStartPosition(): Node[];
|
|
36
|
+
_startNodeIfPossible(node: Node, totalElapsedTime: number): void;
|
|
37
|
+
/**
|
|
38
|
+
* Updates each connection in use with the available throughput based on the number of network requests
|
|
39
|
+
* currently in flight.
|
|
40
|
+
*/
|
|
41
|
+
_updateNetworkCapacity(): void;
|
|
42
|
+
/**
|
|
43
|
+
* Estimates the number of milliseconds remaining given current condidtions before the node is complete.
|
|
44
|
+
*/
|
|
45
|
+
_estimateTimeRemaining(node: Node): number;
|
|
46
|
+
_estimateCPUTimeRemaining(cpuNode: CPUNode): number;
|
|
47
|
+
_estimateNetworkTimeRemaining(networkNode: NetworkNode): number;
|
|
48
|
+
/**
|
|
49
|
+
* Computes and returns the minimum estimated completion time of the nodes currently in progress.
|
|
50
|
+
*/
|
|
51
|
+
_findNextNodeCompletionTime(): number;
|
|
52
|
+
/**
|
|
53
|
+
* Given a time period, computes the progress toward completion that the node made durin that time.
|
|
54
|
+
*/
|
|
55
|
+
_updateProgressMadeInTimePeriod(node: Node, timePeriodLength: number, totalElapsedTime: number): void;
|
|
56
|
+
_computeFinalNodeTimings(): {
|
|
57
|
+
nodeTimings: Map<Node, Lantern.Simulation.NodeTiming>;
|
|
58
|
+
completeNodeTimings: Map<Node, CompleteNodeTiming>;
|
|
59
|
+
};
|
|
60
|
+
getOptions(): Required<Lantern.Simulation.Options>;
|
|
61
|
+
/**
|
|
62
|
+
* Estimates the time taken to process all of the graph's nodes, returns the overall time along with
|
|
63
|
+
* each node annotated by start/end times.
|
|
64
|
+
*
|
|
65
|
+
* Simulator/connection pool are allowed to deviate from what was
|
|
66
|
+
* observed in the trace/devtoolsLog and start requests as soon as they are queued (i.e. do not
|
|
67
|
+
* wait around for a warm connection to be available if the original request was fetched on a warm
|
|
68
|
+
* connection).
|
|
69
|
+
*/
|
|
70
|
+
simulate(graph: Node, options?: {
|
|
71
|
+
label?: string;
|
|
72
|
+
}): Lantern.Simulation.Result<T>;
|
|
73
|
+
computeWastedMsFromWastedBytes(wastedBytes: number): number;
|
|
74
|
+
static get allNodeTimings(): Map<string, Map<Node, CompleteNodeTiming>>;
|
|
75
|
+
/**
|
|
76
|
+
* We attempt to start nodes by their observed start time using the request priority as a tie breaker.
|
|
77
|
+
* When simulating, just because a low priority image started 5ms before a high priority image doesn't mean
|
|
78
|
+
* it would have happened like that when the network was slower.
|
|
79
|
+
*/
|
|
80
|
+
static _computeNodeStartPosition(node: Node): number;
|
|
81
|
+
}
|
|
82
|
+
export { Simulator };
|