@aztec/end-to-end 3.0.3 → 4.0.0-devnet.1-patch.1

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 (208) 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 +13 -14
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +119 -134
  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 +27 -18
  14. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +7 -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 +96 -112
  17. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +16 -11
  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 +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 +8 -1
  24. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  25. package/dest/e2e_epochs/epochs_test.js +48 -17
  26. package/dest/e2e_fees/bridging_race.notest.js +3 -5
  27. package/dest/e2e_fees/fees_test.d.ts +16 -14
  28. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  29. package/dest/e2e_fees/fees_test.js +124 -140
  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 +8 -7
  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 +18 -21
  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 +17 -10
  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 +9 -17
  58. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  59. package/dest/fixtures/e2e_prover_test.js +91 -102
  60. package/dest/fixtures/fixtures.d.ts +2 -3
  61. package/dest/fixtures/fixtures.d.ts.map +1 -1
  62. package/dest/fixtures/fixtures.js +1 -2
  63. package/dest/fixtures/ha_setup.d.ts +71 -0
  64. package/dest/fixtures/ha_setup.d.ts.map +1 -0
  65. package/dest/fixtures/ha_setup.js +114 -0
  66. package/dest/fixtures/index.d.ts +2 -1
  67. package/dest/fixtures/index.d.ts.map +1 -1
  68. package/dest/fixtures/index.js +1 -0
  69. package/dest/fixtures/setup.d.ts +218 -0
  70. package/dest/fixtures/setup.d.ts.map +1 -0
  71. package/dest/fixtures/setup.js +631 -0
  72. package/dest/fixtures/setup_p2p_test.d.ts +12 -8
  73. package/dest/fixtures/setup_p2p_test.d.ts.map +1 -1
  74. package/dest/fixtures/setup_p2p_test.js +29 -21
  75. package/dest/fixtures/token_utils.d.ts +1 -1
  76. package/dest/fixtures/token_utils.d.ts.map +1 -1
  77. package/dest/fixtures/token_utils.js +7 -4
  78. package/dest/fixtures/utils.d.ts +5 -188
  79. package/dest/fixtures/utils.d.ts.map +1 -1
  80. package/dest/fixtures/utils.js +4 -623
  81. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  82. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  83. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  84. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  85. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  86. package/dest/quality_of_service/prometheus_client.js +67 -0
  87. package/dest/shared/cross_chain_test_harness.d.ts +16 -6
  88. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  89. package/dest/shared/cross_chain_test_harness.js +13 -13
  90. package/dest/shared/gas_portal_test_harness.d.ts +11 -1
  91. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  92. package/dest/shared/gas_portal_test_harness.js +1 -1
  93. package/dest/shared/index.d.ts +2 -2
  94. package/dest/shared/index.d.ts.map +1 -1
  95. package/dest/shared/submit-transactions.d.ts +4 -4
  96. package/dest/shared/submit-transactions.d.ts.map +1 -1
  97. package/dest/shared/submit-transactions.js +9 -11
  98. package/dest/shared/uniswap_l1_l2.d.ts +3 -28
  99. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  100. package/dest/shared/uniswap_l1_l2.js +53 -33
  101. package/dest/simulators/lending_simulator.d.ts +5 -1
  102. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  103. package/dest/simulators/lending_simulator.js +2 -2
  104. package/dest/spartan/setup_test_wallets.d.ts +5 -4
  105. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  106. package/dest/spartan/setup_test_wallets.js +64 -35
  107. package/dest/spartan/tx_metrics.d.ts +51 -2
  108. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  109. package/dest/spartan/tx_metrics.js +333 -6
  110. package/dest/spartan/utils/bot.d.ts +27 -0
  111. package/dest/spartan/utils/bot.d.ts.map +1 -0
  112. package/dest/spartan/utils/bot.js +141 -0
  113. package/dest/spartan/utils/chaos.d.ts +79 -0
  114. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  115. package/dest/spartan/utils/chaos.js +142 -0
  116. package/dest/spartan/utils/clients.d.ts +39 -0
  117. package/dest/spartan/utils/clients.d.ts.map +1 -0
  118. package/dest/spartan/utils/clients.js +90 -0
  119. package/dest/spartan/utils/config.d.ts +39 -0
  120. package/dest/spartan/utils/config.d.ts.map +1 -0
  121. package/dest/spartan/utils/config.js +21 -0
  122. package/dest/spartan/utils/health.d.ts +63 -0
  123. package/dest/spartan/utils/health.d.ts.map +1 -0
  124. package/dest/spartan/utils/health.js +202 -0
  125. package/dest/spartan/utils/helm.d.ts +15 -0
  126. package/dest/spartan/utils/helm.d.ts.map +1 -0
  127. package/dest/spartan/utils/helm.js +47 -0
  128. package/dest/spartan/utils/index.d.ts +9 -0
  129. package/dest/spartan/utils/index.d.ts.map +1 -0
  130. package/dest/spartan/utils/index.js +18 -0
  131. package/dest/spartan/utils/k8s.d.ts +126 -0
  132. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  133. package/dest/spartan/utils/k8s.js +375 -0
  134. package/dest/spartan/utils/nodes.d.ts +41 -0
  135. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  136. package/dest/spartan/utils/nodes.js +461 -0
  137. package/dest/spartan/utils/scripts.d.ts +30 -0
  138. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  139. package/dest/spartan/utils/scripts.js +81 -0
  140. package/dest/spartan/utils.d.ts +2 -222
  141. package/dest/spartan/utils.d.ts.map +1 -1
  142. package/dest/spartan/utils.js +1 -782
  143. package/dest/test-wallet/test_wallet.d.ts +82 -0
  144. package/dest/test-wallet/test_wallet.d.ts.map +1 -0
  145. package/dest/test-wallet/test_wallet.js +213 -0
  146. package/dest/test-wallet/utils.d.ts +41 -0
  147. package/dest/test-wallet/utils.d.ts.map +1 -0
  148. package/dest/test-wallet/utils.js +71 -0
  149. package/package.json +44 -39
  150. package/src/bench/client_flows/benchmark.ts +24 -2
  151. package/src/bench/client_flows/client_flows_benchmark.ts +139 -205
  152. package/src/bench/client_flows/config.ts +9 -1
  153. package/src/bench/client_flows/data_extractor.ts +1 -1
  154. package/src/bench/utils.ts +31 -21
  155. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +105 -143
  156. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +127 -117
  157. package/src/e2e_deploy_contract/deploy_test.ts +22 -15
  158. package/src/e2e_epochs/epochs_test.ts +92 -43
  159. package/src/e2e_fees/bridging_race.notest.ts +4 -10
  160. package/src/e2e_fees/fees_test.ts +174 -219
  161. package/src/e2e_l1_publisher/write_json.ts +16 -16
  162. package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
  163. package/src/e2e_p2p/inactivity_slash_test.ts +3 -3
  164. package/src/e2e_p2p/p2p_network.ts +173 -169
  165. package/src/e2e_p2p/reqresp/utils.ts +207 -0
  166. package/src/e2e_p2p/shared.ts +28 -27
  167. package/src/e2e_storage_proof/fixtures/storage_proof.json +915 -0
  168. package/src/e2e_storage_proof/fixtures/storage_proof_fetcher.ts +190 -0
  169. package/src/e2e_storage_proof/fixtures/storage_proof_fixture.ts +173 -0
  170. package/src/e2e_token_contract/token_contract_test.ts +104 -119
  171. package/src/fixtures/dumps/epoch_proof_result.json +1 -1
  172. package/src/fixtures/e2e_prover_test.ts +102 -139
  173. package/src/fixtures/fixtures.ts +1 -3
  174. package/src/fixtures/ha_setup.ts +184 -0
  175. package/src/fixtures/index.ts +1 -0
  176. package/src/fixtures/setup.ts +933 -0
  177. package/src/fixtures/setup_p2p_test.ts +31 -27
  178. package/src/fixtures/token_utils.ts +6 -5
  179. package/src/fixtures/utils.ts +27 -914
  180. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  181. package/src/quality_of_service/prometheus_client.ts +113 -0
  182. package/src/shared/cross_chain_test_harness.ts +16 -36
  183. package/src/shared/gas_portal_test_harness.ts +1 -1
  184. package/src/shared/index.ts +1 -1
  185. package/src/shared/submit-transactions.ts +11 -16
  186. package/src/shared/uniswap_l1_l2.ts +59 -80
  187. package/src/simulators/lending_simulator.ts +2 -2
  188. package/src/spartan/setup_test_wallets.ts +82 -26
  189. package/src/spartan/tx_metrics.ts +255 -9
  190. package/src/spartan/utils/bot.ts +185 -0
  191. package/src/spartan/utils/chaos.ts +253 -0
  192. package/src/spartan/utils/clients.ts +100 -0
  193. package/src/spartan/utils/config.ts +27 -0
  194. package/src/spartan/utils/health.ts +255 -0
  195. package/src/spartan/utils/helm.ts +84 -0
  196. package/src/spartan/utils/index.ts +64 -0
  197. package/src/spartan/utils/k8s.ts +527 -0
  198. package/src/spartan/utils/nodes.ts +538 -0
  199. package/src/spartan/utils/scripts.ts +99 -0
  200. package/src/spartan/utils.ts +1 -984
  201. package/src/test-wallet/test_wallet.ts +296 -0
  202. package/src/test-wallet/utils.ts +112 -0
  203. package/dest/fixtures/snapshot_manager.d.ts +0 -95
  204. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  205. package/dest/fixtures/snapshot_manager.js +0 -515
  206. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  207. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  208. package/src/fixtures/snapshot_manager.ts +0 -680
