@aztec/ethereum 0.0.0-test.0 → 0.0.1-commit.03f7ef2

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 (272) hide show
  1. package/dest/account.d.ts +2 -0
  2. package/dest/account.d.ts.map +1 -0
  3. package/dest/account.js +4 -0
  4. package/dest/chain.d.ts +1 -1
  5. package/dest/client.d.ts +6 -4
  6. package/dest/client.d.ts.map +1 -1
  7. package/dest/client.js +21 -3
  8. package/dest/config.d.ts +71 -16
  9. package/dest/config.d.ts.map +1 -1
  10. package/dest/config.js +138 -22
  11. package/dest/constants.d.ts +1 -1
  12. package/dest/contracts/empire_base.d.ts +25 -8
  13. package/dest/contracts/empire_base.d.ts.map +1 -1
  14. package/dest/contracts/empire_base.js +75 -2
  15. package/dest/contracts/empire_slashing_proposer.d.ts +67 -0
  16. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -0
  17. package/dest/contracts/empire_slashing_proposer.js +209 -0
  18. package/dest/contracts/errors.d.ts +7 -0
  19. package/dest/contracts/errors.d.ts.map +1 -0
  20. package/dest/contracts/errors.js +12 -0
  21. package/dest/contracts/fee_asset_handler.d.ts +19 -0
  22. package/dest/contracts/fee_asset_handler.d.ts.map +1 -0
  23. package/dest/contracts/fee_asset_handler.js +57 -0
  24. package/dest/contracts/fee_juice.d.ts +6 -7
  25. package/dest/contracts/fee_juice.d.ts.map +1 -1
  26. package/dest/contracts/fee_juice.js +27 -20
  27. package/dest/contracts/governance.d.ts +43 -32
  28. package/dest/contracts/governance.d.ts.map +1 -1
  29. package/dest/contracts/governance.js +87 -84
  30. package/dest/contracts/governance_proposer.d.ts +17 -13
  31. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  32. package/dest/contracts/governance_proposer.js +46 -17
  33. package/dest/contracts/gse.d.ts +32 -0
  34. package/dest/contracts/gse.d.ts.map +1 -0
  35. package/dest/contracts/gse.js +72 -0
  36. package/dest/contracts/inbox.d.ts +26 -0
  37. package/dest/contracts/inbox.d.ts.map +1 -0
  38. package/dest/contracts/inbox.js +45 -0
  39. package/dest/contracts/index.d.ts +9 -3
  40. package/dest/contracts/index.d.ts.map +1 -1
  41. package/dest/contracts/index.js +8 -2
  42. package/dest/contracts/multicall.d.ts +21 -0
  43. package/dest/contracts/multicall.d.ts.map +1 -0
  44. package/dest/contracts/multicall.js +156 -0
  45. package/dest/contracts/registry.d.ts +10 -5
  46. package/dest/contracts/registry.d.ts.map +1 -1
  47. package/dest/contracts/registry.js +44 -16
  48. package/dest/contracts/rollup.d.ts +221 -41
  49. package/dest/contracts/rollup.d.ts.map +1 -1
  50. package/dest/contracts/rollup.js +549 -81
  51. package/dest/contracts/slasher_contract.d.ts +44 -0
  52. package/dest/contracts/slasher_contract.d.ts.map +1 -0
  53. package/dest/contracts/slasher_contract.js +75 -0
  54. package/dest/contracts/tally_slashing_proposer.d.ts +140 -0
  55. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -0
  56. package/dest/contracts/tally_slashing_proposer.js +313 -0
  57. package/dest/contracts/utils.d.ts +3 -0
  58. package/dest/contracts/utils.d.ts.map +1 -0
  59. package/dest/contracts/utils.js +11 -0
  60. package/dest/deploy_aztec_l1_contracts.d.ts +245 -0
  61. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  62. package/dest/deploy_aztec_l1_contracts.js +335 -0
  63. package/dest/deploy_l1_contract.d.ts +68 -0
  64. package/dest/deploy_l1_contract.d.ts.map +1 -0
  65. package/dest/deploy_l1_contract.js +312 -0
  66. package/dest/eth-signer/eth-signer.d.ts +21 -0
  67. package/dest/eth-signer/eth-signer.d.ts.map +1 -0
  68. package/dest/eth-signer/eth-signer.js +5 -0
  69. package/dest/eth-signer/index.d.ts +2 -0
  70. package/dest/eth-signer/index.d.ts.map +1 -0
  71. package/dest/eth-signer/index.js +1 -0
  72. package/dest/forwarder_proxy.d.ts +32 -0
  73. package/dest/forwarder_proxy.d.ts.map +1 -0
  74. package/dest/forwarder_proxy.js +93 -0
  75. package/dest/l1_artifacts.d.ts +77364 -0
  76. package/dest/l1_artifacts.d.ts.map +1 -0
  77. package/dest/l1_artifacts.js +166 -0
  78. package/dest/l1_contract_addresses.d.ts +24 -4
  79. package/dest/l1_contract_addresses.d.ts.map +1 -1
  80. package/dest/l1_contract_addresses.js +25 -21
  81. package/dest/l1_reader.d.ts +4 -2
  82. package/dest/l1_reader.d.ts.map +1 -1
  83. package/dest/l1_reader.js +14 -8
  84. package/dest/l1_tx_utils/config.d.ts +59 -0
  85. package/dest/l1_tx_utils/config.d.ts.map +1 -0
  86. package/dest/l1_tx_utils/config.js +96 -0
  87. package/dest/l1_tx_utils/constants.d.ts +12 -0
  88. package/dest/l1_tx_utils/constants.d.ts.map +1 -0
  89. package/dest/l1_tx_utils/constants.js +39 -0
  90. package/dest/l1_tx_utils/factory.d.ts +24 -0
  91. package/dest/l1_tx_utils/factory.d.ts.map +1 -0
  92. package/dest/l1_tx_utils/factory.js +12 -0
  93. package/dest/l1_tx_utils/fee-strategies/index.d.ts +9 -0
  94. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  95. package/dest/l1_tx_utils/fee-strategies/index.js +11 -0
  96. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +18 -0
  97. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  98. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +111 -0
  99. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +32 -0
  100. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  101. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +173 -0
  102. package/dest/l1_tx_utils/fee-strategies/types.d.ts +64 -0
  103. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  104. package/dest/l1_tx_utils/fee-strategies/types.js +24 -0
  105. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  106. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  107. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
  108. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  109. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  110. package/dest/l1_tx_utils/index-blobs.js +2 -0
  111. package/dest/l1_tx_utils/index.d.ts +12 -0
  112. package/dest/l1_tx_utils/index.d.ts.map +1 -0
  113. package/dest/l1_tx_utils/index.js +12 -0
  114. package/dest/l1_tx_utils/interfaces.d.ts +76 -0
  115. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -0
  116. package/dest/l1_tx_utils/interfaces.js +4 -0
  117. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  118. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  119. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  120. package/dest/l1_tx_utils/l1_tx_utils.d.ts +94 -0
  121. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -0
  122. package/dest/l1_tx_utils/l1_tx_utils.js +623 -0
  123. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +26 -0
  124. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -0
  125. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +26 -0
  126. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +87 -0
  127. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -0
  128. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +360 -0
  129. package/dest/l1_tx_utils/signer.d.ts +4 -0
  130. package/dest/l1_tx_utils/signer.d.ts.map +1 -0
  131. package/dest/l1_tx_utils/signer.js +16 -0
  132. package/dest/l1_tx_utils/types.d.ts +67 -0
  133. package/dest/l1_tx_utils/types.d.ts.map +1 -0
  134. package/dest/l1_tx_utils/types.js +26 -0
  135. package/dest/l1_tx_utils/utils.d.ts +4 -0
  136. package/dest/l1_tx_utils/utils.d.ts.map +1 -0
  137. package/dest/l1_tx_utils/utils.js +14 -0
  138. package/dest/l1_types.d.ts +6 -0
  139. package/dest/l1_types.d.ts.map +1 -0
  140. package/dest/l1_types.js +1 -0
  141. package/dest/publisher_manager.d.ts +15 -0
  142. package/dest/publisher_manager.d.ts.map +1 -0
  143. package/dest/publisher_manager.js +88 -0
  144. package/dest/queries.d.ts +4 -2
  145. package/dest/queries.d.ts.map +1 -1
  146. package/dest/queries.js +53 -12
  147. package/dest/test/chain_monitor.d.ts +75 -0
  148. package/dest/test/chain_monitor.d.ts.map +1 -0
  149. package/dest/test/chain_monitor.js +214 -0
  150. package/dest/test/delayed_tx_utils.d.ts +8 -3
  151. package/dest/test/delayed_tx_utils.d.ts.map +1 -1
  152. package/dest/test/delayed_tx_utils.js +13 -6
  153. package/dest/test/eth_cheat_codes.d.ts +217 -0
  154. package/dest/test/eth_cheat_codes.d.ts.map +1 -0
  155. package/dest/test/eth_cheat_codes.js +560 -0
  156. package/dest/test/eth_cheat_codes_with_state.d.ts +2 -2
  157. package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
  158. package/dest/test/eth_cheat_codes_with_state.js +1 -1
  159. package/dest/test/index.d.ts +4 -1
  160. package/dest/test/index.d.ts.map +1 -1
  161. package/dest/test/index.js +3 -0
  162. package/dest/test/rollup_cheat_codes.d.ts +87 -0
  163. package/dest/test/rollup_cheat_codes.d.ts.map +1 -0
  164. package/dest/test/rollup_cheat_codes.js +275 -0
  165. package/dest/test/start_anvil.d.ts +9 -1
  166. package/dest/test/start_anvil.d.ts.map +1 -1
  167. package/dest/test/start_anvil.js +16 -7
  168. package/dest/test/tx_delayer.d.ts +18 -7
  169. package/dest/test/tx_delayer.d.ts.map +1 -1
  170. package/dest/test/tx_delayer.js +97 -20
  171. package/dest/test/upgrade_utils.d.ts +6 -5
  172. package/dest/test/upgrade_utils.d.ts.map +1 -1
  173. package/dest/test/upgrade_utils.js +23 -16
  174. package/dest/types.d.ts +62 -8
  175. package/dest/types.d.ts.map +1 -1
  176. package/dest/types.js +3 -1
  177. package/dest/utils.d.ts +16 -3
  178. package/dest/utils.d.ts.map +1 -1
  179. package/dest/utils.js +61 -88
  180. package/dest/zkPassportVerifierAddress.d.ts +15 -0
  181. package/dest/zkPassportVerifierAddress.d.ts.map +1 -0
  182. package/dest/zkPassportVerifierAddress.js +11 -0
  183. package/package.json +50 -23
  184. package/src/account.ts +5 -0
  185. package/src/client.ts +43 -5
  186. package/src/config.ts +188 -31
  187. package/src/contracts/empire_base.ts +77 -7
  188. package/src/contracts/empire_slashing_proposer.ts +270 -0
  189. package/src/contracts/errors.ts +13 -0
  190. package/src/contracts/fee_asset_handler.ts +63 -0
  191. package/src/contracts/fee_juice.ts +29 -15
  192. package/src/contracts/governance.ts +80 -77
  193. package/src/contracts/governance_proposer.ts +71 -24
  194. package/src/contracts/gse.ts +88 -0
  195. package/src/contracts/inbox.ts +63 -0
  196. package/src/contracts/index.ts +8 -2
  197. package/src/contracts/multicall.ts +155 -0
  198. package/src/contracts/registry.ts +51 -26
  199. package/src/contracts/rollup.ts +624 -78
  200. package/src/contracts/slasher_contract.ts +89 -0
  201. package/src/contracts/tally_slashing_proposer.ts +318 -0
  202. package/src/contracts/utils.ts +14 -0
  203. package/src/deploy_aztec_l1_contracts.ts +556 -0
  204. package/src/deploy_l1_contract.ts +362 -0
  205. package/src/eth-signer/eth-signer.ts +25 -0
  206. package/src/eth-signer/index.ts +1 -0
  207. package/src/forwarder_proxy.ts +108 -0
  208. package/src/l1_artifacts.ts +254 -0
  209. package/src/l1_contract_addresses.ts +49 -34
  210. package/src/l1_reader.ts +17 -9
  211. package/src/l1_tx_utils/README.md +177 -0
  212. package/src/l1_tx_utils/config.ts +161 -0
  213. package/src/l1_tx_utils/constants.ts +29 -0
  214. package/src/l1_tx_utils/factory.ts +64 -0
  215. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  216. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +159 -0
  217. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +241 -0
  218. package/src/l1_tx_utils/fee-strategies/types.ts +88 -0
  219. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
  220. package/src/l1_tx_utils/index-blobs.ts +2 -0
  221. package/src/l1_tx_utils/index.ts +14 -0
  222. package/src/l1_tx_utils/interfaces.ts +86 -0
  223. package/src/l1_tx_utils/l1_fee_analyzer.ts +804 -0
  224. package/src/l1_tx_utils/l1_tx_utils.ts +738 -0
  225. package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +77 -0
  226. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +458 -0
  227. package/src/l1_tx_utils/signer.ts +28 -0
  228. package/src/l1_tx_utils/types.ts +85 -0
  229. package/src/l1_tx_utils/utils.ts +16 -0
  230. package/src/l1_types.ts +6 -0
  231. package/src/publisher_manager.ts +106 -0
  232. package/src/queries.ts +73 -15
  233. package/src/test/chain_monitor.ts +245 -0
  234. package/src/test/delayed_tx_utils.ts +34 -6
  235. package/src/test/eth_cheat_codes.ts +588 -0
  236. package/src/test/eth_cheat_codes_with_state.ts +1 -1
  237. package/src/test/index.ts +3 -0
  238. package/src/test/rollup_cheat_codes.ts +312 -0
  239. package/src/test/start_anvil.ts +24 -5
  240. package/src/test/tx_delayer.ts +130 -27
  241. package/src/test/upgrade_utils.ts +30 -21
  242. package/src/types.ts +71 -7
  243. package/src/utils.ts +79 -91
  244. package/src/zkPassportVerifierAddress.ts +15 -0
  245. package/dest/contracts/forwarder.d.ts +0 -24
  246. package/dest/contracts/forwarder.d.ts.map +0 -1
  247. package/dest/contracts/forwarder.js +0 -101
  248. package/dest/contracts/slashing_proposer.d.ts +0 -21
  249. package/dest/contracts/slashing_proposer.d.ts.map +0 -1
  250. package/dest/contracts/slashing_proposer.js +0 -47
  251. package/dest/deploy_l1_contracts.d.ts +0 -21210
  252. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  253. package/dest/deploy_l1_contracts.js +0 -687
  254. package/dest/eth_cheat_codes.d.ts +0 -147
  255. package/dest/eth_cheat_codes.d.ts.map +0 -1
  256. package/dest/eth_cheat_codes.js +0 -303
  257. package/dest/index.d.ts +0 -14
  258. package/dest/index.d.ts.map +0 -1
  259. package/dest/index.js +0 -13
  260. package/dest/l1_tx_utils.d.ts +0 -192
  261. package/dest/l1_tx_utils.d.ts.map +0 -1
  262. package/dest/l1_tx_utils.js +0 -641
  263. package/dest/l1_tx_utils_with_blobs.d.ts +0 -12
  264. package/dest/l1_tx_utils_with_blobs.d.ts.map +0 -1
  265. package/dest/l1_tx_utils_with_blobs.js +0 -64
  266. package/src/contracts/forwarder.ts +0 -132
  267. package/src/contracts/slashing_proposer.ts +0 -51
  268. package/src/deploy_l1_contracts.ts +0 -948
  269. package/src/eth_cheat_codes.ts +0 -314
  270. package/src/index.ts +0 -13
  271. package/src/l1_tx_utils.ts +0 -847
  272. package/src/l1_tx_utils_with_blobs.ts +0 -86
