@aztec/end-to-end 0.0.1-commit.6230efd → 0.0.1-commit.64b6bbb

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 (196) 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 +12 -13
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +118 -133
  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/client_flows/data_extractor.js +3 -1
  11. package/dest/bench/utils.d.ts +9 -8
  12. package/dest/bench/utils.d.ts.map +1 -1
  13. package/dest/bench/utils.js +17 -12
  14. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -7
  15. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  16. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +96 -112
  17. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +15 -10
  18. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  19. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +90 -70
  20. package/dest/e2e_deploy_contract/deploy_test.d.ts +4 -3
  21. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  22. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  23. package/dest/e2e_epochs/epochs_test.d.ts +7 -1
  24. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  25. package/dest/e2e_epochs/epochs_test.js +40 -12
  26. package/dest/e2e_fees/bridging_race.notest.js +3 -5
  27. package/dest/e2e_fees/fees_test.d.ts +13 -13
  28. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  29. package/dest/e2e_fees/fees_test.js +123 -141
  30. package/dest/e2e_l1_publisher/write_json.d.ts +4 -3
  31. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  32. package/dest/e2e_l1_publisher/write_json.js +14 -16
  33. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  34. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  35. package/dest/e2e_nested_contract/nested_contract_test.js +31 -39
  36. package/dest/e2e_p2p/inactivity_slash_test.d.ts +3 -3
  37. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  38. package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
  39. package/dest/e2e_p2p/p2p_network.d.ts +7 -6
  40. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  41. package/dest/e2e_p2p/p2p_network.js +111 -104
  42. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  43. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  44. package/dest/e2e_p2p/reqresp/utils.js +153 -0
  45. package/dest/e2e_p2p/shared.d.ts +6 -6
  46. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  47. package/dest/e2e_p2p/shared.js +16 -20
  48. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  49. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  50. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  51. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  52. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  53. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  54. package/dest/e2e_token_contract/token_contract_test.d.ts +16 -9
  55. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  56. package/dest/e2e_token_contract/token_contract_test.js +89 -91
  57. package/dest/fixtures/e2e_prover_test.d.ts +8 -14
  58. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  59. package/dest/fixtures/e2e_prover_test.js +86 -95
  60. package/dest/fixtures/ha_setup.d.ts +71 -0
  61. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  62. package/dest/fixtures/ha_setup.js +114 -0
  63. package/dest/fixtures/index.d.ts +2 -1
  64. package/dest/fixtures/index.d.ts.map +1 -1
  65. package/dest/fixtures/index.js +1 -0
  66. package/dest/fixtures/setup.d.ts +218 -0
  67. package/dest/fixtures/setup.d.ts.map +1 -0
  68. package/dest/fixtures/setup.js +630 -0
  69. package/dest/fixtures/setup_p2p_test.d.ts +12 -8
  70. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  71. package/dest/fixtures/setup_p2p_test.js +29 -21
  72. package/dest/fixtures/token_utils.d.ts +1 -1
  73. package/dest/fixtures/token_utils.d.ts.map +1 -1
  74. package/dest/fixtures/token_utils.js +7 -4
  75. package/dest/fixtures/utils.d.ts +5 -194
  76. package/dest/fixtures/utils.d.ts.map +1 -1
  77. package/dest/fixtures/utils.js +4 -619
  78. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  79. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  80. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  81. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  82. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  83. package/dest/quality_of_service/prometheus_client.js +67 -0
  84. package/dest/shared/cross_chain_test_harness.d.ts +16 -6
  85. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  86. package/dest/shared/cross_chain_test_harness.js +13 -13
  87. package/dest/shared/gas_portal_test_harness.d.ts +11 -1
  88. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  89. package/dest/shared/gas_portal_test_harness.js +1 -1
  90. package/dest/shared/index.d.ts +2 -2
  91. package/dest/shared/index.d.ts.map +1 -1
  92. package/dest/shared/submit-transactions.d.ts +3 -3
  93. package/dest/shared/submit-transactions.d.ts.map +1 -1
  94. package/dest/shared/submit-transactions.js +9 -11
  95. package/dest/shared/uniswap_l1_l2.d.ts +3 -28
  96. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  97. package/dest/shared/uniswap_l1_l2.js +53 -33
  98. package/dest/simulators/lending_simulator.d.ts +5 -1
  99. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  100. package/dest/simulators/lending_simulator.js +2 -2
  101. package/dest/spartan/setup_test_wallets.d.ts +4 -3
  102. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  103. package/dest/spartan/setup_test_wallets.js +61 -34
  104. package/dest/spartan/tx_metrics.d.ts +51 -2
  105. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  106. package/dest/spartan/tx_metrics.js +333 -6
  107. package/dest/spartan/utils/bot.d.ts +27 -0
  108. package/dest/spartan/utils/bot.d.ts.map +1 -0
  109. package/dest/spartan/utils/bot.js +141 -0
  110. package/dest/spartan/utils/chaos.d.ts +79 -0
  111. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  112. package/dest/spartan/utils/chaos.js +142 -0
  113. package/dest/spartan/utils/clients.d.ts +39 -0
  114. package/dest/spartan/utils/clients.d.ts.map +1 -0
  115. package/dest/spartan/utils/clients.js +90 -0
  116. package/dest/spartan/utils/config.d.ts +39 -0
  117. package/dest/spartan/utils/config.d.ts.map +1 -0
  118. package/dest/spartan/utils/config.js +21 -0
  119. package/dest/spartan/utils/health.d.ts +63 -0
  120. package/dest/spartan/utils/health.d.ts.map +1 -0
  121. package/dest/spartan/utils/health.js +202 -0
  122. package/dest/spartan/utils/helm.d.ts +15 -0
  123. package/dest/spartan/utils/helm.d.ts.map +1 -0
  124. package/dest/spartan/utils/helm.js +47 -0
  125. package/dest/spartan/utils/index.d.ts +9 -0
  126. package/dest/spartan/utils/index.d.ts.map +1 -0
  127. package/dest/spartan/utils/index.js +18 -0
  128. package/dest/spartan/utils/k8s.d.ts +126 -0
  129. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  130. package/dest/spartan/utils/k8s.js +375 -0
  131. package/dest/spartan/utils/nodes.d.ts +41 -0
  132. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  133. package/dest/spartan/utils/nodes.js +461 -0
  134. package/dest/spartan/utils/scripts.d.ts +30 -0
  135. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  136. package/dest/spartan/utils/scripts.js +81 -0
  137. package/dest/spartan/utils.d.ts +2 -253
  138. package/dest/spartan/utils.d.ts.map +1 -1
  139. package/dest/spartan/utils.js +1 -892
  140. package/package.json +43 -39
  141. package/src/bench/client_flows/benchmark.ts +24 -2
  142. package/src/bench/client_flows/client_flows_benchmark.ts +138 -204
  143. package/src/bench/client_flows/config.ts +9 -1
  144. package/src/bench/client_flows/data_extractor.ts +1 -1
  145. package/src/bench/utils.ts +21 -15
  146. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +104 -142
  147. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +126 -116
  148. package/src/e2e_deploy_contract/deploy_test.ts +21 -14
  149. package/src/e2e_epochs/epochs_test.ts +73 -37
  150. package/src/e2e_fees/bridging_race.notest.ts +3 -9
  151. package/src/e2e_fees/fees_test.ts +171 -219
  152. package/src/e2e_l1_publisher/write_json.ts +16 -16
  153. package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
  154. package/src/e2e_p2p/inactivity_slash_test.ts +3 -3
  155. package/src/e2e_p2p/p2p_network.ts +172 -168
  156. package/src/e2e_p2p/reqresp/utils.ts +207 -0
  157. package/src/e2e_p2p/shared.ts +27 -27
  158. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  159. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  160. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  161. package/src/e2e_token_contract/token_contract_test.ts +103 -118
  162. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  163. package/src/fixtures/e2e_prover_test.ts +97 -132
  164. package/src/fixtures/ha_setup.ts +184 -0
  165. package/src/fixtures/index.ts +1 -0
  166. package/src/fixtures/setup.ts +932 -0
  167. package/src/fixtures/setup_p2p_test.ts +31 -27
  168. package/src/fixtures/token_utils.ts +6 -5
  169. package/src/fixtures/utils.ts +27 -907
  170. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  171. package/src/quality_of_service/prometheus_client.ts +113 -0
  172. package/src/shared/cross_chain_test_harness.ts +16 -36
  173. package/src/shared/gas_portal_test_harness.ts +1 -1
  174. package/src/shared/index.ts +1 -1
  175. package/src/shared/submit-transactions.ts +9 -15
  176. package/src/shared/uniswap_l1_l2.ts +58 -79
  177. package/src/simulators/lending_simulator.ts +2 -2
  178. package/src/spartan/setup_test_wallets.ts +79 -25
  179. package/src/spartan/tx_metrics.ts +255 -9
  180. package/src/spartan/utils/bot.ts +185 -0
  181. package/src/spartan/utils/chaos.ts +253 -0
  182. package/src/spartan/utils/clients.ts +100 -0
  183. package/src/spartan/utils/config.ts +27 -0
  184. package/src/spartan/utils/health.ts +255 -0
  185. package/src/spartan/utils/helm.ts +84 -0
  186. package/src/spartan/utils/index.ts +64 -0
  187. package/src/spartan/utils/k8s.ts +527 -0
  188. package/src/spartan/utils/nodes.ts +538 -0
  189. package/src/spartan/utils/scripts.ts +99 -0
  190. package/src/spartan/utils.ts +1 -1158
  191. package/dest/fixtures/snapshot_manager.d.ts +0 -93
  192. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  193. package/dest/fixtures/snapshot_manager.js +0 -493
  194. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  195. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  196. package/src/fixtures/snapshot_manager.ts +0 -651
