@aztec/end-to-end 0.0.1-commit.7d4e6cd → 0.0.1-commit.7ffbba4

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 (232) hide show
  1. package/dest/bench/client_flows/benchmark.d.ts +3 -2
  2. package/dest/bench/client_flows/benchmark.d.ts.map +1 -1
  3. package/dest/bench/client_flows/benchmark.js +21 -1
  4. package/dest/bench/client_flows/client_flows_benchmark.d.ts +13 -14
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +130 -137
  7. package/dest/bench/client_flows/config.d.ts +2 -2
  8. package/dest/bench/client_flows/config.d.ts.map +1 -1
  9. package/dest/bench/client_flows/config.js +18 -0
  10. package/dest/bench/utils.d.ts +6 -5
  11. package/dest/bench/utils.d.ts.map +1 -1
  12. package/dest/bench/utils.js +13 -8
  13. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +9 -8
  14. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  15. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +107 -113
  16. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +7 -8
  17. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  18. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +68 -64
  19. package/dest/e2e_deploy_contract/deploy_test.d.ts +5 -4
  20. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  21. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  22. package/dest/e2e_epochs/epochs_test.d.ts +15 -7
  23. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  24. package/dest/e2e_epochs/epochs_test.js +86 -39
  25. package/dest/e2e_fees/bridging_race.notest.js +3 -5
  26. package/dest/e2e_fees/fees_test.d.ts +14 -14
  27. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  28. package/dest/e2e_fees/fees_test.js +133 -144
  29. package/dest/e2e_l1_publisher/write_json.d.ts +4 -3
  30. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  31. package/dest/e2e_l1_publisher/write_json.js +14 -13
  32. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  33. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  34. package/dest/e2e_nested_contract/nested_contract_test.js +30 -40
  35. package/dest/e2e_p2p/inactivity_slash_test.d.ts +3 -3
  36. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  37. package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
  38. package/dest/e2e_p2p/p2p_network.d.ts +11 -9
  39. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  40. package/dest/e2e_p2p/p2p_network.js +132 -108
  41. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  42. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  43. package/dest/e2e_p2p/reqresp/utils.js +177 -0
  44. package/dest/e2e_p2p/shared.d.ts +20 -6
  45. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  46. package/dest/e2e_p2p/shared.js +38 -18
  47. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  48. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  49. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  50. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  51. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  52. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  53. package/dest/e2e_token_contract/token_contract_test.d.ts +19 -10
  54. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  55. package/dest/e2e_token_contract/token_contract_test.js +100 -92
  56. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  57. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  58. package/dest/fixtures/authwit_proxy.js +30 -0
  59. package/dest/fixtures/e2e_prover_test.d.ts +11 -17
  60. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  61. package/dest/fixtures/e2e_prover_test.js +112 -127
  62. package/dest/fixtures/elu_monitor.d.ts +21 -0
  63. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  64. package/dest/fixtures/elu_monitor.js +102 -0
  65. package/dest/fixtures/fixtures.d.ts +5 -1
  66. package/dest/fixtures/fixtures.d.ts.map +1 -1
  67. package/dest/fixtures/fixtures.js +6 -0
  68. package/dest/fixtures/ha_setup.d.ts +71 -0
  69. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  70. package/dest/fixtures/ha_setup.js +116 -0
  71. package/dest/fixtures/index.d.ts +2 -1
  72. package/dest/fixtures/index.d.ts.map +1 -1
  73. package/dest/fixtures/index.js +1 -0
  74. package/dest/fixtures/setup.d.ts +234 -0
  75. package/dest/fixtures/setup.d.ts.map +1 -0
  76. package/dest/fixtures/setup.js +605 -0
  77. package/dest/fixtures/setup_p2p_test.d.ts +16 -9
  78. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  79. package/dest/fixtures/setup_p2p_test.js +40 -29
  80. package/dest/fixtures/token_utils.d.ts +2 -2
  81. package/dest/fixtures/token_utils.d.ts.map +1 -1
  82. package/dest/fixtures/token_utils.js +12 -8
  83. package/dest/fixtures/utils.d.ts +5 -191
  84. package/dest/fixtures/utils.d.ts.map +1 -1
  85. package/dest/fixtures/utils.js +4 -615
  86. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  87. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  88. package/dest/quality_of_service/prometheus_client.js +67 -0
  89. package/dest/shared/cross_chain_test_harness.d.ts +14 -4
  90. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  91. package/dest/shared/cross_chain_test_harness.js +24 -24
  92. package/dest/shared/gas_portal_test_harness.d.ts +11 -1
  93. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  94. package/dest/shared/gas_portal_test_harness.js +3 -3
  95. package/dest/shared/index.d.ts +2 -1
  96. package/dest/shared/index.d.ts.map +1 -1
  97. package/dest/shared/index.js +1 -0
  98. package/dest/shared/jest_setup.js +41 -1
  99. package/dest/shared/mock_state_view.d.ts +86 -0
  100. package/dest/shared/mock_state_view.d.ts.map +1 -0
  101. package/dest/shared/mock_state_view.js +186 -0
  102. package/dest/shared/submit-transactions.d.ts +4 -4
  103. package/dest/shared/submit-transactions.d.ts.map +1 -1
  104. package/dest/shared/submit-transactions.js +9 -11
  105. package/dest/shared/uniswap_l1_l2.d.ts +1 -1
  106. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  107. package/dest/shared/uniswap_l1_l2.js +24 -22
  108. package/dest/simulators/lending_simulator.d.ts +5 -1
  109. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  110. package/dest/simulators/lending_simulator.js +4 -4
  111. package/dest/simulators/token_simulator.d.ts +1 -1
  112. package/dest/simulators/token_simulator.d.ts.map +1 -1
  113. package/dest/simulators/token_simulator.js +3 -24
  114. package/dest/spartan/setup_test_wallets.d.ts +9 -2
  115. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  116. package/dest/spartan/setup_test_wallets.js +94 -36
  117. package/dest/spartan/tx_metrics.d.ts +51 -2
  118. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  119. package/dest/spartan/tx_metrics.js +334 -7
  120. package/dest/spartan/utils/bot.d.ts +28 -0
  121. package/dest/spartan/utils/bot.d.ts.map +1 -0
  122. package/dest/spartan/utils/bot.js +142 -0
  123. package/dest/spartan/utils/chaos.d.ts +79 -0
  124. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  125. package/dest/spartan/utils/chaos.js +142 -0
  126. package/dest/spartan/utils/clients.d.ts +39 -0
  127. package/dest/spartan/utils/clients.d.ts.map +1 -0
  128. package/dest/spartan/utils/clients.js +90 -0
  129. package/dest/spartan/utils/config.d.ts +42 -0
  130. package/dest/spartan/utils/config.d.ts.map +1 -0
  131. package/dest/spartan/utils/config.js +22 -0
  132. package/dest/spartan/utils/health.d.ts +63 -0
  133. package/dest/spartan/utils/health.d.ts.map +1 -0
  134. package/dest/spartan/utils/health.js +202 -0
  135. package/dest/spartan/utils/helm.d.ts +15 -0
  136. package/dest/spartan/utils/helm.d.ts.map +1 -0
  137. package/dest/spartan/utils/helm.js +47 -0
  138. package/dest/spartan/utils/index.d.ts +10 -0
  139. package/dest/spartan/utils/index.d.ts.map +1 -0
  140. package/dest/spartan/utils/index.js +20 -0
  141. package/dest/spartan/utils/k8s.d.ts +128 -0
  142. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  143. package/dest/spartan/utils/k8s.js +381 -0
  144. package/dest/spartan/utils/nodes.d.ts +40 -0
  145. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  146. package/dest/spartan/utils/nodes.js +461 -0
  147. package/dest/spartan/utils/scripts.d.ts +30 -0
  148. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  149. package/dest/spartan/utils/scripts.js +81 -0
  150. package/dest/spartan/utils.d.ts +2 -253
  151. package/dest/spartan/utils.d.ts.map +1 -1
  152. package/dest/spartan/utils.js +1 -892
  153. package/dest/test-wallet/test_wallet.d.ts +83 -0
  154. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  155. package/dest/test-wallet/test_wallet.js +214 -0
  156. package/dest/test-wallet/utils.d.ts +41 -0
  157. package/dest/test-wallet/utils.d.ts.map +1 -0
  158. package/dest/test-wallet/utils.js +71 -0
  159. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  160. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  161. package/dest/test-wallet/wallet_worker_script.js +48 -0
  162. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  163. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  164. package/dest/test-wallet/worker_wallet.js +151 -0
  165. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  166. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  167. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  168. package/package.json +47 -43
  169. package/src/bench/client_flows/benchmark.ts +24 -2
  170. package/src/bench/client_flows/client_flows_benchmark.ts +148 -210
  171. package/src/bench/client_flows/config.ts +9 -1
  172. package/src/bench/utils.ts +15 -8
  173. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +120 -145
  174. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +103 -111
  175. package/src/e2e_deploy_contract/deploy_test.ts +22 -15
  176. package/src/e2e_epochs/epochs_test.ts +129 -93
  177. package/src/e2e_fees/bridging_race.notest.ts +4 -10
  178. package/src/e2e_fees/fees_test.ts +170 -224
  179. package/src/e2e_l1_publisher/write_json.ts +16 -13
  180. package/src/e2e_nested_contract/nested_contract_test.ts +35 -56
  181. package/src/e2e_p2p/inactivity_slash_test.ts +3 -3
  182. package/src/e2e_p2p/p2p_network.ts +196 -166
  183. package/src/e2e_p2p/reqresp/utils.ts +235 -0
  184. package/src/e2e_p2p/shared.ts +66 -23
  185. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  186. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  187. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  188. package/src/e2e_token_contract/token_contract_test.ts +121 -119
  189. package/src/fixtures/authwit_proxy.ts +50 -0
  190. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  191. package/src/fixtures/e2e_prover_test.ts +133 -171
  192. package/src/fixtures/elu_monitor.ts +126 -0
  193. package/src/fixtures/fixtures.ts +10 -0
  194. package/src/fixtures/ha_setup.ts +186 -0
  195. package/src/fixtures/index.ts +1 -0
  196. package/src/fixtures/setup.ts +897 -0
  197. package/src/fixtures/setup_p2p_test.ts +40 -44
  198. package/src/fixtures/token_utils.ts +10 -6
  199. package/src/fixtures/utils.ts +27 -901
  200. package/src/guides/up_quick_start.sh +3 -3
  201. package/src/quality_of_service/prometheus_client.ts +113 -0
  202. package/src/shared/cross_chain_test_harness.ts +24 -34
  203. package/src/shared/gas_portal_test_harness.ts +2 -2
  204. package/src/shared/index.ts +1 -0
  205. package/src/shared/jest_setup.ts +51 -1
  206. package/src/shared/mock_state_view.ts +188 -0
  207. package/src/shared/submit-transactions.ts +11 -16
  208. package/src/shared/uniswap_l1_l2.ts +26 -33
  209. package/src/simulators/lending_simulator.ts +6 -4
  210. package/src/simulators/token_simulator.ts +6 -30
  211. package/src/spartan/setup_test_wallets.ts +121 -26
  212. package/src/spartan/tx_metrics.ts +256 -10
  213. package/src/spartan/utils/bot.ts +188 -0
  214. package/src/spartan/utils/chaos.ts +253 -0
  215. package/src/spartan/utils/clients.ts +100 -0
  216. package/src/spartan/utils/config.ts +28 -0
  217. package/src/spartan/utils/health.ts +255 -0
  218. package/src/spartan/utils/helm.ts +84 -0
  219. package/src/spartan/utils/index.ts +68 -0
  220. package/src/spartan/utils/k8s.ts +535 -0
  221. package/src/spartan/utils/nodes.ts +543 -0
  222. package/src/spartan/utils/scripts.ts +99 -0
  223. package/src/spartan/utils.ts +1 -1158
  224. package/src/test-wallet/test_wallet.ts +306 -0
  225. package/src/test-wallet/utils.ts +112 -0
  226. package/src/test-wallet/wallet_worker_script.ts +60 -0
  227. package/src/test-wallet/worker_wallet.ts +213 -0
  228. package/src/test-wallet/worker_wallet_schema.ts +13 -0
  229. package/dest/fixtures/snapshot_manager.d.ts +0 -93
  230. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  231. package/dest/fixtures/snapshot_manager.js +0 -488
  232. package/src/fixtures/snapshot_manager.ts +0 -646