@@ -1,624 +1,5 @@
1
- import { SchnorrAccountContractArtifact } from '@aztec/accounts/schnorr';
2
- import { generateSchnorrAccounts, getInitialTestAccountsData } from '@aztec/accounts/testing';
3
- import { createArchiver } from '@aztec/archiver';
4
- import { AztecNodeService, getConfigEnvVars } from '@aztec/aztec-node';
5
- import { BatchCall } from '@aztec/aztec.js/contracts';
6
- import { publishContractClass, publishInstance } from '@aztec/aztec.js/deployment';
7
- import { Fr } from '@aztec/aztec.js/fields';
8
- import { createLogger } from '@aztec/aztec.js/log';
9
- import { createAztecNodeClient, waitForNode } from '@aztec/aztec.js/node';
10
- import { AnvilTestWatcher, CheatCodes } from '@aztec/aztec/testing';
11
- import { createBlobSinkClient } from '@aztec/blob-sink/client';
12
- import { createBlobSinkServer } from '@aztec/blob-sink/server';
13
- import { SPONSORED_FPC_SALT } from '@aztec/constants';
14
- import { isAnvilTestChain } from '@aztec/ethereum/chain';
15
- import { createExtendedL1Client } from '@aztec/ethereum/client';
16
- import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
17
- import { NULL_KEY } from '@aztec/ethereum/constants';
18
- import { deployAztecL1Contracts } from '@aztec/ethereum/deploy-aztec-l1-contracts';
19
- import { DelayedTxUtils, EthCheatCodes, EthCheatCodesWithState, createDelayedL1TxUtilsFromViemWallet, startAnvil } from '@aztec/ethereum/test';
20
- import { EpochNumber } from '@aztec/foundation/branded-types';
21
- import { SecretValue } from '@aztec/foundation/config';
22
- import { EthAddress } from '@aztec/foundation/eth-address';
23
- import { tryRmDir } from '@aztec/foundation/fs';
24
- import { withLogNameSuffix } from '@aztec/foundation/log';
25
- import { retryUntil } from '@aztec/foundation/retry';
26
- import { sleep } from '@aztec/foundation/sleep';
27
- import { DateProvider, TestDateProvider } from '@aztec/foundation/timer';
28
- import { SponsoredFPCContract } from '@aztec/noir-contracts.js/SponsoredFPC';
29
- import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
30
- import { MockGossipSubNetwork, getMockPubSubP2PServiceFactory } from '@aztec/p2p/test-helpers';
31
- import { protocolContractsHash } from '@aztec/protocol-contracts';
32
- import { createProverNode } from '@aztec/prover-node';
33
- import { getPXEConfig } from '@aztec/pxe/server';
34
- import { getContractClassFromArtifact, getContractInstanceFromInstantiationParams } from '@aztec/stdlib/contract';
35
- import { tryStop } from '@aztec/stdlib/interfaces/server';
36
- import { getConfigEnvVars as getTelemetryConfig, initTelemetryClient } from '@aztec/telemetry-client';
37
- import { BenchmarkTelemetryClient } from '@aztec/telemetry-client/bench';
38
- import { TestWallet, deployFundedSchnorrAccounts } from '@aztec/test-wallet/server';
39
- import { getGenesisValues } from '@aztec/world-state/testing';
40
- import { randomBytes } from 'crypto';
41
- import fs from 'fs/promises';
42
- import getPort from 'get-port';
43
- import { tmpdir } from 'os';
44
- import * as path from 'path';
45
- import { generatePrivateKey, mnemonicToAccount, privateKeyToAccount } from 'viem/accounts';
46
- import { foundry } from 'viem/chains';
47
- import { MNEMONIC, TEST_PEER_CHECK_INTERVAL_MS } from './fixtures.js';
48
- import { getACVMConfig } from './get_acvm_config.js';
49
- import { getBBConfig } from './get_bb_config.js';
50
- import { isMetricsLoggingRequested, setupMetricsLogger } from './logging.js';
51
- export { deployAndInitializeTokenAndBridgeContracts } from '../shared/cross_chain_test_harness.js';
52
- export { startAnvil };
53
- const { AZTEC_NODE_URL = '' } = process.env;
54
- const getAztecUrl = ()=>AZTEC_NODE_URL;
55
- let telemetry = undefined;
56
- async function getTelemetryClient(partialConfig = {}) {
57
- if (!telemetry) {
58
- const config = {
59
- ...getTelemetryConfig(),
60
- ...partialConfig
61
- };
62
- telemetry = config.benchmark ? new BenchmarkTelemetryClient() : await initTelemetryClient(config);
63
- }
64
- return telemetry;
65
- }
66
- if (typeof afterAll === 'function') {
67
- afterAll(async ()=>{
68
- await telemetry?.stop();
69
- });
70
- }
71
- export const getPrivateKeyFromIndex = (index)=>{
72
- const hdAccount = mnemonicToAccount(MNEMONIC, {
73
- addressIndex: index
74
- });
75
- const privKeyRaw = hdAccount.getHdKey().privateKey;
76
- return privKeyRaw === null ? null : Buffer.from(privKeyRaw);
77
- };
78
- /**
79
- * Sets up Private eXecution Environment (PXE) and returns the corresponding test wallet.
80
- * @param aztecNode - An instance of Aztec Node.
81
- * @param opts - Partial configuration for the PXE.
82
- * @param logger - The logger to be used.
83
- * @param useLogSuffix - Whether to add a randomly generated suffix to the PXE debug logs.
84
- * @returns A test wallet, logger and teardown function.
85
- */ export async function setupPXEAndGetWallet(aztecNode, opts = {}, logger = getLogger(), useLogSuffix = false) {
86
- const PXEConfig = {
87
- ...getPXEConfig(),
88
- ...opts
89
- };
90
- // For tests we only want proving enabled if specifically requested
91
- PXEConfig.proverEnabled = !!opts.proverEnabled;
92
- // If no data directory provided, create a temp directory and clean up afterwards
93
- const configuredDataDirectory = PXEConfig.dataDirectory;
94
- if (!configuredDataDirectory) {
95
- PXEConfig.dataDirectory = path.join(tmpdir(), randomBytes(8).toString('hex'));
96
- }
97
- const teardown = configuredDataDirectory ? ()=>Promise.resolve() : ()=>tryRmDir(PXEConfig.dataDirectory);
98
- const wallet = await TestWallet.create(aztecNode, PXEConfig, {
99
- useLogSuffix
100
- });
101
- return {
102
- wallet,
103
- logger,
104
- teardown
105
- };
106
- }
107
- /**
108
- * Function to setup the test against a remote deployment. It is assumed that L1 contract are already deployed
109
- * @param account - The account for use in create viem wallets.
110
- * @param config - The aztec Node Configuration
111
- * @param logger - The logger to be used
112
- * @param numberOfAccounts - The number of new accounts to be created once the PXE is initiated.
113
- * (will create extra accounts if the environment doesn't already have enough accounts)
114
- * @returns Private eXecution Environment (PXE) client, viem wallets, contract addresses etc.
115
- */ async function setupWithRemoteEnvironment(account, config, logger, numberOfAccounts) {
116
- // we are setting up against a remote environment, l1 contracts are already deployed
117
- const aztecNodeUrl = getAztecUrl();
118
- logger.verbose(`Creating Aztec Node client to remote host ${aztecNodeUrl}`);
119
- const aztecNode = createAztecNodeClient(aztecNodeUrl);
120
- await waitForNode(aztecNode, logger);
121
- logger.verbose('JSON RPC client connected to Aztec Node');
122
- logger.verbose(`Retrieving contract addresses from ${aztecNodeUrl}`);
123
- const { l1ContractAddresses, rollupVersion } = await aztecNode.getNodeInfo();
124
- const l1Client = createExtendedL1Client(config.l1RpcUrls, account, foundry);
125
- const deployL1ContractsValues = {
126
- l1ContractAddresses,
127
- l1Client,
128
- rollupVersion
129
- };
130
- const ethCheatCodes = new EthCheatCodes(config.l1RpcUrls, new DateProvider());
131
- const wallet = await TestWallet.create(aztecNode);
132
- const cheatCodes = await CheatCodes.create(config.l1RpcUrls, aztecNode, new DateProvider());
133
- const teardown = ()=>Promise.resolve();
134
- logger.verbose('Populating wallet from already registered accounts...');
135
- const initialFundedAccounts = await getInitialTestAccountsData();
136
- if (initialFundedAccounts.length < numberOfAccounts) {
137
- throw new Error(`Required ${numberOfAccounts} accounts. Found ${initialFundedAccounts.length}.`);
138
- // Deploy new accounts if there's a test that requires more funded accounts in the remote environment.
139
- }
140
- const testAccounts = await Promise.all(initialFundedAccounts.slice(0, numberOfAccounts).map(async (account)=>{
141
- const accountManager = await wallet.createSchnorrAccount(account.secret, account.salt, account.signingKey);
142
- return accountManager.address;
143
- }));
144
- return {
145
- aztecNode,
146
- aztecNodeAdmin: undefined,
147
- sequencer: undefined,
148
- proverNode: undefined,
149
- deployL1ContractsValues,
150
- config,
151
- initialFundedAccounts,
152
- wallet,
153
- accounts: testAccounts,
154
- logger,
155
- cheatCodes,
156
- ethCheatCodes,
157
- prefilledPublicData: undefined,
158
- mockGossipSubNetwork: undefined,
159
- watcher: undefined,
160
- dateProvider: undefined,
161
- blobSink: undefined,
162
- telemetryClient: undefined,
163
- teardown
164
- };
165
- }
166
- /**
167
- * Sets up the environment for the end-to-end tests.
168
- * @param numberOfAccounts - The number of new accounts to be created once the PXE is initiated.
169
- * @param opts - Options to pass to the node initialization and to the setup script.
170
- * @param pxeOpts - Options to pass to the PXE initialization.
171
- */ export async function setup(numberOfAccounts = 1, opts = {}, pxeOpts = {}, chain = foundry) {
172
- let anvil;
173
- try {
174
- opts.aztecTargetCommitteeSize ??= 0;
175
- opts.slasherFlavor ??= 'none';
176
- const config = {
177
- ...getConfigEnvVars(),
178
- ...opts
179
- };
180
- // use initialValidators for the node config
181
- config.validatorPrivateKeys = new SecretValue(opts.initialValidators?.map((v)=>v.privateKey) ?? []);
182
- config.peerCheckIntervalMS = TEST_PEER_CHECK_INTERVAL_MS;
183
- // For tests we only want proving enabled if specifically requested
184
- config.realProofs = !!opts.realProofs;
185
- // Only enforce the time table if requested
186
- config.enforceTimeTable = !!opts.enforceTimeTable;
187
- const logger = getLogger();
188
- // Create a temp directory for any services that need it and cleanup later
189
- const directoryToCleanup = path.join(tmpdir(), randomBytes(8).toString('hex'));
190
- await fs.mkdir(directoryToCleanup, {
191
- recursive: true
192
- });
193
- if (!config.dataDirectory) {
194
- config.dataDirectory = directoryToCleanup;
195
- }
196
- if (!config.l1RpcUrls?.length) {
197
- if (!isAnvilTestChain(chain.id)) {
198
- throw new Error(`No ETHEREUM_HOSTS set but non anvil chain requested`);
199
- }
200
- if (AZTEC_NODE_URL) {
201
- throw new Error(`AZTEC_NODE_URL provided but no ETHEREUM_HOSTS set. Refusing to run, please set both variables so tests can deploy L1 contracts to the same Anvil instance`);
202
- }
203
- const res = await startAnvil({
204
- l1BlockTime: opts.ethereumSlotDuration,
205
- accounts: opts.anvilAccounts,
206
- port: opts.anvilPort
207
- });
208
- anvil = res.anvil;
209
- config.l1RpcUrls = [
210
- res.rpcUrl
211
- ];
212
- }
213
- // Enable logging metrics to a local file named after the test suite
214
- if (isMetricsLoggingRequested()) {
215
- const filename = path.join('log', getJobName() + '.jsonl');
216
- logger.info(`Logging metrics to ${filename}`);
217
- setupMetricsLogger(filename);
218
- }
219
- const dateProvider = new TestDateProvider();
220
- const ethCheatCodes = new EthCheatCodesWithState(config.l1RpcUrls, dateProvider);
221
- if (opts.stateLoad) {
222
- await ethCheatCodes.loadChainState(opts.stateLoad);
223
- }
224
- if (opts.l1StartTime) {
225
- await ethCheatCodes.warp(opts.l1StartTime, {
226
- resetBlockInterval: true
227
- });
228
- }
229
- let publisherPrivKeyHex = undefined;
230
- let publisherHdAccount = undefined;
231
- if (opts.l1PublisherKey && opts.l1PublisherKey.getValue() && opts.l1PublisherKey.getValue() != NULL_KEY) {
232
- publisherPrivKeyHex = opts.l1PublisherKey.getValue();
233
- publisherHdAccount = privateKeyToAccount(publisherPrivKeyHex);
234
- } else if (config.publisherPrivateKeys && config.publisherPrivateKeys.length > 0 && config.publisherPrivateKeys[0].getValue() != NULL_KEY) {
235
- publisherPrivKeyHex = config.publisherPrivateKeys[0].getValue();
236
- publisherHdAccount = privateKeyToAccount(publisherPrivKeyHex);
237
- } else if (!MNEMONIC) {
238
- throw new Error(`Mnemonic not provided and no publisher private key`);
239
- } else {
240
- publisherHdAccount = mnemonicToAccount(MNEMONIC, {
241
- addressIndex: 0
242
- });
243
- const publisherPrivKeyRaw = publisherHdAccount.getHdKey().privateKey;
244
- const publisherPrivKey = publisherPrivKeyRaw === null ? null : Buffer.from(publisherPrivKeyRaw);
245
- publisherPrivKeyHex = `0x${publisherPrivKey.toString('hex')}`;
246
- config.publisherPrivateKeys = [
247
- new SecretValue(publisherPrivKeyHex)
248
- ];
249
- }
250
- if (config.coinbase === undefined) {
251
- config.coinbase = EthAddress.fromString(publisherHdAccount.address);
252
- }
253
- if (AZTEC_NODE_URL) {
254
- // we are setting up against a remote environment, l1 contracts are assumed to already be deployed
255
- return await setupWithRemoteEnvironment(publisherHdAccount, config, logger, numberOfAccounts);
256
- }
257
- const initialFundedAccounts = opts.initialFundedAccounts ?? await generateSchnorrAccounts(opts.numberOfInitialFundedAccounts ?? numberOfAccounts);
258
- const { genesisArchiveRoot, prefilledPublicData, fundingNeeded } = await getGenesisValues(initialFundedAccounts.map((a)=>a.address), opts.initialAccountFeeJuice, opts.genesisPublicData);
259
- const wasAutomining = await ethCheatCodes.isAutoMining();
260
- const enableAutomine = opts.automineL1Setup && !wasAutomining && isAnvilTestChain(chain.id);
261
- if (enableAutomine) {
262
- await ethCheatCodes.setAutomine(true);
263
- }
264
- const l1Client = createExtendedL1Client(config.l1RpcUrls, publisherHdAccount, chain);
265
- const deployL1ContractsValues = await deployAztecL1Contracts(config.l1RpcUrls[0], publisherPrivKeyHex, chain.id, {
266
- ...getL1ContractsConfigEnvVars(),
267
- ...opts,
268
- vkTreeRoot: getVKTreeRoot(),
269
- protocolContractsHash,
270
- genesisArchiveRoot,
271
- initialValidators: opts.initialValidators,
272
- feeJuicePortalInitialBalance: fundingNeeded,
273
- realVerifier: false
274
- });
275
- config.l1Contracts = deployL1ContractsValues.l1ContractAddresses;
276
- config.rollupVersion = deployL1ContractsValues.rollupVersion;
277
- if (enableAutomine) {
278
- await ethCheatCodes.setAutomine(false);
279
- await ethCheatCodes.setIntervalMining(config.ethereumSlotDuration);
280
- dateProvider.setTime(await ethCheatCodes.timestamp() * 1000);
281
- }
282
- if (opts.l2StartTime) {
283
- // This should only be used in synching test or when you need to have a stable
284
- // timestamp for the first l2 block.
285
- await ethCheatCodes.warp(opts.l2StartTime, {
286
- resetBlockInterval: true
287
- });
288
- }
289
- const watcher = new AnvilTestWatcher(new EthCheatCodesWithState(config.l1RpcUrls, dateProvider), deployL1ContractsValues.l1ContractAddresses.rollupAddress, deployL1ContractsValues.l1Client, dateProvider);
290
- if (!opts.disableAnvilTestWatcher) {
291
- await watcher.start();
292
- }
293
- const telemetry = await getTelemetryClient(opts.telemetryConfig);
294
- // Blob sink service - blobs get posted here and served from here
295
- const blobSinkPort = await getPort();
296
- const blobSink = await createBlobSinkServer({
297
- l1ChainId: config.l1ChainId,
298
- l1RpcUrls: config.l1RpcUrls,
299
- l1Contracts: config.l1Contracts,
300
- port: blobSinkPort,
301
- dataDirectory: config.dataDirectory,
302
- dataStoreMapSizeKb: config.dataStoreMapSizeKb
303
- }, telemetry);
304
- await blobSink.start();
305
- config.blobSinkUrl = `http://localhost:${blobSinkPort}`;
306
- logger.verbose('Creating and synching an aztec node', config);
307
- const acvmConfig = await getACVMConfig(logger);
308
- if (acvmConfig) {
309
- config.acvmWorkingDirectory = acvmConfig.acvmWorkingDirectory;
310
- config.acvmBinaryPath = acvmConfig.acvmBinaryPath;
311
- }
312
- const bbConfig = await getBBConfig(logger);
313
- if (bbConfig) {
314
- config.bbBinaryPath = bbConfig.bbBinaryPath;
315
- config.bbWorkingDirectory = bbConfig.bbWorkingDirectory;
316
- }
317
- const blobSinkClient = createBlobSinkClient(config, {
318
- logger: createLogger('node:blob-sink:client')
319
- });
320
- let mockGossipSubNetwork;
321
- let p2pClientDeps = undefined;
322
- if (opts.mockGossipSubNetwork) {
323
- mockGossipSubNetwork = new MockGossipSubNetwork();
324
- p2pClientDeps = {
325
- p2pServiceFactory: getMockPubSubP2PServiceFactory(mockGossipSubNetwork)
326
- };
327
- }
328
- // Transactions built against the genesis state must be included in block 1, otherwise they are dropped.
329
- // To avoid test failures from dropped transactions, we ensure progression beyond genesis before proceeding.
330
- // For account deployments, we set minTxsPerBlock=1 and deploy accounts sequentially for guaranteed success.
331
- // If no accounts need deployment, we await an empty block to confirm network progression. After either path
332
- // completes, we restore the original minTxsPerBlock setting. The deployment and waiting for empty block is
333
- // handled by the if-else branches on line 632.
334
- // For more details on why the tx would be dropped see `validate_include_by_timestamp` function in
335
- // `noir-projects/noir-protocol-circuits/crates/rollup-lib/src/base/components/validation_requests.nr`.
336
- //
337
- // Note: If the following seems too convoluted or if it starts making problems, we could drop the "progressing
338
- // past genesis via an account contract deployment" optimization and just call flush() on the sequencer and wait
339
- // for an empty block to be mined. This would simplify it all quite a bit but the setup would be slower for tests
340
- // deploying accounts.
341
- const originalMinTxsPerBlock = config.minTxsPerBlock;
342
- if (originalMinTxsPerBlock === undefined) {
343
- throw new Error('minTxsPerBlock is undefined in e2e test setup');
344
- }
345
- config.minTxsPerBlock = numberOfAccounts === 0 ? 0 : 1;
346
- config.p2pEnabled = opts.mockGossipSubNetwork || config.p2pEnabled;
347
- config.p2pIp = opts.p2pIp ?? config.p2pIp ?? '127.0.0.1';
348
- if (!config.disableValidator) {
349
- if ((config.validatorPrivateKeys?.getValue().length ?? 0) === 0) {
350
- config.validatorPrivateKeys = new SecretValue([
351
- generatePrivateKey()
352
- ]);
353
- }
354
- }
355
- const aztecNode = await AztecNodeService.createAndSync(config, {
356
- dateProvider,
357
- blobSinkClient,
358
- telemetry,
359
- p2pClientDeps,
360
- logger: createLogger('node:MAIN-aztec-node')
361
- }, {
362
- prefilledPublicData
363
- });
364
- const sequencerClient = aztecNode.getSequencer();
365
- if (sequencerClient) {
366
- const publisher = sequencerClient.sequencer.publisher;
367
- publisher.l1TxUtils = DelayedTxUtils.fromL1TxUtils(publisher.l1TxUtils, config.ethereumSlotDuration, l1Client);
368
- }
369
- let proverNode = undefined;
370
- if (opts.startProverNode) {
371
- logger.verbose('Creating and syncing a simulated prover node...');
372
- const proverNodePrivateKey = getPrivateKeyFromIndex(2);
373
- const proverNodePrivateKeyHex = `0x${proverNodePrivateKey.toString('hex')}`;
374
- const proverNodeDataDirectory = path.join(directoryToCleanup, randomBytes(8).toString('hex'));
375
- const proverNodeConfig = {
376
- ...config.proverNodeConfig,
377
- dataDirectory: proverNodeDataDirectory
378
- };
379
- proverNode = await createAndSyncProverNode(proverNodePrivateKeyHex, config, proverNodeConfig, aztecNode, prefilledPublicData);
380
- }
381
- logger.verbose('Creating a pxe...');
382
- const { wallet, teardown: pxeTeardown } = await setupPXEAndGetWallet(aztecNode, pxeOpts, logger);
383
- const cheatCodes = await CheatCodes.create(config.l1RpcUrls, aztecNode, dateProvider);
384
- if (opts.aztecTargetCommitteeSize && opts.aztecTargetCommitteeSize > 0 || opts.initialValidators && opts.initialValidators.length > 0) {
385
- // We need to advance such that the committee is set up.
386
- await cheatCodes.rollup.advanceToEpoch(EpochNumber.fromBigInt(BigInt(await cheatCodes.rollup.getEpoch()) + BigInt(config.lagInEpochsForValidatorSet + 1)));
387
- await cheatCodes.rollup.setupEpoch();
388
- await cheatCodes.rollup.debugRollup();
389
- }
390
- let accounts = [];
391
- // Below we continue with what we described in the long comment on line 571.
392
- if (numberOfAccounts === 0) {
393
- logger.info('No accounts are being deployed, waiting for an empty block 1 to be mined');
394
- while(await aztecNode.getBlockNumber() === 0){
395
- await sleep(2000);
396
- }
397
- } else {
398
- logger.info(`${numberOfAccounts} accounts are being deployed. Reliably progressing past genesis by setting minTxsPerBlock to 1 and waiting for the accounts to be deployed`);
399
- const accountsData = initialFundedAccounts.slice(0, numberOfAccounts);
400
- const accountManagers = await deployFundedSchnorrAccounts(wallet, aztecNode, accountsData);
401
- accounts = accountManagers.map((accountManager)=>accountManager.address);
402
- }
403
- // Now we restore the original minTxsPerBlock setting.
404
- sequencerClient.getSequencer().updateConfig({
405
- minTxsPerBlock: originalMinTxsPerBlock
406
- });
407
- if (initialFundedAccounts.length < numberOfAccounts) {
408
- // TODO: Create (numberOfAccounts - initialFundedAccounts.length) wallets without funds.
409
- throw new Error(`Unable to deploy ${numberOfAccounts} accounts. Only ${initialFundedAccounts.length} accounts were funded.`);
410
- }
411
- const teardown = async ()=>{
412
- try {
413
- await pxeTeardown();
414
- await tryStop(aztecNode, logger);
415
- await tryStop(proverNode, logger);
416
- if (acvmConfig?.cleanup) {
417
- await acvmConfig.cleanup();
418
- }
419
- if (bbConfig?.cleanup) {
420
- await bbConfig.cleanup();
421
- }
422
- await tryStop(watcher, logger);
423
- await tryStop(anvil, logger);
424
- await tryStop(blobSink, logger);
425
- await tryRmDir(directoryToCleanup, logger);
426
- } catch (err) {
427
- logger.error(`Error during e2e test teardown`, err);
428
- }
429
- };
430
- return {
431
- aztecNode,
432
- aztecNodeAdmin: aztecNode,
433
- blobSink,
434
- cheatCodes,
435
- ethCheatCodes,
436
- config,
437
- dateProvider,
438
- deployL1ContractsValues,
439
- initialFundedAccounts,
440
- logger,
441
- mockGossipSubNetwork,
442
- prefilledPublicData,
443
- proverNode,
444
- sequencer: sequencerClient,
445
- teardown,
446
- telemetryClient: telemetry,
447
- wallet,
448
- accounts,
449
- watcher
450
- };
451
- } catch (err) {
452
- // TODO: Just hoisted anvil for now to ensure cleanup. Prob need to hoist the rest.
453
- await anvil?.stop();
454
- throw err;
455
- }
456
- }
457
- /**
458
- * Registers the contract class used for test accounts and publicly deploys the instances requested.
459
- * Use this when you need to make a public call to an account contract, such as for requesting a public authwit.
460
- * @param sender - Wallet to send the deployment tx.
461
- * @param accountsToDeploy - Which accounts to publicly deploy.
462
- */ export async function ensureAccountContractsPublished(wallet, accountsToDeploy) {
463
- // We have to check whether the accounts are already deployed. This can happen if the test runs against
464
- // the local network and the test accounts exist
465
- const accountsAndAddresses = await Promise.all(accountsToDeploy.map(async (address)=>{
466
- return {
467
- address,
468
- deployed: (await wallet.getContractMetadata(address)).isContractPublished
469
- };
470
- }));
471
- const instances = (await Promise.all(accountsAndAddresses.filter(({ deployed })=>!deployed).map(({ address })=>wallet.getContractMetadata(address)))).map((contractMetadata)=>contractMetadata.contractInstance);
472
- const contractClass = await getContractClassFromArtifact(SchnorrAccountContractArtifact);
473
- if (!(await wallet.getContractClassMetadata(contractClass.id, true)).isContractClassPubliclyRegistered) {
474
- await (await publishContractClass(wallet, SchnorrAccountContractArtifact)).send({
475
- from: accountsToDeploy[0]
476
- }).wait();
477
- }
478
- const requests = await Promise.all(instances.map(async (instance)=>await publishInstance(wallet, instance)));
479
- const batch = new BatchCall(wallet, requests);
480
- await batch.send({
481
- from: accountsToDeploy[0]
482
- }).wait();
483
- }
484
- /** Returns the job name for the current test. */ function getJobName() {
485
- return process.env.JOB_NAME ?? expect.getState().currentTestName?.split(' ')[0].replaceAll('/', '_') ?? 'unknown';
486
- }
487
1
  /**
488
- * Returns a logger instance for the current test.
489
- * @returns a logger instance for the current test.
490
- */ export function getLogger() {
491
- const describeBlockName = expect.getState().currentTestName?.split(' ')[0].replaceAll('/', ':');
492
- if (!describeBlockName) {
493
- const name = expect.getState().testPath?.split('/').pop()?.split('.')[0] ?? 'unknown';
494
- return createLogger('e2e:' + name);
495
- }
496
- return createLogger('e2e:' + describeBlockName);
497
- }
498
- export function getBalancesFn(symbol, method, from, logger) {
499
- const balances = async (...addressLikes)=>{
500
- const addresses = addressLikes.map((addressLike)=>'address' in addressLike ? addressLike.address : addressLike);
501
- const b = await Promise.all(addresses.map((address)=>method(address).simulate({
502
- from
503
- })));
504
- const debugString = `${symbol} balances: ${addresses.map((address, i)=>`${address}: ${b[i]}`).join(', ')}`;
505
- logger.verbose(debugString);
506
- return b;
507
- };
508
- return balances;
509
- }
510
- export async function expectMapping(fn, inputs, expectedOutputs) {
511
- expect(inputs.length).toBe(expectedOutputs.length);
512
- const outputs = await fn(...inputs);
513
- expect(outputs).toEqual(expectedOutputs);
514
- }
515
- export async function expectMappingDelta(initialValues, fn, inputs, expectedDiffs) {
516
- expect(inputs.length).toBe(expectedDiffs.length);
517
- const outputs = await fn(...inputs);
518
- const diffs = outputs.map((output, i)=>output - initialValues[i]);
519
- expect(diffs).toEqual(expectedDiffs);
520
- }
521
- /**
522
- * Computes the address of the "canonical" SponsoredFPCContract. This is not a protocol contract
523
- * but by conventions its address is computed with a salt of 0.
524
- * @returns The address of the sponsored FPC contract
525
- */ export function getSponsoredFPCInstance() {
526
- return Promise.resolve(getContractInstanceFromInstantiationParams(SponsoredFPCContract.artifact, {
527
- salt: new Fr(SPONSORED_FPC_SALT)
528
- }));
529
- }
530
- /**
531
- * Computes the address of the "canonical" SponsoredFPCContract. This is not a protocol contract
532
- * but by conventions its address is computed with a salt of 0.
533
- * @returns The address of the sponsored FPC contract
534
- */ export async function getSponsoredFPCAddress() {
535
- const sponsoredFPCInstance = await getSponsoredFPCInstance();
536
- return sponsoredFPCInstance.address;
537
- }
538
- /**
539
- * Deploy a sponsored FPC contract to a running instance.
540
- */ export async function setupSponsoredFPC(wallet) {
541
- const instance = await getContractInstanceFromInstantiationParams(SponsoredFPCContract.artifact, {
542
- salt: new Fr(SPONSORED_FPC_SALT)
543
- });
544
- await wallet.registerContract(instance, SponsoredFPCContract.artifact);
545
- getLogger().info(`SponsoredFPC: ${instance.address}`);
546
- return instance;
547
- }
548
- /**
549
- * Registers the SponsoredFPC in this PXE instance
550
- * @param wallet - The wallet
551
- */ export async function registerSponsoredFPC(wallet) {
552
- await wallet.registerContract(await getSponsoredFPCInstance(), SponsoredFPCContract.artifact);
553
- }
554
- export async function waitForProvenChain(node, targetBlock, timeoutSec = 60, intervalSec = 1) {
555
- targetBlock ??= await node.getBlockNumber();
556
- await retryUntil(async ()=>await node.getProvenBlockNumber() >= targetBlock, 'proven chain status', timeoutSec, intervalSec);
557
- }
558
- export function createAndSyncProverNode(proverNodePrivateKey, aztecNodeConfig, proverNodeConfig, aztecNode, prefilledPublicData = [], proverNodeDeps = {}) {
559
- return withLogNameSuffix('prover-node', async ()=>{
560
- // Disable stopping the aztec node as the prover coordination test will kill it otherwise
561
- // This is only required when stopping the prover node for testing
562
- const aztecNodeTxProvider = aztecNode && {
563
- getTxByHash: aztecNode.getTxByHash.bind(aztecNode),
564
- getTxsByHash: aztecNode.getTxsByHash.bind(aztecNode),
565
- stop: ()=>Promise.resolve()
566
- };
567
- const blobSinkClient = createBlobSinkClient(aztecNodeConfig);
568
- // Creating temp store and archiver for simulated prover node
569
- const archiverConfig = {
570
- ...aztecNodeConfig,
571
- dataDirectory: proverNodeConfig.dataDirectory
572
- };
573
- const archiver = await createArchiver(archiverConfig, {
574
- blobSinkClient,
575
- dateProvider: proverNodeDeps.dateProvider
576
- }, {
577
- blockUntilSync: true
578
- });
579
- // Prover node config is for simulated proofs
580
- const proverConfig = {
581
- ...aztecNodeConfig,
582
- txCollectionNodeRpcUrls: [],
583
- realProofs: false,
584
- proverAgentCount: 2,
585
- publisherPrivateKeys: [
586
- new SecretValue(proverNodePrivateKey)
587
- ],
588
- proverNodeMaxPendingJobs: 10,
589
- proverNodeMaxParallelBlocksPerEpoch: 32,
590
- proverNodePollingIntervalMs: 200,
591
- txGatheringIntervalMs: 1000,
592
- txGatheringBatchSize: 10,
593
- txGatheringMaxParallelRequestsPerNode: 10,
594
- txGatheringTimeoutMs: 24_000,
595
- proverNodeFailedEpochStore: undefined,
596
- proverId: EthAddress.fromNumber(1),
597
- proverNodeEpochProvingDelayMs: undefined,
598
- ...proverNodeConfig
599
- };
600
- const l1TxUtils = createDelayedL1TxUtils(aztecNodeConfig, proverNodePrivateKey, 'prover-node', proverNodeDeps.dateProvider);
601
- const proverNode = await createProverNode(proverConfig, {
602
- ...proverNodeDeps,
603
- aztecNodeTxProvider,
604
- archiver: archiver,
605
- l1TxUtils
606
- }, {
607
- prefilledPublicData
608
- });
609
- getLogger().info(`Created and synced prover node`, {
610
- publisherAddress: l1TxUtils.client.account.address
611
- });
612
- if (!proverNodeConfig.dontStart) {
613
- await proverNode.start();
614
- }
615
- return proverNode;
616
- });
617
- }
618
- function createDelayedL1TxUtils(aztecNodeConfig, privateKey, logName, dateProvider) {
619
- const l1Client = createExtendedL1Client(aztecNodeConfig.l1RpcUrls, privateKey, foundry);
620
- const log = createLogger(logName);
621
- const l1TxUtils = createDelayedL1TxUtilsFromViemWallet(l1Client, log, dateProvider, aztecNodeConfig);
622
- l1TxUtils.enableDelayer(aztecNodeConfig.ethereumSlotDuration);
623
- return l1TxUtils;
624
- }
2
+ * Re-exports from the unified setup module for backward compatibility.
3
+ * Tests that previously used utils.ts should continue to work.
4
+ */ export { createAndSyncProverNode, deployAccounts, ensureAccountContractsPublished, expectMapping, expectMappingDelta, getBalancesFn, getLogger, getPrivateKeyFromIndex, getSponsoredFPCAddress, getSponsoredFPCInstance, publicDeployAccounts, registerSponsoredFPC, setup, setupPXEAndGetWallet, setupSharedBlobStorage, setupSponsoredFPC, startAnvil, teardown, waitForProvenChain } from './setup.js';
5
+ export { deployAndInitializeTokenAndBridgeContracts } from '../shared/cross_chain_test_harness.js';
@@ -0,0 +1,41 @@
1
+ import type { Logger } from '@aztec/aztec.js/log';
2
+ export interface AlertConfig {
3
+ alert: string;
4
+ expr: string;
5
+ start?: number;
6
+ end?: number;
7
+ step?: number;
8
+ for: string;
9
+ labels: Record<string, string>;
10
+ annotations: Record<string, string>;
11
+ }
12
+ export interface AlertCheckerConfig {
13
+ grafanaEndpoint: string;
14
+ grafanaCredentials: string;
15
+ }
16
+ export declare class GrafanaClient {
17
+ private config;
18
+ private logger;
19
+ constructor(logger: Logger, config?: Partial<AlertCheckerConfig>);
20
+ /**
21
+ * Load the alerts config from a file path.
22
+ * @param filePath - The absolute path to the alerts file.
23
+ */
24
+ private loadAlertsConfig;
25
+ private queryGrafana;
26
+ private checkAlerts;
27
+ /**
28
+ * Run the alert check based on the alerts defined in an array.
29
+ * @param alerts - The alerts to check.
30
+ */
31
+ runAlertCheck(alerts: AlertConfig[]): Promise<void>;
32
+ /**
33
+ * Run the alert check based on the alerts defined in a yaml file.
34
+ * @param filePath - The absolute path to the alerts file.
35
+ */
36
+ runAlertCheckFromFilePath(filePath: string): Promise<void>;
37
+ }
38
+ export declare class AlertTriggeredError extends Error {
39
+ name: string;
40
+ }
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhZmFuYV9jbGllbnQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWFsaXR5X29mX3NlcnZpY2UvZ3JhZmFuYV9jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFLbEQsTUFBTSxXQUFXLFdBQVc7SUFDMUIsS0FBSyxFQUFFLE1BQU0sQ0FBQztJQUNkLElBQUksRUFBRSxNQUFNLENBQUM7SUFDYixLQUFLLENBQUMsRUFBRSxNQUFNLENBQUM7SUFDZixHQUFHLENBQUMsRUFBRSxNQUFNLENBQUM7SUFDYixJQUFJLENBQUMsRUFBRSxNQUFNLENBQUM7SUFDZCxHQUFHLEVBQUUsTUFBTSxDQUFDO0lBQ1osTUFBTSxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDL0IsV0FBVyxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUM7Q0FDckM7QUFFRCxNQUFNLFdBQVcsa0JBQWtCO0lBQ2pDLGVBQWUsRUFBRSxNQUFNLENBQUM7SUFDeEIsa0JBQWtCLEVBQUUsTUFBTSxDQUFDO0NBQzVCO0FBUUQscUJBQWEsYUFBYTtJQUN4QixPQUFPLENBQUMsTUFBTSxDQUFxQjtJQUNuQyxPQUFPLENBQUMsTUFBTSxDQUFTO0lBRXZCLFlBQVksTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLEdBQUUsT0FBTyxDQUFDLGtCQUFrQixDQUFNLEVBR25FO0lBRUQ7OztPQUdHO0lBQ0gsT0FBTyxDQUFDLGdCQUFnQjtZQU1WLFlBQVk7WUFxQ1osV0FBVztJQXFCekI7OztPQUdHO0lBQ1UsYUFBYSxDQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBUS9EO0lBRUQ7OztPQUdHO0lBQ1UseUJBQXlCLENBQUMsUUFBUSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBR3RFO0NBQ0Y7QUFFRCxxQkFBYSxtQkFBb0IsU0FBUSxLQUFLO0lBQ25DLElBQUksU0FBeUI7Q0FDdkMifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"grafana_client.d.ts","sourceRoot":"","sources":["../../src/quality_of_service/grafana_client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAKlD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,kBAAkB;IACjC,eAAe,EAAE,MAAM,CAAC;IACxB,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAQD,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAqB;IACnC,OAAO,CAAC,MAAM,CAAS;IAEvB,YAAY,MAAM,EAAE,MAAM,EAAE,MAAM,GAAE,OAAO,CAAC,kBAAkB,CAAM,EAGnE;IAED;;;OAGG;IACH,OAAO,CAAC,gBAAgB;YAMV,YAAY;YAqCZ,WAAW;IAqBzB;;;OAGG;IACU,aAAa,CAAC,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAQ/D;IAED;;;OAGG;IACU,yBAAyB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAGtE;CACF;AAED,qBAAa,mBAAoB,SAAQ,KAAK;IACnC,IAAI,SAAyB;CACvC"}