@aztec/end-to-end 0.0.1-commit.e6bd8901 → 0.0.1-commit.ec7ac5448

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