@@ -7,22 +7,15 @@ import type { TxHash } from '@aztec/aztec.js/tx';
7
7
  import type { CheatCodes } from '@aztec/aztec/testing';
8
8
  import type { TokenContract } from '@aztec/noir-contracts.js/Token';
9
9
  import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
10
+ import { GenericProxyContract } from '@aztec/noir-test-contracts.js/GenericProxy';
10
11
  import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
11
12
  import type { SequencerClient } from '@aztec/sequencer-client';
12
- import type { TestWallet } from '@aztec/test-wallet/server';
13
13
 
14
14
  import { jest } from '@jest/globals';
15
15
 
16
- import {
17
- type ISnapshotManager,
18
- type SubsystemsContext,
19
- createSnapshotManager,
20
- deployAccounts,
21
- publicDeployAccounts,
22
- } from '../fixtures/snapshot_manager.js';
16
+ import { type EndToEndContext, deployAccounts, publicDeployAccounts, setup, teardown } from '../fixtures/setup.js';
23
17
  import { TokenSimulator } from '../simulators/token_simulator.js';
24
-
25
- const { E2E_DATA_PATH: dataPath } = process.env;
18
+ import type { TestWallet } from '../test-wallet/test_wallet.js';
26
19
 
27
20
  export class Role {
28
21
  private isAdmin = false;
@@ -55,12 +48,13 @@ export class BlacklistTokenContractTest {
55
48
  // This value MUST match the same value that we have in the contract
56
49
  static CHANGE_ROLES_DELAY = 86400;
57
50
 
58
- private snapshotManager: ISnapshotManager;
51
+ context!: EndToEndContext;
59
52
  logger: Logger;
60
53
  wallet!: TestWallet;
61
54
  asset!: TokenBlacklistContract;
62
55
  tokenSim!: TokenSimulator;
63
56
  badAccount!: InvalidAccountContract;
57
+ authwitProxy!: GenericProxyContract;
64
58
  cheatCodes!: CheatCodes;
65
59
  sequencer!: SequencerClient;
66
60
  aztecNode!: AztecNode;
@@ -71,7 +65,6 @@ export class BlacklistTokenContractTest {
71
65
 
72
66
  constructor(testName: string) {
73
67
  this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
74
- this.snapshotManager = createSnapshotManager(`e2e_blacklist_token_contract/${testName}`, dataPath);
75
68
  }
76
69
 
77
70
  async crossTimestampOfChange() {
@@ -83,86 +76,83 @@ export class BlacklistTokenContractTest {
83
76
  }
84
77
 
85
78
  /**
86
- * Adds two state shifts to snapshot manager.
79
+ * Applies base setup:
87
80
  * 1. Add 3 accounts.
88
81
  * 2. Publicly deploy accounts, deploy token contract and a "bad account".
89
82
  */
90
- async applyBaseSnapshots() {
83
+ async applyBaseSetup() {
91
84
  // Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
92
85
  jest.setTimeout(120_000);
93
86
 
94
- await this.snapshotManager.snapshot(
95
- '3_accounts',
96
- deployAccounts(3, this.logger),
97
- ({ deployedAccounts }, { cheatCodes, aztecNode, sequencer, wallet }) => {
98
- this.cheatCodes = cheatCodes;
99
- this.aztecNode = aztecNode;
100
- this.sequencer = sequencer;
101
- this.wallet = wallet;
102
- this.adminAddress = deployedAccounts[0].address;
103
- this.otherAddress = deployedAccounts[1].address;
104
- this.blacklistedAddress = deployedAccounts[2].address;
105
- return Promise.resolve();
106
- },
87
+ this.logger.info('Deploying 3 accounts');
88
+ const { deployedAccounts } = await deployAccounts(
89
+ 3,
90
+ this.logger,
91
+ )({
92
+ wallet: this.context.wallet,
93
+ initialFundedAccounts: this.context.initialFundedAccounts,
94
+ });
95
+
96
+ this.cheatCodes = this.context.cheatCodes;
97
+ this.aztecNode = this.context.aztecNodeService;
98
+ this.sequencer = this.context.sequencer!;
99
+ this.wallet = this.context.wallet;
100
+ this.adminAddress = deployedAccounts[0].address;
101
+ this.otherAddress = deployedAccounts[1].address;
102
+ this.blacklistedAddress = deployedAccounts[2].address;
103
+
104
+ this.logger.info('Setting up blacklist token contract');
105
+ // Create the token contract state.
106
+ this.logger.verbose(`Public deploy accounts...`);
107
+ await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
108
+
109
+ this.logger.verbose(`Deploying TokenContract...`);
110
+ ({ contract: this.asset } = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
111
+ from: this.adminAddress,
112
+ }));
113
+ this.logger.verbose(`Token deployed to ${this.asset.address}`);
114
+
115
+ this.logger.verbose(`Deploying bad account...`);
116
+ ({ contract: this.badAccount } = await InvalidAccountContract.deploy(this.wallet).send({
117
+ from: this.adminAddress,
118
+ }));
119
+ this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
120
+
121
+ // Deploy a proxy contract for "on behalf of other" tests. The note owner must be the tx sender
122
+ // (so their notes are in scope), but msg_sender in the target must differ from the note owner
123
+ // to trigger authwit validation. The proxy forwards calls so that msg_sender != tx sender.
124
+ this.logger.verbose(`Deploying generic proxy...`);
125
+ ({ contract: this.authwitProxy } = await GenericProxyContract.deploy(this.wallet).send({
126
+ from: this.adminAddress,
127
+ }));
128
+ this.logger.verbose(`Deployed to ${this.authwitProxy.address}.`);
129
+
130
+ await this.crossTimestampOfChange();
131
+
132
+ this.tokenSim = new TokenSimulator(
133
+ this.asset as unknown as TokenContract,
134
+ this.wallet,
135
+ this.adminAddress,
136
+ this.logger,
137
+ [this.adminAddress, this.otherAddress, this.blacklistedAddress],
107
138
  );
108
139
 
109
- await this.snapshotManager.snapshot(
110
- 'e2e_blacklist_token_contract',
111
- async () => {
112
- // Create the token contract state.
113
- // Move this account thing to addAccounts above?
114
- this.logger.verbose(`Public deploy accounts...`);
115
- await publicDeployAccounts(this.wallet, [this.adminAddress, this.otherAddress, this.blacklistedAddress]);
116
-
117
- this.logger.verbose(`Deploying TokenContract...`);
118
- this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress)
119
- .send({ from: this.adminAddress })
120
- .deployed();
121
- this.logger.verbose(`Token deployed to ${this.asset.address}`);
122
-
123
- this.logger.verbose(`Deploying bad account...`);
124
- this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({ from: this.adminAddress }).deployed();
125
- this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
126
-
127
- await this.crossTimestampOfChange();
128
-
129
- return { tokenContractAddress: this.asset.address, badAccountAddress: this.badAccount.address };
130
- },
131
- async ({ tokenContractAddress, badAccountAddress }) => {
132
- // Restore the token contract state.
133
- this.asset = TokenBlacklistContract.at(tokenContractAddress, this.wallet);
134
- this.logger.verbose(`Token contract address: ${this.asset.address}`);
135
-
136
- this.tokenSim = new TokenSimulator(
137
- this.asset as unknown as TokenContract,
138
- this.wallet,
139
- this.adminAddress,
140
- this.logger,
141
- [this.adminAddress, this.otherAddress, this.blacklistedAddress],
142
- );
143
-
144
- this.badAccount = InvalidAccountContract.at(badAccountAddress, this.wallet);
145
- this.logger.verbose(`Bad account address: ${this.badAccount.address}`);
146
-
147
- expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
148
- new Role().withAdmin().toNoirStruct(),
149
- );
150
- },
151
- );
140
+ expect(
141
+ (await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).result,
142
+ ).toEqual(new Role().withAdmin().toNoirStruct());
152
143
  }
153
144
 
154
145
  async setup() {
155
- await this.snapshotManager.setup();
146
+ this.logger.info('Setting up fresh context');
147
+ this.context = await setup(0, {
148
+ fundSponsoredFPC: true,
149
+ skipAccountDeployment: true,
150
+ });
151
+ await this.applyBaseSetup();
156
152
  }
157
153
 
158
- snapshot = <T>(
159
- name: string,
160
- apply: (context: SubsystemsContext) => Promise<T>,
161
- restore: (snapshotData: T, context: SubsystemsContext) => Promise<void> = () => Promise.resolve(),
162
- ): Promise<void> => this.snapshotManager.snapshot(name, apply, restore);
163
-
164
154
  async teardown() {
165
- await this.snapshotManager.teardown();
155
+ await teardown(this.context);
166
156
  }
167
157
 
168
158
  async addPendingShieldNoteToPXE(
@@ -174,7 +164,7 @@ export class BlacklistTokenContractTest {
174
164
  ) {
175
165
  const txEffects = await this.aztecNode.getTxEffect(txHash);
176
166
  await contract.methods
177
- .deliver_transparent_note(
167
+ .process_transparent_note(
178
168
  contract.address,
179
169
  amount,
180
170
  secretHash,
@@ -186,71 +176,56 @@ export class BlacklistTokenContractTest {
186
176
  .simulate({ from: recipient });
187
177
  }
188
178
 
189
- async applyMintSnapshot() {
190
- await this.snapshotManager.snapshot(
191
- 'mint',
192
- async () => {
193
- const { asset } = this;
194
- const amount = 10000n;
195
-
196
- const adminMinterRole = new Role().withAdmin().withMinter();
197
- await this.asset.methods
198
- .update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
199
- .send({ from: this.adminAddress })
200
- .wait();
201
-
202
- const blacklistRole = new Role().withBlacklisted();
203
- await this.asset.methods
204
- .update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
205
- .send({ from: this.adminAddress })
206
- .wait();
207
-
208
- await this.crossTimestampOfChange();
209
-
210
- expect(await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).toEqual(
211
- adminMinterRole.toNoirStruct(),
212
- );
213
-
214
- this.logger.verbose(`Minting ${amount} publicly...`);
215
- await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress }).wait();
216
-
217
- this.logger.verbose(`Minting ${amount} privately...`);
218
- const secret = Fr.random();
219
- const secretHash = await computeSecretHash(secret);
220
- const receipt = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress }).wait();
221
-
222
- await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
223
- const txClaim = asset.methods
224
- .redeem_shield(this.adminAddress, amount, secret)
225
- .send({ from: this.adminAddress });
226
- await txClaim.wait();
227
- this.logger.verbose(`Minting complete.`);
228
-
229
- return { amount };
230
- },
231
- async ({ amount }) => {
232
- const { asset, tokenSim } = this;
233
- tokenSim.mintPublic(this.adminAddress, amount);
234
-
235
- const publicBalance = await asset.methods
236
- .balance_of_public(this.adminAddress)
237
- .simulate({ from: this.adminAddress });
238
- this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
239
- expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
240
-
241
- tokenSim.mintPrivate(this.adminAddress, amount);
242
- const privateBalance = await asset.methods
243
- .balance_of_private(this.adminAddress)
244
- .simulate({ from: this.adminAddress });
245
- this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
246
- expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
247
-
248
- const totalSupply = await asset.methods.total_supply().simulate({ from: this.adminAddress });
249
- this.logger.verbose(`Total supply: ${totalSupply}`);
250
- expect(totalSupply).toEqual(tokenSim.totalSupply);
251
-
252
- return Promise.resolve();
253
- },
254
- );
179
+ async applyMint() {
180
+ this.logger.info('Applying mint setup');
181
+ const { asset, tokenSim } = this;
182
+ const amount = 10000n;
183
+
184
+ const adminMinterRole = new Role().withAdmin().withMinter();
185
+ await this.asset.methods
186
+ .update_roles(this.adminAddress, adminMinterRole.toNoirStruct())
187
+ .send({ from: this.adminAddress });
188
+
189
+ const blacklistRole = new Role().withBlacklisted();
190
+ await this.asset.methods
191
+ .update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct())
192
+ .send({ from: this.adminAddress });
193
+
194
+ await this.crossTimestampOfChange();
195
+
196
+ expect(
197
+ (await this.asset.methods.get_roles(this.adminAddress).simulate({ from: this.adminAddress })).result,
198
+ ).toEqual(adminMinterRole.toNoirStruct());
199
+
200
+ this.logger.verbose(`Minting ${amount} publicly...`);
201
+ await asset.methods.mint_public(this.adminAddress, amount).send({ from: this.adminAddress });
202
+
203
+ this.logger.verbose(`Minting ${amount} privately...`);
204
+ const secret = Fr.random();
205
+ const secretHash = await computeSecretHash(secret);
206
+ const { receipt } = await asset.methods.mint_private(amount, secretHash).send({ from: this.adminAddress });
207
+
208
+ await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
209
+ await asset.methods.redeem_shield(this.adminAddress, amount, secret).send({ from: this.adminAddress });
210
+ this.logger.verbose(`Minting complete.`);
211
+
212
+ tokenSim.mintPublic(this.adminAddress, amount);
213
+
214
+ const { result: publicBalance } = await asset.methods
215
+ .balance_of_public(this.adminAddress)
216
+ .simulate({ from: this.adminAddress });
217
+ this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
218
+ expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
219
+
220
+ tokenSim.mintPrivate(this.adminAddress, amount);
221
+ const { result: privateBalance } = await asset.methods
222
+ .balance_of_private(this.adminAddress)
223
+ .simulate({ from: this.adminAddress });
224
+ this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
225
+ expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
226
+
227
+ const { result: totalSupply } = await asset.methods.total_supply().simulate({ from: this.adminAddress });
228
+ this.logger.verbose(`Total supply: ${totalSupply}`);
229
+ expect(totalSupply).toEqual(tokenSim.totalSupply);
255
230
  }
256
231
  }
@@ -13,35 +13,34 @@ import type {
13
13
  } from '@aztec/ethereum/deploy-aztec-l1-contracts';
14
14
  import { deployL1Contract } from '@aztec/ethereum/deploy-l1-contract';
15
15
  import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
16
- import { CheckpointNumber, EpochNumber } from '@aztec/foundation/branded-types';
16
+ import { EpochNumber } from '@aztec/foundation/branded-types';
17
17
  import { sleep } from '@aztec/foundation/sleep';
18
18
  import { TestERC20Abi, TestERC20Bytecode } from '@aztec/l1-artifacts';
19
19
  import { TokenContract } from '@aztec/noir-contracts.js/Token';
20
20
  import { TokenBridgeContract } from '@aztec/noir-contracts.js/TokenBridge';
21
21
  import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
22
- import type { TestWallet } from '@aztec/test-wallet/server';
23
22
 
24
23
  import { MNEMONIC } from '../fixtures/fixtures.js';
25
24
  import {
26
- type ISnapshotManager,
27
- type SubsystemsContext,
28
- createSnapshotManager,
25
+ type EndToEndContext,
26
+ type SetupOptions,
29
27
  deployAccounts,
30
28
  publicDeployAccounts,
31
- } from '../fixtures/snapshot_manager.js';
32
- import type { SetupOptions } from '../fixtures/utils.js';
29
+ setup,
30
+ teardown,
31
+ } from '../fixtures/setup.js';
33
32
  import { CrossChainTestHarness } from '../shared/cross_chain_test_harness.js';
