@aztec/end-to-end 0.0.1-commit.c7c42ec → 0.0.1-commit.d1f2d6c

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 (166) hide show
  1. package/dest/bench/client_flows/benchmark.d.ts +3 -2
  2. package/dest/bench/client_flows/benchmark.d.ts.map +1 -1
  3. package/dest/bench/client_flows/benchmark.js +21 -1
  4. package/dest/bench/client_flows/client_flows_benchmark.d.ts +12 -13
  5. package/dest/bench/client_flows/client_flows_benchmark.d.ts.map +1 -1
  6. package/dest/bench/client_flows/client_flows_benchmark.js +118 -133
  7. package/dest/bench/client_flows/data_extractor.js +3 -1
  8. package/dest/bench/utils.d.ts +9 -8
  9. package/dest/bench/utils.d.ts.map +1 -1
  10. package/dest/bench/utils.js +17 -12
  11. package/dest/e2e_blacklist_token_contract/blacklist_token_contract_test.d.ts +6 -7
  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 +96 -112
  14. package/dest/e2e_cross_chain_messaging/cross_chain_messaging_test.d.ts +15 -10
  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 +89 -70
  17. package/dest/e2e_deploy_contract/deploy_test.d.ts +4 -3
  18. package/dest/e2e_deploy_contract/deploy_test.d.ts.map +1 -1
  19. package/dest/e2e_deploy_contract/deploy_test.js +18 -13
  20. package/dest/e2e_epochs/epochs_test.d.ts +1 -1
  21. package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
  22. package/dest/e2e_epochs/epochs_test.js +5 -2
  23. package/dest/e2e_fees/bridging_race.notest.js +3 -5
  24. package/dest/e2e_fees/fees_test.d.ts +13 -13
  25. package/dest/e2e_fees/fees_test.d.ts.map +1 -1
  26. package/dest/e2e_fees/fees_test.js +123 -141
  27. package/dest/e2e_l1_publisher/write_json.d.ts +2 -2
  28. package/dest/e2e_l1_publisher/write_json.d.ts.map +1 -1
  29. package/dest/e2e_l1_publisher/write_json.js +19 -15
  30. package/dest/e2e_nested_contract/nested_contract_test.d.ts +6 -9
  31. package/dest/e2e_nested_contract/nested_contract_test.d.ts.map +1 -1
  32. package/dest/e2e_nested_contract/nested_contract_test.js +31 -39
  33. package/dest/e2e_p2p/inactivity_slash_test.d.ts +3 -3
  34. package/dest/e2e_p2p/inactivity_slash_test.d.ts.map +1 -1
  35. package/dest/e2e_p2p/inactivity_slash_test.js +3 -3
  36. package/dest/e2e_p2p/p2p_network.d.ts +7 -6
  37. package/dest/e2e_p2p/p2p_network.d.ts.map +1 -1
  38. package/dest/e2e_p2p/p2p_network.js +109 -103
  39. package/dest/e2e_p2p/shared.d.ts +6 -6
  40. package/dest/e2e_p2p/shared.d.ts.map +1 -1
  41. package/dest/e2e_p2p/shared.js +11 -18
  42. package/dest/e2e_token_contract/token_contract_test.d.ts +16 -9
  43. package/dest/e2e_token_contract/token_contract_test.d.ts.map +1 -1
  44. package/dest/e2e_token_contract/token_contract_test.js +89 -91
  45. package/dest/fixtures/e2e_prover_test.d.ts +8 -14
  46. package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
  47. package/dest/fixtures/e2e_prover_test.js +85 -94
  48. package/dest/fixtures/setup.d.ts +216 -0
  49. package/dest/fixtures/setup.d.ts.map +1 -0
  50. package/dest/fixtures/setup.js +684 -0
  51. package/dest/fixtures/token_utils.d.ts +1 -1
  52. package/dest/fixtures/token_utils.d.ts.map +1 -1
  53. package/dest/fixtures/token_utils.js +7 -4
  54. package/dest/fixtures/utils.d.ts +5 -194
  55. package/dest/fixtures/utils.d.ts.map +1 -1
  56. package/dest/fixtures/utils.js +4 -619
  57. package/dest/quality_of_service/grafana_client.d.ts +41 -0
  58. package/dest/quality_of_service/grafana_client.d.ts.map +1 -0
  59. package/dest/quality_of_service/{alert_checker.js → grafana_client.js} +1 -1
  60. package/dest/quality_of_service/prometheus_client.d.ts +38 -0
  61. package/dest/quality_of_service/prometheus_client.d.ts.map +1 -0
  62. package/dest/quality_of_service/prometheus_client.js +67 -0
  63. package/dest/shared/cross_chain_test_harness.d.ts +16 -6
  64. package/dest/shared/cross_chain_test_harness.d.ts.map +1 -1
  65. package/dest/shared/cross_chain_test_harness.js +13 -13
  66. package/dest/shared/gas_portal_test_harness.d.ts +11 -1
  67. package/dest/shared/gas_portal_test_harness.d.ts.map +1 -1
  68. package/dest/shared/gas_portal_test_harness.js +1 -1
  69. package/dest/shared/index.d.ts +2 -2
  70. package/dest/shared/index.d.ts.map +1 -1
  71. package/dest/shared/submit-transactions.d.ts +3 -3
  72. package/dest/shared/submit-transactions.d.ts.map +1 -1
  73. package/dest/shared/submit-transactions.js +9 -11
  74. package/dest/shared/uniswap_l1_l2.d.ts +3 -28
  75. package/dest/shared/uniswap_l1_l2.d.ts.map +1 -1
  76. package/dest/shared/uniswap_l1_l2.js +51 -33
  77. package/dest/simulators/lending_simulator.d.ts +5 -1
  78. package/dest/simulators/lending_simulator.d.ts.map +1 -1
  79. package/dest/simulators/lending_simulator.js +2 -2
  80. package/dest/spartan/setup_test_wallets.d.ts +4 -3
  81. package/dest/spartan/setup_test_wallets.d.ts.map +1 -1
  82. package/dest/spartan/setup_test_wallets.js +61 -34
  83. package/dest/spartan/tx_metrics.d.ts +17 -2
  84. package/dest/spartan/tx_metrics.d.ts.map +1 -1
  85. package/dest/spartan/tx_metrics.js +183 -6
  86. package/dest/spartan/utils/bot.d.ts +27 -0
  87. package/dest/spartan/utils/bot.d.ts.map +1 -0
  88. package/dest/spartan/utils/bot.js +141 -0
  89. package/dest/spartan/utils/chaos.d.ts +79 -0
  90. package/dest/spartan/utils/chaos.d.ts.map +1 -0
  91. package/dest/spartan/utils/chaos.js +142 -0
  92. package/dest/spartan/utils/clients.d.ts +39 -0
  93. package/dest/spartan/utils/clients.d.ts.map +1 -0
  94. package/dest/spartan/utils/clients.js +90 -0
  95. package/dest/spartan/utils/config.d.ts +36 -0
  96. package/dest/spartan/utils/config.d.ts.map +1 -0
  97. package/dest/spartan/utils/config.js +20 -0
  98. package/dest/spartan/utils/health.d.ts +63 -0
  99. package/dest/spartan/utils/health.d.ts.map +1 -0
  100. package/dest/spartan/utils/health.js +202 -0
  101. package/dest/spartan/utils/helm.d.ts +15 -0
  102. package/dest/spartan/utils/helm.d.ts.map +1 -0
  103. package/dest/spartan/utils/helm.js +47 -0
  104. package/dest/spartan/utils/index.d.ts +9 -0
  105. package/dest/spartan/utils/index.d.ts.map +1 -0
  106. package/dest/spartan/utils/index.js +18 -0
  107. package/dest/spartan/utils/k8s.d.ts +98 -0
  108. package/dest/spartan/utils/k8s.d.ts.map +1 -0
  109. package/dest/spartan/utils/k8s.js +257 -0
  110. package/dest/spartan/utils/nodes.d.ts +31 -0
  111. package/dest/spartan/utils/nodes.d.ts.map +1 -0
  112. package/dest/spartan/utils/nodes.js +290 -0
  113. package/dest/spartan/utils/scripts.d.ts +16 -0
  114. package/dest/spartan/utils/scripts.d.ts.map +1 -0
  115. package/dest/spartan/utils/scripts.js +66 -0
  116. package/dest/spartan/utils.d.ts +2 -253
  117. package/dest/spartan/utils.d.ts.map +1 -1
  118. package/dest/spartan/utils.js +1 -892
  119. package/package.json +40 -39
  120. package/src/bench/client_flows/benchmark.ts +24 -2
  121. package/src/bench/client_flows/client_flows_benchmark.ts +138 -204
  122. package/src/bench/client_flows/data_extractor.ts +1 -1
  123. package/src/bench/utils.ts +20 -14
  124. package/src/e2e_blacklist_token_contract/blacklist_token_contract_test.ts +104 -142
  125. package/src/e2e_cross_chain_messaging/cross_chain_messaging_test.ts +127 -116
  126. package/src/e2e_deploy_contract/deploy_test.ts +21 -14
  127. package/src/e2e_epochs/epochs_test.ts +31 -26
  128. package/src/e2e_fees/bridging_race.notest.ts +3 -9
  129. package/src/e2e_fees/fees_test.ts +172 -220
  130. package/src/e2e_l1_publisher/write_json.ts +21 -16
  131. package/src/e2e_nested_contract/nested_contract_test.ts +33 -56
  132. package/src/e2e_p2p/inactivity_slash_test.ts +5 -5
  133. package/src/e2e_p2p/p2p_network.ts +171 -168
  134. package/src/e2e_p2p/shared.ts +16 -25
  135. package/src/e2e_token_contract/token_contract_test.ts +103 -118
  136. package/src/fixtures/e2e_prover_test.ts +98 -133
  137. package/src/fixtures/setup.ts +1006 -0
  138. package/src/fixtures/token_utils.ts +6 -5
  139. package/src/fixtures/utils.ts +27 -907
  140. package/src/quality_of_service/{alert_checker.ts → grafana_client.ts} +1 -1
  141. package/src/quality_of_service/prometheus_client.ts +113 -0
  142. package/src/shared/cross_chain_test_harness.ts +16 -36
  143. package/src/shared/gas_portal_test_harness.ts +1 -1
  144. package/src/shared/index.ts +1 -1
  145. package/src/shared/submit-transactions.ts +9 -15
  146. package/src/shared/uniswap_l1_l2.ts +58 -77
  147. package/src/simulators/lending_simulator.ts +2 -2
  148. package/src/spartan/setup_test_wallets.ts +79 -25
  149. package/src/spartan/tx_metrics.ts +129 -9
  150. package/src/spartan/utils/bot.ts +185 -0
  151. package/src/spartan/utils/chaos.ts +253 -0
  152. package/src/spartan/utils/clients.ts +100 -0
  153. package/src/spartan/utils/config.ts +26 -0
  154. package/src/spartan/utils/health.ts +255 -0
  155. package/src/spartan/utils/helm.ts +84 -0
  156. package/src/spartan/utils/index.ts +62 -0
  157. package/src/spartan/utils/k8s.ts +375 -0
  158. package/src/spartan/utils/nodes.ts +323 -0
  159. package/src/spartan/utils/scripts.ts +63 -0
  160. package/src/spartan/utils.ts +1 -1158
  161. package/dest/fixtures/snapshot_manager.d.ts +0 -93
  162. package/dest/fixtures/snapshot_manager.d.ts.map +0 -1
  163. package/dest/fixtures/snapshot_manager.js +0 -493
  164. package/dest/quality_of_service/alert_checker.d.ts +0 -41
  165. package/dest/quality_of_service/alert_checker.d.ts.map +0 -1
  166. package/src/fixtures/snapshot_manager.ts +0 -651
