@paulirish/trace_engine 0.0.25 → 0.0.27

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.
Files changed (176) hide show
  1. package/core/platform/TypedArrayUtilities.d.ts +7 -0
  2. package/core/platform/TypedArrayUtilities.js +41 -0
  3. package/core/platform/TypedArrayUtilities.js.map +1 -1
  4. package/core/platform/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  5. package/core/platform/platform-tsconfig.json +0 -1
  6. package/generated/protocol.d.ts +36 -2
  7. package/models/cpu_profile/cpu_profile-tsconfig.json +0 -1
  8. package/models/cpu_profile/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  9. package/models/trace/LanternComputationData.d.ts +8 -0
  10. package/models/trace/LanternComputationData.js +368 -0
  11. package/models/trace/LanternComputationData.js.map +1 -0
  12. package/models/trace/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  13. package/models/trace/extras/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  14. package/models/trace/extras/extras-tsconfig.json +0 -1
  15. package/models/trace/handlers/EnhancedTracesHandler.d.ts +46 -0
  16. package/models/trace/handlers/EnhancedTracesHandler.js +137 -0
  17. package/models/trace/handlers/EnhancedTracesHandler.js.map +1 -0
  18. package/models/trace/handlers/LayoutShiftsHandler.d.ts +1 -1
  19. package/models/trace/handlers/LayoutShiftsHandler.js +1 -1
  20. package/models/trace/handlers/LayoutShiftsHandler.js.map +1 -1
  21. package/models/trace/handlers/ModelHandlers.d.ts +1 -0
  22. package/models/trace/handlers/ModelHandlers.js +1 -0
  23. package/models/trace/handlers/ModelHandlers.js.map +1 -1
  24. package/models/trace/handlers/UserInteractionsHandler.d.ts +6 -0
  25. package/models/trace/handlers/UserInteractionsHandler.js +15 -0
  26. package/models/trace/handlers/UserInteractionsHandler.js.map +1 -1
  27. package/models/trace/handlers/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  28. package/models/trace/handlers/handlers-tsconfig.json +1 -1
  29. package/models/trace/helpers/Timing.d.ts +0 -6
  30. package/models/trace/helpers/Timing.js +0 -76
  31. package/models/trace/helpers/Timing.js.map +1 -1
  32. package/models/trace/helpers/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  33. package/models/trace/helpers/helpers-tsconfig.json +0 -1
  34. package/models/trace/insights/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  35. package/models/trace/insights/insights-tsconfig.json +0 -1
  36. package/models/trace/lantern/BaseNode.d.ts +91 -0
  37. package/models/trace/lantern/BaseNode.js +268 -0
  38. package/models/trace/lantern/BaseNode.js.map +1 -0
  39. package/models/trace/lantern/CPUNode.d.ts +24 -0
  40. package/models/trace/lantern/CPUNode.js +64 -0
  41. package/models/trace/lantern/CPUNode.js.map +1 -0
  42. package/models/trace/lantern/LanternError.d.ts +3 -0
  43. package/models/trace/lantern/LanternError.js +7 -0
  44. package/models/trace/lantern/LanternError.js.map +1 -0
  45. package/models/trace/lantern/MetricsModule.d.ts +11 -0
  46. package/models/trace/lantern/MetricsModule.js +14 -0
  47. package/models/trace/lantern/MetricsModule.js.map +1 -0
  48. package/models/trace/lantern/NetworkNode.d.ts +22 -0
  49. package/models/trace/lantern/NetworkNode.js +83 -0
  50. package/models/trace/lantern/NetworkNode.js.map +1 -0
  51. package/models/trace/lantern/PageDependencyGraph.d.ts +43 -0
  52. package/models/trace/lantern/PageDependencyGraph.js +509 -0
  53. package/models/trace/lantern/PageDependencyGraph.js.map +1 -0
  54. package/models/trace/lantern/SimulationModule.d.ts +17 -0
  55. package/models/trace/lantern/SimulationModule.js +13 -0
  56. package/models/trace/lantern/SimulationModule.js.map +1 -0
  57. package/models/trace/lantern/bundle-tsconfig.json +1 -0
  58. package/models/trace/lantern/core/LanternError.d.ts +3 -0
  59. package/models/trace/lantern/core/LanternError.js +7 -0
  60. package/models/trace/lantern/core/LanternError.js.map +1 -0
  61. package/models/trace/lantern/core/NetworkAnalyzer.d.ts +112 -0
  62. package/models/trace/lantern/core/NetworkAnalyzer.js +486 -0
  63. package/models/trace/lantern/core/NetworkAnalyzer.js.map +1 -0
  64. package/models/trace/lantern/core/bundle-tsconfig.json +1 -0
  65. package/models/trace/lantern/core/core-tsconfig.json +43 -0
  66. package/models/trace/lantern/core/core.d.ts +2 -0
  67. package/models/trace/lantern/core/core.js +6 -0
  68. package/models/trace/lantern/core/core.js.map +1 -0
  69. package/models/trace/lantern/core/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
  70. package/models/trace/lantern/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
  71. package/models/trace/lantern/graph/BaseNode.d.ts +91 -0
  72. package/models/trace/lantern/graph/BaseNode.js +268 -0
  73. package/models/trace/lantern/graph/BaseNode.js.map +1 -0
  74. package/models/trace/lantern/graph/CPUNode.d.ts +24 -0
  75. package/models/trace/lantern/graph/CPUNode.js +64 -0
  76. package/models/trace/lantern/graph/CPUNode.js.map +1 -0
  77. package/models/trace/lantern/graph/NetworkNode.d.ts +22 -0
  78. package/models/trace/lantern/graph/NetworkNode.js +83 -0
  79. package/models/trace/lantern/graph/NetworkNode.js.map +1 -0
  80. package/models/trace/lantern/graph/PageDependencyGraph.d.ts +43 -0
  81. package/models/trace/lantern/graph/PageDependencyGraph.js +509 -0
  82. package/models/trace/lantern/graph/PageDependencyGraph.js.map +1 -0
  83. package/models/trace/lantern/graph/bundle-tsconfig.json +1 -0
  84. package/models/trace/lantern/graph/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
  85. package/models/trace/lantern/graph/graph-tsconfig.json +48 -0
  86. package/models/trace/lantern/graph/graph.d.ts +4 -0
  87. package/models/trace/lantern/graph/graph.js +8 -0
  88. package/models/trace/lantern/graph/graph.js.map +1 -0
  89. package/models/trace/lantern/lantern-tsconfig.json +53 -0
  90. package/models/trace/lantern/lantern.d.ts +6 -0
  91. package/models/trace/lantern/lantern.js +10 -0
  92. package/models/trace/lantern/lantern.js.map +1 -0
  93. package/models/trace/lantern/metrics/FirstContentfulPaint.d.ts +40 -0
  94. package/models/trace/lantern/metrics/FirstContentfulPaint.js +137 -0
  95. package/models/trace/lantern/metrics/FirstContentfulPaint.js.map +1 -0
  96. package/models/trace/lantern/metrics/Interactive.d.ts +12 -0
  97. package/models/trace/lantern/metrics/Interactive.js +67 -0
  98. package/models/trace/lantern/metrics/Interactive.js.map +1 -0
  99. package/models/trace/lantern/metrics/LargestContentfulPaint.d.ts +17 -0
  100. package/models/trace/lantern/metrics/LargestContentfulPaint.js +69 -0
  101. package/models/trace/lantern/metrics/LargestContentfulPaint.js.map +1 -0
  102. package/models/trace/lantern/metrics/MaxPotentialFID.d.ts +14 -0
  103. package/models/trace/lantern/metrics/MaxPotentialFID.js +48 -0
  104. package/models/trace/lantern/metrics/MaxPotentialFID.js.map +1 -0
  105. package/models/trace/lantern/metrics/Metric.d.ts +44 -0
  106. package/models/trace/lantern/metrics/Metric.js +70 -0
  107. package/models/trace/lantern/metrics/Metric.js.map +1 -0
  108. package/models/trace/lantern/metrics/SpeedIndex.d.ts +25 -0
  109. package/models/trace/lantern/metrics/SpeedIndex.js +101 -0
  110. package/models/trace/lantern/metrics/SpeedIndex.js.map +1 -0
  111. package/models/trace/lantern/metrics/TBTUtils.d.ts +31 -0
  112. package/models/trace/lantern/metrics/TBTUtils.js +65 -0
  113. package/models/trace/lantern/metrics/TBTUtils.js.map +1 -0
  114. package/models/trace/lantern/metrics/TotalBlockingTime.d.ts +16 -0
  115. package/models/trace/lantern/metrics/TotalBlockingTime.js +78 -0
  116. package/models/trace/lantern/metrics/TotalBlockingTime.js.map +1 -0
  117. package/models/trace/lantern/metrics/bundle-tsconfig.json +1 -0
  118. package/models/trace/lantern/metrics/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
  119. package/models/trace/lantern/metrics/metrics-tsconfig.json +58 -0
  120. package/models/trace/lantern/metrics/metrics.d.ts +8 -0
  121. package/models/trace/lantern/metrics/metrics.js +12 -0
  122. package/models/trace/lantern/metrics/metrics.js.map +1 -0
  123. package/models/trace/lantern/simulation/ConnectionPool.d.ts +26 -0
  124. package/models/trace/lantern/simulation/ConnectionPool.js +116 -0
  125. package/models/trace/lantern/simulation/ConnectionPool.js.map +1 -0
  126. package/models/trace/lantern/simulation/Constants.d.ts +31 -0
  127. package/models/trace/lantern/simulation/Constants.js +43 -0
  128. package/models/trace/lantern/simulation/Constants.js.map +1 -0
  129. package/models/trace/lantern/simulation/DNSCache.d.ts +22 -0
  130. package/models/trace/lantern/simulation/DNSCache.js +48 -0
  131. package/models/trace/lantern/simulation/DNSCache.js.map +1 -0
  132. package/models/trace/lantern/simulation/NetworkAnalyzer.d.ts +112 -0
  133. package/models/trace/lantern/simulation/NetworkAnalyzer.js +486 -0
  134. package/models/trace/lantern/simulation/NetworkAnalyzer.js.map +1 -0
  135. package/models/trace/lantern/simulation/SimulationTimingMap.d.ts +69 -0
  136. package/models/trace/lantern/simulation/SimulationTimingMap.js +134 -0
  137. package/models/trace/lantern/simulation/SimulationTimingMap.js.map +1 -0
  138. package/models/trace/lantern/simulation/Simulator.d.ts +84 -0
  139. package/models/trace/lantern/simulation/Simulator.js +449 -0
  140. package/models/trace/lantern/simulation/Simulator.js.map +1 -0
  141. package/models/trace/lantern/simulation/TCPConnection.d.ts +48 -0
  142. package/models/trace/lantern/simulation/TCPConnection.js +158 -0
  143. package/models/trace/lantern/simulation/TCPConnection.js.map +1 -0
  144. package/models/trace/lantern/simulation/bundle-tsconfig.json +1 -0
  145. package/models/trace/lantern/simulation/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
  146. package/models/trace/lantern/simulation/simulation-tsconfig.json +50 -0
  147. package/models/trace/lantern/simulation/simulation.d.ts +6 -0
  148. package/models/trace/lantern/simulation/simulation.js +10 -0
  149. package/models/trace/lantern/simulation/simulation.js.map +1 -0
  150. package/models/trace/lantern/types/bundle-tsconfig.json +1 -0
  151. package/models/trace/lantern/types/devtools_entrypoint-bundle-typescript-tsconfig.json +42 -0
  152. package/models/trace/lantern/types/lantern.d.ts +199 -0
  153. package/models/trace/lantern/types/lantern.js +24 -0
  154. package/models/trace/lantern/types/lantern.js.map +1 -0
  155. package/models/trace/lantern/types/types-tsconfig.json +42 -0
  156. package/models/trace/lantern/types/types.d.ts +1 -0
  157. package/models/trace/lantern/types/types.js +5 -0
  158. package/models/trace/lantern/types/types.js.map +1 -0
  159. package/models/trace/root-causes/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  160. package/models/trace/root-causes/root-causes-tsconfig.json +0 -1
  161. package/models/trace/trace-tsconfig.json +4 -1
  162. package/models/trace/trace.d.ts +3 -1
  163. package/models/trace/trace.js +3 -1
  164. package/models/trace/trace.js.map +1 -1
  165. package/models/trace/types/Extensions.d.ts +2 -3
  166. package/models/trace/types/Extensions.js +2 -11
  167. package/models/trace/types/Extensions.js.map +1 -1
  168. package/models/trace/types/File.d.ts +1 -0
  169. package/models/trace/types/File.js.map +1 -1
  170. package/models/trace/types/TraceEvents.d.ts +49 -0
  171. package/models/trace/types/TraceEvents.js +33 -0
  172. package/models/trace/types/TraceEvents.js.map +1 -1
  173. package/models/trace/types/devtools_entrypoint-bundle-typescript-tsconfig.json +0 -1
  174. package/models/trace/types/types-tsconfig.json +0 -1
  175. package/package.json +1 -1
  176. package/PAUL.readme.md +0 -5
