@aztec/end-to-end 0.0.0-test.1 → 0.0.1-commit.1142ef1

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 (186) hide show
  1. package/dest/bench/client_flows/benchmark.d.ts +61 -0
  2. package/dest/bench/client_flows/benchmark.d.ts.map +1 -0
  3. package/dest/bench/client_flows/benchmark.js +261 -0
  4. package/dest/bench/client_flows/client_flows_benchmark.d.ts +80 -0
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -0
  6. package/dest/bench/client_flows/client_flows_benchmark.js +336 -0
  7. package/dest/bench/client_flows/config.d.ts +14 -0
  8. package/dest/bench/client_flows/config.d.ts.map +1 -0
  9. package/dest/bench/client_flows/config.js +106 -0
  10. package/dest/bench/client_flows/data_extractor.d.ts +2 -0
  11. package/dest/bench/client_flows/data_extractor.d.ts.map +1 -0
  12. package/dest/bench/client_flows/data_extractor.js +79 -0
  13. package/dest/bench/utils.d.ts +14 -40
  14. package/dest/bench/utils.d.ts.map +1 -1
  15. package/dest/bench/utils.js +37 -70
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +21 -13
  17. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  18. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +85 -57
  19. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +29 -28
  20. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  21. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +79 -82
  22. package/dest/e2e_deploy_contract/deploy_test.d.ts +16 -8
  23. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  24. package/dest/e2e_deploy_contract/deploy_test.js +13 -19
  25. package/dest/e2e_epochs/epochs_test.d.ts +65 -22
  26. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  27. package/dest/e2e_epochs/epochs_test.js +233 -49
  28. package/dest/e2e_fees/bridging_race.notest.d.ts +2 -0
  29. package/dest/e2e_fees/bridging_race.notest.d.ts.map +1 -0
  30. package/dest/e2e_fees/bridging_race.notest.js +63 -0
  31. package/dest/e2e_fees/fees_test.d.ts +27 -12
  32. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  33. package/dest/e2e_fees/fees_test.js +107 -110
  34. package/dest/e2e_l1_publisher/write_json.d.ts +10 -0
  35. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -0
  36. package/dest/e2e_l1_publisher/write_json.js +55 -0
  37. package/dest/e2e_multi_validator/utils.d.ts +12 -0
  38. package/dest/e2e_multi_validator/utils.d.ts.map +1 -0
  39. package/dest/e2e_multi_validator/utils.js +214 -0
  40. package/dest/e2e_nested_contract/nested_contract_test.d.ts +10 -7
  41. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  42. package/dest/e2e_nested_contract/nested_contract_test.js +24 -20
  43. package/dest/e2e_p2p/inactivity_slash_test.d.ts +31 -0
  44. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -0
  45. package/dest/e2e_p2p/inactivity_slash_test.js +136 -0
  46. package/dest/e2e_p2p/p2p_network.d.ts +276 -23
  47. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  48. package/dest/e2e_p2p/p2p_network.js +188 -133
  49. package/dest/e2e_p2p/shared.d.ts +43 -7
  50. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  51. package/dest/e2e_p2p/shared.js +164 -19
  52. package/dest/e2e_token_contract/token_contract_test.d.ts +12 -6
  53. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  54. package/dest/e2e_token_contract/token_contract_test.js +50 -26
  55. package/dest/fixtures/e2e_prover_test.d.ts +61 -0
  56. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -0
  57. package/dest/{e2e_prover → fixtures}/e2e_prover_test.js +108 -113
  58. package/dest/fixtures/fixtures.d.ts +6 -8
  59. package/dest/fixtures/fixtures.d.ts.map +1 -1
  60. package/dest/fixtures/fixtures.js +5 -5
  61. package/dest/fixtures/get_acvm_config.d.ts +2 -2
  62. package/dest/fixtures/get_acvm_config.d.ts.map +1 -1
  63. package/dest/fixtures/get_acvm_config.js +3 -15
  64. package/dest/fixtures/get_bb_config.d.ts +2 -2
  65. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  66. package/dest/fixtures/get_bb_config.js +10 -17
  67. package/dest/fixtures/index.d.ts +1 -1
  68. package/dest/fixtures/l1_to_l2_messaging.d.ts +11 -7
  69. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  70. package/dest/fixtures/l1_to_l2_messaging.js +45 -19
  71. package/dest/fixtures/logging.d.ts +1 -1
  72. package/dest/fixtures/setup_p2p_test.d.ts +15 -14
  73. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  74. package/dest/fixtures/setup_p2p_test.js +82 -22
  75. package/dest/fixtures/snapshot_manager.d.ts +20 -14
  76. package/dest/fixtures/snapshot_manager.d.ts.map +1 -1
  77. package/dest/fixtures/snapshot_manager.js +147 -138
  78. package/dest/fixtures/token_utils.d.ts +10 -4
  79. package/dest/fixtures/token_utils.d.ts.map +1 -1
  80. package/dest/fixtures/token_utils.js +28 -12
  81. package/dest/fixtures/utils.d.ts +92 -54
  82. package/dest/fixtures/utils.d.ts.map +1 -1
  83. package/dest/fixtures/utils.js +452 -389
  84. package/dest/fixtures/web3signer.d.ts +5 -0
  85. package/dest/fixtures/web3signer.d.ts.map +1 -0
  86. package/dest/fixtures/web3signer.js +53 -0
  87. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  88. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  89. package/dest/fixtures/with_telemetry_utils.js +2 -2
  90. package/dest/index.d.ts +1 -1
  91. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  92. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  93. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  94. package/dest/shared/cross_chain_test_harness.d.ts +42 -35
  95. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  96. package/dest/shared/cross_chain_test_harness.js +106 -52
  97. package/dest/shared/gas_portal_test_harness.d.ts +29 -31
  98. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  99. package/dest/shared/gas_portal_test_harness.js +51 -30
  100. package/dest/shared/index.d.ts +2 -2
  101. package/dest/shared/index.d.ts.map +1 -1
  102. package/dest/shared/jest_setup.d.ts +1 -1
  103. package/dest/shared/jest_setup.js +1 -1
  104. package/dest/shared/submit-transactions.d.ts +6 -4
  105. package/dest/shared/submit-transactions.d.ts.map +1 -1
  106. package/dest/shared/submit-transactions.js +8 -7
  107. package/dest/shared/uniswap_l1_l2.d.ts +3 -25
  108. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  109. package/dest/shared/uniswap_l1_l2.js +170 -120
  110. package/dest/simulators/index.d.ts +1 -1
  111. package/dest/simulators/lending_simulator.d.ts +7 -11
  112. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  113. package/dest/simulators/lending_simulator.js +16 -17
  114. package/dest/simulators/token_simulator.d.ts +6 -3
  115. package/dest/simulators/token_simulator.d.ts.map +1 -1
  116. package/dest/simulators/token_simulator.js +16 -13
  117. package/dest/spartan/setup_test_wallets.d.ts +27 -11
  118. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  119. package/dest/spartan/setup_test_wallets.js +202 -58
  120. package/dest/spartan/tx_metrics.d.ts +39 -0
  121. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  122. package/dest/spartan/tx_metrics.js +95 -0
  123. package/dest/spartan/utils.d.ts +151 -313
  124. package/dest/spartan/utils.d.ts.map +1 -1
  125. package/dest/spartan/utils.js +598 -151
  126. package/package.json +65 -58
  127. package/src/bench/client_flows/benchmark.ts +341 -0
  128. package/src/bench/client_flows/client_flows_benchmark.ts +450 -0
  129. package/src/bench/client_flows/config.ts +61 -0
  130. package/src/bench/client_flows/data_extractor.ts +89 -0
  131. package/src/bench/utils.ts +35 -81
  132. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +80 -77
  133. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +103 -122
  134. package/src/e2e_deploy_contract/deploy_test.ts +24 -39
  135. package/src/e2e_epochs/epochs_test.ts +299 -65
  136. package/src/e2e_fees/bridging_race.notest.ts +80 -0
  137. package/src/e2e_fees/fees_test.ts +150 -142
  138. package/src/e2e_l1_publisher/write_json.ts +74 -0
  139. package/src/e2e_multi_validator/utils.ts +258 -0
  140. package/src/e2e_nested_contract/nested_contract_test.ts +29 -19
  141. package/src/e2e_p2p/inactivity_slash_test.ts +179 -0
  142. package/src/e2e_p2p/p2p_network.ts +274 -171
  143. package/src/e2e_p2p/shared.ts +252 -29
  144. package/src/e2e_token_contract/token_contract_test.ts +43 -39
  145. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  146. package/src/{e2e_prover → fixtures}/e2e_prover_test.ts +112 -160
  147. package/src/fixtures/fixtures.ts +5 -7
  148. package/src/fixtures/get_acvm_config.ts +4 -12
  149. package/src/fixtures/get_bb_config.ts +18 -13
  150. package/src/fixtures/l1_to_l2_messaging.ts +56 -24
  151. package/src/fixtures/setup_p2p_test.ts +127 -39
  152. package/src/fixtures/snapshot_manager.ts +189 -160
  153. package/src/fixtures/token_utils.ts +32 -15
  154. package/src/fixtures/utils.ts +556 -475
  155. package/src/fixtures/web3signer.ts +63 -0
  156. package/src/fixtures/with_telemetry_utils.ts +2 -2
  157. package/src/guides/up_quick_start.sh +7 -15
  158. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +2 -2
  159. package/src/shared/cross_chain_test_harness.ts +113 -87
  160. package/src/shared/gas_portal_test_harness.ts +59 -50
  161. package/src/shared/index.ts +1 -1
  162. package/src/shared/jest_setup.ts +1 -1
  163. package/src/shared/submit-transactions.ts +12 -8
  164. package/src/shared/uniswap_l1_l2.ts +194 -211
  165. package/src/simulators/lending_simulator.ts +15 -16
  166. package/src/simulators/token_simulator.ts +21 -13
  167. package/src/spartan/DEVELOP.md +128 -0
  168. package/src/spartan/setup_test_wallets.ts +258 -93
  169. package/src/spartan/tx_metrics.ts +130 -0
  170. package/src/spartan/utils.ts +722 -146
  171. package/dest/e2e_prover/e2e_prover_test.d.ts +0 -56
  172. package/dest/e2e_prover/e2e_prover_test.d.ts.map +0 -1
  173. package/dest/fixtures/setup_l1_contracts.d.ts +0 -6
  174. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  175. package/dest/fixtures/setup_l1_contracts.js +0 -17
  176. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  177. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  178. package/dest/sample-dapp/connect.js +0 -12
  179. package/dest/sample-dapp/contracts.js +0 -10
  180. package/dest/sample-dapp/deploy.js +0 -35
  181. package/dest/sample-dapp/index.js +0 -98
  182. package/src/fixtures/setup_l1_contracts.ts +0 -27
  183. package/src/sample-dapp/connect.mjs +0 -16
  184. package/src/sample-dapp/contracts.mjs +0 -14
  185. package/src/sample-dapp/deploy.mjs +0 -40
  186. package/src/sample-dapp/index.mjs +0 -128