@@ -1,10 +1,10 @@
1
1
  import type { InitialAccountData } from '@aztec/accounts/testing';
2
2
  import type { AztecNodeService } from '@aztec/aztec-node';
3
3
  import { AztecAddress } from '@aztec/aztec.js/addresses';
4
- import { type SentTx, getContractInstanceFromInstantiationParams } from '@aztec/aztec.js/contracts';
4
+ import { NO_WAIT, getContractInstanceFromInstantiationParams } from '@aztec/aztec.js/contracts';
5
5
  import { Fr } from '@aztec/aztec.js/fields';
6
6
  import type { Logger } from '@aztec/aztec.js/log';
7
- import { Tx, TxStatus } from '@aztec/aztec.js/tx';
7
+ import { TxHash } from '@aztec/aztec.js/tx';
8
8
  import type { RollupCheatCodes } from '@aztec/aztec/testing';
9
9
  import type {
10
10
  EmpireSlashingProposerContract,
@@ -13,6 +13,7 @@ import type {
13
13
  } from '@aztec/ethereum/contracts';
14
14
  import { EpochNumber } from '@aztec/foundation/branded-types';
15
15
  import { timesAsync, unique } from '@aztec/foundation/collection';
16
+ import { EthAddress } from '@aztec/foundation/eth-address';
16
17
  import { retryUntil } from '@aztec/foundation/retry';
17
18
  import { pluralize } from '@aztec/foundation/string';
18
19
  import type { SpamContract } from '@aztec/noir-test-contracts.js/Spam';
@@ -21,7 +22,7 @@ import { getPXEConfig, getPXEConfig as getRpcConfig } from '@aztec/pxe/server';
21
22
  import { getRoundForOffense } from '@aztec/slasher';
22
23
  import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
23
24
  import type { SlashFactoryContract } from '@aztec/stdlib/l1-contracts';
24
- import { TestWallet, proveInteraction } from '@aztec/test-wallet/server';
25
+ import { type ProvenTx, TestWallet, proveInteraction } from '@aztec/test-wallet/server';
25
26
 
26
27
  import { submitTxsTo } from '../shared/submit-transactions.js';
27
28
 
@@ -33,24 +34,15 @@ export const submitComplexTxsTo = async (
33
34
  numTxs: number,
34
35
  opts: { callPublic?: boolean } = {},
35
36
  ) => {
36
- const txs: SentTx[] = [];
37
+ const txs: TxHash[] = [];
37
38
 
38
39
  const seed = 1234n;
39
40
  const spamCount = 15;
40
41
  for (let i = 0; i < numTxs; i++) {
41
- const tx = spamContract.methods.spam(seed + BigInt(i * spamCount), spamCount, !!opts.callPublic).send({ from });
42
- const txHash = await tx.getTxHash();
43
-
42
+ const method = spamContract.methods.spam(seed + BigInt(i * spamCount), spamCount, !!opts.callPublic);
43
+ const txHash = await method.send({ from, wait: NO_WAIT });
44
44
  logger.info(`Tx sent with hash ${txHash.toString()}`);
45
- const receipt = await tx.getReceipt();
46
- expect(receipt).toEqual(
47
- expect.objectContaining({
48
- status: TxStatus.PENDING,
49
- error: '',
50
- }),
51
- );
52
- logger.info(`Receipt received for ${txHash.toString()}`);
53
- txs.push(tx);
45
+ txs.push(txHash);
54
46
  }
55
47
  return txs;
56
48
  };
@@ -61,10 +53,14 @@ export const submitTransactions = async (
61
53
  node: AztecNodeService,
62
54
  numTxs: number,
63
55
  fundedAccount: InitialAccountData,
64
- ): Promise<SentTx[]> => {
56
+ ): Promise<TxHash[]> => {
65
57
  const rpcConfig = getRpcConfig();
66
58
  rpcConfig.proverEnabled = false;
67
- const wallet = await TestWallet.create(node, { ...getPXEConfig(), proverEnabled: false }, { useLogSuffix: true });
59
+ const wallet = await TestWallet.create(
60
+ node,
61
+ { ...getPXEConfig(), proverEnabled: false },
62
+ { loggerActorLabel: 'pxe-tx' },
63
+ );
68
64
  const fundedAccountManager = await wallet.createSchnorrAccount(fundedAccount.secret, fundedAccount.salt);
69
65
  return submitTxsTo(wallet, fundedAccountManager.address, numTxs, logger);
70
66
  };
@@ -74,11 +70,15 @@ export async function prepareTransactions(
74
70
  node: AztecNodeService,
75
71
  numTxs: number,
76
72
  fundedAccount: InitialAccountData,
77
- ): Promise<Tx[]> {
73
+ ): Promise<ProvenTx[]> {
78
74
  const rpcConfig = getRpcConfig();
79
75
  rpcConfig.proverEnabled = false;
80
76
 
81
- const wallet = await TestWallet.create(node, { ...getPXEConfig(), proverEnabled: false }, { useLogSuffix: true });
77
+ const wallet = await TestWallet.create(
78
+ node,
79
+ { ...getPXEConfig(), proverEnabled: false },
80
+ { loggerActorLabel: 'pxe-tx' },
81
+ );
82
82
  const fundedAccountManager = await wallet.createSchnorrAccount(fundedAccount.secret, fundedAccount.salt);
83
83
 
84
84
  const testContractInstance = await getContractInstanceFromInstantiationParams(TestContractArtifact, {
@@ -91,8 +91,7 @@ export async function prepareTransactions(
91
91
  const tx = await proveInteraction(wallet, contract.methods.emit_nullifier(Fr.random()), {
92
92
  from: fundedAccountManager.address,
93
93
  });
94
- const txHash = tx.getTxHash();
95
- logger.info(`Tx prepared with hash ${txHash}`);
94
+ logger.info(`Tx prepared with hash ${tx.getTxHash()}`);
96
95
  return tx;
97
96
  });
98
97
  }
@@ -137,7 +136,7 @@ export async function awaitCommitteeExists({
137
136
  logger: Logger;
138
137
  }): Promise<readonly `0x${string}`[]> {
139
138
  logger.info(`Waiting for committee to be set`);
140
- let committee: readonly `0x${string}`[] | undefined;
139
+ let committee: EthAddress[] | undefined;
141
140
  await retryUntil(
142
141
  async () => {
143
142
  committee = await rollup.getCurrentEpochCommittee();
@@ -146,7 +145,8 @@ export async function awaitCommitteeExists({
146
145
  'non-empty committee',
147
146
  60,
148
147
  );
149
- return committee!;
148
+ logger.warn(`Committee has been formed`, { committee: committee!.map(c => c.toString()) });
149
+ return committee!.map(c => c.toString() as `0x${string}`);
150
150
  }
151
151
 
152
152
  export async function awaitOffenseDetected({
@@ -218,9 +218,9 @@ export async function awaitCommitteeKicked({
218
218
 
219
219
  if (slashingProposer.type === 'empire') {
220
220
  // Await for the slash payload to be created if empire (no payload is created on tally until execution time)
221
- const targetEpoch = BigInt(await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1n;
221
+ const targetEpoch = EpochNumber((await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1);
222
222
  logger.info(`Advancing to epoch ${targetEpoch} so we start slashing`);
223
- await cheatCodes.advanceToEpoch(EpochNumber.fromBigInt(targetEpoch));
223
+ await cheatCodes.advanceToEpoch(targetEpoch);
224
224
 
225
225
  const slashPayloadEvents = await retryUntil(
226
226
  async () => {
@@ -275,7 +275,7 @@ export async function awaitCommitteeKicked({
275
275
  logger.info(`Advancing to check current committee`);
276
276
  await cheatCodes.debugRollup();
277
277
  await cheatCodes.advanceToEpoch(
278
- EpochNumber.fromBigInt(BigInt(await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1n),
278
+ EpochNumber((await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1),
279
279
  );
280
280
  await cheatCodes.debugRollup();
281
281