@aztec/end-to-end 0.0.1-commit.9b94fc1 → 0.0.1-commit.9ee6fcc6

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 (267) 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 +15 -16
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +136 -141
  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 +31 -19
  14. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +9 -8
  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 +107 -113
  17. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +20 -14
  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 +92 -71
  20. package/dest/e2e_deploy_contract/deploy_test.d.ts +5 -4
  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 +27 -15
  24. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  25. package/dest/e2e_epochs/epochs_test.js +104 -52
  26. package/dest/e2e_fees/bridging_race.notest.js +4 -6
  27. package/dest/e2e_fees/fees_test.d.ts +21 -17
  28. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  29. package/dest/e2e_fees/fees_test.js +137 -145
  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_multi_validator/utils.js +1 -1
  34. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  35. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  36. package/dest/e2e_nested_contract/nested_contract_test.js +30 -40
  37. package/dest/e2e_p2p/inactivity_slash_test.d.ts +4 -4
  38. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  39. package/dest/e2e_p2p/inactivity_slash_test.js +6 -9
  40. package/dest/e2e_p2p/p2p_network.d.ts +17 -14
  41. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  42. package/dest/e2e_p2p/p2p_network.js +141 -115
  43. package/dest/e2e_p2p/reqresp/utils.d.ts +22 -0
  44. package/dest/e2e_p2p/reqresp/utils.d.ts.map +1 -0
  45. package/dest/e2e_p2p/reqresp/utils.js +190 -0
  46. package/dest/e2e_p2p/shared.d.ts +27 -7
  47. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  48. package/dest/e2e_p2p/shared.js +50 -22
  49. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts +2 -0
  50. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.d.ts.map +1 -0
  51. package/dest/e2e_storage_proof/fixtures/storage_proof_fetcher.js +184 -0
  52. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts +18 -0
  53. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.d.ts.map +1 -0
  54. package/dest/e2e_storage_proof/fixtures/storage_proof_fixture.js +120 -0
  55. package/dest/e2e_token_contract/token_contract_test.d.ts +19 -10
  56. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  57. package/dest/e2e_token_contract/token_contract_test.js +100 -92
  58. package/dest/fixtures/authwit_proxy.d.ts +15 -0
  59. package/dest/fixtures/authwit_proxy.d.ts.map +1 -0
  60. package/dest/fixtures/authwit_proxy.js +30 -0
  61. package/dest/fixtures/e2e_prover_test.d.ts +16 -23
  62. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  63. package/dest/fixtures/e2e_prover_test.js +117 -138
  64. package/dest/fixtures/elu_monitor.d.ts +21 -0
  65. package/dest/fixtures/elu_monitor.d.ts.map +1 -0
  66. package/dest/fixtures/elu_monitor.js +102 -0
  67. package/dest/fixtures/fixtures.d.ts +6 -3
  68. package/dest/fixtures/fixtures.d.ts.map +1 -1
  69. package/dest/fixtures/fixtures.js +8 -3
  70. package/dest/fixtures/get_acvm_config.js +1 -1
  71. package/dest/fixtures/get_bb_config.d.ts +1 -1
  72. package/dest/fixtures/get_bb_config.d.ts.map +1 -1
  73. package/dest/fixtures/get_bb_config.js +5 -5
  74. package/dest/fixtures/ha_setup.d.ts +71 -0
  75. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  76. package/dest/fixtures/ha_setup.js +116 -0
  77. package/dest/fixtures/index.d.ts +2 -1
  78. package/dest/fixtures/index.d.ts.map +1 -1
  79. package/dest/fixtures/index.js +1 -0
  80. package/dest/fixtures/l1_to_l2_messaging.d.ts +4 -3
  81. package/dest/fixtures/l1_to_l2_messaging.d.ts.map +1 -1
  82. package/dest/fixtures/l1_to_l2_messaging.js +2 -2
  83. package/dest/fixtures/setup.d.ts +239 -0
  84. package/dest/fixtures/setup.d.ts.map +1 -0
  85. package/dest/fixtures/setup.js +608 -0
  86. package/dest/fixtures/setup_p2p_test.d.ts +16 -9
  87. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  88. package/dest/fixtures/setup_p2p_test.js +43 -32
  89. package/dest/fixtures/token_utils.d.ts +2 -2
  90. package/dest/fixtures/token_utils.d.ts.map +1 -1
  91. package/dest/fixtures/token_utils.js +12 -8
  92. package/dest/fixtures/utils.d.ts +5 -637
  93. package/dest/fixtures/utils.d.ts.map +1 -1
  94. package/dest/fixtures/utils.js +4 -647
  95. package/dest/fixtures/web3signer.js +1 -1
  96. package/dest/fixtures/with_telemetry_utils.d.ts +2 -2
  97. package/dest/fixtures/with_telemetry_utils.d.ts.map +1 -1
  98. package/dest/fixtures/with_telemetry_utils.js +2 -2
  99. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  100. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  101. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  102. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  103. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  104. package/dest/quality_of_service/prometheus_client.js +67 -0
  105. package/dest/shared/cross_chain_test_harness.d.ts +18 -6
  106. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  107. package/dest/shared/cross_chain_test_harness.js +27 -27
  108. package/dest/shared/gas_portal_test_harness.d.ts +12 -2
  109. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  110. package/dest/shared/gas_portal_test_harness.js +3 -3
  111. package/dest/shared/index.d.ts +3 -2
  112. package/dest/shared/index.d.ts.map +1 -1
  113. package/dest/shared/index.js +1 -0
  114. package/dest/shared/jest_setup.js +41 -1
  115. package/dest/shared/mock_state_view.d.ts +86 -0
  116. package/dest/shared/mock_state_view.d.ts.map +1 -0
  117. package/dest/shared/mock_state_view.js +186 -0
  118. package/dest/shared/submit-transactions.d.ts +4 -4
  119. package/dest/shared/submit-transactions.d.ts.map +1 -1
  120. package/dest/shared/submit-transactions.js +9 -11
  121. package/dest/shared/uniswap_l1_l2.d.ts +3 -27
  122. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  123. package/dest/shared/uniswap_l1_l2.js +58 -39
  124. package/dest/simulators/lending_simulator.d.ts +6 -2
  125. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  126. package/dest/simulators/lending_simulator.js +6 -6
  127. package/dest/simulators/token_simulator.d.ts +1 -1
  128. package/dest/simulators/token_simulator.d.ts.map +1 -1
  129. package/dest/simulators/token_simulator.js +3 -24
  130. package/dest/spartan/setup_test_wallets.d.ts +15 -5
  131. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  132. package/dest/spartan/setup_test_wallets.js +109 -38
  133. package/dest/spartan/tx_metrics.d.ts +88 -0
  134. package/dest/spartan/tx_metrics.d.ts.map +1 -0
  135. package/dest/spartan/tx_metrics.js +422 -0
  136. package/dest/spartan/utils/bot.d.ts +28 -0
  137. package/dest/spartan/utils/bot.d.ts.map +1 -0
  138. package/dest/spartan/utils/bot.js +142 -0
  139. package/dest/spartan/utils/chaos.d.ts +79 -0
  140. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  141. package/dest/spartan/utils/chaos.js +142 -0
  142. package/dest/spartan/utils/clients.d.ts +39 -0
  143. package/dest/spartan/utils/clients.d.ts.map +1 -0
  144. package/dest/spartan/utils/clients.js +90 -0
  145. package/dest/spartan/utils/config.d.ts +45 -0
  146. package/dest/spartan/utils/config.d.ts.map +1 -0
  147. package/dest/spartan/utils/config.js +23 -0
  148. package/dest/spartan/utils/health.d.ts +63 -0
  149. package/dest/spartan/utils/health.d.ts.map +1 -0
  150. package/dest/spartan/utils/health.js +202 -0
  151. package/dest/spartan/utils/helm.d.ts +15 -0
  152. package/dest/spartan/utils/helm.d.ts.map +1 -0
  153. package/dest/spartan/utils/helm.js +47 -0
  154. package/dest/spartan/utils/index.d.ts +11 -0
  155. package/dest/spartan/utils/index.d.ts.map +1 -0
  156. package/dest/spartan/utils/index.js +22 -0
  157. package/dest/spartan/utils/k8s.d.ts +128 -0
  158. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  159. package/dest/spartan/utils/k8s.js +381 -0
  160. package/dest/spartan/utils/nodes.d.ts +40 -0
  161. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  162. package/dest/spartan/utils/nodes.js +461 -0
  163. package/dest/spartan/utils/pod_logs.d.ts +25 -0
  164. package/dest/spartan/utils/pod_logs.d.ts.map +1 -0
  165. package/dest/spartan/utils/pod_logs.js +74 -0
  166. package/dest/spartan/utils/scripts.d.ts +30 -0
  167. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  168. package/dest/spartan/utils/scripts.js +81 -0
  169. package/dest/spartan/utils.d.ts +2 -218
  170. package/dest/spartan/utils.d.ts.map +1 -1
  171. package/dest/spartan/utils.js +1 -749
  172. package/dest/test-wallet/test_wallet.d.ts +76 -0
  173. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  174. package/dest/test-wallet/test_wallet.js +214 -0
  175. package/dest/test-wallet/utils.d.ts +41 -0
  176. package/dest/test-wallet/utils.d.ts.map +1 -0
  177. package/dest/test-wallet/utils.js +71 -0
  178. package/dest/test-wallet/wallet_worker_script.d.ts +2 -0
  179. package/dest/test-wallet/wallet_worker_script.d.ts.map +1 -0
  180. package/dest/test-wallet/wallet_worker_script.js +48 -0
  181. package/dest/test-wallet/worker_wallet.d.ts +52 -0
  182. package/dest/test-wallet/worker_wallet.d.ts.map +1 -0
  183. package/dest/test-wallet/worker_wallet.js +151 -0
  184. package/dest/test-wallet/worker_wallet_schema.d.ts +274 -0
  185. package/dest/test-wallet/worker_wallet_schema.d.ts.map +1 -0
  186. package/dest/test-wallet/worker_wallet_schema.js +10 -0
  187. package/package.json +48 -45
  188. package/src/bench/client_flows/benchmark.ts +24 -2
  189. package/src/bench/client_flows/client_flows_benchmark.ts +156 -215
  190. package/src/bench/client_flows/config.ts +9 -1
  191. package/src/bench/client_flows/data_extractor.ts +1 -1
  192. package/src/bench/utils.ts +36 -21
  193. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +120 -145
  194. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +140 -126
  195. package/src/e2e_deploy_contract/deploy_test.ts +22 -15
  196. package/src/e2e_epochs/epochs_test.ts +172 -111
  197. package/src/e2e_fees/bridging_race.notest.ts +5 -11
  198. package/src/e2e_fees/fees_test.ts +178 -228
  199. package/src/e2e_l1_publisher/write_json.ts +16 -16
  200. package/src/e2e_multi_validator/utils.ts +1 -1
  201. package/src/e2e_nested_contract/nested_contract_test.ts +35 -56
  202. package/src/e2e_p2p/inactivity_slash_test.ts +7 -10
  203. package/src/e2e_p2p/p2p_network.ts +204 -181
  204. package/src/e2e_p2p/reqresp/utils.ts +256 -0
  205. package/src/e2e_p2p/shared.ts +87 -29
  206. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  207. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  208. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  209. package/src/e2e_token_contract/token_contract_test.ts +121 -119
  210. package/src/fixtures/authwit_proxy.ts +50 -0
  211. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  212. package/src/fixtures/e2e_prover_test.ts +141 -188
  213. package/src/fixtures/elu_monitor.ts +126 -0
  214. package/src/fixtures/fixtures.ts +12 -5
  215. package/src/fixtures/get_acvm_config.ts +1 -1
  216. package/src/fixtures/get_bb_config.ts +7 -6
  217. package/src/fixtures/ha_setup.ts +186 -0
  218. package/src/fixtures/index.ts +1 -0
  219. package/src/fixtures/l1_to_l2_messaging.ts +4 -2
  220. package/src/fixtures/setup.ts +905 -0
  221. package/src/fixtures/setup_p2p_test.ts +43 -47
  222. package/src/fixtures/token_utils.ts +10 -6
  223. package/src/fixtures/utils.ts +27 -966
  224. package/src/fixtures/web3signer.ts +1 -1
  225. package/src/fixtures/with_telemetry_utils.ts +2 -2
  226. package/src/guides/up_quick_start.sh +3 -3
  227. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  228. package/src/quality_of_service/prometheus_client.ts +113 -0
  229. package/src/shared/cross_chain_test_harness.ts +30 -43
  230. package/src/shared/gas_portal_test_harness.ts +3 -3
  231. package/src/shared/index.ts +2 -1
  232. package/src/shared/jest_setup.ts +51 -1
  233. package/src/shared/mock_state_view.ts +188 -0
  234. package/src/shared/submit-transactions.ts +11 -16
  235. package/src/shared/uniswap_l1_l2.ts +86 -102
  236. package/src/simulators/lending_simulator.ts +11 -7
  237. package/src/simulators/token_simulator.ts +6 -30
  238. package/src/spartan/DEVELOP.md +7 -0
  239. package/src/spartan/setup_test_wallets.ts +167 -27
  240. package/src/spartan/tx_metrics.ts +376 -0
  241. package/src/spartan/utils/bot.ts +188 -0
  242. package/src/spartan/utils/chaos.ts +253 -0
  243. package/src/spartan/utils/clients.ts +100 -0
  244. package/src/spartan/utils/config.ts +29 -0
  245. package/src/spartan/utils/health.ts +255 -0
  246. package/src/spartan/utils/helm.ts +84 -0
  247. package/src/spartan/utils/index.ts +71 -0
  248. package/src/spartan/utils/k8s.ts +535 -0
  249. package/src/spartan/utils/nodes.ts +543 -0
  250. package/src/spartan/utils/pod_logs.ts +99 -0
  251. package/src/spartan/utils/scripts.ts +99 -0
  252. package/src/spartan/utils.ts +1 -942
  253. package/src/test-wallet/test_wallet.ts +294 -0
  254. package/src/test-wallet/utils.ts +112 -0
  255. package/src/test-wallet/wallet_worker_script.ts +60 -0
  256. package/src/test-wallet/worker_wallet.ts +213 -0
  257. package/src/test-wallet/worker_wallet_schema.ts +13 -0
  258. package/dest/fixtures/setup_l1_contracts.d.ts +0 -477
  259. package/dest/fixtures/setup_l1_contracts.d.ts.map +0 -1
  260. package/dest/fixtures/setup_l1_contracts.js +0 -17
  261. package/dest/fixtures/snapshot_manager.d.ts +0 -95
  262. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  263. package/dest/fixtures/snapshot_manager.js +0 -505
  264. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  265. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  266. package/src/fixtures/setup_l1_contracts.ts +0 -26
  267. package/src/fixtures/snapshot_manager.ts +0 -665