@@ -1,12 +1,9 @@
1
- import { BatchCall, INITIAL_L2_BLOCK_NUM } from '@aztec/aztec.js';
2
- import { mean, stdDev, timesParallel } from '@aztec/foundation/collection';
3
- import { randomInt } from '@aztec/foundation/crypto';
4
- import { BenchmarkingContract } from '@aztec/noir-contracts.js/Benchmarking';
5
- import { createPXEService } from '@aztec/pxe/server';
6
- import { writeFileSync } from 'fs';
7
- import { mkdirpSync } from 'fs-extra';
8
- import { globSync } from 'glob';
9
- import { join } from 'path';
1
+ import { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import { BatchCall } from '@aztec/aztec.js/contracts';
3
+ import { mean, stdDev, times } from '@aztec/foundation/collection';
4
+ import { BenchmarkingContract } from '@aztec/noir-test-contracts.js/Benchmarking';
5
+ import { mkdirSync, writeFileSync } from 'fs';
6
+ import path from 'path';
10
7
  import { setup } from '../fixtures/utils.js';
11
8
  /**
12
9
  * Setup for benchmarks. Initializes a remote node with a single account and deploys a benchmark contract.
@@ -17,7 +14,10 @@ import { setup } from '../fixtures/utils.js';
17
14
  benchmark: true
18
15
  }
19
16
  });
20
- const contract = await BenchmarkingContract.deploy(context.wallet).send().deployed();
17
+ const defaultAccountAddress = context.accounts[0];
18
+ const contract = await BenchmarkingContract.deploy(context.wallet).send({
19
+ from: defaultAccountAddress
20
+ }).deployed();
21
21
  context.logger.info(`Deployed benchmarking contract at ${contract.address}`);
22
22
  const sequencer = context.aztecNode.getSequencer();
23
23
  const telemetry = context.telemetryClient;
@@ -28,7 +28,13 @@ import { setup } from '../fixtures/utils.js';
28
28
  await telemetry.flush();
29
29
  const data = telemetry.getMeters();
30
30
  const formatted = formatMetricsForGithubBenchmarkAction(data, opts.metrics);
31
+ if (formatted.length === 0) {
32
+ throw new Error(`No benchmark data generated. Please review your test setup.`);
33
+ }
31
34
  const benchOutput = opts.benchOutput ?? process.env.BENCH_OUTPUT ?? 'bench.json';
35
+ mkdirSync(path.dirname(benchOutput), {
36
+ recursive: true
37
+ });
32
38
  writeFileSync(benchOutput, JSON.stringify(formatted));
33
39
  context.logger.info(`Wrote ${data.length} metrics to ${benchOutput}`);
34
40
  await origTeardown();
@@ -40,17 +46,20 @@ import { setup } from '../fixtures/utils.js';
40
46
  sequencer
41
47
  };
42
48
  }
49
+ function isMetricDefinition(f) {
50
+ return 'description' in f;
51
+ }
43
52
  function formatMetricsForGithubBenchmarkAction(data, filter) {
44
- const allFilters = filter.map((f)=>typeof f === 'string' ? {
45
- name: f,
53
+ const allFilters = filter.map((f)=>isMetricDefinition(f) ? {
54
+ name: f.name,
46
55
  source: f,
47
56
  transform: (x)=>x,
48
- unit: undefined
57
+ unit: f.unit
49
58
  } : f);
50
59
  return data.flatMap((meter)=>{
51
- return meter.metrics.filter((metric)=>allFilters.map((f)=>f.source).includes(metric.name)).map((metric)=>[
60
+ return meter.metrics.filter((metric)=>allFilters.map((f)=>f.source.name).includes(metric.name)).map((metric)=>[
52
61
  metric,
53
- allFilters.find((f)=>f.source === metric.name)
62
+ allFilters.find((f)=>f.source.name === metric.name)
54
63
  ]).map(([metric, filter])=>({
55
64
  name: `${meter.name}/${filter.name}`,
56
65
  unit: filter.unit ?? metric.unit ?? 'unknown',
@@ -76,28 +85,6 @@ function getMetricValues(points) {
76
85
  };
77
86
  }
78
87
  }
79
- /**
80
- * Creates and returns a directory with the current job name and a random number.
81
- * @param index - Index to merge into the dir path.
82
- * @returns A path to a created dir.
83
- */ export function makeDataDirectory(index) {
84
- const testName = expect.getState().currentTestName.split(' ')[0].replaceAll('/', '_');
85
- const db = join('data', testName, index.toString(), `${randomInt(99)}`);
86
- mkdirpSync(db);
87
- return db;
88
- }
89
- /**
90
- * Returns the size in disk of a folder.
91
- * @param path - Path to the folder.
92
- * @returns Size in bytes.
93
- */ export function getFolderSize(path) {
94
- return globSync('**', {
95
- stat: true,
96
- cwd: path,
97
- nodir: true,
98
- withFileTypes: true
99
- }).reduce((accum, file)=>accum + file.size, 0);
100
- }
101
88
  /**
102
89
  * Returns a call to the benchmark contract. Each call has a private execution (account entrypoint),
103
90
  * a nested private call (create_note), a public call (increment_balance), and a nested public
@@ -108,17 +95,19 @@ function getMetricValues(points) {
108
95
  * @param contract - Benchmarking contract.
109
96
  * @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
110
97
  * @returns A BatchCall instance.
111
- */ export async function makeCall(index, context, contract, heavyPublicCompute) {
112
- const owner = context.wallet.getAddress();
113
- const sender = owner;
98
+ */ async function makeCall(index, context, contract, heavyPublicCompute) {
114
99
  if (heavyPublicCompute) {
115
100
  return new BatchCall(context.wallet, [
116
- await contract.methods.sha256_hash_2048(randomBytesAsBigInts(2048)).request()
101
+ contract.methods.sha256_hash_1024(randomBytesAsBigInts(1024))
117
102
  ]);
118
103
  } else {
104
+ // We use random address for the new note owner because we can emit at most UNFINALIZED_TAGGING_INDEXES_WINDOW_LEN
105
+ // logs for a given sender-recipient-contract tuple.
106
+ const ownerOfNewNote = await AztecAddress.random();
107
+ const [ownerOfBalance] = context.accounts;
119
108
  return new BatchCall(context.wallet, [
120
- await contract.methods.create_note(owner, sender, index + 1).request(),
121
- await contract.methods.increment_balance(owner, index + 1).request()
109
+ contract.methods.create_note(ownerOfNewNote, index + 1),
110
+ contract.methods.increment_balance(ownerOfBalance, index + 1)
122
111
  ]);
123
112
  }
124
113
  }
@@ -131,41 +120,19 @@ function getMetricValues(points) {
131
120
  * @param heavyPublicCompute - Whether the transactions include heavy public compute (like a big sha256).
132
121
  * @returns Array of sent txs.
133
122
  */ export async function sendTxs(txCount, context, contract, heavyPublicCompute = false) {
134
- const calls = await timesParallel(txCount, (index)=>makeCall(index, context, contract, heavyPublicCompute));
123
+ const calls = await Promise.all(times(txCount, (index)=>makeCall(index, context, contract, heavyPublicCompute)));
135
124
  context.logger.info(`Creating ${txCount} txs`);
136
- const provenTxs = await Promise.all(calls.map((call)=>call.prove({
137
- skipPublicSimulation: true
138
- })));
125
+ const [from] = context.accounts;
139
126
  context.logger.info(`Sending ${txCount} txs`);
140
- return provenTxs.map((tx)=>tx.send());
127
+ return calls.map((call)=>call.send({
128
+ from
129
+ }));
141
130
  }
142
131
  export async function waitTxs(txs, context, txWaitOpts) {
143
132
  context.logger.info(`Awaiting ${txs.length} txs to be mined`);
144
133
  await Promise.all(txs.map((tx)=>tx.wait(txWaitOpts)));
145
134
  context.logger.info(`All ${txs.length} txs have been mined`);
146
135
  }
147
- /**
148
- * Creates a new PXE
149
- * @param node - Node to connect the pxe to.
150
- * @param contract - Benchmark contract to add to the pxe.
151
- * @param startingBlock - First l2 block to process.
152
- * @returns The new PXE.
153
- */ export async function createNewPXE(node, contract, startingBlock = INITIAL_L2_BLOCK_NUM) {
154
- const l1Contracts = await node.getL1ContractAddresses();
155
- const { l1ChainId, protocolVersion } = await node.getNodeInfo();
156
- const pxeConfig = {
157
- l2StartingBlock: startingBlock,
158
- l2BlockPollingIntervalMS: 100,
159
- dataDirectory: undefined,
160
- dataStoreMapSizeKB: 1024 * 1024,
161
- l1Contracts,
162
- l1ChainId,
163
- version: protocolVersion
164
- };
165
- const pxe = await createPXEService(node, pxeConfig);
166
- await pxe.registerContract(contract);
167
- return pxe;
168
- }
169
136
  function randomBytesAsBigInts(length) {
170
137
  return [
171
138
  ...Array(length)
@@ -1,6 +1,13 @@
1
- import { type AccountWallet, type CompleteAddress, Fr, type Logger, type TxHash } from '@aztec/aztec.js';
2
- import { DocsExampleContract } from '@aztec/noir-contracts.js/DocsExample';
1
+ import { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import { Fr } from '@aztec/aztec.js/fields';
3
+ import { type Logger } from '@aztec/aztec.js/log';
4
+ import type { AztecNode } from '@aztec/aztec.js/node';
5
+ import type { TxHash } from '@aztec/aztec.js/tx';
6
+ import type { CheatCodes } from '@aztec/aztec/testing';
3
7
  import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
8
+ import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
9
+ import type { SequencerClient } from '@aztec/sequencer-client';
10
+ import type { TestWallet } from '@aztec/test-wallet/server';
4
11
  import { type SubsystemsContext } from '../fixtures/snapshot_manager.js';
5
12
  import { TokenSimulator } from '../simulators/token_simulator.js';
6
13
  export declare class Role {
@@ -17,20 +24,21 @@ export declare class Role {
17
24
  };
18
25
  }
19
26
  export declare class BlacklistTokenContractTest {
20
- #private;
21
- static DELAY: number;
27
+ static CHANGE_ROLES_DELAY: number;
22
28
  private snapshotManager;
23
29
  logger: Logger;
24
- wallets: AccountWallet[];
25
- accounts: CompleteAddress[];
30
+ wallet: TestWallet;
26
31
  asset: TokenBlacklistContract;
27
32
  tokenSim: TokenSimulator;
28
- badAccount: DocsExampleContract;
29
- admin: AccountWallet;
30
- other: AccountWallet;
31
- blacklisted: AccountWallet;
33
+ badAccount: InvalidAccountContract;
34
+ cheatCodes: CheatCodes;
35
+ sequencer: SequencerClient;
36
+ aztecNode: AztecNode;
37
+ adminAddress: AztecAddress;
38
+ otherAddress: AztecAddress;
39
+ blacklistedAddress: AztecAddress;
32
40
  constructor(testName: string);
33
- mineBlocks(amount?: number): Promise<void>;
41
+ crossTimestampOfChange(): Promise<void>;
34
42
  /**
35
43
  * Adds two state shifts to snapshot manager.
36
44
  * 1. Add 3 accounts.
@@ -40,7 +48,7 @@ export declare class BlacklistTokenContractTest {
40
48
  setup(): Promise<void>;
41
49
  snapshot: <T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>) => Promise<void>;
42
50
  teardown(): Promise<void>;
43
- addPendingShieldNoteToPXE(contract: TokenBlacklistContract, wallet: AccountWallet, amount: bigint, secretHash: Fr, txHash: TxHash): Promise<void>;
51
+ addPendingShieldNoteToPXE(contract: TokenBlacklistContract, recipient: AztecAddress, amount: bigint, secretHash: Fr, txHash: TxHash): Promise<void>;
44
52
  applyMintSnapshot(): Promise<void>;
45
53
  }
46
- //# sourceMappingURL=blacklist_token_contract_test.d.ts.map
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxhY2tsaXN0X3Rva2VuX2NvbnRyYWN0X3Rlc3QuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lMmVfYmxhY2tsaXN0X3Rva2VuX2NvbnRyYWN0L2JsYWNrbGlzdF90b2tlbl9jb250cmFjdF90ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV6RCxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUMsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXZELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ3RGLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQy9ELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBSTVELE9BQU8sRUFFTCxLQUFLLGlCQUFpQixFQUl2QixNQUFNLGlDQUFpQyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUlsRSxxQkFBYSxJQUFJO0lBQ2YsT0FBTyxDQUFDLE9BQU8sQ0FBUztJQUN4QixPQUFPLENBQUMsUUFBUSxDQUFTO0lBQ3pCLE9BQU8sQ0FBQyxhQUFhLENBQVM7SUFFOUIsU0FBUyxTQUdSO0lBRUQsVUFBVSxTQUdUO0lBRUQsZUFBZSxTQUdkO0lBRUQsWUFBWTs7OztNQUlYO0NBQ0Y7QUFFRCxxQkFBYSwwQkFBMEI7SUFFckMsTUFBTSxDQUFDLGtCQUFrQixTQUFTO0lBRWxDLE9BQU8sQ0FBQyxlQUFlLENBQW1CO0lBQzFDLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDZixNQUFNLEVBQUcsVUFBVSxDQUFDO0lBQ3BCLEtBQUssRUFBRyxzQkFBc0IsQ0FBQztJQUMvQixRQUFRLEVBQUcsY0FBYyxDQUFDO0lBQzFCLFVBQVUsRUFBRyxzQkFBc0IsQ0FBQztJQUNwQyxVQUFVLEVBQUcsVUFBVSxDQUFDO0lBQ3hCLFNBQVMsRUFBRyxlQUFlLENBQUM7SUFDNUIsU0FBUyxFQUFHLFNBQVMsQ0FBQztJQUV0QixZQUFZLEVBQUcsWUFBWSxDQUFDO0lBQzVCLFlBQVksRUFBRyxZQUFZLENBQUM7SUFDNUIsa0JBQWtCLEVBQUcsWUFBWSxDQUFDO0lBRWxDLFlBQVksUUFBUSxFQUFFLE1BQU0sRUFHM0I7SUFFSyxzQkFBc0Isa0JBTTNCO0lBRUQ7Ozs7T0FJRztJQUNHLGtCQUFrQixrQkE4RHZCO0lBRUssS0FBSyxrQkFFVjtJQUVELFFBQVEsR0FBSSxDQUFDLDhKQUkyRDtJQUVsRSxRQUFRLGtCQUViO0lBRUsseUJBQXlCLENBQzdCLFFBQVEsRUFBRSxzQkFBc0IsRUFDaEMsU0FBUyxFQUFFLFlBQVksRUFDdkIsTUFBTSxFQUFFLE1BQU0sRUFDZCxVQUFVLEVBQUUsRUFBRSxFQUNkLE1BQU0sRUFBRSxNQUFNLGlCQWNmO0lBRUssaUJBQWlCLGtCQWtFdEI7Q0FDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"blacklist_token_contract_test.d.ts","sourceRoot":"","sources":["../../src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,eAAe,EACpB,EAAE,EACF,KAAK,MAAM,EACX,KAAK,MAAM,EAGZ,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAE3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AAIjF,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAIlE,qBAAa,IAAI;IACf,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,aAAa,CAAS;IAE9B,SAAS;IAKT,UAAU;IAKV,eAAe;IAKf,YAAY;;;;;CAKb;AAED,qBAAa,0BAA0B;;IAGrC,MAAM,CAAC,KAAK,SAAK;IAEjB,OAAO,CAAC,eAAe,CAAmB;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,aAAa,EAAE,CAAM;IAC9B,QAAQ,EAAE,eAAe,EAAE,CAAM;IACjC,KAAK,EAAG,sBAAsB,CAAC;IAC/B,QAAQ,EAAG,cAAc,CAAC;IAC1B,UAAU,EAAG,mBAAmB,CAAC;IAEjC,KAAK,EAAG,aAAa,CAAC;IACtB,KAAK,EAAG,aAAa,CAAC;IACtB,WAAW,EAAG,aAAa,CAAC;gBAEhB,QAAQ,EAAE,MAAM;IAKtB,UAAU,CAAC,MAAM,GAAE,MAAyC;IAMlE;;;;OAIG;IACG,kBAAkB;IA0DlB,KAAK;IAIX,QAAQ,YACA,MAAM,SACL,CAAC,OAAO,EAAE,iBAAiB,KAAK,QAAQ,CAAC,CAAC,YACxC,CAAC,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,KAAK,QAAQ,IAAI,CAAC,KACtE,QAAQ,IAAI,CAAC,CAAwD;IAElE,QAAQ;IAQR,yBAAyB,CAC7B,QAAQ,EAAE,sBAAsB,EAChC,MAAM,EAAE,aAAa,EACrB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,EAAE,EACd,MAAM,EAAE,MAAM;IAgBV,iBAAiB;CAmExB"}
1
+ {"version":3,"file":"blacklist_token_contract_test.d.ts","sourceRoot":"","sources":["../../src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAEzD,OAAO,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAC5C,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAEvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;AACtF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAI5D,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAIlE,qBAAa,IAAI;IACf,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,aAAa,CAAS;IAE9B,SAAS,SAGR;IAED,UAAU,SAGT;IAED,eAAe,SAGd;IAED,YAAY;;;;MAIX;CACF;AAED,qBAAa,0BAA0B;IAErC,MAAM,CAAC,kBAAkB,SAAS;IAElC,OAAO,CAAC,eAAe,CAAmB;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAG,UAAU,CAAC;IACpB,KAAK,EAAG,sBAAsB,CAAC;IAC/B,QAAQ,EAAG,cAAc,CAAC;IAC1B,UAAU,EAAG,sBAAsB,CAAC;IACpC,UAAU,EAAG,UAAU,CAAC;IACxB,SAAS,EAAG,eAAe,CAAC;IAC5B,SAAS,EAAG,SAAS,CAAC;IAEtB,YAAY,EAAG,YAAY,CAAC;IAC5B,YAAY,EAAG,YAAY,CAAC;IAC5B,kBAAkB,EAAG,YAAY,CAAC;IAElC,YAAY,QAAQ,EAAE,MAAM,EAG3B;IAEK,sBAAsB,kBAM3B;IAED;;;;OAIG;IACG,kBAAkB,kBA8DvB;IAEK,KAAK,kBAEV;IAED,QAAQ,GAAI,CAAC,8JAI2D;IAElE,QAAQ,kBAEb;IAEK,yBAAyB,CAC7B,QAAQ,EAAE,sBAAsB,EAChC,SAAS,EAAE,YAAY,EACvB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,EAAE,EACd,MAAM,EAAE,MAAM,iBAcf;IAEK,iBAAiB,kBAkEtB;CACF"}
@@ -1,8 +1,8 @@
1
- import { getSchnorrWallet } from '@aztec/accounts/schnorr';
2
- import { Fr, computeSecretHash, createLogger } from '@aztec/aztec.js';
3
- import { MAX_NOTE_HASHES_PER_TX } from '@aztec/constants';
4
- import { DocsExampleContract } from '@aztec/noir-contracts.js/DocsExample';
1
+ import { computeSecretHash } from '@aztec/aztec.js/crypto';
2
+ import { Fr } from '@aztec/aztec.js/fields';
3
+ import { createLogger } from '@aztec/aztec.js/log';
5
4
  import { TokenBlacklistContract } from '@aztec/noir-contracts.js/TokenBlacklist';
5
+ import { InvalidAccountContract } from '@aztec/noir-test-contracts.js/InvalidAccount';
6
6
  import { jest } from '@jest/globals';
7
7
  import { createSnapshotManager, deployAccounts, publicDeployAccounts } from '../fixtures/snapshot_manager.js';
8
8
  import { TokenSimulator } from '../simulators/token_simulator.js';
@@ -34,27 +34,26 @@ export class Role {
34
34
  }
35
35
  }
36
36
  export class BlacklistTokenContractTest {
37
- // A low delay is really poor ux, but we need to keep it low for the tests to run "quickly".
38
37
  // This value MUST match the same value that we have in the contract
39
- static DELAY = 2;
38
+ static CHANGE_ROLES_DELAY = 86400;
40
39
  snapshotManager;
41
40
  logger;
42
- wallets = [];
43
- accounts = [];
41
+ wallet;
44
42
  asset;
45
43
  tokenSim;
46
44
  badAccount;
47
- admin;
48
- other;
49
- blacklisted;
45
+ cheatCodes;
46
+ sequencer;
47
+ aztecNode;
48
+ adminAddress;
49
+ otherAddress;
50
+ blacklistedAddress;
50
51
  constructor(testName){
51
52
  this.logger = createLogger(`e2e:e2e_blacklist_token_contract:${testName}`);
52
53
  this.snapshotManager = createSnapshotManager(`e2e_blacklist_token_contract/${testName}`, dataPath);
53
54
  }
54
- async mineBlocks(amount = BlacklistTokenContractTest.DELAY) {
55
- for(let i = 0; i < amount; ++i){
56
- await this.asset.methods.get_roles(this.admin.getAddress()).send().wait();
57
- }
55
+ async crossTimestampOfChange() {
56
+ await this.cheatCodes.warpL2TimeAtLeastBy(this.sequencer, this.aztecNode, BlacklistTokenContractTest.CHANGE_ROLES_DELAY);
58
57
  }
59
58
  /**
60
59
  * Adds two state shifts to snapshot manager.
@@ -63,37 +62,54 @@ export class BlacklistTokenContractTest {
63
62
  */ async applyBaseSnapshots() {
64
63
  // Adding a timeout of 2 minutes in here such that it is propagated to the underlying tests
65
64
  jest.setTimeout(120_000);
66
- await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger), async ({ deployedAccounts }, { pxe })=>{
67
- this.wallets = await Promise.all(deployedAccounts.map((a)=>getSchnorrWallet(pxe, a.address, a.signingKey)));
68
- this.admin = this.wallets[0];
69
- this.other = this.wallets[1];
70
- this.blacklisted = this.wallets[2];
71
- this.accounts = this.wallets.map((w)=>w.getCompleteAddress());
65
+ await this.snapshotManager.snapshot('3_accounts', deployAccounts(3, this.logger), ({ deployedAccounts }, { cheatCodes, aztecNode, sequencer, wallet })=>{
66
+ this.cheatCodes = cheatCodes;
67
+ this.aztecNode = aztecNode;
68
+ this.sequencer = sequencer;
69
+ this.wallet = wallet;
70
+ this.adminAddress = deployedAccounts[0].address;
71
+ this.otherAddress = deployedAccounts[1].address;
72
+ this.blacklistedAddress = deployedAccounts[2].address;
73
+ return Promise.resolve();
72
74
  });
73
75
  await this.snapshotManager.snapshot('e2e_blacklist_token_contract', async ()=>{
74
76
  // Create the token contract state.
75
77
  // Move this account thing to addAccounts above?
76
78
  this.logger.verbose(`Public deploy accounts...`);
77
- await publicDeployAccounts(this.wallets[0], this.accounts.slice(0, 3));
79
+ await publicDeployAccounts(this.wallet, [
80
+ this.adminAddress,
81
+ this.otherAddress,
82
+ this.blacklistedAddress
83
+ ]);
78
84
  this.logger.verbose(`Deploying TokenContract...`);
79
- this.asset = await TokenBlacklistContract.deploy(this.admin, this.admin.getAddress()).send().deployed();
85
+ this.asset = await TokenBlacklistContract.deploy(this.wallet, this.adminAddress).send({
86
+ from: this.adminAddress
87
+ }).deployed();
80
88
  this.logger.verbose(`Token deployed to ${this.asset.address}`);
81
89
  this.logger.verbose(`Deploying bad account...`);
82
- this.badAccount = await DocsExampleContract.deploy(this.wallets[0]).send().deployed();
90
+ this.badAccount = await InvalidAccountContract.deploy(this.wallet).send({
91
+ from: this.adminAddress
92
+ }).deployed();
83
93
  this.logger.verbose(`Deployed to ${this.badAccount.address}.`);
84
- await this.mineBlocks();
94
+ await this.crossTimestampOfChange();
85
95
  return {
86
96
  tokenContractAddress: this.asset.address,
87
97
  badAccountAddress: this.badAccount.address
88
98
  };
89
99
  }, async ({ tokenContractAddress, badAccountAddress })=>{
90
100
  // Restore the token contract state.
91
- this.asset = await TokenBlacklistContract.at(tokenContractAddress, this.wallets[0]);
101
+ this.asset = TokenBlacklistContract.at(tokenContractAddress, this.wallet);
92
102
  this.logger.verbose(`Token contract address: ${this.asset.address}`);
93
- this.tokenSim = new TokenSimulator(this.asset, this.wallets[0], this.logger, this.accounts.map((a)=>a.address));
94
- this.badAccount = await DocsExampleContract.at(badAccountAddress, this.wallets[0]);
103
+ this.tokenSim = new TokenSimulator(this.asset, this.wallet, this.adminAddress, this.logger, [
104
+ this.adminAddress,
105
+ this.otherAddress,
106
+ this.blacklistedAddress
107
+ ]);
108
+ this.badAccount = InvalidAccountContract.at(badAccountAddress, this.wallet);
95
109
  this.logger.verbose(`Bad account address: ${this.badAccount.address}`);
96
- expect(await this.asset.methods.get_roles(this.admin.getAddress()).simulate()).toEqual(new Role().withAdmin().toNoirStruct());
110
+ expect(await this.asset.methods.get_roles(this.adminAddress).simulate({
111
+ from: this.adminAddress
112
+ })).toEqual(new Role().withAdmin().toNoirStruct());
97
113
  });
98
114
  }
99
115
  async setup() {
@@ -103,52 +119,64 @@ export class BlacklistTokenContractTest {
103
119
  async teardown() {
104
120
  await this.snapshotManager.teardown();
105
121
  }
106
- #toBoundedVec(arr, maxLen) {
107
- return {
108
- len: arr.length,
109
- storage: arr.concat(new Array(maxLen - arr.length).fill(new Fr(0)))
110
- };
111
- }
112
- async addPendingShieldNoteToPXE(contract, wallet, amount, secretHash, txHash) {
113
- const txEffects = await wallet.getTxEffect(txHash);
114
- await contract.methods.deliver_transparent_note(contract.address, amount, secretHash, txHash.hash, this.#toBoundedVec(txEffects.data.noteHashes, MAX_NOTE_HASHES_PER_TX), txEffects.data.nullifiers[0], wallet.getAddress()).simulate();
122
+ async addPendingShieldNoteToPXE(contract, recipient, amount, secretHash, txHash) {
123
+ const txEffects = await this.aztecNode.getTxEffect(txHash);
124
+ await contract.methods.deliver_transparent_note(contract.address, amount, secretHash, txHash.hash, txEffects.data.noteHashes, txEffects.data.nullifiers[0], recipient).simulate({
125
+ from: recipient
126
+ });
115
127
  }
116
128
  async applyMintSnapshot() {
117
129
  await this.snapshotManager.snapshot('mint', async ()=>{
118
- const { asset, accounts, wallets } = this;
130
+ const { asset } = this;
119
131
  const amount = 10000n;
120
132
  const adminMinterRole = new Role().withAdmin().withMinter();
121
- await this.asset.withWallet(this.admin).methods.update_roles(this.admin.getAddress(), adminMinterRole.toNoirStruct()).send().wait();
133
+ await this.asset.methods.update_roles(this.adminAddress, adminMinterRole.toNoirStruct()).send({
134
+ from: this.adminAddress
135
+ }).wait();
122
136
  const blacklistRole = new Role().withBlacklisted();
123
- await this.asset.withWallet(this.admin).methods.update_roles(this.blacklisted.getAddress(), blacklistRole.toNoirStruct()).send().wait();
124
- await this.mineBlocks(); // This gets us past the block of change
125
- expect(await this.asset.methods.get_roles(this.admin.getAddress()).simulate()).toEqual(adminMinterRole.toNoirStruct());
137
+ await this.asset.methods.update_roles(this.blacklistedAddress, blacklistRole.toNoirStruct()).send({
138
+ from: this.adminAddress
139
+ }).wait();
140
+ await this.crossTimestampOfChange();
141
+ expect(await this.asset.methods.get_roles(this.adminAddress).simulate({
142
+ from: this.adminAddress
143
+ })).toEqual(adminMinterRole.toNoirStruct());
126
144
  this.logger.verbose(`Minting ${amount} publicly...`);
127
- await asset.methods.mint_public(accounts[0].address, amount).send().wait();
145
+ await asset.methods.mint_public(this.adminAddress, amount).send({
146
+ from: this.adminAddress
147
+ }).wait();
128
148
  this.logger.verbose(`Minting ${amount} privately...`);
129
149
  const secret = Fr.random();
130
150
  const secretHash = await computeSecretHash(secret);
131
- const receipt = await asset.methods.mint_private(amount, secretHash).send().wait();
132
- await this.addPendingShieldNoteToPXE(asset, wallets[0], amount, secretHash, receipt.txHash);
133
- const txClaim = asset.methods.redeem_shield(accounts[0].address, amount, secret).send();
134
- await txClaim.wait({
135
- debug: true
151
+ const receipt = await asset.methods.mint_private(amount, secretHash).send({
152
+ from: this.adminAddress
153
+ }).wait();
154
+ await this.addPendingShieldNoteToPXE(asset, this.adminAddress, amount, secretHash, receipt.txHash);
155
+ const txClaim = asset.methods.redeem_shield(this.adminAddress, amount, secret).send({
156
+ from: this.adminAddress
136
157
  });
158
+ await txClaim.wait();
137
159
  this.logger.verbose(`Minting complete.`);
138
160
  return {
139
161
  amount
140
162
  };
141
163
  }, async ({ amount })=>{
142
- const { asset, accounts: [{ address }], tokenSim } = this;
143
- tokenSim.mintPublic(address, amount);
144
- const publicBalance = await asset.methods.balance_of_public(address).simulate();
164
+ const { asset, tokenSim } = this;
165
+ tokenSim.mintPublic(this.adminAddress, amount);
166
+ const publicBalance = await asset.methods.balance_of_public(this.adminAddress).simulate({
167
+ from: this.adminAddress
168
+ });
145
169
  this.logger.verbose(`Public balance of wallet 0: ${publicBalance}`);
146
- expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(address));
147
- tokenSim.mintPrivate(address, amount);
148
- const privateBalance = await asset.methods.balance_of_private(address).simulate();
170
+ expect(publicBalance).toEqual(this.tokenSim.balanceOfPublic(this.adminAddress));
171
+ tokenSim.mintPrivate(this.adminAddress, amount);
172
+ const privateBalance = await asset.methods.balance_of_private(this.adminAddress).simulate({
173
+ from: this.adminAddress
174
+ });
149
175
  this.logger.verbose(`Private balance of wallet 0: ${privateBalance}`);
150
- expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(address));
151
- const totalSupply = await asset.methods.total_supply().simulate();
176
+ expect(privateBalance).toEqual(tokenSim.balanceOfPrivate(this.adminAddress));
177
+ const totalSupply = await asset.methods.total_supply().simulate({
178
+ from: this.adminAddress
179
+ });
152
180
  this.logger.verbose(`Total supply: ${totalSupply}`);
153
181
  expect(totalSupply).toEqual(tokenSim.totalSupply);
154
182
  return Promise.resolve();
@@ -1,47 +1,48 @@
1
1
  import type { AztecNodeConfig } from '@aztec/aztec-node';
2
- import { type AccountWallet, AztecAddress, type AztecNode, CheatCodes, type CompleteAddress, EthAddress, type Logger, type PXE } from '@aztec/aztec.js';
3
- import { type ViemPublicClient } from '@aztec/ethereum';
2
+ import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
3
+ import { type Logger } from '@aztec/aztec.js/log';
4
+ import type { AztecNode } from '@aztec/aztec.js/node';
5
+ import type { TxReceipt } from '@aztec/aztec.js/tx';
6
+ import { CheatCodes } from '@aztec/aztec/testing';
7
+ import { InboxContract, OutboxContract, RollupContract } from '@aztec/ethereum/contracts';
8
+ import type { DeployAztecL1ContractsArgs, DeployAztecL1ContractsReturnType } from '@aztec/ethereum/deploy-aztec-l1-contracts';
9
+ import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
10
+ import { EpochNumber } from '@aztec/foundation/branded-types';
4
11
  import { TokenContract } from '@aztec/noir-contracts.js/Token';
5
12
  import { TokenBridgeContract } from '@aztec/noir-contracts.js/TokenBridge';
13
+ import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
14
+ import type { TestWallet } from '@aztec/test-wallet/server';
6
15
  import { type SubsystemsContext } from '../fixtures/snapshot_manager.js';
16
+ import type { SetupOptions } from '../fixtures/utils.js';
7
17
  import { CrossChainTestHarness } from '../shared/cross_chain_test_harness.js';
8
18
  export declare class CrossChainMessagingTest {
9
19
  private snapshotManager;
20
+ private requireEpochProven;
10
21
  logger: Logger;
11
- wallets: AccountWallet[];
12
- accounts: CompleteAddress[];
13
22
  aztecNode: AztecNode;
14
- pxe: PXE;
15
23
  aztecNodeConfig: AztecNodeConfig;
16
- publicClient: ViemPublicClient | undefined;
17
- user1Wallet: AccountWallet;
18
- user2Wallet: AccountWallet;
24
+ aztecNodeAdmin: AztecNodeAdmin;
25
+ ctx: SubsystemsContext;
26
+ l1Client: ExtendedViemWalletClient | undefined;
27
+ wallet: TestWallet;
28
+ ownerAddress: AztecAddress;
29
+ user1Address: AztecAddress;
30
+ user2Address: AztecAddress;
19
31
  crossChainTestHarness: CrossChainTestHarness;
20
32
  ethAccount: EthAddress;
21
- ownerAddress: AztecAddress;
22
33
  l2Token: TokenContract;
23
34
  l2Bridge: TokenBridgeContract;
24
- rollup: any;
25
- inbox: any;
26
- outbox: any;
27
- cheatcodes: CheatCodes;
28
- constructor(testName: string);
29
- assumeProven(): Promise<void>;
35
+ rollup: RollupContract;
36
+ inbox: InboxContract;
37
+ outbox: OutboxContract;
38
+ cheatCodes: CheatCodes;
39
+ deployL1ContractsValues: DeployAztecL1ContractsReturnType;
40
+ constructor(testName: string, opts?: SetupOptions, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>);
30
41
  setup(): Promise<void>;
42
+ advanceToEpochProven(l2TxReceipt: TxReceipt): Promise<EpochNumber>;
43
+ catchUpProvenChain(): Promise<void>;
31
44
  snapshot: <T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>) => Promise<void>;
32
45
  teardown(): Promise<void>;
33
46
  applyBaseSnapshots(): Promise<void>;
34
- toCrossChainContext(): CrossChainContext;
35
47
  }
36
- type CrossChainContext = {
37
- l2Token: AztecAddress;
38
- l2Bridge: AztecAddress;
39
- tokenPortal: EthAddress;
40
- underlying: EthAddress;
41
- ethAccount: EthAddress;
42
- ownerAddress: AztecAddress;
43
- inbox: EthAddress;
44
- outbox: EthAddress;
45
- };
46
- export {};
47
- //# sourceMappingURL=cross_chain_messaging_test.d.ts.map
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Jvc3NfY2hhaW5fbWVzc2FnaW5nX3Rlc3QuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lMmVfY3Jvc3NfY2hhaW5fbWVzc2FnaW5nL2Nyb3NzX2NoYWluX21lc3NhZ2luZ190ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFckUsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFnQixNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUVsRCxPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRixPQUFPLEtBQUssRUFDViwwQkFBMEIsRUFDMUIsZ0NBQWdDLEVBQ2pDLE1BQU0sMkNBQTJDLENBQUM7QUFFbkQsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RSxPQUFPLEVBQW9CLFdBQVcsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBR2hGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMvRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUc1RCxPQUFPLEVBRUwsS0FBSyxpQkFBaUIsRUFJdkIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUk5RSxxQkFBYSx1QkFBdUI7SUFDbEMsT0FBTyxDQUFDLGVBQWUsQ0FBbUI7SUFDMUMsT0FBTyxDQUFDLGtCQUFrQixDQUFVO0lBQ3BDLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDZixTQUFTLEVBQUcsU0FBUyxDQUFDO0lBQ3RCLGVBQWUsRUFBRyxlQUFlLENBQUM7SUFDbEMsY0FBYyxFQUFHLGNBQWMsQ0FBQztJQUNoQyxHQUFHLEVBQUcsaUJBQWlCLENBQUM7SUFFeEIsUUFBUSxFQUFHLHdCQUF3QixHQUFHLFNBQVMsQ0FBQztJQUVoRCxNQUFNLEVBQUcsVUFBVSxDQUFDO0lBQ3BCLFlBQVksRUFBRyxZQUFZLENBQUM7SUFDNUIsWUFBWSxFQUFHLFlBQVksQ0FBQztJQUM1QixZQUFZLEVBQUcsWUFBWSxDQUFDO0lBQzVCLHFCQUFxQixFQUFHLHFCQUFxQixDQUFDO0lBQzlDLFVBQVUsRUFBRyxVQUFVLENBQUM7SUFDeEIsT0FBTyxFQUFHLGFBQWEsQ0FBQztJQUN4QixRQUFRLEVBQUcsbUJBQW1CLENBQUM7SUFFL0IsTUFBTSxFQUFHLGNBQWMsQ0FBQztJQUN4QixLQUFLLEVBQUcsYUFBYSxDQUFDO0lBQ3RCLE1BQU0sRUFBRyxjQUFjLENBQUM7SUFDeEIsVUFBVSxFQUFHLFVBQVUsQ0FBQztJQUV4Qix1QkFBdUIsRUFBRyxnQ0FBZ0MsQ0FBQztJQUUzRCxZQUNFLFFBQVEsRUFBRSxNQUFNLEVBQ2hCLElBQUksR0FBRSxZQUFpQixFQUN2QixxQkFBcUIsR0FBRSxPQUFPLENBQUMsMEJBQTBCLENBQU0sRUFRaEU7SUFFSyxLQUFLLGtCQWFWO0lBRUssb0JBQW9CLENBQUMsV0FBVyxFQUFFLFNBQVMsR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLENBVXZFO0lBRUssa0JBQWtCLGtCQUt2QjtJQUVELFFBQVEsR0FBSSxDQUFDLDhKQUkyRDtJQUVsRSxRQUFRLGtCQUViO0lBRUssa0JBQWtCLGtCQStFdkI7Q0FDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"cross_chain_messaging_test.d.ts","sourceRoot":"","sources":["../../src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EACL,KAAK,aAAa,EAClB,YAAY,EACZ,KAAK,SAAS,EACd,UAAU,EACV,KAAK,eAAe,EACpB,UAAU,EACV,KAAK,MAAM,EACX,KAAK,GAAG,EAET,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,KAAK,gBAAgB,EAAqC,MAAM,iBAAiB,CAAC;AAE3F,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAK3E,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAI9E,qBAAa,uBAAuB;IAClC,OAAO,CAAC,eAAe,CAAmB;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,aAAa,EAAE,CAAM;IAC9B,QAAQ,EAAE,eAAe,EAAE,CAAM;IACjC,SAAS,EAAG,SAAS,CAAC;IACtB,GAAG,EAAG,GAAG,CAAC;IACV,eAAe,EAAG,eAAe,CAAC;IAElC,YAAY,EAAG,gBAAgB,GAAG,SAAS,CAAC;IAE5C,WAAW,EAAG,aAAa,CAAC;IAC5B,WAAW,EAAG,aAAa,CAAC;IAC5B,qBAAqB,EAAG,qBAAqB,CAAC;IAC9C,UAAU,EAAG,UAAU,CAAC;IACxB,YAAY,EAAG,YAAY,CAAC;IAC5B,OAAO,EAAG,aAAa,CAAC;IACxB,QAAQ,EAAG,mBAAmB,CAAC;IAE/B,MAAM,EAAG,GAAG,CAAC;IACb,KAAK,EAAG,GAAG,CAAC;IACZ,MAAM,EAAG,GAAG,CAAC;IACb,UAAU,EAAG,UAAU,CAAC;gBAEZ,QAAQ,EAAE,MAAM;IAKtB,YAAY;IAIZ,KAAK;IAQX,QAAQ,YACA,MAAM,SACL,CAAC,OAAO,EAAE,iBAAiB,KAAK,QAAQ,CAAC,CAAC,YACxC,CAAC,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,KAAK,QAAQ,IAAI,CAAC,KACtE,QAAQ,IAAI,CAAC,CAAwD;IAElE,QAAQ;IAIR,kBAAkB;IAiHxB,mBAAmB,IAAI,iBAAiB;CAYzC;AAED,KAAK,iBAAiB,GAAG;IACvB,OAAO,EAAE,YAAY,CAAC;IACtB,QAAQ,EAAE,YAAY,CAAC;IACvB,WAAW,EAAE,UAAU,CAAC;IACxB,UAAU,EAAE,UAAU,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;IACvB,YAAY,EAAE,YAAY,CAAC;IAC3B,KAAK,EAAE,UAAU,CAAC;IAClB,MAAM,EAAE,UAAU,CAAC;CACpB,CAAC"}
1
+ {"version":3,"file":"cross_chain_messaging_test.d.ts","sourceRoot":"","sources":["../../src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAErE,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,qBAAqB,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC1F,OAAO,KAAK,EACV,0BAA0B,EAC1B,gCAAgC,EACjC,MAAM,2CAA2C,CAAC;AAEnD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAoB,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAGhF,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACtE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAG5D,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAI9E,qBAAa,uBAAuB;IAClC,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,kBAAkB,CAAU;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAG,SAAS,CAAC;IACtB,eAAe,EAAG,eAAe,CAAC;IAClC,cAAc,EAAG,cAAc,CAAC;IAChC,GAAG,EAAG,iBAAiB,CAAC;IAExB,QAAQ,EAAG,wBAAwB,GAAG,SAAS,CAAC;IAEhD,MAAM,EAAG,UAAU,CAAC;IACpB,YAAY,EAAG,YAAY,CAAC;IAC5B,YAAY,EAAG,YAAY,CAAC;IAC5B,YAAY,EAAG,YAAY,CAAC;IAC5B,qBAAqB,EAAG,qBAAqB,CAAC;IAC9C,UAAU,EAAG,UAAU,CAAC;IACxB,OAAO,EAAG,aAAa,CAAC;IACxB,QAAQ,EAAG,mBAAmB,CAAC;IAE/B,MAAM,EAAG,cAAc,CAAC;IACxB,KAAK,EAAG,aAAa,CAAC;IACtB,MAAM,EAAG,cAAc,CAAC;IACxB,UAAU,EAAG,UAAU,CAAC;IAExB,uBAAuB,EAAG,gCAAgC,CAAC;IAE3D,YACE,QAAQ,EAAE,MAAM,EAChB,IAAI,GAAE,YAAiB,EACvB,qBAAqB,GAAE,OAAO,CAAC,0BAA0B,CAAM,EAQhE;IAEK,KAAK,kBAaV;IAEK,oBAAoB,CAAC,WAAW,EAAE,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAUvE;IAEK,kBAAkB,kBAKvB;IAED,QAAQ,GAAI,CAAC,8JAI2D;IAElE,QAAQ,kBAEb;IAEK,kBAAkB,kBA+EvB;CACF"}