34
-
35
- const { E2E_DATA_PATH: dataPath } = process.env;
33
+ import type { TestWallet } from '../test-wallet/test_wallet.js';
36
34
 
37
35
  export class CrossChainMessagingTest {
38
- private snapshotManager: ISnapshotManager;
39
36
  private requireEpochProven: boolean;
37
+ private setupOptions: SetupOptions;
38
+ private deployL1ContractsArgs: Partial<DeployAztecL1ContractsArgs>;
40
39
  logger: Logger;
40
+ context!: EndToEndContext;
41
41
  aztecNode!: AztecNode;
42
42
  aztecNodeConfig!: AztecNodeConfig;
43
43
  aztecNodeAdmin!: AztecNodeAdmin;
44
- ctx!: SubsystemsContext;
45
44
 
46
45
  l1Client!: ExtendedViemWalletClient | undefined;
47
46
 
@@ -67,32 +66,28 @@ export class CrossChainMessagingTest {
67
66
  deployL1ContractsArgs: Partial<DeployAztecL1ContractsArgs> = {},
68
67
  ) {
69
68
  this.logger = createLogger(`e2e:e2e_cross_chain_messaging:${testName}`);
70
- this.snapshotManager = createSnapshotManager(`e2e_cross_chain_messaging/${testName}`, dataPath, opts, {
69
+ this.setupOptions = opts;
70
+ this.deployL1ContractsArgs = {
71
71
  initialValidators: [],
72
72
  ...deployL1ContractsArgs,
73
- });
73
+ };
74
74
  this.requireEpochProven = opts.startProverNode ?? false;
75
75
  }
76
76
 
77
77
  async setup() {
78
- this.ctx = await this.snapshotManager.setup();
79
- this.aztecNode = this.ctx.aztecNode;
80
- this.wallet = this.ctx.wallet;
81
- this.aztecNodeConfig = this.ctx.aztecNodeConfig;
82
- this.cheatCodes = this.ctx.cheatCodes;
83
- this.deployL1ContractsValues = this.ctx.deployL1ContractsValues;
84
- this.aztecNodeAdmin = this.ctx.aztecNode;
85
-
86
- if (this.requireEpochProven) {
87
- // Turn off the watcher to prevent it from keep marking blocks as proven.
88
- this.ctx.watcher.setIsMarkingAsProven(false);
89
- }
78
+ this.logger.info('Setting up cross chain messaging test');
79
+ this.context = await setup(0, {
80
+ ...this.setupOptions,
81
+ fundSponsoredFPC: true,
82
+ skipAccountDeployment: true,
83
+ l1ContractsArgs: this.deployL1ContractsArgs,
84
+ });
85
+ await this.applyBaseSetup();
90
86
  }
91
87
 
92
88
  async advanceToEpochProven(l2TxReceipt: TxReceipt): Promise<EpochNumber> {
93
- const epoch = await this.rollup.getEpochNumberForCheckpoint(
94
- CheckpointNumber.fromBlockNumber(l2TxReceipt.blockNumber!),
95
- );
89
+ const block = await this.aztecNode.getBlock(l2TxReceipt.blockNumber!);
90
+ const epoch = await this.rollup.getEpochNumberForCheckpoint(block!.checkpointNumber);
96
91
  // Warp to the next epoch.
97
92
  await this.cheatCodes.rollup.advanceToEpoch(EpochNumber(epoch + 1));
98
93
  // Wait for the tx to be proven.
@@ -108,94 +103,91 @@ export class CrossChainMessagingTest {
108
103
  }
109
104
  }
110
105
 
111
- snapshot = <T>(
112
- name: string,
113
- apply: (context: SubsystemsContext) => Promise<T>,
114
- restore: (snapshotData: T, context: SubsystemsContext) => Promise<void> = () => Promise.resolve(),
115
- ): Promise<void> => this.snapshotManager.snapshot(name, apply, restore);
116
-
117
106
  async teardown() {
118
- await this.snapshotManager.teardown();
107
+ await teardown(this.context);
119
108
  }
120
109
 
121
- async applyBaseSnapshots() {
122
- // Note that we are using the same `wallet`, `aztecNodeConfig` and `aztecNode` across all snapshots.
123
- // This is to not have issues with different networks.
124
-
125
- await this.snapshotManager.snapshot(
126
- '3_accounts',
127
- deployAccounts(3, this.logger),
128
- ({ deployedAccounts }, { wallet, aztecNodeConfig, aztecNode }) => {
129
- [this.ownerAddress, this.user1Address, this.user2Address] = deployedAccounts.map(a => a.address);
130
- this.wallet = wallet;
131
- this.aztecNode = aztecNode;
132
- this.aztecNodeConfig = aztecNodeConfig;
133
- return Promise.resolve();
134
- },
110
+ async applyBaseSetup() {
111
+ // Set up base context fields
112
+ this.aztecNode = this.context.aztecNodeService;
113
+ this.wallet = this.context.wallet;
114
+ this.aztecNodeConfig = this.context.config;
115
+ this.cheatCodes = this.context.cheatCodes;
116
+ this.deployL1ContractsValues = this.context.deployL1ContractsValues;
117
+ this.aztecNodeAdmin = this.context.aztecNodeService;
118
+
119
+ if (this.requireEpochProven) {
120
+ // Turn off the watcher to prevent it from keep marking blocks as proven.
121
+ this.context.watcher.setIsMarkingAsProven(false);
122
+ }
123
+
124
+ // Deploy 3 accounts
125
+ this.logger.info('Applying 3_accounts setup');
126
+ const { deployedAccounts } = await deployAccounts(
127
+ 3,
128
+ this.logger,
129
+ )({
130
+ wallet: this.context.wallet,
131
+ initialFundedAccounts: this.context.initialFundedAccounts,
132
+ });
133
+ [this.ownerAddress, this.user1Address, this.user2Address] = deployedAccounts.map(a => a.address);
134
+
135
+ // Set up cross chain messaging
136
+ this.logger.info('Applying e2e_cross_chain_messaging setup');
137
+
138
+ // Create the token contract state.
139
+ this.logger.verbose(`Public deploy accounts...`);
140
+ await publicDeployAccounts(this.wallet, [this.ownerAddress, this.user1Address, this.user2Address]);
141
+
142
+ this.l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
143
+
144
+ const underlyingERC20Address = await deployL1Contract(this.l1Client, TestERC20Abi, TestERC20Bytecode, [
145
+ 'Underlying',
146
+ 'UND',
147
+ this.l1Client.account.address,
148
+ ]).then(({ address }) => address);
149
+
150
+ this.logger.verbose(`Setting up cross chain harness...`);
151
+ this.crossChainTestHarness = await CrossChainTestHarness.new(
152
+ this.aztecNode,
153
+ this.l1Client,
154
+ this.wallet,
155
+ this.ownerAddress,
156
+ this.logger,
157
+ underlyingERC20Address,
135
158
  );
136
159
 
137
- await this.snapshotManager.snapshot(
138
- 'e2e_cross_chain_messaging',
139
- async () => {
140
- // Create the token contract state.
141
- // Move this account thing to addAccounts above?
142
- this.logger.verbose(`Public deploy accounts...`);
143
- await publicDeployAccounts(this.wallet, [this.ownerAddress, this.user1Address, this.user2Address]);
144
-
145
- this.l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
146
-
147
- const underlyingERC20Address = await deployL1Contract(this.l1Client, TestERC20Abi, TestERC20Bytecode, [
148
- 'Underlying',
149
- 'UND',
150
- this.l1Client.account.address,
151
- ]).then(({ address }) => address);
152
-
153
- this.logger.verbose(`Setting up cross chain harness...`);
154
- this.crossChainTestHarness = await CrossChainTestHarness.new(
155
- this.aztecNode,
156
- this.l1Client,
157
- this.wallet,
158
- this.ownerAddress,
159
- this.logger,
160
- underlyingERC20Address,
161
- );
162
-
163
- this.logger.verbose(`L2 token deployed to: ${this.crossChainTestHarness.l2Token.address}`);
164
-
165
- return this.crossChainTestHarness.toCrossChainContext();
166
- },
167
- crossChainContext => {
168
- this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
169
- this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
170
-
171
- // There is an issue with the reviver so we are getting strings sometimes. Working around it here.
172
- this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
173
- const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
174
-
175
- const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
176
- this.l1Client = l1Client;
177
-
178
- const l1Contracts = this.aztecNodeConfig.l1Contracts;
179
- this.rollup = new RollupContract(l1Client, l1Contracts.rollupAddress.toString());
180
- this.inbox = new InboxContract(l1Client, l1Contracts.inboxAddress.toString());
181
- this.outbox = new OutboxContract(l1Client, l1Contracts.outboxAddress.toString());
182
-
183
- this.crossChainTestHarness = new CrossChainTestHarness(
184
- this.aztecNode,
185
- this.logger,
186
- this.l2Token,
187
- this.l2Bridge,
188
- this.ethAccount,
189
- tokenPortalAddress,
190
- crossChainContext.underlying,
191
- l1Client,
192
- this.aztecNodeConfig.l1Contracts,
193
- this.wallet,
194
- this.ownerAddress,
195
- );
196
-
197
- return Promise.resolve();
198
- },
160
+ this.logger.verbose(`L2 token deployed to: ${this.crossChainTestHarness.l2Token.address}`);
161
+
162
+ const crossChainContext = this.crossChainTestHarness.toCrossChainContext();
163
+
164
+ this.l2Token = TokenContract.at(crossChainContext.l2Token, this.wallet);
165
+ this.l2Bridge = TokenBridgeContract.at(crossChainContext.l2Bridge, this.wallet);
166
+
167
+ // There is an issue with the reviver so we are getting strings sometimes. Working around it here.
168
+ this.ethAccount = EthAddress.fromString(crossChainContext.ethAccount.toString());
169
+ const tokenPortalAddress = EthAddress.fromString(crossChainContext.tokenPortal.toString());
170
+
171
+ const l1Client = createExtendedL1Client(this.aztecNodeConfig.l1RpcUrls, MNEMONIC);
172
+ this.l1Client = l1Client;
173
+
174
+ const l1Contracts = this.aztecNodeConfig.l1Contracts;
175
+ this.rollup = new RollupContract(l1Client, l1Contracts.rollupAddress.toString());
176
+ this.inbox = new InboxContract(l1Client, l1Contracts.inboxAddress.toString());
177
+ this.outbox = new OutboxContract(l1Client, l1Contracts.outboxAddress.toString());
178
+
179
+ this.crossChainTestHarness = new CrossChainTestHarness(
180
+ this.aztecNode,
181
+ this.logger,
182
+ this.l2Token,
183
+ this.l2Bridge,
184
+ this.ethAccount,
185
+ tokenPortalAddress,
186
+ crossChainContext.underlying,
187
+ l1Client,
188
+ this.aztecNodeConfig.l1Contracts,
189
+ this.wallet,
190
+ this.ownerAddress,
199
191
  );
200
192
  }
201
193
  }
@@ -8,14 +8,12 @@ import type { AztecNode } from '@aztec/aztec.js/node';
8
8
  import type { Wallet } from '@aztec/aztec.js/wallet';
9
9
  import type { StatefulTestContract } from '@aztec/noir-test-contracts.js/StatefulTest';
10
10
  import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
11
- import type { TestWallet } from '@aztec/test-wallet/server';
12
11
 
13
- import { type ISnapshotManager, createSnapshotManager, deployAccounts } from '../fixtures/snapshot_manager.js';
14
-
15
- const { E2E_DATA_PATH: dataPath } = process.env;
12
+ import { type EndToEndContext, deployAccounts, setup, teardown } from '../fixtures/setup.js';
13
+ import type { TestWallet } from '../test-wallet/test_wallet.js';
16
14
 
17
15
  export class DeployTest {
18
- private snapshotManager: ISnapshotManager;
16
+ public context!: EndToEndContext;
19
17
  public logger: Logger;
20
18
  public wallet!: TestWallet;
21
19
  public defaultAccountAddress!: AztecAddress;
@@ -24,26 +22,35 @@ export class DeployTest {
24
22
 
25
23
  constructor(testName: string) {
26
24
  this.logger = createLogger(`e2e:e2e_deploy_contract:${testName}`);
27
- this.snapshotManager = createSnapshotManager(`e2e_deploy_contract/${testName}`, dataPath);
28
25
  }
29
26
 
30
27
  async setup() {
31
- await this.applyInitialAccountSnapshot();
32
- const context = await this.snapshotManager.setup();
33
- ({ aztecNode: this.aztecNode, wallet: this.wallet } = context);
34
- this.aztecNodeAdmin = context.aztecNode;
28
+ this.logger.info('Setting up test environment');
29
+ this.context = await setup(0, {
30
+ fundSponsoredFPC: true,
31
+ skipAccountDeployment: true,
32
+ });
33
+ this.aztecNode = this.context.aztecNodeService;
34
+ this.wallet = this.context.wallet;
35
+ this.aztecNodeAdmin = this.context.aztecNodeService;
36
+ await this.applyInitialAccount();
35
37
  return this;
36
38
  }
37
39
 
38
40
  async teardown() {
39
- await this.snapshotManager.teardown();
41
+ await teardown(this.context);
40
42
  }
41
43
 
42
- private async applyInitialAccountSnapshot() {
43
- await this.snapshotManager.snapshot('initial_account', deployAccounts(1, this.logger), ({ deployedAccounts }) => {
44
- this.defaultAccountAddress = deployedAccounts[0].address;
45
- return Promise.resolve();
44
+ private async applyInitialAccount() {
45
+ this.logger.info('Applying initial account setup');
46
+ const { deployedAccounts } = await deployAccounts(
47
+ 1,
48
+ this.logger,
49
+ )({
50
+ wallet: this.context.wallet,
51
+ initialFundedAccounts: this.context.initialFundedAccounts,
46
52
  });
53
+ this.defaultAccountAddress = deployedAccounts[0].address;
47
54
  }
48
55
 
49
56
  async registerContract<T extends ContractBase>(