@@ -0,0 +1,186 @@
1
+ import { EthAddress } from '@aztec/aztec.js/addresses';
2
+ import { Fr } from '@aztec/aztec.js/fields';
3
+ import type { Logger } from '@aztec/aztec.js/log';
4
+ import { SecretValue } from '@aztec/foundation/config';
5
+
6
+ import { Pool } from 'pg';
7
+ import { privateKeyToAccount } from 'viem/accounts';
8
+
9
+ /**
10
+ * Configuration for HA database connection
11
+ */
12
+ export interface HADatabaseConfig {
13
+ /** PostgreSQL connection URL */
14
+ databaseUrl: string;
15
+ /** Node ID for HA coordination */
16
+ nodeId: string;
17
+ /** Enable HA signing */
18
+ haSigningEnabled: boolean;
19
+ /** Polling interval in ms */
20
+ pollingIntervalMs: number;
21
+ /** Signing timeout in ms */
22
+ signingTimeoutMs: number;
23
+ /** Max stuck duties age in ms */
24
+ maxStuckDutiesAgeMs: number;
25
+ }
26
+
27
+ /**
28
+ * Get database configuration from environment variables
29
+ */
30
+ export function createHADatabaseConfig(nodeId: string): HADatabaseConfig {
31
+ const databaseUrl = process.env.DATABASE_URL || 'postgresql://aztec:aztec@localhost:5432/aztec_ha_test';
32
+
33
+ return {
34
+ databaseUrl,
35
+ nodeId,
36
+ haSigningEnabled: true,
37
+ pollingIntervalMs: 100,
38
+ signingTimeoutMs: 3000,
39
+ maxStuckDutiesAgeMs: 72000,
40
+ };
41
+ }
42
+
43
+ /**
44
+ * Setup PostgreSQL database connection pool for HA tests
45
+ *
46
+ * Note: Database migrations should be run separately before starting tests,
47
+ * either via docker-compose entrypoint or manually with: aztec migrate-ha-db up
48
+ */
49
+ export function setupHADatabase(databaseUrl: string, logger?: Logger): Pool {
50
+ try {
51
+ // Create connection pool for test usage
52
+ // Migrations are already run by docker-compose entrypoint before tests start
53
+ const pool = new Pool({ connectionString: databaseUrl });
54
+
55
+ logger?.info('Connected to HA database (migrations should already be applied)');
56
+
57
+ return pool;
58
+ } catch (error) {
59
+ logger?.error(`Failed to connect to HA database: ${error}`);
60
+ throw error;
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Clean up HA database - drop all tables
66
+ * Use this between tests to ensure clean state
67
+ */
68
+ export async function cleanupHADatabase(pool: Pool, logger?: Logger): Promise<void> {
69
+ try {
70
+ // Drop all HA tables
71
+ await pool.query('DROP TABLE IF EXISTS validator_duties CASCADE');
72
+ await pool.query('DROP TABLE IF EXISTS schema_version CASCADE');
73
+ // Drop migration tracking table (node-pg-migrate uses 'pgmigrations' by default)
74
+ // This ensures migrations will run fresh on next startup
75
+ await pool.query('DROP TABLE IF EXISTS pgmigrations CASCADE');
76
+
77
+ logger?.info('HA database cleaned up successfully');
78
+ } catch (error) {
79
+ logger?.error(`Failed to cleanup HA database: ${error}`);
80
+ throw error;
81
+ }
82
+ }
83
+
84
+ /**
85
+ * Query validator duties from the database
86
+ */
87
+ export async function getValidatorDuties(
88
+ pool: Pool,
89
+ slot: bigint,
90
+ dutyType?: 'ATTESTATION' | 'BLOCK_PROPOSAL' | 'GOVERNANCE_VOTE' | 'SLASHING_VOTE',
91
+ ): Promise<
92
+ Array<{
93
+ slot: string;
94
+ dutyType: string;
95
+ validatorAddress: string;
96
+ nodeId: string;
97
+ startedAt: Date;
98
+ completedAt: Date | undefined;
99
+ }>
100
+ > {
101
+ const query = dutyType
102
+ ? 'SELECT slot, duty_type, validator_address, node_id, started_at, completed_at FROM validator_duties WHERE slot = $1 AND duty_type = $2 ORDER BY started_at'
103
+ : 'SELECT slot, duty_type, validator_address, node_id, started_at, completed_at FROM validator_duties WHERE slot = $1 ORDER BY started_at';
104
+
105
+ const params = dutyType ? [slot.toString(), dutyType] : [slot.toString()];
106
+
107
+ const result = await pool.query<{
108
+ slot: string;
109
+ duty_type: string;
110
+ validator_address: string;
111
+ node_id: string;
112
+ started_at: Date;
113
+ completed_at: Date | undefined;
114
+ }>(query, params);
115
+
116
+ return result.rows.map(row => ({
117
+ slot: row.slot,
118
+ dutyType: row.duty_type,
119
+ validatorAddress: row.validator_address,
120
+ nodeId: row.node_id,
121
+ startedAt: row.started_at,
122
+ completedAt: row.completed_at,
123
+ }));
124
+ }
125
+
126
+ /**
127
+ * Convert private keys to Ethereum addresses
128
+ */
129
+ export function getAddressesFromPrivateKeys(privateKeys: `0x${string}`[]): string[] {
130
+ return privateKeys.map(pk => {
131
+ const account = privateKeyToAccount(pk);
132
+ return account.address;
133
+ });
134
+ }
135
+
136
+ /**
137
+ * Create initial validators from private keys for L1 contract deployment
138
+ */
139
+ export function createInitialValidatorsFromPrivateKeys(attesterPrivateKeys: `0x${string}`[]): Array<{
140
+ attester: EthAddress;
141
+ withdrawer: EthAddress;
142
+ privateKey: `0x${string}`;
143
+ bn254SecretKey: SecretValue<bigint>;
144
+ }> {
145
+ return attesterPrivateKeys.map(pk => {
146
+ const account = privateKeyToAccount(pk);
147
+ return {
148
+ attester: EthAddress.fromString(account.address),
149
+ withdrawer: EthAddress.fromString(account.address),
150
+ privateKey: pk,
151
+ bn254SecretKey: new SecretValue(Fr.random().toBigInt()),
152
+ };
153
+ });
154
+ }
155
+
156
+ /**
157
+ * Verify no duplicate attestations per validator (HA coordination check)
158
+ * Groups duties by validator address and verifies each validator attested exactly once
159
+ */
160
+ export function verifyNoDuplicateAttestations(
161
+ attestationDuties: Array<{
162
+ validatorAddress: string;
163
+ nodeId: string;
164
+ completedAt: Date | undefined;
165
+ }>,
166
+ logger?: Logger,
167
+ ): Map<string, typeof attestationDuties> {
168
+ const dutiesByValidator = new Map<string, typeof attestationDuties>();
169
+ for (const duty of attestationDuties) {
170
+ const existing = dutiesByValidator.get(duty.validatorAddress) || [];
171
+ existing.push(duty);
172
+ dutiesByValidator.set(duty.validatorAddress, existing);
173
+ }
174
+
175
+ for (const [validatorAddress, validatorDuties] of dutiesByValidator.entries()) {
176
+ if (validatorDuties.length !== 1) {
177
+ throw new Error(`Validator ${validatorAddress} attested ${validatorDuties.length} times (expected exactly once)`);
178
+ }
179
+ if (!validatorDuties[0].completedAt) {
180
+ throw new Error(`Validator ${validatorAddress} attestation duty not completed`);
181
+ }
182
+ logger?.info(`Validator ${validatorAddress} attested once via node ${validatorDuties[0].nodeId}`);
183
+ }
184
+
185
+ return dutiesByValidator;
186
+ }
@@ -1,4 +1,5 @@
1
1
  export * from './fixtures.js';
2
+ export * from './ha_setup.js';
2
3
  export * from './logging.js';
3
4
  export * from './utils.js';
4
5
  export * from './token_utils.js';
@@ -1,5 +1,7 @@
1
- import { type ExtendedViemWalletClient, type L1ContractAddresses, RollupContract } from '@aztec/ethereum';
2
- import { Fr } from '@aztec/foundation/fields';
1
+ import { RollupContract } from '@aztec/ethereum/contracts';
2
+ import type { L1ContractAddresses } from '@aztec/ethereum/l1-contract-addresses';
3
+ import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
4
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
5
  import { tryJsonStringify } from '@aztec/foundation/json-rpc';
4
6
  import { InboxAbi } from '@aztec/l1-artifacts';
5
7
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';