@aztec/end-to-end 0.0.1-commit.e558bd1c → 0.0.1-commit.e5a3663dd

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 (202) hide show
  1. package/README.md +27 -0
  2. package/dest/bench/client_flows/client_flows_benchmark.d.ts +2 -2
  3. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  4. package/dest/bench/client_flows/client_flows_benchmark.js +24 -31
  5. package/dest/bench/client_flows/config.d.ts +2 -2
  6. package/dest/bench/client_flows/config.d.ts.map +1 -1
  7. package/dest/bench/client_flows/config.js +18 -0
  8. package/dest/bench/utils.d.ts +1 -1
  9. package/dest/bench/utils.d.ts.map +1 -1
  10. package/dest/bench/utils.js +6 -3
  11. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -3
  12. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts.map +1 -1
  13. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.js +23 -13
  14. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +2 -2
  15. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts.map +1 -1
  16. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.js +1 -1
  17. package/dest/e2e_deploy_contract/deploy_test.d.ts +2 -2
  18. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  19. package/dest/e2e_epochs/epochs_test.d.ts +26 -7
  20. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  21. package/dest/e2e_epochs/epochs_test.js +117 -41
  22. package/dest/e2e_fees/fees_test.d.ts +2 -2
  23. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  24. package/dest/e2e_fees/fees_test.js +22 -15
  25. package/dest/e2e_nested_contract/nested_contract_test.d.ts +1 -1
  26. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  27. package/dest/e2e_nested_contract/nested_contract_test.js +4 -6
  28. package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
  29. package/dest/e2e_p2p/p2p_network.d.ts +14 -12
  30. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  31. package/dest/e2e_p2p/p2p_network.js +70 -34
  32. package/dest/e2e_p2p/reqresp/utils.d.ts +3 -3
  33. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -1
  34. package/dest/e2e_p2p/reqresp/utils.js +49 -9
  35. package/dest/e2e_p2p/shared.d.ts +26 -8
  36. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  37. package/dest/e2e_p2p/shared.js +71 -50
  38. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  39. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  40. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  41. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  42. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  43. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  44. package/dest/e2e_token_contract/token_contract_test.d.ts +4 -2
  45. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  46. package/dest/e2e_token_contract/token_contract_test.js +19 -9
  47. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  48. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  49. package/dest/fixtures/authwit_proxy.js +34 -0
  50. package/dest/fixtures/e2e_prover_test.d.ts +7 -6
  51. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  52. package/dest/fixtures/e2e_prover_test.js +37 -49
  53. package/dest/fixtures/elu_monitor.d.ts +21 -0
  54. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  55. package/dest/fixtures/elu_monitor.js +102 -0
  56. package/dest/fixtures/fixtures.d.ts +16 -1
  57. package/dest/fixtures/fixtures.d.ts.map +1 -1
  58. package/dest/fixtures/fixtures.js +16 -0
  59. package/dest/fixtures/get_bb_config.d.ts +1 -1
  60. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  61. package/dest/fixtures/get_bb_config.js +5 -5
  62. package/dest/fixtures/ha_setup.d.ts +2 -2
  63. package/dest/fixtures/ha_setup.d.ts.map +1 -1
  64. package/dest/fixtures/ha_setup.js +4 -2
  65. package/dest/fixtures/schnorr_hardcoded_account_contract.d.ts +25 -0
  66. package/dest/fixtures/schnorr_hardcoded_account_contract.d.ts.map +1 -0
  67. package/dest/fixtures/schnorr_hardcoded_account_contract.js +39 -0
  68. package/dest/fixtures/setup.d.ts +59 -31
  69. package/dest/fixtures/setup.d.ts.map +1 -1
  70. package/dest/fixtures/setup.js +97 -167
  71. package/dest/fixtures/setup_p2p_test.d.ts +10 -7
  72. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  73. package/dest/fixtures/setup_p2p_test.js +18 -15
  74. package/dest/fixtures/token_utils.d.ts +2 -2
  75. package/dest/fixtures/token_utils.d.ts.map +1 -1
  76. package/dest/fixtures/token_utils.js +5 -7
  77. package/dest/forward-compatibility/wallet_rpc_client.d.ts +7 -0
  78. package/dest/forward-compatibility/wallet_rpc_client.d.ts.map +1 -0
  79. package/dest/forward-compatibility/wallet_rpc_client.js +15 -0
  80. package/dest/forward-compatibility/wallet_service.d.ts +3 -0
  81. package/dest/forward-compatibility/wallet_service.d.ts.map +1 -0
  82. package/dest/forward-compatibility/wallet_service.js +109 -0
  83. package/dest/legacy-jest-resolver.d.cts +3 -0
  84. package/dest/legacy-jest-resolver.d.cts.map +1 -0
  85. package/dest/shared/cross_chain_test_harness.d.ts +1 -1
  86. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  87. package/dest/shared/cross_chain_test_harness.js +13 -13
  88. package/dest/shared/gas_portal_test_harness.js +3 -3
  89. package/dest/shared/index.d.ts +2 -1
  90. package/dest/shared/index.d.ts.map +1 -1
  91. package/dest/shared/index.js +1 -0
  92. package/dest/shared/jest_setup.js +41 -1
  93. package/dest/shared/mock_state_view.d.ts +86 -0
  94. package/dest/shared/mock_state_view.d.ts.map +1 -0
  95. package/dest/shared/mock_state_view.js +186 -0
  96. package/dest/shared/submit-transactions.d.ts +2 -2
  97. package/dest/shared/submit-transactions.d.ts.map +1 -1
  98. package/dest/shared/submit-transactions.js +1 -1
  99. package/dest/shared/uniswap_l1_l2.d.ts +1 -1
  100. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  101. package/dest/shared/uniswap_l1_l2.js +15 -22
  102. package/dest/simulators/lending_simulator.d.ts +1 -1
  103. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  104. package/dest/simulators/lending_simulator.js +4 -4
  105. package/dest/simulators/token_simulator.d.ts +1 -1
  106. package/dest/simulators/token_simulator.d.ts.map +1 -1
  107. package/dest/simulators/token_simulator.js +3 -24
  108. package/dest/spartan/setup_test_wallets.d.ts +12 -3
  109. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  110. package/dest/spartan/setup_test_wallets.js +100 -39
  111. package/dest/spartan/tx_metrics.d.ts +1 -1
  112. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  113. package/dest/spartan/tx_metrics.js +19 -3
  114. package/dest/spartan/utils/bot.d.ts +3 -2
  115. package/dest/spartan/utils/bot.d.ts.map +1 -1
  116. package/dest/spartan/utils/bot.js +2 -1
  117. package/dest/spartan/utils/config.d.ts +7 -1
  118. package/dest/spartan/utils/config.d.ts.map +1 -1
  119. package/dest/spartan/utils/config.js +3 -1
  120. package/dest/spartan/utils/index.d.ts +4 -2
  121. package/dest/spartan/utils/index.d.ts.map +1 -1
  122. package/dest/spartan/utils/index.js +5 -1
  123. package/dest/spartan/utils/k8s.d.ts +3 -1
  124. package/dest/spartan/utils/k8s.d.ts.map +1 -1
  125. package/dest/spartan/utils/k8s.js +6 -0
  126. package/dest/spartan/utils/nodes.d.ts +4 -5
  127. package/dest/spartan/utils/nodes.d.ts.map +1 -1
  128. package/dest/spartan/utils/nodes.js +9 -9
  129. package/dest/spartan/utils/pod_logs.d.ts +25 -0
  130. package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
  131. package/dest/spartan/utils/pod_logs.js +74 -0
  132. package/dest/test-wallet/test_wallet.d.ts +84 -0
  133. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  134. package/dest/test-wallet/test_wallet.js +255 -0
  135. package/dest/test-wallet/utils.d.ts +41 -0
  136. package/dest/test-wallet/utils.d.ts.map +1 -0
  137. package/dest/test-wallet/utils.js +71 -0
  138. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  139. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  140. package/dest/test-wallet/wallet_worker_script.js +48 -0
  141. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  142. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  143. package/dest/test-wallet/worker_wallet.js +151 -0
  144. package/dest/test-wallet/worker_wallet_schema.d.ts +279 -0
  145. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  146. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  147. package/package.json +43 -43
  148. package/src/bench/client_flows/client_flows_benchmark.ts +33 -20
  149. package/src/bench/client_flows/config.ts +9 -1
  150. package/src/bench/utils.ts +8 -3
  151. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +31 -21
  152. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +5 -5
  153. package/src/e2e_deploy_contract/deploy_test.ts +3 -3
  154. package/src/e2e_epochs/epochs_test.ts +138 -67
  155. package/src/e2e_fees/bridging_race.notest.ts +1 -1
  156. package/src/e2e_fees/fees_test.ts +25 -31
  157. package/src/e2e_nested_contract/nested_contract_test.ts +7 -5
  158. package/src/e2e_p2p/inactivity_slash_test.ts +7 -7
  159. package/src/e2e_p2p/p2p_network.ts +93 -49
  160. package/src/e2e_p2p/reqresp/utils.ts +63 -13
  161. package/src/e2e_p2p/shared.ts +90 -64
  162. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  163. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  164. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  165. package/src/e2e_token_contract/token_contract_test.ts +26 -9
  166. package/src/fixtures/authwit_proxy.ts +54 -0
  167. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  168. package/src/fixtures/e2e_prover_test.ts +46 -55
  169. package/src/fixtures/elu_monitor.ts +126 -0
  170. package/src/fixtures/fixtures.ts +32 -0
  171. package/src/fixtures/get_bb_config.ts +7 -6
  172. package/src/fixtures/ha_setup.ts +7 -3
  173. package/src/fixtures/schnorr_hardcoded_account_contract.ts +49 -0
  174. package/src/fixtures/setup.ts +147 -232
  175. package/src/fixtures/setup_p2p_test.ts +17 -25
  176. package/src/fixtures/token_utils.ts +3 -3
  177. package/src/forward-compatibility/wallet_rpc_client.ts +14 -0
  178. package/src/forward-compatibility/wallet_service.ts +104 -0
  179. package/src/guides/up_quick_start.sh +3 -5
  180. package/src/legacy-jest-resolver.cjs +135 -0
  181. package/src/shared/cross_chain_test_harness.ts +13 -9
  182. package/src/shared/gas_portal_test_harness.ts +1 -2
  183. package/src/shared/index.ts +1 -0
  184. package/src/shared/jest_setup.ts +51 -1
  185. package/src/shared/mock_state_view.ts +188 -0
  186. package/src/shared/submit-transactions.ts +3 -2
  187. package/src/shared/uniswap_l1_l2.ts +37 -34
  188. package/src/simulators/lending_simulator.ts +8 -4
  189. package/src/simulators/token_simulator.ts +6 -30
  190. package/src/spartan/setup_test_wallets.ts +141 -32
  191. package/src/spartan/tx_metrics.ts +17 -5
  192. package/src/spartan/utils/bot.ts +4 -1
  193. package/src/spartan/utils/config.ts +2 -0
  194. package/src/spartan/utils/index.ts +7 -0
  195. package/src/spartan/utils/k8s.ts +8 -0
  196. package/src/spartan/utils/nodes.ts +15 -10
  197. package/src/spartan/utils/pod_logs.ts +99 -0
  198. package/src/test-wallet/test_wallet.ts +357 -0
  199. package/src/test-wallet/utils.ts +112 -0
  200. package/src/test-wallet/wallet_worker_script.ts +60 -0
  201. package/src/test-wallet/worker_wallet.ts +214 -0
  202. package/src/test-wallet/worker_wallet_schema.ts +13 -0