@@ -1,93 +0,0 @@
1
- import { type InitialAccountData } from '@aztec/accounts/testing';
2
- import { type AztecNodeConfig, AztecNodeService } from '@aztec/aztec-node';
3
- import { AztecAddress } from '@aztec/aztec.js/addresses';
4
- import type { Logger } from '@aztec/aztec.js/log';
5
- import type { AztecNode } from '@aztec/aztec.js/node';
6
- import type { Wallet } from '@aztec/aztec.js/wallet';
7
- import { AnvilTestWatcher, CheatCodes } from '@aztec/aztec/testing';
8
- import { type DeployAztecL1ContractsArgs, type DeployAztecL1ContractsReturnType } from '@aztec/ethereum/deploy-aztec-l1-contracts';
9
- import { TestDateProvider } from '@aztec/foundation/timer';
10
- import type { ProverNode } from '@aztec/prover-node';
11
- import type { SequencerClient } from '@aztec/sequencer-client';
12
- import { TestWallet } from '@aztec/test-wallet/server';
13
- import type { Anvil } from '@viem/anvil';
14
- import { type SetupOptions } from './utils.js';
15
- export type SubsystemsContext = {
16
- anvil: Anvil;
17
- acvmConfig: any;
18
- bbConfig: any;
19
- aztecNode: AztecNodeService;
20
- aztecNodeConfig: AztecNodeConfig;
21
- wallet: TestWallet;
22
- deployL1ContractsValues: DeployAztecL1ContractsReturnType;
23
- proverNode?: ProverNode;
24
- watcher: AnvilTestWatcher;
25
- cheatCodes: CheatCodes;
26
- sequencer: SequencerClient;
27
- dateProvider: TestDateProvider;
28
- initialFundedAccounts: InitialAccountData[];
29
- directoryToCleanup?: string;
30
- };
31
- export declare function createSnapshotManager(testName: string, dataPath?: string, config?: Partial<SetupOptions>, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>): MockSnapshotManager | SnapshotManager;
32
- export interface ISnapshotManager {
33
- snapshot<T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>): Promise<void>;
34
- setup(): Promise<SubsystemsContext>;
35
- teardown(): Promise<void>;
36
- }
37
- /** Snapshot manager that does not perform snapshotting, it just applies transition and restoration functions as it receives them. */
38
- declare class MockSnapshotManager implements ISnapshotManager {
39
- private config;
40
- private deployL1ContractsArgs;
41
- private context?;
42
- private logger;
43
- constructor(testName: string, config?: Partial<AztecNodeConfig>, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>);
44
- snapshot<T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>): Promise<void>;
45
- setup(): Promise<SubsystemsContext>;
46
- teardown(): Promise<void>;
47
- }
48
- /**
49
- * Snapshot engine for local e2e tests. Read more:
50
- * https://github.com/AztecProtocol/aztec-packages/pull/5526
51
- */
52
- declare class SnapshotManager implements ISnapshotManager {
53
- private dataPath;
54
- private config;
55
- private deployL1ContractsArgs;
56
- private snapshotStack;
57
- private context?;
58
- private livePath;
59
- private logger;
60
- constructor(testName: string, dataPath: string, config?: Partial<SetupOptions>, deployL1ContractsArgs?: Partial<DeployAztecL1ContractsArgs>);
61
- snapshot<T>(name: string, apply: (context: SubsystemsContext) => Promise<T>, restore?: (snapshotData: T, context: SubsystemsContext) => Promise<void>): Promise<void>;
62
- /**
63
- * Creates and returns the subsystem context based on the current snapshot stack.
64
- * If the subsystem context already exists, just return it.
65
- * If you want to be sure to get a clean snapshot, be sure to call teardown() before calling setup().
66
- */
67
- setup(): Promise<SubsystemsContext>;
68
- /**
69
- * Destroys the current subsystem context.
70
- */
71
- teardown(): Promise<void>;
72
- }
73
- /**
74
- * Snapshot 'apply' helper function to add accounts.
75
- * The 'restore' function is not provided, as it must be a closure within the test context to capture the results.
76
- */
77
- export declare const deployAccounts: (numberOfAccounts: number, logger: Logger) => ({ wallet, initialFundedAccounts }: {
78
- wallet: TestWallet;
79
- initialFundedAccounts: InitialAccountData[];
80
- }) => Promise<{
81
- deployedAccounts: InitialAccountData[];
82
- }>;
83
- /**
84
- * Registers the contract class used for test accounts and publicly deploys the instances requested.
85
- * Use this when you need to make a public call to an account contract, such as for requesting a public authwit.
86
- * @param sender - Wallet to send the deployment tx.
87
- * @param accountsToDeploy - Which accounts to publicly deploy.
88
- * @param waitUntilProven - Whether to wait for the tx to be proven.
89
- * @param node - AztecNode used to wait for proven tx.
90
- */
91
- export declare function publicDeployAccounts(wallet: Wallet, accountsToDeploy: AztecAddress[], waitUntilProven?: boolean, node?: AztecNode): Promise<void>;
92
- export {};
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hcHNob3RfbWFuYWdlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZpeHR1cmVzL3NuYXBzaG90X21hbmFnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssa0JBQWtCLEVBQTJCLE1BQU0seUJBQXlCLENBQUM7QUFDM0YsT0FBTyxFQUFFLEtBQUssZUFBZSxFQUFFLGdCQUFnQixFQUFvQixNQUFNLG1CQUFtQixDQUFDO0FBQzdGLE9BQU8sRUFBRSxZQUFZLEVBQWMsTUFBTSwyQkFBMkIsQ0FBQztBQUlyRSxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNsRCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFLcEUsT0FBTyxFQUNMLEtBQUssMEJBQTBCLEVBQy9CLEtBQUssZ0NBQWdDLEVBRXRDLE1BQU0sMkNBQTJDLENBQUM7QUFRbkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHM0QsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFckQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHL0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBR3ZELE9BQU8sS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQWF6QyxPQUFPLEVBQ0wsS0FBSyxZQUFZLEVBTWxCLE1BQU0sWUFBWSxDQUFDO0FBR3BCLE1BQU0sTUFBTSxpQkFBaUIsR0FBRztJQUM5QixLQUFLLEVBQUUsS0FBSyxDQUFDO0lBQ2IsVUFBVSxF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
@@ -1 +0,0 @@
1
- {"version":3,"file":"snapshot_manager.d.ts","sourceRoot":"","sources":["../../src/fixtures/snapshot_manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,kBAAkB,EAA2B,MAAM,yBAAyB,CAAC;AAC3F,OAAO,EAAE,KAAK,eAAe,EAAE,gBAAgB,EAAoB,MAAM,mBAAmB,CAAC;AAC7F,OAAO,EAAE,YAAY,EAAc,MAAM,2BAA2B,CAAC;AAIrE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAKpE,OAAO,EACL,KAAK,0BAA0B,EAC/B,KAAK,gCAAgC,EAEtC,MAAM,2CAA2C,CAAC;AAQnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAG/D,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAazC,OAAO,EACL,KAAK,YAAY,EAMlB,MAAM,YAAY,CAAC;AAGpB,MAAM,MAAM,iBAAiB,GAAG;IAC9B,KAAK,EAAE,KAAK,CAAC;IACb,UAAU,EAAE,GAAG,CAAC;IAChB,QAAQ,EAAE,GAAG,CAAC;IACd,SAAS,EAAE,gBAAgB,CAAC;IAC5B,eAAe,EAAE,eAAe,CAAC;IACjC,MAAM,EAAE,UAAU,CAAC;IACnB,uBAAuB,EAAE,gCAAgC,CAAC;IAC1D,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,OAAO,EAAE,gBAAgB,CAAC;IAC1B,UAAU,EAAE,UAAU,CAAC;IACvB,SAAS,EAAE,eAAe,CAAC;IAC3B,YAAY,EAAE,gBAAgB,CAAC;IAC/B,qBAAqB,EAAE,kBAAkB,EAAE,CAAC;IAC5C,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B,CAAC;AASF,wBAAgB,qBAAqB,CACnC,QAAQ,EAAE,MAAM,EAChB,QAAQ,CAAC,EAAE,MAAM,EACjB,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,EAClC,qBAAqB,GAAE,OAAO,CAAC,0BAA0B,CAExD,yCAKF;AAED,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,CAAC,EACR,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,CAAC,CAAC,EACjD,OAAO,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,IAAI,CAAC,GACvE,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB,KAAK,IAAI,OAAO,CAAC,iBAAiB,CAAC,CAAC;IAEpC,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3B;AAED,qIAAqI;AACrI,cAAM,mBAAoB,YAAW,gBAAgB;IAMjD,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,qBAAqB;IAN/B,OAAO,CAAC,OAAO,CAAC,CAAoB;IACpC,OAAO,CAAC,MAAM,CAAS;IAEvB,YACE,QAAQ,EAAE,MAAM,EACR,MAAM,GAAE,OAAO,CAAC,eAAe,CAAM,EACrC,qBAAqB,GAAE,OAAO,CAAC,0BAA0B,CAAM,EAIxE;IAEY,QAAQ,CAAC,CAAC,EACrB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,CAAC,CAAC,EACjD,OAAO,GAAE,CAAC,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,IAAI,CAA2B,iBAUlG;IAEY,KAAK,+BAKjB;IAEY,QAAQ,kBAGpB;CACF;AAED;;;GAGG;AACH,cAAM,eAAgB,YAAW,gBAAgB;IAQ7C,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,qBAAqB;IAT/B,OAAO,CAAC,aAAa,CAAuB;IAC5C,OAAO,CAAC,OAAO,CAAC,CAAoB;IACpC,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,MAAM,CAAS;IAEvB,YACE,QAAQ,EAAE,MAAM,EACR,QAAQ,EAAE,MAAM,EAChB,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,EAClC,qBAAqB,GAAE,OAAO,CAAC,0BAA0B,CAAM,EAIxE;IAEY,QAAQ,CAAC,CAAC,EACrB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,CAAC,CAAC,EACjD,OAAO,GAAE,CAAC,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,IAAI,CAA2B,iBA0ClG;IAED;;;;OAIG;IACU,KAAK,+BAwBjB;IAED;;OAEG;IACU,QAAQ,kBAIpB;CACF;AAoUD;;;GAGG;AACH,eAAO,MAAM,cAAc;;;;;EA0BxB,CAAC;AAEJ;;;;;;;GAOG;AACH,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,MAAM,EACd,gBAAgB,EAAE,YAAY,EAAE,EAChC,eAAe,UAAQ,EACvB,IAAI,CAAC,EAAE,SAAS,iBAwBjB"}
@@ -1,493 +0,0 @@
1
- import { SchnorrAccountContractArtifact } from '@aztec/accounts/schnorr';
2
- import { generateSchnorrAccounts } from '@aztec/accounts/testing';
3
- import { AztecNodeService, getConfigEnvVars } from '@aztec/aztec-node';
4
- import { AztecAddress, EthAddress } from '@aztec/aztec.js/addresses';
5
- import { getContractClassFromArtifact } from '@aztec/aztec.js/contracts';
6
- import { BatchCall, waitForProven } from '@aztec/aztec.js/contracts';
7
- import { publishContractClass, publishInstance } from '@aztec/aztec.js/deployment';
8
- import { AnvilTestWatcher, CheatCodes } from '@aztec/aztec/testing';
9
- import { createBlobClientWithFileStores } from '@aztec/blob-client/client';
10
- import { createExtendedL1Client } from '@aztec/ethereum/client';
11
- import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
12
- import { deployMulticall3 } from '@aztec/ethereum/contracts';
13
- import { deployAztecL1Contracts } from '@aztec/ethereum/deploy-aztec-l1-contracts';
14
- import { EthCheatCodesWithState, startAnvil } from '@aztec/ethereum/test';
15
- import { asyncMap } from '@aztec/foundation/async-map';
16
- import { SecretValue } from '@aztec/foundation/config';
17
- import { randomBytes } from '@aztec/foundation/crypto/random';
18
- import { tryRmDir } from '@aztec/foundation/fs';
19
- import { createLogger } from '@aztec/foundation/log';
20
- import { resolver, reviver } from '@aztec/foundation/serialize';
21
- import { TestDateProvider } from '@aztec/foundation/timer';
22
- import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
23
- import { protocolContractsHash } from '@aztec/protocol-contracts';
24
- import { getPXEConfig } from '@aztec/pxe/server';
25
- import { tryStop } from '@aztec/stdlib/interfaces/server';
26
- import { getConfigEnvVars as getTelemetryConfig, initTelemetryClient } from '@aztec/telemetry-client';
27
- import { TestWallet } from '@aztec/test-wallet/server';
28
- import { getGenesisValues } from '@aztec/world-state/testing';
29
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
30
- import { copySync, removeSync } from 'fs-extra/esm';
31
- import fs from 'fs/promises';
32
- import { tmpdir } from 'os';
33
- import path, { join } from 'path';
34
- import { mnemonicToAccount } from 'viem/accounts';
35
- import { foundry } from 'viem/chains';
36
- import { MNEMONIC, TEST_MAX_PENDING_TX_POOL_COUNT, TEST_PEER_CHECK_INTERVAL_MS } from './fixtures.js';
37
- import { getACVMConfig } from './get_acvm_config.js';
38
- import { getBBConfig } from './get_bb_config.js';
39
- import { createAndSyncProverNode, getLogger, getPrivateKeyFromIndex, getSponsoredFPCAddress, setupSharedBlobStorage } from './utils.js';
40
- import { getEndToEndTestTelemetryClient } from './with_telemetry_utils.js';
41
- export function createSnapshotManager(testName, dataPath, config = {}, deployL1ContractsArgs = {
42
- initialValidators: []
43
- }) {
44
- return dataPath ? new SnapshotManager(testName, dataPath, config, deployL1ContractsArgs) : new MockSnapshotManager(testName, config, deployL1ContractsArgs);
45
- }
46
- /** Snapshot manager that does not perform snapshotting, it just applies transition and restoration functions as it receives them. */ class MockSnapshotManager {
47
- config;
48
- deployL1ContractsArgs;
49
- context;
50
- logger;
51
- constructor(testName, config = {}, deployL1ContractsArgs = {}){
52
- this.config = config;
53
- this.deployL1ContractsArgs = deployL1ContractsArgs;
54
- this.logger = createLogger(`e2e:snapshot_manager:${testName}`);
55
- this.logger.warn(`No data path given, will not persist any snapshots.`);
56
- }
57
- async snapshot(name, apply, restore = ()=>Promise.resolve()) {
58
- // We are running in disabled mode. Just apply the state.
59
- const context = await this.setup();
60
- this.logger.verbose(`Applying state transition for ${name}...`);
61
- const snapshotData = await apply(context);
62
- this.logger.verbose(`State transition for ${name} complete.`);
63
- // Execute the restoration function.
64
- await restore(snapshotData, context);
65
- return;
66
- }
67
- async setup() {
68
- if (!this.context) {
69
- this.context = await setupFromFresh(undefined, this.logger, this.config, this.deployL1ContractsArgs);
70
- }
71
- return this.context;
72
- }
73
- async teardown() {
74
- await teardown(this.context);
75
- this.context = undefined;
76
- }
77
- }
78
- /**
79
- * Snapshot engine for local e2e tests. Read more:
80
- * https://github.com/AztecProtocol/aztec-packages/pull/5526
81
- */ class SnapshotManager {
82
- dataPath;
83
- config;
84
- deployL1ContractsArgs;
85
- snapshotStack;
86
- context;
87
- livePath;
88
- logger;
89
- constructor(testName, dataPath, config = {}, deployL1ContractsArgs = {}){
90
- this.dataPath = dataPath;
91
- this.config = config;
92
- this.deployL1ContractsArgs = deployL1ContractsArgs;
93
- this.snapshotStack = [];
94
- this.livePath = join(this.dataPath, 'live', testName);
95
- this.logger = createLogger(`e2e:snapshot_manager:${testName}`);
96
- }
97
- async snapshot(name, apply, restore = ()=>Promise.resolve()) {
98
- const snapshotPath = join(this.dataPath, 'snapshots', ...this.snapshotStack.map((e)=>e.name), name, 'snapshot');
99
- if (existsSync(snapshotPath)) {
100
- // Snapshot exists. Record entry on stack but do nothing else as we're probably still descending the tree.
101
- // It's the tests responsibility to call setup() before a test to ensure subsystems get created.
102
- this.logger.verbose(`Snapshot exists at ${snapshotPath}. Continuing...`);
103
- this.snapshotStack.push({
104
- name,
105
- apply,
106
- restore,
107
- snapshotPath
108
- });
109
- return;
110
- }
111
- // Snapshot didn't exist at snapshotPath, and by definition none of the child snapshots can exist.
112
- // If we have no subsystem context yet, create it from the top of the snapshot stack (if it exists).
113
- const context = await this.setup();
114
- this.snapshotStack.push({
115
- name,
116
- apply,
117
- restore,
118
- snapshotPath
119
- });
120
- // Apply current state transition.
121
- this.logger.verbose(`Applying state transition for ${name}...`);
122
- const snapshotData = await apply(context);
123
- this.logger.verbose(`State transition for ${name} complete.`);
124
- // Execute the restoration function.
125
- await restore(snapshotData, context);
126
- // Save the snapshot data.
127
- const ethCheatCodes = new EthCheatCodesWithState(context.aztecNodeConfig.l1RpcUrls, context.dateProvider);
128
- const anvilStateFile = `${this.livePath}/anvil.dat`;
129
- await ethCheatCodes.dumpChainState(anvilStateFile);
130
- writeFileSync(`${this.livePath}/${name}.json`, JSON.stringify(snapshotData || {}, resolver));
131
- // Copy everything to snapshot path.
132
- // We want it to be atomic, in case multiple processes are racing to create the snapshot.
133
- this.logger.verbose(`Saving snapshot to ${snapshotPath}...`);
134
- if (mkdirSync(snapshotPath, {
135
- recursive: true
136
- })) {
137
- copySync(this.livePath, snapshotPath);
138
- this.logger.verbose(`Snapshot copied to ${snapshotPath}.`);
139
- } else {
140
- this.logger.verbose(`Snapshot already exists at ${snapshotPath}. Discarding our version.`);
141
- await this.teardown();
142
- }
143
- }
144
- /**
145
- * Creates and returns the subsystem context based on the current snapshot stack.
146
- * If the subsystem context already exists, just return it.
147
- * If you want to be sure to get a clean snapshot, be sure to call teardown() before calling setup().
148
- */ async setup() {
149
- // We have no subsystem context yet.
150
- // If one exists on the snapshot stack, create one from that snapshot.
151
- // Otherwise create a fresh one.
152
- if (!this.context) {
153
- removeSync(this.livePath);
154
- mkdirSync(this.livePath, {
155
- recursive: true
156
- });
157
- const previousSnapshotPath = this.snapshotStack[this.snapshotStack.length - 1]?.snapshotPath;
158
- if (previousSnapshotPath) {
159
- this.logger.verbose(`Copying snapshot from ${previousSnapshotPath} to ${this.livePath}...`);
160
- copySync(previousSnapshotPath, this.livePath);
161
- this.context = await setupFromState(this.livePath, this.logger);
162
- // Execute each of the previous snapshots restoration functions in turn.
163
- await asyncMap(this.snapshotStack, async (e)=>{
164
- const snapshotData = JSON.parse(readFileSync(`${e.snapshotPath}/${e.name}.json`, 'utf-8'), reviver);
165
- this.logger.verbose(`Executing restoration function for ${e.name}...`);
166
- await e.restore(snapshotData, this.context);
167
- this.logger.verbose(`Restoration of ${e.name} complete.`);
168
- });
169
- } else {
170
- this.context = await setupFromFresh(this.livePath, this.logger, this.config, this.deployL1ContractsArgs);
171
- }
172
- }
173
- return this.context;
174
- }
175
- /**
176
- * Destroys the current subsystem context.
177
- */ async teardown() {
178
- await teardown(this.context);
179
- this.context = undefined;
180
- removeSync(this.livePath);
181
- }
182
- }
183
- /**
184
- * Destroys the current subsystem context.
185
- */ async function teardown(context) {
186
- if (!context) {
187
- return;
188
- }
189
- const logger = getLogger();
190
- try {
191
- logger.info('Tearing down subsystems');
192
- await tryStop(context.proverNode);
193
- await tryStop(context.aztecNode);
194
- await context.acvmConfig?.cleanup();
195
- await context.bbConfig?.cleanup();
196
- await tryStop(context.anvil);
197
- await tryStop(context.watcher);
198
- await tryRmDir(context.directoryToCleanup, logger);
199
- } catch (err) {
200
- logger.error('Error during teardown', err);
201
- }
202
- }
203
- /**
204
- * Initializes a fresh set of subsystems.
205
- * If given a statePath, the state will be written to the path.
206
- * If there is no statePath, in-memory and temporary state locations will be used.
207
- */ async function setupFromFresh(statePath, logger, { numberOfInitialFundedAccounts = 10, ...opts } = {}, deployL1ContractsArgs = {
208
- initialValidators: []
209
- }) {
210
- logger.verbose(`Initializing state...`);
211
- // Default to no slashing
212
- opts.slasherFlavor ??= 'none';
213
- deployL1ContractsArgs.slasherFlavor ??= opts.slasherFlavor;
214
- // Fetch the AztecNode config.
215
- // TODO: For some reason this is currently the union of a bunch of subsystems. That needs fixing.
216
- const aztecNodeConfig = {
217
- ...getConfigEnvVars(),
218
- ...opts
219
- };
220
- aztecNodeConfig.peerCheckIntervalMS = TEST_PEER_CHECK_INTERVAL_MS;
221
- aztecNodeConfig.maxPendingTxCount = opts.maxPendingTxCount ?? TEST_MAX_PENDING_TX_POOL_COUNT;
222
- // Only enable proving if specifically requested.
223
- aztecNodeConfig.realProofs = !!opts.realProofs;
224
- // Only enforce the time table if requested
225
- aztecNodeConfig.enforceTimeTable = !!opts.enforceTimeTable;
226
- // Only set the target committee size if it is explicitly set
227
- aztecNodeConfig.aztecTargetCommitteeSize = opts.aztecTargetCommitteeSize ?? 0;
228
- aztecNodeConfig.listenAddress = '127.0.0.1';
229
- deployL1ContractsArgs.aztecTargetCommitteeSize ??= aztecNodeConfig.aztecTargetCommitteeSize;
230
- // Create a temp directory for all ephemeral state and cleanup afterwards
231
- const directoryToCleanup = path.join(tmpdir(), randomBytes(8).toString('hex'));
232
- await fs.mkdir(directoryToCleanup, {
233
- recursive: true
234
- });
235
- if (statePath === undefined) {
236
- aztecNodeConfig.dataDirectory = directoryToCleanup;
237
- } else {
238
- aztecNodeConfig.dataDirectory = statePath;
239
- }
240
- await setupSharedBlobStorage(aztecNodeConfig);
241
- const hdAccount = mnemonicToAccount(MNEMONIC, {
242
- addressIndex: 0
243
- });
244
- const publisherPrivKeyRaw = hdAccount.getHdKey().privateKey;
245
- const publisherPrivKey = publisherPrivKeyRaw === null ? null : Buffer.from(publisherPrivKeyRaw);
246
- const publisherPrivKeyHex = `0x${publisherPrivKey.toString('hex')}`;
247
- const l1Client = createExtendedL1Client([
248
- aztecNodeConfig.l1RpcUrls[0]
249
- ], hdAccount, foundry);
250
- const validatorPrivKey = getPrivateKeyFromIndex(0);
251
- const proverNodePrivateKey = getPrivateKeyFromIndex(0);
252
- aztecNodeConfig.publisherPrivateKeys = [
253
- new SecretValue(publisherPrivKeyHex)
254
- ];
255
- aztecNodeConfig.validatorPrivateKeys = new SecretValue([
256
- `0x${validatorPrivKey.toString('hex')}`
257
- ]);
258
- aztecNodeConfig.coinbase = opts.coinbase ?? EthAddress.fromString(`${hdAccount.address}`);
259
- logger.info(`Setting up environment with config`, aztecNodeConfig);
260
- // Start anvil. We go via a wrapper script to ensure if the parent dies, anvil dies.
261
- logger.verbose('Starting anvil...');
262
- const res = await startAnvil({
263
- l1BlockTime: opts.ethereumSlotDuration
264
- });
265
- const anvil = res.anvil;
266
- aztecNodeConfig.l1RpcUrls = [
267
- res.rpcUrl
268
- ];
269
- const dateProvider = new TestDateProvider();
270
- const ethCheatCodes = new EthCheatCodesWithState(aztecNodeConfig.l1RpcUrls, dateProvider);
271
- // Deploy our L1 contracts.
272
- logger.verbose('Deploying Aztec L1 contracts...');
273
- if (opts.l1StartTime) {
274
- await ethCheatCodes.warp(opts.l1StartTime, {
275
- resetBlockInterval: true
276
- });
277
- }
278
- const initialFundedAccounts = await generateSchnorrAccounts(numberOfInitialFundedAccounts);
279
- const sponsoredFPCAddress = await getSponsoredFPCAddress();
280
- const { genesisArchiveRoot, prefilledPublicData, fundingNeeded } = await getGenesisValues(initialFundedAccounts.map((a)=>a.address).concat(sponsoredFPCAddress), opts.initialAccountFeeJuice);
281
- const vkTreeRoot = getVKTreeRoot();
282
- await deployMulticall3(l1Client, logger);
283
- // Define args, defaulted to our environment variables.
284
- const args = {
285
- ...getL1ContractsConfigEnvVars(),
286
- ...deployL1ContractsArgs,
287
- vkTreeRoot,
288
- genesisArchiveRoot,
289
- protocolContractsHash,
290
- initialValidators: opts.initialValidators,
291
- feeJuicePortalInitialBalance: fundingNeeded,
292
- realVerifier: false
293
- };
294
- const deployL1ContractsValues = await deployAztecL1Contracts(aztecNodeConfig.l1RpcUrls[0], publisherPrivKeyHex, foundry.id, args);
295
- aztecNodeConfig.l1Contracts = deployL1ContractsValues.l1ContractAddresses;
296
- aztecNodeConfig.rollupVersion = deployL1ContractsValues.rollupVersion;
297
- const watcher = new AnvilTestWatcher(new EthCheatCodesWithState(aztecNodeConfig.l1RpcUrls, dateProvider), deployL1ContractsValues.l1ContractAddresses.rollupAddress, deployL1ContractsValues.l1Client, dateProvider);
298
- await watcher.start();
299
- const acvmConfig = await getACVMConfig(logger);
300
- if (acvmConfig) {
301
- aztecNodeConfig.acvmWorkingDirectory = acvmConfig.acvmWorkingDirectory;
302
- aztecNodeConfig.acvmBinaryPath = acvmConfig.acvmBinaryPath;
303
- }
304
- const bbConfig = await getBBConfig(logger);
305
- if (bbConfig) {
306
- aztecNodeConfig.bbBinaryPath = bbConfig.bbBinaryPath;
307
- aztecNodeConfig.bbWorkingDirectory = bbConfig.bbWorkingDirectory;
308
- }
309
- const telemetry = await getEndToEndTestTelemetryClient(opts.metricsPort);
310
- const blobClient = await createBlobClientWithFileStores(aztecNodeConfig, createLogger('node:blob-client:client'));
311
- logger.info('Creating and synching an aztec node...');
312
- const aztecNode = await AztecNodeService.createAndSync(aztecNodeConfig, {
313
- telemetry,
314
- dateProvider,
315
- blobClient
316
- }, {
317
- prefilledPublicData
318
- });
319
- let proverNode = undefined;
320
- if (opts.startProverNode) {
321
- logger.verbose('Creating and syncing a simulated prover node with p2p disabled...');
322
- proverNode = await createAndSyncProverNode(`0x${proverNodePrivateKey.toString('hex')}`, aztecNodeConfig, {
323
- ...aztecNodeConfig.proverNodeConfig,
324
- dataDirectory: path.join(directoryToCleanup, randomBytes(8).toString('hex')),
325
- p2pEnabled: false
326
- }, aztecNode, prefilledPublicData);
327
- }
328
- logger.verbose('Creating pxe...');
329
- const pxeConfig = getPXEConfig();
330
- pxeConfig.dataDirectory = statePath ?? path.join(directoryToCleanup, randomBytes(8).toString('hex'));
331
- // Only enable proving if specifically requested.
332
- pxeConfig.proverEnabled = !!opts.realProofs;
333
- const wallet = await TestWallet.create(aztecNode, pxeConfig);
334
- const cheatCodes = await CheatCodes.create(aztecNodeConfig.l1RpcUrls, aztecNode, dateProvider);
335
- if (statePath) {
336
- writeFileSync(`${statePath}/aztec_node_config.json`, JSON.stringify(aztecNodeConfig, resolver));
337
- writeFileSync(`${statePath}/accounts.json`, JSON.stringify(initialFundedAccounts, resolver));
338
- }
339
- return {
340
- aztecNodeConfig,
341
- anvil,
342
- aztecNode,
343
- wallet,
344
- sequencer: aztecNode.getSequencer(),
345
- acvmConfig,
346
- bbConfig,
347
- deployL1ContractsValues,
348
- proverNode,
349
- watcher,
350
- cheatCodes,
351
- dateProvider,
352
- initialFundedAccounts,
353
- directoryToCleanup
354
- };
355
- }
356
- /**
357
- * Given a statePath, setup the system starting from that state.
358
- */ async function setupFromState(statePath, logger) {
359
- logger.verbose(`Initializing with saved state at ${statePath}...`);
360
- const directoryToCleanup = path.join(tmpdir(), randomBytes(8).toString('hex'));
361
- await fs.mkdir(directoryToCleanup, {
362
- recursive: true
363
- });
364
- // TODO: For some reason this is currently the union of a bunch of subsystems. That needs fixing.
365
- const aztecNodeConfig = JSON.parse(readFileSync(`${statePath}/aztec_node_config.json`, 'utf-8'), reviver);
366
- aztecNodeConfig.dataDirectory = statePath;
367
- aztecNodeConfig.listenAddress = '127.0.0.1';
368
- await setupSharedBlobStorage(aztecNodeConfig);
369
- const initialFundedAccounts = JSON.parse(readFileSync(`${statePath}/accounts.json`, 'utf-8'), reviver) || [];
370
- const { prefilledPublicData } = await getGenesisValues(initialFundedAccounts.map((a)=>a.address));
371
- // Start anvil. We go via a wrapper script to ensure if the parent dies, anvil dies.
372
- const { anvil, rpcUrl } = await startAnvil();
373
- aztecNodeConfig.l1RpcUrls = [
374
- rpcUrl
375
- ];
376
- // Load anvil state.
377
- const anvilStateFile = `${statePath}/anvil.dat`;
378
- const dateProvider = new TestDateProvider();
379
- const ethCheatCodes = new EthCheatCodesWithState(aztecNodeConfig.l1RpcUrls, dateProvider);
380
- await ethCheatCodes.loadChainState(anvilStateFile);
381
- // TODO: Encapsulate this in a NativeAcvm impl.
382
- const acvmConfig = await getACVMConfig(logger);
383
- if (acvmConfig) {
384
- aztecNodeConfig.acvmWorkingDirectory = acvmConfig.acvmWorkingDirectory;
385
- aztecNodeConfig.acvmBinaryPath = acvmConfig.acvmBinaryPath;
386
- }
387
- const bbConfig = await getBBConfig(logger);
388
- if (bbConfig) {
389
- aztecNodeConfig.bbBinaryPath = bbConfig.bbBinaryPath;
390
- aztecNodeConfig.bbWorkingDirectory = bbConfig.bbWorkingDirectory;
391
- }
392
- logger.verbose('Creating ETH clients...');
393
- const l1Client = createExtendedL1Client(aztecNodeConfig.l1RpcUrls, mnemonicToAccount(MNEMONIC));
394
- const watcher = new AnvilTestWatcher(ethCheatCodes, aztecNodeConfig.l1Contracts.rollupAddress, l1Client, dateProvider);
395
- await watcher.start();
396
- const telemetry = await initTelemetryClient(getTelemetryConfig());
397
- const blobClient = await createBlobClientWithFileStores(aztecNodeConfig, createLogger('node:blob-client:client'));
398
- logger.verbose('Creating aztec node...');
399
- const aztecNode = await AztecNodeService.createAndSync(aztecNodeConfig, {
400
- telemetry,
401
- dateProvider,
402
- blobClient
403
- }, {
404
- prefilledPublicData
405
- });
406
- let proverNode = undefined;
407
- if (aztecNodeConfig.startProverNode) {
408
- logger.verbose('Creating and syncing a simulated prover node...');
409
- const proverNodePrivateKey = getPrivateKeyFromIndex(2);
410
- const proverNodePrivateKeyHex = `0x${proverNodePrivateKey.toString('hex')}`;
411
- proverNode = await createAndSyncProverNode(proverNodePrivateKeyHex, aztecNodeConfig, {
412
- ...aztecNodeConfig.proverNodeConfig,
413
- dataDirectory: path.join(directoryToCleanup, randomBytes(8).toString('hex')),
414
- p2pEnabled: false
415
- }, aztecNode, prefilledPublicData);
416
- }
417
- logger.verbose('Creating pxe...');
418
- const pxeConfig = getPXEConfig();
419
- pxeConfig.dataDirectory = statePath;
420
- const wallet = await TestWallet.create(aztecNode, pxeConfig);
421
- const cheatCodes = await CheatCodes.create(aztecNodeConfig.l1RpcUrls, aztecNode, dateProvider);
422
- return {
423
- aztecNodeConfig,
424
- anvil,
425
- aztecNode,
426
- wallet,
427
- sequencer: aztecNode.getSequencer(),
428
- acvmConfig,
429
- bbConfig,
430
- proverNode,
431
- deployL1ContractsValues: {
432
- l1Client,
433
- l1ContractAddresses: aztecNodeConfig.l1Contracts,
434
- rollupVersion: aztecNodeConfig.rollupVersion
435
- },
436
- watcher,
437
- cheatCodes,
438
- dateProvider,
439
- initialFundedAccounts,
440
- directoryToCleanup
441
- };
442
- }
443
- /**
444
- * Snapshot 'apply' helper function to add accounts.
445
- * The 'restore' function is not provided, as it must be a closure within the test context to capture the results.
446
- */ export const deployAccounts = (numberOfAccounts, logger)=>async ({ wallet, initialFundedAccounts })=>{
447
- if (initialFundedAccounts.length < numberOfAccounts) {
448
- throw new Error(`Cannot deploy more than ${initialFundedAccounts.length} initial accounts.`);
449
- }
450
- logger.verbose('Deploying accounts funded with fee juice...');
451
- const deployedAccounts = initialFundedAccounts.slice(0, numberOfAccounts);
452
- // Serial due to https://github.com/AztecProtocol/aztec-packages/issues/12045
453
- for(let i = 0; i < deployedAccounts.length; i++){
454
- const accountManager = await wallet.createSchnorrAccount(deployedAccounts[i].secret, deployedAccounts[i].salt, deployedAccounts[i].signingKey);
455
- const deployMethod = await accountManager.getDeployMethod();
456
- await deployMethod.send({
457
- from: AztecAddress.ZERO,
458
- skipClassPublication: i !== 0
459
- }).wait();
460
- }
461
- return {
462
- deployedAccounts
463
- };
464
- };
465
- /**
466
- * Registers the contract class used for test accounts and publicly deploys the instances requested.
467
- * Use this when you need to make a public call to an account contract, such as for requesting a public authwit.
468
- * @param sender - Wallet to send the deployment tx.
469
- * @param accountsToDeploy - Which accounts to publicly deploy.
470
- * @param waitUntilProven - Whether to wait for the tx to be proven.
471
- * @param node - AztecNode used to wait for proven tx.
472
- */ export async function publicDeployAccounts(wallet, accountsToDeploy, waitUntilProven = false, node) {
473
- const instances = (await Promise.all(accountsToDeploy.map((account)=>wallet.getContractMetadata(account)))).map((metadata)=>metadata.contractInstance);
474
- const contractClass = await getContractClassFromArtifact(SchnorrAccountContractArtifact);
475
- const alreadyRegistered = (await wallet.getContractClassMetadata(contractClass.id)).isContractClassPubliclyRegistered;
476
- const calls = await Promise.all([
477
- ...!alreadyRegistered ? [
478
- publishContractClass(wallet, SchnorrAccountContractArtifact)
479
- ] : [],
480
- ...instances.map((instance)=>publishInstance(wallet, instance))
481
- ]);
482
- const batch = new BatchCall(wallet, calls);
483
- const txReceipt = await batch.send({
484
- from: accountsToDeploy[0]
485
- }).wait();
486
- if (waitUntilProven) {
487
- if (!node) {
488
- throw new Error('Need to provide an AztecNode to wait for proven.');
489
- } else {
490
- await waitForProven(node, txReceipt);
491
- }
492
- }
493
- }
@@ -1,41 +0,0 @@
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 AlertChecker {
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnRfY2hlY2tlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3F1YWxpdHlfb2Zfc2VydmljZS9hbGVydF9jaGVja2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBS2xELE1BQU0sV0FBVyxXQUFXO0lBQzFCLEtBQUssRUFBRSxNQUFNLENBQUM7SUFDZCxJQUFJLEVBQUUsTUFBTSxDQUFDO0lBQ2IsS0FBSyxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ2YsR0FBRyxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ2IsSUFBSSxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ2QsR0FBRyxFQUFFLE1BQU0sQ0FBQztJQUNaLE1BQU0sRUFBRSxNQUFNLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQy9CLFdBQVcsRUFBRSxNQUFNLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0NBQ3JDO0FBRUQsTUFBTSxXQUFXLGtCQUFrQjtJQUNqQyxlQUFlLEVBQUUsTUFBTSxDQUFDO0lBQ3hCLGtCQUFrQixFQUFFLE1BQU0sQ0FBQztDQUM1QjtBQVFELHFCQUFhLFlBQVk7SUFDdkIsT0FBTyxDQUFDLE1BQU0sQ0FBcUI7SUFDbkMsT0FBTyxDQUFDLE1BQU0sQ0FBUztJQUV2QixZQUFZLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxHQUFFLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBTSxFQUduRTtJQUVEOzs7T0FHRztJQUNILE9BQU8sQ0FBQyxnQkFBZ0I7WUFNVixZQUFZO1lBcUNaLFdBQVc7SUFxQnpCOzs7T0FHRztJQUNVLGFBQWEsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQVEvRDtJQUVEOzs7T0FHRztJQUNVLHlCQUF5QixDQUFDLFFBQVEsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUd0RTtDQUNGO0FBRUQscUJBQWEsbUJBQW9CLFNBQVEsS0FBSztJQUNuQyxJQUFJLFNBQXlCO0NBQ3ZDIn0=
@@ -1 +0,0 @@
1
- {"version":3,"file":"alert_checker.d.ts","sourceRoot":"","sources":["../../src/quality_of_service/alert_checker.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,YAAY;IACvB,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"}