@@ -0,0 +1,87 @@
1
+ import type { L1ContractAddresses } from '@aztec/ethereum/l1-contract-addresses';
2
+ import type { ViemPublicClient } from '@aztec/ethereum/types';
3
+ import { CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
4
+ import type { DateProvider } from '@aztec/foundation/timer';
5
+ import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
6
+ import { type GetContractReturnType, type Hex } from 'viem';
7
+ import { EthCheatCodes } from './eth_cheat_codes.js';
8
+ /** Cheat codes for the L1 rollup contract. */
9
+ export declare class RollupCheatCodes {
10
+ private ethCheatCodes;
11
+ private client;
12
+ private rollup;
13
+ private logger;
14
+ constructor(ethCheatCodes: EthCheatCodes, addresses: Pick<L1ContractAddresses, 'rollupAddress'>);
15
+ static create(rpcUrls: string[], addresses: Pick<L1ContractAddresses, 'rollupAddress'>, dateProvider: DateProvider): RollupCheatCodes;
16
+ /** Returns the current slot */
17
+ getSlot(): Promise<SlotNumber>;
18
+ /** Returns the current epoch */
19
+ getEpoch(): Promise<EpochNumber>;
20
+ /**
21
+ * Returns the pending and proven chain tips
22
+ * @returns The pending and proven chain tips
23
+ */
24
+ getTips(): Promise<{
25
+ /** The pending chain tip */ pending: CheckpointNumber;
26
+ /** The proven chain tip */ proven: CheckpointNumber;
27
+ }>;
28
+ /**
29
+ * Logs the current state of the rollup contract.
30
+ */
31
+ debugRollup(): Promise<void>;
32
+ /** Fetches the epoch and slot duration config from the rollup contract */
33
+ getConfig(): Promise<{
34
+ /** Epoch duration */ epochDuration: bigint;
35
+ /** Slot duration */ slotDuration: number;
36
+ }>;
37
+ /**
38
+ * Advances time to the beginning of the given epoch
39
+ * @param epoch - The epoch to advance to
40
+ * @param opts - Options
41
+ */
42
+ advanceToEpoch(epoch: EpochNumber, opts?: {
43
+ /** Offset in seconds */
44
+ offset?: number;
45
+ }): Promise<bigint>;
46
+ /** Warps time in L1 until the next epoch */
47
+ advanceToNextEpoch(): Promise<void>;
48
+ /** Warps time in L1 until the beginning of the next slot. */
49
+ advanceToNextSlot(): Promise<(bigint | SlotNumber)[]>;
50
+ /**
51
+ * Warps time in L1 equivalent to however many slots.
52
+ * @param howMany - The number of slots to advance.
53
+ */
54
+ advanceSlots(howMany: number): Promise<void>;
55
+ /**
56
+ * Marks the specified checkpoint (or latest if none) as proven
57
+ * @param maybeCheckpointNumber - The checkpoint number to mark as proven (defaults to latest pending)
58
+ */
59
+ markAsProven(maybeCheckpointNumber?: number | bigint): Promise<void>;
60
+ /**
61
+ * Overrides the inProgress field of the Inbox contract state
62
+ * @param howMuch - How many checkpoints to move it forward
63
+ */
64
+ advanceInboxInProgress(howMuch: number | bigint): Promise<bigint>;
65
+ /**
66
+ * Executes an action impersonated as the owner of the Rollup contract.
67
+ * @param action - The action to execute
68
+ */
69
+ asOwner(action: (owner: Hex, rollup: GetContractReturnType<typeof RollupAbi, ViemPublicClient>) => Promise<void>): Promise<void>;
70
+ /**
71
+ * Sets up the epoch.
72
+ */
73
+ setupEpoch(): Promise<void>;
74
+ /** Directly calls the L1 gas fee oracle. */
75
+ updateL1GasFeeOracle(): Promise<void>;
76
+ /**
77
+ * Bumps proving cost per mana.
78
+ * @param bumper - Callback to calculate the new proving cost per mana based on current value.
79
+ */
80
+ bumpProvingCostPerMana(bumper: (before: bigint) => bigint): Promise<void>;
81
+ /**
82
+ * Directly updates proving cost per mana.
83
+ * @param ethValue - The new proving cost per mana in ETH
84
+ */
85
+ setProvingCostPerMana(ethValue: bigint): Promise<void>;
86
+ }
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sbHVwX2NoZWF0X2NvZGVzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC9yb2xsdXBfY2hlYXRfY29kZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNqRixPQUFPLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzlELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFHNUYsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBRTFELE9BQU8sRUFDTCxLQUFLLHFCQUFxQixFQUMxQixLQUFLLEdBQUcsRUFNVCxNQUFNLE1BQU0sQ0FBQztBQUVkLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUVyRCw4Q0FBOEM7QUFDOUMscUJBQWEsZ0JBQWdCO0lBT3pCLE9BQU8sQ0FBQyxhQUFhO0lBTnZCLE9BQU8sQ0FBQyxNQUFNLENBQW1CO0lBQ2pDLE9BQU8sQ0FBQyxNQUFNLENBQTREO0lBRTFFLE9BQU8sQ0FBQyxNQUFNLENBQXVDO0lBRXJELFlBQ1UsYUFBYSxFQUFFLGFBQWEsRUFDcEMsU0FBUyxFQUFFLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxlQUFlLENBQUMsRUFXdEQ7SUFFRCxNQUFNLENBQUMsTUFBTSxDQUNYLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFDakIsU0FBUyxFQUFFLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxlQUFlLENBQUMsRUFDckQsWUFBWSxFQUFFLFlBQVksR0FDekIsZ0JBQWdCLENBR2xCO0lBRUQsK0JBQStCO0lBQ2xCLE9BQU8sSUFBSSxPQUFPLENBQUMsVUFBVSxDQUFDLENBRzFDO0lBRUQsZ0NBQWdDO0lBQ25CLFFBQVEsSUFBSSxPQUFPLENBQUMsV0FBVyxDQUFDLENBRzVDO0lBRUQ7OztPQUdHO0lBQ1UsT0FBTyxJQUFJLE9BQU8sQ0FBQztRQUM5Qiw0QkFBNEIsQ0FBQyxPQUFPLEVBQUUsZ0JBQWdCLENBQUM7UUFDdkQsMkJBQTJCLENBQUMsTUFBTSxFQUFFLGdCQUFnQixDQUFDO0tBQ3RELENBQUMsQ0FNRDtJQUVEOztPQUVHO0lBQ1UsV0FBVyxrQkFpQnZCO0lBRUQsMEVBQTBFO0lBQzdELFNBQVMsSUFBSSxPQUFPLENBQUM7UUFDaEMscUJBQXFCLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQztRQUM1QyxvQkFBb0IsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDO0tBQzNDLENBQUMsQ0FNRDtJQUVEOzs7O09BSUc7SUFDVSxjQUFjLENBQ3pCLEtBQUssRUFBRSxXQUFXLEVBQ2xCLElBQUksR0FBRTtRQUNKLHdCQUF3QjtRQUN4QixNQUFNLENBQUMsRUFBRSxNQUFNLENBQUM7S0FDWixtQkFZUDtJQUVELDRDQUE0QztJQUMvQixrQkFBa0Isa0JBVzlCO0lBRUQsNkRBQTZEO0lBQ2hELGlCQUFpQixxQ0FPN0I7SUFFRDs7O09BR0c7SUFDVSxZQUFZLENBQUMsT0FBTyxFQUFFLE1BQU0saUJBT3hDO0lBRUQ7OztPQUdHO0lBQ0ksWUFBWSxDQUFDLHFCQUFxQixDQUFDLEVBQUUsTUFBTSxHQUFHLE1BQU0saUJBK0IxRDtJQUVEOzs7T0FHRztJQUNJLHNCQUFzQixDQUFDLE9BQU8sRUFBRSxNQUFNLEdBQUcsTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FtQ3ZFO0lBRUQ7OztPQUdHO0lBQ1UsT0FBTyxDQUNsQixNQUFNLEVBQUUsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFLE1BQU0sRUFBRSxxQkFBcUIsQ0FBQyxPQUFPLFNBQVMsRUFBRSxnQkFBZ0IsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxJQUFJLENBQUMsaUJBTXpHO0lBRUQ7O09BRUc7SUFDVSxVQUFVLGtCQU90QjtJQUVELDRDQUE0QztJQUMvQixvQkFBb0Isa0JBTWhDO0lBRUQ7OztPQUdHO0lBQ1Usc0JBQXNCLENBQUMsTUFBTSxFQUFFLENBQUMsTUFBTSxFQUFFLE1BQU0sS0FBSyxNQUFNLGlCQUlyRTtJQUVEOzs7T0FHRztJQUNVLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxNQUFNLGlCQVVsRDtDQUNGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rollup_cheat_codes.d.ts","sourceRoot":"","sources":["../../src/test/rollup_cheat_codes.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAG5F,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAE1D,OAAO,EACL,KAAK,qBAAqB,EAC1B,KAAK,GAAG,EAMT,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,8CAA8C;AAC9C,qBAAa,gBAAgB;IAOzB,OAAO,CAAC,aAAa;IANvB,OAAO,CAAC,MAAM,CAAmB;IACjC,OAAO,CAAC,MAAM,CAA4D;IAE1E,OAAO,CAAC,MAAM,CAAuC;IAErD,YACU,aAAa,EAAE,aAAa,EACpC,SAAS,EAAE,IAAI,CAAC,mBAAmB,EAAE,eAAe,CAAC,EAWtD;IAED,MAAM,CAAC,MAAM,CACX,OAAO,EAAE,MAAM,EAAE,EACjB,SAAS,EAAE,IAAI,CAAC,mBAAmB,EAAE,eAAe,CAAC,EACrD,YAAY,EAAE,YAAY,GACzB,gBAAgB,CAGlB;IAED,+BAA+B;IAClB,OAAO,IAAI,OAAO,CAAC,UAAU,CAAC,CAG1C;IAED,gCAAgC;IACnB,QAAQ,IAAI,OAAO,CAAC,WAAW,CAAC,CAG5C;IAED;;;OAGG;IACU,OAAO,IAAI,OAAO,CAAC;QAC9B,4BAA4B,CAAC,OAAO,EAAE,gBAAgB,CAAC;QACvD,2BAA2B,CAAC,MAAM,EAAE,gBAAgB,CAAC;KACtD,CAAC,CAMD;IAED;;OAEG;IACU,WAAW,kBAiBvB;IAED,0EAA0E;IAC7D,SAAS,IAAI,OAAO,CAAC;QAChC,qBAAqB,CAAC,aAAa,EAAE,MAAM,CAAC;QAC5C,oBAAoB,CAAC,YAAY,EAAE,MAAM,CAAC;KAC3C,CAAC,CAMD;IAED;;;;OAIG;IACU,cAAc,CACzB,KAAK,EAAE,WAAW,EAClB,IAAI,GAAE;QACJ,wBAAwB;QACxB,MAAM,CAAC,EAAE,MAAM,CAAC;KACZ,mBAYP;IAED,4CAA4C;IAC/B,kBAAkB,kBAW9B;IAED,6DAA6D;IAChD,iBAAiB,qCAO7B;IAED;;;OAGG;IACU,YAAY,CAAC,OAAO,EAAE,MAAM,iBAOxC;IAED;;;OAGG;IACI,YAAY,CAAC,qBAAqB,CAAC,EAAE,MAAM,GAAG,MAAM,iBA+B1D;IAED;;;OAGG;IACI,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAmCvE;IAED;;;OAGG;IACU,OAAO,CAClB,MAAM,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,qBAAqB,CAAC,OAAO,SAAS,EAAE,gBAAgB,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,iBAMzG;IAED;;OAEG;IACU,UAAU,kBAOtB;IAED,4CAA4C;IAC/B,oBAAoB,kBAMhC;IAED;;;OAGG;IACU,sBAAsB,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,MAAM,iBAIrE;IAED;;;OAGG;IACU,qBAAqB,CAAC,QAAQ,EAAE,MAAM,iBAUlD;CACF"}
@@ -0,0 +1,275 @@
1
+ import { RollupContract } from '@aztec/ethereum/contracts';
2
+ import { CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { EthAddress } from '@aztec/foundation/eth-address';
4
+ import { createLogger } from '@aztec/foundation/log';
5
+ import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
6
+ import { createPublicClient, fallback, getContract, hexToBigInt, http } from 'viem';
7
+ import { EthCheatCodes } from './eth_cheat_codes.js';
8
+ /** Cheat codes for the L1 rollup contract. */ export class RollupCheatCodes {
9
+ ethCheatCodes;
10
+ client;
11
+ rollup;
12
+ logger;
13
+ constructor(ethCheatCodes, addresses){
14
+ this.ethCheatCodes = ethCheatCodes;
15
+ this.logger = createLogger('aztecjs:cheat_codes');
16
+ this.client = createPublicClient({
17
+ chain: ethCheatCodes.chain,
18
+ transport: fallback(ethCheatCodes.rpcUrls.map((url)=>http(url, {
19
+ batch: false
20
+ })))
21
+ });
22
+ this.rollup = getContract({
23
+ abi: RollupAbi,
24
+ address: addresses.rollupAddress.toString(),
25
+ client: this.client
26
+ });
27
+ }
28
+ static create(rpcUrls, addresses, dateProvider) {
29
+ const ethCheatCodes = new EthCheatCodes(rpcUrls, dateProvider);
30
+ return new RollupCheatCodes(ethCheatCodes, addresses);
31
+ }
32
+ /** Returns the current slot */ async getSlot() {
33
+ const ts = BigInt((await this.client.getBlock()).timestamp);
34
+ return SlotNumber.fromBigInt(await this.rollup.read.getSlotAt([
35
+ ts
36
+ ]));
37
+ }
38
+ /** Returns the current epoch */ async getEpoch() {
39
+ const slotNumber = await this.getSlot();
40
+ return EpochNumber.fromBigInt(await this.rollup.read.getEpochAtSlot([
41
+ BigInt(slotNumber)
42
+ ]));
43
+ }
44
+ /**
45
+ * Returns the pending and proven chain tips
46
+ * @returns The pending and proven chain tips
47
+ */ async getTips() {
48
+ const { pending, proven } = await this.rollup.read.getTips();
49
+ return {
50
+ pending: CheckpointNumber.fromBigInt(pending),
51
+ proven: CheckpointNumber.fromBigInt(proven)
52
+ };
53
+ }
54
+ /**
55
+ * Logs the current state of the rollup contract.
56
+ */ async debugRollup() {
57
+ const rollup = new RollupContract(this.client, this.rollup.address);
58
+ const pendingNum = await rollup.getCheckpointNumber();
59
+ const provenNum = await rollup.getProvenCheckpointNumber();
60
+ const validators = await rollup.getAttesters();
61
+ const committee = await rollup.getCurrentEpochCommittee();
62
+ const archive = await rollup.archive();
63
+ const slot = await this.getSlot();
64
+ const epochNum = await rollup.getEpochNumberForSlotNumber(slot);
65
+ this.logger.info(`Pending checkpoint num: ${pendingNum}`);
66
+ this.logger.info(`Proven checkpoint num: ${provenNum}`);
67
+ this.logger.info(`Validators: ${validators.map((v)=>v.toString()).join(', ')}`);
68
+ this.logger.info(`Committee: ${committee?.map((v)=>v.toString()).join(', ')}`);
69
+ this.logger.info(`Archive: ${archive}`);
70
+ this.logger.info(`Epoch num: ${epochNum}`);
71
+ this.logger.info(`Slot: ${slot}`);
72
+ }
73
+ /** Fetches the epoch and slot duration config from the rollup contract */ async getConfig() {
74
+ const [epochDuration, slotDuration] = await Promise.all([
75
+ this.rollup.read.getEpochDuration(),
76
+ this.rollup.read.getSlotDuration()
77
+ ]);
78
+ return {
79
+ epochDuration,
80
+ slotDuration: Number(slotDuration)
81
+ };
82
+ }
83
+ /**
84
+ * Advances time to the beginning of the given epoch
85
+ * @param epoch - The epoch to advance to
86
+ * @param opts - Options
87
+ */ async advanceToEpoch(epoch, opts = {}) {
88
+ const { epochDuration: slotsInEpoch } = await this.getConfig();
89
+ const slotNumber = SlotNumber(epoch * Number(slotsInEpoch));
90
+ const timestamp = await this.rollup.read.getTimestampForSlot([
91
+ BigInt(slotNumber)
92
+ ]) + BigInt(opts.offset ?? 0);
93
+ try {
94
+ await this.ethCheatCodes.warp(Number(timestamp), {
95
+ ...opts,
96
+ silent: true,
97
+ resetBlockInterval: true
98
+ });
99
+ this.logger.warn(`Warped to epoch ${epoch}`, {
100
+ offset: opts.offset,
101
+ timestamp
102
+ });
103
+ } catch (err) {
104
+ this.logger.warn(`Warp to epoch ${epoch} failed: ${err}`);
105
+ }
106
+ return timestamp;
107
+ }
108
+ /** Warps time in L1 until the next epoch */ async advanceToNextEpoch() {
109
+ const slot = await this.getSlot();
110
+ const { epochDuration, slotDuration } = await this.getConfig();
111
+ const slotsUntilNextEpoch = epochDuration - BigInt(slot) % epochDuration + 1n;
112
+ const timeToNextEpoch = slotsUntilNextEpoch * BigInt(slotDuration);
113
+ const l1Timestamp = BigInt((await this.client.getBlock()).timestamp);
114
+ await this.ethCheatCodes.warp(Number(l1Timestamp + timeToNextEpoch), {
115
+ silent: true,
116
+ resetBlockInterval: true
117
+ });
118
+ this.logger.warn(`Advanced to next epoch`);
119
+ }
120
+ /** Warps time in L1 until the beginning of the next slot. */ async advanceToNextSlot() {
121
+ const currentSlot = await this.getSlot();
122
+ const nextSlot = SlotNumber(currentSlot + 1);
123
+ const timestamp = await this.rollup.read.getTimestampForSlot([
124
+ BigInt(nextSlot)
125
+ ]);
126
+ await this.ethCheatCodes.warp(Number(timestamp), {
127
+ silent: true,
128
+ resetBlockInterval: true
129
+ });
130
+ this.logger.warn(`Advanced to slot ${nextSlot}`);
131
+ return [
132
+ timestamp,
133
+ nextSlot
134
+ ];
135
+ }
136
+ /**
137
+ * Warps time in L1 equivalent to however many slots.
138
+ * @param howMany - The number of slots to advance.
139
+ */ async advanceSlots(howMany) {
140
+ const l1Timestamp = (await this.client.getBlock()).timestamp;
141
+ const slotDuration = Number(await this.rollup.read.getSlotDuration());
142
+ const timeToWarp = BigInt(howMany) * BigInt(slotDuration);
143
+ await this.ethCheatCodes.warp(l1Timestamp + timeToWarp, {
144
+ silent: true,
145
+ resetBlockInterval: true
146
+ });
147
+ const [slot, epoch] = await Promise.all([
148
+ this.getSlot(),
149
+ this.getEpoch()
150
+ ]);
151
+ this.logger.warn(`Advanced ${howMany} slots up to slot ${slot} in epoch ${epoch}`);
152
+ }
153
+ /**
154
+ * Marks the specified checkpoint (or latest if none) as proven
155
+ * @param maybeCheckpointNumber - The checkpoint number to mark as proven (defaults to latest pending)
156
+ */ markAsProven(maybeCheckpointNumber) {
157
+ return this.ethCheatCodes.execWithPausedAnvil(async ()=>{
158
+ const tipsBefore = await this.getTips();
159
+ const { pending, proven } = tipsBefore;
160
+ let checkpointNumber = maybeCheckpointNumber;
161
+ if (checkpointNumber === undefined || checkpointNumber > pending) {
162
+ checkpointNumber = pending;
163
+ }
164
+ if (checkpointNumber <= proven) {
165
+ this.logger.debug(`Checkpoint ${checkpointNumber} is already proven`);
166
+ return;
167
+ }
168
+ // @note @LHerskind this is heavily dependent on the storage layout and size of values
169
+ // The rollupStore is a struct and if the size of elements or the struct changes, this can break
170
+ const provenCheckpointNumberSlot = hexToBigInt(RollupContract.stfStorageSlot);
171
+ // Need to pack it as a single 32 byte word
172
+ const newValue = BigInt(tipsBefore.pending) << 128n | BigInt(checkpointNumber);
173
+ await this.ethCheatCodes.store(EthAddress.fromString(this.rollup.address), provenCheckpointNumberSlot, newValue);
174
+ const tipsAfter = await this.getTips();
175
+ if (tipsAfter.pending < tipsAfter.proven) {
176
+ throw new Error('Overwrote pending tip to a checkpoint in the past');
177
+ }
178
+ this.logger.info(`Proven tip moved: ${tipsBefore.proven} -> ${tipsAfter.proven}. Pending tip: ${tipsAfter.pending}.`);
179
+ });
180
+ }
181
+ /**
182
+ * Overrides the inProgress field of the Inbox contract state
183
+ * @param howMuch - How many checkpoints to move it forward
184
+ */ advanceInboxInProgress(howMuch) {
185
+ return this.ethCheatCodes.execWithPausedAnvil(async ()=>{
186
+ // Storage slot 2 contains the InboxState struct
187
+ const inboxStateSlot = 2n;
188
+ // Get inbox and its current state values
189
+ const inboxAddress = await this.rollup.read.getInbox();
190
+ const currentStateValue = await this.ethCheatCodes.load(EthAddress.fromString(inboxAddress), inboxStateSlot);
191
+ // Extract current values from the packed storage slot
192
+ // Storage layout: rollingHash (128 bits) | totalMessagesInserted (64 bits) | inProgress (64 bits)
193
+ const currentRollingHash = currentStateValue & (1n << 128n) - 1n;
194
+ const currentTotalMessages = currentStateValue >> 128n & (1n << 64n) - 1n;
195
+ const currentInProgress = currentStateValue >> 192n;
196
+ const newInProgress = currentInProgress + BigInt(howMuch);
197
+ // Pack new values: rollingHash (low 128 bits) | totalMessages (middle 64 bits) | inProgress (high 64 bits)
198
+ const newValue = BigInt(newInProgress) << 192n | currentTotalMessages << 128n | currentRollingHash;
199
+ await this.ethCheatCodes.store(EthAddress.fromString(inboxAddress), inboxStateSlot, newValue, {
200
+ silent: true
201
+ });
202
+ this.logger.warn(`Inbox inProgress advanced from ${currentInProgress} to ${newInProgress}`, {
203
+ inbox: inboxAddress,
204
+ oldValue: '0x' + currentStateValue.toString(16),
205
+ newValue: '0x' + newValue.toString(16),
206
+ rollingHash: currentRollingHash,
207
+ totalMessages: currentTotalMessages,
208
+ oldInProgress: currentInProgress,
209
+ newInProgress
210
+ });
211
+ return newInProgress;
212
+ });
213
+ }
214
+ /**
215
+ * Executes an action impersonated as the owner of the Rollup contract.
216
+ * @param action - The action to execute
217
+ */ async asOwner(action) {
218
+ const owner = await this.rollup.read.owner();
219
+ await this.ethCheatCodes.startImpersonating(owner);
220
+ await action(owner, this.rollup);
221
+ await this.ethCheatCodes.stopImpersonating(owner);
222
+ }
223
+ /**
224
+ * Sets up the epoch.
225
+ */ async setupEpoch() {
226
+ // Doesn't need to be done as owner, but the functionality is here...
227
+ await this.asOwner(async (account, rollup)=>{
228
+ const hash = await rollup.write.setupEpoch({
229
+ account
230
+ });
231
+ await this.client.waitForTransactionReceipt({
232
+ hash
233
+ });
234
+ this.logger.warn(`Setup epoch`);
235
+ });
236
+ }
237
+ /** Directly calls the L1 gas fee oracle. */ async updateL1GasFeeOracle() {
238
+ await this.asOwner(async (account, rollup)=>{
239
+ const hash = await rollup.write.updateL1GasFeeOracle({
240
+ account,
241
+ chain: this.client.chain
242
+ });
243
+ await this.client.waitForTransactionReceipt({
244
+ hash
245
+ });
246
+ this.logger.warn(`Updated L1 gas fee oracle`);
247
+ });
248
+ }
249
+ /**
250
+ * Bumps proving cost per mana.
251
+ * @param bumper - Callback to calculate the new proving cost per mana based on current value.
252
+ */ async bumpProvingCostPerMana(bumper) {
253
+ const currentCost = await this.rollup.read.getProvingCostPerManaInEth();
254
+ const newCost = bumper(currentCost);
255
+ await this.setProvingCostPerMana(newCost);
256
+ }
257
+ /**
258
+ * Directly updates proving cost per mana.
259
+ * @param ethValue - The new proving cost per mana in ETH
260
+ */ async setProvingCostPerMana(ethValue) {
261
+ await this.asOwner(async (account, rollup)=>{
262
+ const hash = await rollup.write.setProvingCostPerMana([
263
+ ethValue
264
+ ], {
265
+ account,
266
+ chain: this.client.chain,
267
+ gasLimit: 1000000n
268
+ });
269
+ await this.client.waitForTransactionReceipt({
270
+ hash
271
+ });
272
+ this.logger.warn(`Updated proving cost per mana to ${ethValue}`);
273
+ });
274
+ }
275
+ }
@@ -3,10 +3,18 @@ import { type Anvil } from '@viem/anvil';
3
3
  * Ensures there's a running Anvil instance and returns the RPC URL.
4
4
  */
5
5
  export declare function startAnvil(opts?: {
6
+ port?: number;
6
7
  l1BlockTime?: number;
8
+ log?: boolean;
9
+ captureMethodCalls?: boolean;
10
+ accounts?: number;
11
+ chainId?: number;
12
+ /** The hardfork to use - note: @viem/anvil types are out of date but 'cancun' and 'latest' work */
13
+ hardfork?: string;
7
14
  }): Promise<{
8
15
  anvil: Anvil;
16
+ methodCalls?: string[];
9
17
  rpcUrl: string;
10
18
  stop: () => Promise<void>;
11
19
  }>;
12
- //# sourceMappingURL=start_anvil.d.ts.map
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhcnRfYW52aWwuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0L3N0YXJ0X2FudmlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSxLQUFLLEtBQUssRUFBZSxNQUFNLGFBQWEsQ0FBQztBQUd0RDs7R0FFRztBQUNILHdCQUFzQixVQUFVLENBQzlCLElBQUksR0FBRTtJQUNKLElBQUksQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUNkLFdBQVcsQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUNyQixHQUFHLENBQUMsRUFBRSxPQUFPLENBQUM7SUFDZCxrQkFBa0IsQ0FBQyxFQUFFLE9BQU8sQ0FBQztJQUM3QixRQUFRLENBQUMsRUFBRSxNQUFNLENBQUM7SUFDbEIsT0FBTyxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ2pCLG1HQUFtRztJQUNuRyxRQUFRLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDZCxHQUNMLE9BQU8sQ0FBQztJQUFFLEtBQUssRUFBRSxLQUFLLENBQUM7SUFBQyxXQUFXLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQztJQUFDLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFBQyxJQUFJLEVBQUUsTUFBTSxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7Q0FBRSxDQUFDLENBaUQ5RiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"start_anvil.d.ts","sourceRoot":"","sources":["../../src/test/start_anvil.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,KAAK,EAAe,MAAM,aAAa,CAAC;AAGtD;;GAEG;AACH,wBAAsB,UAAU,CAC9B,IAAI,GAAE;IACJ,WAAW,CAAC,EAAE,MAAM,CAAC;CACjB,GACL,OAAO,CAAC;IAAE,KAAK,EAAE,KAAK,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAAE,CAAC,CAsCtE"}
1
+ {"version":3,"file":"start_anvil.d.ts","sourceRoot":"","sources":["../../src/test/start_anvil.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,KAAK,EAAe,MAAM,aAAa,CAAC;AAGtD;;GAEG;AACH,wBAAsB,UAAU,CAC9B,IAAI,GAAE;IACJ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,GAAG,CAAC,EAAE,OAAO,CAAC;IACd,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,mGAAmG;IACnG,QAAQ,CAAC,EAAE,MAAM,CAAC;CACd,GACL,OAAO,CAAC;IAAE,KAAK,EAAE,KAAK,CAAC;IAAC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAAE,CAAC,CAiD9F"}
@@ -1,3 +1,4 @@
1
+ import { createLogger } from '@aztec/foundation/log';
1
2
  import { makeBackoff, retry } from '@aztec/foundation/retry';
2
3
  import { fileURLToPath } from '@aztec/foundation/url';
3
4
  import { createAnvil } from '@viem/anvil';
@@ -6,24 +7,34 @@ import { dirname, resolve } from 'path';
6
7
  * Ensures there's a running Anvil instance and returns the RPC URL.
7
8
  */ export async function startAnvil(opts = {}) {
8
9
  const anvilBinary = resolve(dirname(fileURLToPath(import.meta.url)), '../../', 'scripts/anvil_kill_wrapper.sh');
10
+ const logger = opts.log ? createLogger('ethereum:anvil') : undefined;
11
+ const methodCalls = opts.captureMethodCalls ? [] : undefined;
9
12
  let port;
10
13
  // Start anvil.
11
14
  // We go via a wrapper script to ensure if the parent dies, anvil dies.
12
15
  const anvil = await retry(async ()=>{
13
16
  const anvil = createAnvil({
14
17
  anvilBinary,
15
- port: 0,
18
+ host: '127.0.0.1',
19
+ port: opts.port ?? 8545,
16
20
  blockTime: opts.l1BlockTime,
17
- stopTimeout: 1000
21
+ stopTimeout: 1000,
22
+ accounts: opts.accounts ?? 20,
23
+ gasLimit: 45_000_000n,
24
+ chainId: opts.chainId ?? 31337
18
25
  });
19
26
  // Listen to the anvil output to get the port.
20
27
  const removeHandler = anvil.on('message', (message)=>{
28
+ logger?.debug(message.trim());
29
+ methodCalls?.push(...message.match(/eth_[^\s]+/g) || []);
21
30
  if (port === undefined && message.includes('Listening on')) {
22
31
  port = parseInt(message.match(/Listening on ([^:]+):(\d+)/)[2]);
23
32
  }
24
33
  });
25
34
  await anvil.start();
26
- removeHandler();
35
+ if (!logger && !opts.captureMethodCalls) {
36
+ removeHandler();
37
+ }
27
38
  return anvil;
28
39
  }, 'Start anvil', makeBackoff([
29
40
  5,
@@ -34,12 +45,10 @@ import { dirname, resolve } from 'path';
34
45
  throw new Error('Failed to start anvil');
35
46
  }
36
47
  // Monkeypatch the anvil instance to include the actually assigned port
37
- Object.defineProperty(anvil, 'port', {
38
- value: port,
39
- writable: false
40
- });
48
+ // Object.defineProperty(anvil, 'port', { value: port, writable: false });
41
49
  return {
42
50
  anvil,
51
+ methodCalls,
43
52
  stop: ()=>anvil.stop(),
44
53
  rpcUrl: `http://127.0.0.1:${port}`
45
54
  };
@@ -1,25 +1,36 @@
1
1
  import { type Logger } from '@aztec/foundation/log';
2
+ import type { DateProvider } from '@aztec/foundation/timer';
2
3
  import { type Client, type Hex } from 'viem';
3
- import type { ViemWalletClient } from '../types.js';
4
- export declare function waitUntilBlock<T extends Client>(client: T, blockNumber: number | bigint, logger?: Logger): Promise<boolean>;
5
- export declare function waitUntilL1Timestamp<T extends Client>(client: T, timestamp: number | bigint, logger?: Logger): Promise<boolean>;
4
+ import { type ViemClient } from '../types.js';
5
+ export declare function waitUntilBlock<T extends Client>(client: T, blockNumber: number | bigint, logger?: Logger, timeout?: number): Promise<boolean>;
6
+ export declare function waitUntilL1Timestamp<T extends Client>(client: T, timestamp: number | bigint, logger?: Logger, timeout?: number): Promise<boolean>;
6
7
  export interface Delayer {
7
- /** Returns the list of all txs (not just the delayed ones) sent through the attached client. */
8
- getTxs(): Hex[];
8
+ /** Returns the hashes of all effectively sent txs. */
9
+ getSentTxHashes(): Hex[];
10
+ /** Returns the raw hex for all cancelled txs. */
11
+ getCancelledTxs(): Hex[];
9
12
  /** Delays the next tx to be sent so it lands on the given L1 block number. */
10
13
  pauseNextTxUntilBlock(l1BlockNumber: number | bigint | undefined): void;
11
14
  /** Delays the next tx to be sent so it lands on the given timestamp. */
12
15
  pauseNextTxUntilTimestamp(l1Timestamp: number | bigint | undefined): void;
16
+ /** Delays the next tx to be sent indefinitely. */
17
+ cancelNextTx(): void;
18
+ /**
19
+ * Sets max inclusion time into slot. If more than this many seconds have passed
20
+ * since the last L1 block was mined, then any tx will not be mined in the current
21
+ * L1 slot but will be deferred for the next one.
22
+ */
23
+ setMaxInclusionTimeIntoSlot(seconds: number | bigint | undefined): void;
13
24
  }
14
25
  /**
15
26
  * Returns a new client (without modifying the one passed in) with an injected tx delayer.
16
27
  * The delayer can be used to hold off the next tx to be sent until a given block number.
17
28
  * TODO(#10824): This doesn't play along well with blob txs for some reason.
18
29
  */
19
- export declare function withDelayer<T extends ViemWalletClient>(client: T, opts: {
30
+ export declare function withDelayer<T extends ViemClient>(client: T, dateProvider: DateProvider, opts: {
20
31
  ethereumSlotDuration: bigint | number;
21
32
  }): {
22
33
  client: T;
23
34
  delayer: Delayer;
24
35
  };
25
- //# sourceMappingURL=tx_delayer.d.ts.map
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHhfZGVsYXllci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Rlc3QvdHhfZGVsYXllci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQWdCLE1BQU0sdUJBQXVCLENBQUM7QUFFbEUsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHNUQsT0FBTyxFQUNMLEtBQUssTUFBTSxFQUNYLEtBQUssR0FBRyxFQVFULE1BQU0sTUFBTSxDQUFDO0FBRWQsT0FBTyxFQUFFLEtBQUssVUFBVSxFQUFvQixNQUFNLGFBQWEsQ0FBQztBQUloRSx3QkFBZ0IsY0FBYyxDQUFDLENBQUMsU0FBUyxNQUFNLEVBQzdDLE1BQU0sRUFBRSxDQUFDLEVBQ1QsV0FBVyxFQUFFLE1BQU0sR0FBRyxNQUFNLEVBQzVCLE1BQU0sQ0FBQyxFQUFFLE1BQU0sRUFDZixPQUFPLENBQUMsRUFBRSxNQUFNLG9CQWlCakI7QUFFRCx3QkFBZ0Isb0JBQW9CLENBQUMsQ0FBQyxTQUFTLE1BQU0sRUFDbkQsTUFBTSxFQUFFLENBQUMsRUFDVCxTQUFTLEVBQUUsTUFBTSxHQUFHLE1BQU0sRUFDMUIsTUFBTSxDQUFDLEVBQUUsTUFBTSxFQUNmLE9BQU8sQ0FBQyxFQUFFLE1BQU0sb0JBd0JqQjtBQUVELE1BQU0sV0FBVyxPQUFPO0lBQ3RCLHNEQUFzRDtJQUN0RCxlQUFlLElBQUksR0FBRyxFQUFFLENBQUM7SUFDekIsaURBQWlEO0lBQ2pELGVBQWUsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUN6Qiw4RUFBOEU7SUFDOUUscUJBQXFCLENBQUMsYUFBYSxFQUFFLE1BQU0sR0FBRyxNQUFNLEdBQUcsU0FBUyxHQUFHLElBQUksQ0FBQztJQUN4RSx3RUFBd0U7SUFDeEUseUJBQXlCLENBQUMsV0FBVyxFQUFFLE1BQU0sR0FBRyxNQUFNLEdBQUcsU0FBUyxHQUFHLElBQUksQ0FBQztJQUMxRSxrREFBa0Q7SUFDbEQsWUFBWSxJQUFJLElBQUksQ0FBQztJQUNyQjs7OztPQUlHO0lBQ0gsMkJBQTJCLENBQUMsT0FBTyxFQUFFLE1BQU0sR0FBRyxNQUFNLEdBQUcsU0FBUyxHQUFHLElBQUksQ0FBQztDQUN6RTtBQTBDRDs7OztHQUlHO0FBQ0gsd0JBQWdCLFdBQVcsQ0FBQyxDQUFDLFNBQVMsVUFBVSxFQUM5QyxNQUFNLEVBQUUsQ0FBQyxFQUNULFlBQVksRUFBRSxZQUFZLEVBQzFCLElBQUksRUFBRTtJQUFFLG9CQUFvQixFQUFFLE1BQU0sR0FBRyxNQUFNLENBQUE7Q0FBRSxHQUM5QztJQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFBQyxPQUFPLEVBQUUsT0FBTyxDQUFBO0NBQUUsQ0EwR2pDIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"tx_delayer.d.ts","sourceRoot":"","sources":["../../src/test/tx_delayer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAIlE,OAAO,EACL,KAAK,MAAM,EACX,KAAK,GAAG,EAMT,MAAM,MAAM,CAAC;AAEd,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,wBAAgB,cAAc,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,oBAgBxG;AAED,wBAAgB,oBAAoB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,oBAuB5G;AAED,MAAM,WAAW,OAAO;IACtB,gGAAgG;IAChG,MAAM,IAAI,GAAG,EAAE,CAAC;IAChB,8EAA8E;IAC9E,qBAAqB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IACxE,wEAAwE;IACxE,yBAAyB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;CAC3E;AAwBD;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,CAAC,SAAS,gBAAgB,EACpD,MAAM,EAAE,CAAC,EACT,IAAI,EAAE;IAAE,oBAAoB,EAAE,MAAM,GAAG,MAAM,CAAA;CAAE,GAC9C;IAAE,MAAM,EAAE,CAAC,CAAC;IAAC,OAAO,EAAE,OAAO,CAAA;CAAE,CA+DjC"}
1
+ {"version":3,"file":"tx_delayer.d.ts","sourceRoot":"","sources":["../../src/test/tx_delayer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAElE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAG5D,OAAO,EACL,KAAK,MAAM,EACX,KAAK,GAAG,EAQT,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,KAAK,UAAU,EAAoB,MAAM,aAAa,CAAC;AAIhE,wBAAgB,cAAc,CAAC,CAAC,SAAS,MAAM,EAC7C,MAAM,EAAE,CAAC,EACT,WAAW,EAAE,MAAM,GAAG,MAAM,EAC5B,MAAM,CAAC,EAAE,MAAM,EACf,OAAO,CAAC,EAAE,MAAM,oBAiBjB;AAED,wBAAgB,oBAAoB,CAAC,CAAC,SAAS,MAAM,EACnD,MAAM,EAAE,CAAC,EACT,SAAS,EAAE,MAAM,GAAG,MAAM,EAC1B,MAAM,CAAC,EAAE,MAAM,EACf,OAAO,CAAC,EAAE,MAAM,oBAwBjB;AAED,MAAM,WAAW,OAAO;IACtB,sDAAsD;IACtD,eAAe,IAAI,GAAG,EAAE,CAAC;IACzB,iDAAiD;IACjD,eAAe,IAAI,GAAG,EAAE,CAAC;IACzB,8EAA8E;IAC9E,qBAAqB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IACxE,wEAAwE;IACxE,yBAAyB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IAC1E,kDAAkD;IAClD,YAAY,IAAI,IAAI,CAAC;IACrB;;;;OAIG;IACH,2BAA2B,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;CACzE;AA0CD;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,CAAC,SAAS,UAAU,EAC9C,MAAM,EAAE,CAAC,EACT,YAAY,EAAE,YAAY,EAC1B,IAAI,EAAE;IAAE,oBAAoB,EAAE,MAAM,GAAG,MAAM,CAAA;CAAE,GAC9C;IAAE,MAAM,EAAE,CAAC,CAAC;IAAC,OAAO,EAAE,OAAO,CAAA;CAAE,CA0GjC"}