@@ -6,12 +6,9 @@ import { Fr } from '@aztec/aztec.js/fields';
6
6
  import type { Logger } from '@aztec/aztec.js/log';
7
7
  import { TxHash } from '@aztec/aztec.js/tx';
8
8
  import type { RollupCheatCodes } from '@aztec/aztec/testing';
9
- import type {
10
- EmpireSlashingProposerContract,
11
- RollupContract,
12
- TallySlashingProposerContract,
13
- } from '@aztec/ethereum/contracts';
14
- import { EpochNumber } from '@aztec/foundation/branded-types';
9
+ import type { EpochCacheInterface } from '@aztec/epoch-cache';
10
+ import type { RollupContract, SlashingProposerContract } from '@aztec/ethereum/contracts';
11
+ import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
15
12
  import { timesAsync, unique } from '@aztec/foundation/collection';
16
13
  import { EthAddress } from '@aztec/foundation/eth-address';
17
14
  import { retryUntil } from '@aztec/foundation/retry';
@@ -21,10 +18,11 @@ import { TestContract, TestContractArtifact } from '@aztec/noir-test-contracts.j
21
18
  import { getPXEConfig, getPXEConfig as getRpcConfig } from '@aztec/pxe/server';
22
19
  import { getRoundForOffense } from '@aztec/slasher';