@@ -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 * as Graph from '../graph/graph.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 === Graph.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 * as Graph from '../graph/graph.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<Graph.Node, NodeTimingData>;\n\n constructor() {\n this._nodeTimings = new Map<Graph.Node, NodeTimingData>();\n }\n\n getNodes(): Graph.Node[] {\n return Array.from(this._nodeTimings.keys());\n }\n\n setReadyToStart(node: Graph.Node, values: {queuedTime: number}): void {\n this._nodeTimings.set(node, values);\n }\n\n setInProgress(node: Graph.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 === Graph.BaseNode.types.NETWORK ? {...nodeTiming, timeElapsedOvershoot: 0, bytesDownloaded: 0} :\n nodeTiming,\n );\n }\n\n setCompleted(node: Graph.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: Graph.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: Graph.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(\n node: Graph.NetworkNode,\n values: {timeElapsed: number, timeElapsedOvershoot: number, bytesDownloaded: number}): 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: Graph.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: Graph.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: Graph.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: Graph.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: Graph.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: Graph.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,84 @@
1
+ import * as Graph from '../graph/graph.js';
2
+ import type * as Lantern from '../types/types.js';
3
+ import { ConnectionPool } from './ConnectionPool.js';
4
+ import { DNSCache } from './DNSCache.js';
5
+ import { type CompleteNodeTiming, type ConnectionTiming, SimulatorTimingMap } from './SimulationTimingMap.js';
6
+ import { TCPConnection } from './TCPConnection.js';
7
+ export interface Result<T = Lantern.AnyNetworkObject> {
8
+ timeInMs: number;
9
+ nodeTimings: Map<Graph.Node<T>, Lantern.Simulation.NodeTiming>;
10
+ }
11
+ declare class Simulator<T = Lantern.AnyNetworkObject> {
12
+ static createSimulator(settings: Lantern.Simulation.Settings): Simulator;
13
+ _options: Required<Lantern.Simulation.Options>;
14
+ _rtt: number;
15
+ _throughput: number;
16
+ _maximumConcurrentRequests: number;
17
+ _cpuSlowdownMultiplier: number;
18
+ _layoutTaskMultiplier: number;
19
+ _cachedNodeListByStartPosition: Graph.Node[];
20
+ _nodeTimings: SimulatorTimingMap;
21
+ _numberInProgressByType: Map<string, number>;
22
+ _nodes: Record<number, Set<Graph.Node>>;
23
+ _dns: DNSCache;
24
+ _connectionPool: ConnectionPool;
25
+ constructor(options?: Lantern.Simulation.Options);
26
+ get rtt(): number;
27
+ _initializeConnectionPool(graph: Graph.Node): void;
28
+ /**
29
+ * Initializes the various state data structures such _nodeTimings and the _node Sets by state.
30
+ */
31
+ _initializeAuxiliaryData(): void;
32
+ _numberInProgress(type: string): number;
33
+ _markNodeAsReadyToStart(node: Graph.Node, queuedTime: number): void;
34
+ _markNodeAsInProgress(node: Graph.Node, startTime: number): void;
35
+ _markNodeAsComplete(node: Graph.Node, endTime: number, connectionTiming?: ConnectionTiming): void;
36
+ _acquireConnection(request: Lantern.NetworkRequest): TCPConnection | null;
37
+ _getNodesSortedByStartPosition(): Graph.Node[];
38
+ _startNodeIfPossible(node: Graph.Node, totalElapsedTime: number): void;
39
+ /**
40
+ * Updates each connection in use with the available throughput based on the number of network requests
41
+ * currently in flight.
42
+ */
43
+ _updateNetworkCapacity(): void;
44
+ /**
45
+ * Estimates the number of milliseconds remaining given current condidtions before the node is complete.
46
+ */
47
+ _estimateTimeRemaining(node: Graph.Node): number;
48
+ _estimateCPUTimeRemaining(cpuNode: Graph.CPUNode): number;
49
+ _estimateNetworkTimeRemaining(networkNode: Graph.NetworkNode): number;
50
+ /**
51
+ * Computes and returns the minimum estimated completion time of the nodes currently in progress.
52
+ */
53
+ _findNextNodeCompletionTime(): number;
54
+ /**
55
+ * Given a time period, computes the progress toward completion that the node made durin that time.
56
+ */
57
+ _updateProgressMadeInTimePeriod(node: Graph.Node, timePeriodLength: number, totalElapsedTime: number): void;
58
+ _computeFinalNodeTimings(): {
59
+ nodeTimings: Map<Graph.Node, Lantern.Simulation.NodeTiming>;
60
+ completeNodeTimings: Map<Graph.Node, CompleteNodeTiming>;
61
+ };
62
+ getOptions(): Required<Lantern.Simulation.Options>;
63
+ /**
64
+ * Estimates the time taken to process all of the graph's nodes, returns the overall time along with
65
+ * each node annotated by start/end times.
66
+ *
67
+ * Simulator/connection pool are allowed to deviate from what was
68
+ * observed in the trace/devtoolsLog and start requests as soon as they are queued (i.e. do not
69
+ * wait around for a warm connection to be available if the original request was fetched on a warm
70
+ * connection).
71
+ */
72
+ simulate(graph: Graph.Node, options?: {
73
+ label?: string;
74
+ }): Result<T>;
75
+ computeWastedMsFromWastedBytes(wastedBytes: number): number;
76
+ static get allNodeTimings(): Map<string, Map<Graph.Node, CompleteNodeTiming>>;
77
+ /**
78
+ * We attempt to start nodes by their observed start time using the request priority as a tie breaker.
79
+ * When simulating, just because a low priority image started 5ms before a high priority image doesn't mean
80
+ * it would have happened like that when the network was slower.
81
+ */
82
+ static _computeNodeStartPosition(node: Graph.Node): number;
83
+ }
84
+ export { Simulator };