23
20
  import type { AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
24
- import type { SlashFactoryContract } from '@aztec/stdlib/l1-contracts';
25
- import { type ProvenTx, TestWallet, proveInteraction } from '@aztec/test-wallet/server';
26
21
 
22
+ import { SchnorrHardcodedKeyAccountContract } from '../fixtures/schnorr_hardcoded_account_contract.js';
27
23
  import { submitTxsTo } from '../shared/submit-transactions.js';
24
+ import { TestWallet } from '../test-wallet/test_wallet.js';
25
+ import { type ProvenTx, proveInteraction } from '../test-wallet/utils.js';
28
26
 
29
27
  // submits a set of transactions to the provided Private eXecution Environment (PXE)
30
28
  export const submitComplexTxsTo = async (
@@ -40,7 +38,7 @@ export const submitComplexTxsTo = async (
40
38
  const spamCount = 15;
41
39
  for (let i = 0; i < numTxs; i++) {
42
40
  const method = spamContract.methods.spam(seed + BigInt(i * spamCount), spamCount, !!opts.callPublic);
43
- const txHash = await method.send({ from, wait: NO_WAIT });
41
+ const { txHash } = await method.send({ from, wait: NO_WAIT });
44
42
  logger.info(`Tx sent with hash ${txHash.toString()}`);
45
43
  txs.push(txHash);
46
44
  }
@@ -58,10 +56,17 @@ export const submitTransactions = async (
58
56
  rpcConfig.proverEnabled = false;
59
57
  const wallet = await TestWallet.create(
60
58
  node,
61
- { ...getPXEConfig(), proverEnabled: false },
59
+ // Use checkpointed chain tip to avoid anchoring on provisional blocks that the archiver can prune
60
+ // when their slot ends without a checkpoint landing on L1.
61
+ { ...getPXEConfig(), proverEnabled: false, syncChainTip: 'checkpointed' },
62
62
  { loggerActorLabel: 'pxe-tx' },
63
63
  );
64
- const fundedAccountManager = await wallet.createSchnorrAccount(fundedAccount.secret, fundedAccount.salt);
64
+ const contract = new SchnorrHardcodedKeyAccountContract();
65
+ const fundedAccountManager = await wallet.createAccount({
66
+ secret: fundedAccount.secret,
67
+ salt: fundedAccount.salt,
68
+ contract,
69
+ });
65
70
  return submitTxsTo(wallet, fundedAccountManager.address, numTxs, logger);
66
71
  };
67
72
 
@@ -76,10 +81,15 @@ export async function prepareTransactions(
76
81
 
77
82
  const wallet = await TestWallet.create(
78
83
  node,
79
- { ...getPXEConfig(), proverEnabled: false },
84
+ { ...getPXEConfig(), proverEnabled: false, syncChainTip: 'checkpointed' },
80
85
  { loggerActorLabel: 'pxe-tx' },
81
86
  );
82
- const fundedAccountManager = await wallet.createSchnorrAccount(fundedAccount.secret, fundedAccount.salt);
87
+ const accountContract = new SchnorrHardcodedKeyAccountContract();
88
+ const fundedAccountManager = await wallet.createAccount({
89
+ secret: fundedAccount.secret,
90
+ salt: fundedAccount.salt,
91
+ contract: accountContract,
92
+ });
83
93
 
84
94
  const testContractInstance = await getContractInstanceFromInstantiationParams(TestContractArtifact, {
85
95
  salt: Fr.random(),
@@ -97,7 +107,7 @@ export async function prepareTransactions(
97
107
  }
98
108
 
99
109
  export function awaitProposalExecution(
100
- slashingProposer: EmpireSlashingProposerContract | TallySlashingProposerContract,
110
+ slashingProposer: SlashingProposerContract,
101
111
  timeoutSeconds: number,
102
112
  logger: Logger,
103
113
  ): Promise<bigint> {
@@ -107,24 +117,12 @@ export function awaitProposalExecution(
107
117
  reject(new Error(`Timeout waiting for proposal execution after ${timeoutSeconds}s`));
108
118
  }, timeoutSeconds * 1000);
109
119
 
110
- if (slashingProposer.type === 'empire') {
111
- const unwatch = slashingProposer.listenToPayloadSubmitted(args => {
112
- logger.warn(`Proposal ${args.payload} from round ${args.round} executed`);
113
- clearTimeout(timeout);
114
- unwatch();
115
- resolve(args.round);
116
- });
117
- } else if (slashingProposer.type === 'tally') {
118
- const unwatch = slashingProposer.listenToRoundExecuted(args => {
119
- logger.warn(`Slash from round ${args.round} executed`);
120
- clearTimeout(timeout);
121
- unwatch();
122
- resolve(args.round);
123
- });
124
- } else {
120
+ const unwatch = slashingProposer.listenToRoundExecuted(args => {
121
+ logger.warn(`Slash from round ${args.round} executed`);
125
122
  clearTimeout(timeout);
126
- reject(new Error(`Unknown slashing proposer type: ${(slashingProposer as any).type}`));
127
- }
123
+ unwatch();
124
+ resolve(args.round);
125
+ });
128
126
  });
129
127
  }
130
128
 
@@ -149,6 +147,58 @@ export async function awaitCommitteeExists({
149
147
  return committee!.map(c => c.toString() as `0x${string}`);
150
148
  }
151
149
 
150
+ /**
151
+ * Advance epochs until we find one where the target proposer is selected for at least one slot,
152
+ * then stop one epoch before it. This leaves time for the caller to start sequencers before
153
+ * warping to the target epoch, avoiding the race where the target epoch passes before sequencers
154
+ * are ready.
155
+ *
156
+ * Returns the target epoch number so the caller can warp to it after starting sequencers.
157
+ */
158
+ export async function advanceToEpochBeforeProposer({
159
+ epochCache,
160
+ cheatCodes,
161
+ targetProposer,
162
+ logger,
163
+ maxAttempts = 20,
164
+ }: {
165
+ epochCache: EpochCacheInterface;
166
+ cheatCodes: RollupCheatCodes;
167
+ targetProposer: EthAddress;
168
+ logger: Logger;
169
+ maxAttempts?: number;
170
+ }): Promise<{ targetEpoch: EpochNumber }> {
171
+ const { epochDuration } = await cheatCodes.getConfig();
172
+
173
+ for (let attempt = 0; attempt < maxAttempts; attempt++) {
174
+ const currentEpoch = await cheatCodes.getEpoch();
175
+ // Check the NEXT epoch's slots so we stay one epoch before the target,
176
+ // giving the caller time to start sequencers before the target epoch arrives.
177
+ const nextEpoch = Number(currentEpoch) + 1;
178
+ const startSlot = nextEpoch * Number(epochDuration);
179
+ const endSlot = startSlot + Number(epochDuration);
180
+
181
+ logger.info(
182
+ `Checking next epoch ${nextEpoch} (slots ${startSlot}-${endSlot - 1}) for proposer ${targetProposer} (current epoch: ${currentEpoch})`,
183
+ );
184
+
185
+ for (let s = startSlot; s < endSlot; s++) {
186
+ const proposer = await epochCache.getProposerAttesterAddressInSlot(SlotNumber(s));
187
+ if (proposer && proposer.equals(targetProposer)) {
188
+ logger.warn(
189
+ `Found target proposer ${targetProposer} in slot ${s} of epoch ${nextEpoch}. Staying at epoch ${currentEpoch} to allow sequencer startup.`,
190
+ );
191
+ return { targetEpoch: EpochNumber(nextEpoch) };
192
+ }
193
+ }
194
+
195
+ logger.info(`Target proposer not found in epoch ${nextEpoch}, advancing to next epoch`);
196
+ await cheatCodes.advanceToNextEpoch();
197
+ }
198
+
199
+ throw new Error(`Target proposer ${targetProposer} not found in any slot after ${maxAttempts} epoch attempts`);
200
+ }
201
+
152
202
  export async function awaitOffenseDetected({
153
203
  logger,
154
204
  nodeAdmin,
@@ -191,7 +241,6 @@ export async function awaitCommitteeKicked({
191
241
  rollup,
192
242
  cheatCodes,
193
243
  committee,
194
- slashFactory,
195
244
  slashingProposer,
196
245
  slashingRoundSize,
197
246
  aztecSlotDuration,
@@ -202,8 +251,7 @@ export async function awaitCommitteeKicked({
202
251
  rollup: RollupContract;
203
252
  cheatCodes: RollupCheatCodes;
204
253
  committee: readonly `0x${string}`[];
205
- slashFactory: SlashFactoryContract;
206
- slashingProposer: EmpireSlashingProposerContract | TallySlashingProposerContract | undefined;
254
+ slashingProposer: SlashingProposerContract | undefined;
207
255
  slashingRoundSize: number;
208
256
  aztecSlotDuration: number;
209
257
  aztecEpochDuration: number;
@@ -216,36 +264,14 @@ export async function awaitCommitteeKicked({
216
264
 
217
265
  await cheatCodes.debugRollup();
218
266
 
219
- if (slashingProposer.type === 'empire') {
220
- // Await for the slash payload to be created if empire (no payload is created on tally until execution time)
221
- const targetEpoch = EpochNumber((await cheatCodes.getEpoch()) + (await rollup.getLagInEpochsForValidatorSet()) + 1);
222
- logger.info(`Advancing to epoch ${targetEpoch} so we start slashing`);
223
- await cheatCodes.advanceToEpoch(targetEpoch);
224
-
225
- const slashPayloadEvents = await retryUntil(
226
- async () => {
227
- const events = await slashFactory.getSlashPayloadCreatedEvents();
228
- return events.length > 0 ? events : undefined;
229
- },
230
- 'slash payload created',
231
- 120,
232
- 1,
233
- );
234
- expect(slashPayloadEvents.length).toBe(1);
235
- // The uniqueness check is needed since a validator may be slashed more than once on the same round (eg because they let two epochs be pruned)
236
- expect(unique(slashPayloadEvents[0].slashes.map(slash => slash.validator.toString()))).toHaveLength(
237
- committee.length,
238
- );
239
- } else {
240
- // Use the slash offset to ensure we are in the right epoch for tally
241
- const slashOffsetInRounds = await slashingProposer.getSlashOffsetInRounds();
242
- const slashingRoundSizeInEpochs = slashingRoundSize / aztecEpochDuration;
243
- const slashingOffsetInEpochs = Number(slashOffsetInRounds) * slashingRoundSizeInEpochs;
244
- const firstEpochInOffenseRound = offenseEpoch - (offenseEpoch % slashingRoundSizeInEpochs);
245
- const targetEpoch = firstEpochInOffenseRound + slashingOffsetInEpochs;
246
- logger.info(`Advancing to epoch ${targetEpoch} so we start slashing`);
247
- await cheatCodes.advanceToEpoch(EpochNumber(targetEpoch), { offset: -aztecSlotDuration / 2 });
248
- }
267
+ // Use the slash offset to ensure we are in the right epoch for tally
268
+ const slashOffsetInRounds = await slashingProposer.getSlashOffsetInRounds();
269
+ const slashingRoundSizeInEpochs = slashingRoundSize / aztecEpochDuration;
270
+ const slashingOffsetInEpochs = Number(slashOffsetInRounds) * slashingRoundSizeInEpochs;
271
+ const firstEpochInOffenseRound = offenseEpoch - (offenseEpoch % slashingRoundSizeInEpochs);
272
+ const targetEpoch = firstEpochInOffenseRound + slashingOffsetInEpochs;
273
+ logger.info(`Advancing to epoch ${targetEpoch} so we start slashing`);
274
+ await cheatCodes.advanceToEpoch(EpochNumber(targetEpoch), { offset: -aztecSlotDuration / 2 });
249
275
 
250
276
  const attestersPre = await rollup.getAttesters();
251
277
  expect(attestersPre.length).toBe(committee.length);