@aztec/aztec 0.0.0-test.1 → 0.0.1-commit.0b941701

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 (156) hide show
  1. package/README.md +1 -1
  2. package/dest/bin/index.d.ts +1 -1
  3. package/dest/bin/index.js +23 -12
  4. package/dest/cli/aztec_start_action.d.ts +1 -1
  5. package/dest/cli/aztec_start_action.d.ts.map +1 -1
  6. package/dest/cli/aztec_start_action.js +40 -40
  7. package/dest/cli/aztec_start_options.d.ts +5 -3
  8. package/dest/cli/aztec_start_options.d.ts.map +1 -1
  9. package/dest/cli/aztec_start_options.js +146 -225
  10. package/dest/cli/cli.d.ts +1 -1
  11. package/dest/cli/cli.d.ts.map +1 -1
  12. package/dest/cli/cli.js +12 -7
  13. package/dest/cli/cmds/migrate_ha_db.d.ts +3 -0
  14. package/dest/cli/cmds/migrate_ha_db.d.ts.map +1 -0
  15. package/dest/cli/cmds/migrate_ha_db.js +27 -0
  16. package/dest/cli/cmds/start_archiver.d.ts +1 -1
  17. package/dest/cli/cmds/start_archiver.d.ts.map +1 -1
  18. package/dest/cli/cmds/start_archiver.js +24 -18
  19. package/dest/cli/cmds/start_bot.d.ts +4 -7
  20. package/dest/cli/cmds/start_bot.d.ts.map +1 -1
  21. package/dest/cli/cmds/start_bot.js +25 -14
  22. package/dest/cli/cmds/start_node.d.ts +2 -2
  23. package/dest/cli/cmds/start_node.d.ts.map +1 -1
  24. package/dest/cli/cmds/start_node.js +68 -81
  25. package/dest/cli/cmds/start_p2p_bootstrap.d.ts +1 -1
  26. package/dest/cli/cmds/start_p2p_bootstrap.d.ts.map +1 -1
  27. package/dest/cli/cmds/start_p2p_bootstrap.js +9 -4
  28. package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
  29. package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
  30. package/dest/cli/cmds/start_prover_agent.js +33 -4
  31. package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
  32. package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
  33. package/dest/cli/cmds/start_prover_broker.js +10 -4
  34. package/dest/cli/cmds/start_prover_node.d.ts +1 -1
  35. package/dest/cli/cmds/start_prover_node.d.ts.map +1 -1
  36. package/dest/cli/cmds/start_prover_node.js +44 -46
  37. package/dest/cli/cmds/start_txe.d.ts +1 -1
  38. package/dest/cli/index.d.ts +1 -1
  39. package/dest/cli/preload_crs.d.ts +3 -0
  40. package/dest/cli/preload_crs.d.ts.map +1 -0
  41. package/dest/cli/preload_crs.js +6 -0
  42. package/dest/cli/release_version.d.ts +2 -0
  43. package/dest/cli/release_version.d.ts.map +1 -0
  44. package/dest/cli/release_version.js +14 -0
  45. package/dest/cli/util.d.ts +38 -7
  46. package/dest/cli/util.d.ts.map +1 -1
  47. package/dest/cli/util.js +198 -28
  48. package/dest/cli/versioning.d.ts +1 -1
  49. package/dest/cli/versioning.js +3 -3
  50. package/dest/examples/token.d.ts +1 -1
  51. package/dest/examples/token.js +31 -18
  52. package/dest/examples/util.d.ts +5 -6
  53. package/dest/examples/util.d.ts.map +1 -1
  54. package/dest/examples/util.js +5 -6
  55. package/dest/index.d.ts +2 -2
  56. package/dest/index.d.ts.map +1 -1
  57. package/dest/index.js +1 -1
  58. package/dest/local-network/banana_fpc.d.ts +10 -0
  59. package/dest/local-network/banana_fpc.d.ts.map +1 -0
  60. package/dest/{sandbox → local-network}/banana_fpc.js +22 -24
  61. package/dest/local-network/index.d.ts +4 -0
  62. package/dest/local-network/index.d.ts.map +1 -0
  63. package/dest/local-network/index.js +3 -0
  64. package/dest/local-network/local-network.d.ts +71 -0
  65. package/dest/local-network/local-network.d.ts.map +1 -0
  66. package/dest/local-network/local-network.js +194 -0
  67. package/dest/local-network/sponsored_fpc.d.ts +5 -0
  68. package/dest/local-network/sponsored_fpc.d.ts.map +1 -0
  69. package/dest/local-network/sponsored_fpc.js +18 -0
  70. package/dest/mnemonic.d.ts +1 -1
  71. package/dest/splash.d.ts +1 -1
  72. package/dest/testing/anvil_test_watcher.d.ts +34 -0
  73. package/dest/testing/anvil_test_watcher.d.ts.map +1 -0
  74. package/dest/testing/anvil_test_watcher.js +144 -0
  75. package/dest/testing/cheat_codes.d.ts +43 -0
  76. package/dest/testing/cheat_codes.d.ts.map +1 -0
  77. package/dest/testing/cheat_codes.js +62 -0
  78. package/dest/testing/epoch_test_settler.d.ts +19 -0
  79. package/dest/testing/epoch_test_settler.d.ts.map +1 -0
  80. package/dest/testing/epoch_test_settler.js +62 -0
  81. package/dest/testing/index.d.ts +5 -0
  82. package/dest/testing/index.d.ts.map +1 -0
  83. package/dest/testing/index.js +4 -0
  84. package/package.json +55 -45
  85. package/scripts/aztec.sh +63 -0
  86. package/scripts/compile.sh +44 -0
  87. package/scripts/extract_function.js +47 -0
  88. package/scripts/flamegraph.sh +59 -0
  89. package/scripts/init.sh +35 -0
  90. package/scripts/new.sh +59 -0
  91. package/scripts/setup_project.sh +31 -0
  92. package/src/bin/index.ts +28 -12
  93. package/src/cli/aztec_start_action.ts +36 -38
  94. package/src/cli/aztec_start_options.ts +161 -222
  95. package/src/cli/cli.ts +20 -11
  96. package/src/cli/cmds/migrate_ha_db.ts +43 -0
  97. package/src/cli/cmds/start_archiver.ts +15 -20
  98. package/src/cli/cmds/start_bot.ts +36 -13
  99. package/src/cli/cmds/start_node.ts +91 -86
  100. package/src/cli/cmds/start_p2p_bootstrap.ts +12 -4
  101. package/src/cli/cmds/start_prover_agent.ts +24 -12
  102. package/src/cli/cmds/start_prover_broker.ts +24 -4
  103. package/src/cli/cmds/start_prover_node.ts +54 -51
  104. package/src/cli/preload_crs.ts +7 -0
  105. package/src/cli/release_version.ts +21 -0
  106. package/src/cli/util.ts +208 -34
  107. package/src/cli/versioning.ts +3 -3
  108. package/src/examples/token.ts +21 -19
  109. package/src/examples/util.ts +6 -8
  110. package/src/index.ts +5 -6
  111. package/src/{sandbox → local-network}/banana_fpc.ts +27 -28
  112. package/src/local-network/index.ts +7 -0
  113. package/src/local-network/local-network.ts +240 -0
  114. package/src/local-network/sponsored_fpc.ts +26 -0
  115. package/src/testing/anvil_test_watcher.ts +166 -0
  116. package/src/testing/cheat_codes.ts +79 -0
  117. package/src/testing/epoch_test_settler.ts +71 -0
  118. package/src/testing/index.ts +4 -0
  119. package/dest/cli/chain_l2_config.d.ts +0 -19
  120. package/dest/cli/chain_l2_config.d.ts.map +0 -1
  121. package/dest/cli/chain_l2_config.js +0 -56
  122. package/dest/cli/cmds/start_blob_sink.d.ts +0 -3
  123. package/dest/cli/cmds/start_blob_sink.d.ts.map +0 -1
  124. package/dest/cli/cmds/start_blob_sink.js +0 -17
  125. package/dest/cli/cmds/start_faucet.d.ts +0 -4
  126. package/dest/cli/cmds/start_faucet.d.ts.map +0 -1
  127. package/dest/cli/cmds/start_faucet.js +0 -20
  128. package/dest/cli/cmds/start_pxe.d.ts +0 -16
  129. package/dest/cli/cmds/start_pxe.d.ts.map +0 -1
  130. package/dest/cli/cmds/start_pxe.js +0 -95
  131. package/dest/cli/get_l1_config.d.ts +0 -7
  132. package/dest/cli/get_l1_config.d.ts.map +0 -1
  133. package/dest/cli/get_l1_config.js +0 -13
  134. package/dest/sandbox/banana_fpc.d.ts +0 -11
  135. package/dest/sandbox/banana_fpc.d.ts.map +0 -1
  136. package/dest/sandbox/index.d.ts +0 -5
  137. package/dest/sandbox/index.d.ts.map +0 -1
  138. package/dest/sandbox/index.js +0 -4
  139. package/dest/sandbox/sandbox.d.ts +0 -76
  140. package/dest/sandbox/sandbox.d.ts.map +0 -1
  141. package/dest/sandbox/sandbox.js +0 -181
  142. package/dest/sandbox/sponsored_fee_payment_method.d.ts +0 -23
  143. package/dest/sandbox/sponsored_fee_payment_method.d.ts.map +0 -1
  144. package/dest/sandbox/sponsored_fee_payment_method.js +0 -36
  145. package/dest/sandbox/sponsored_fpc.d.ts +0 -6
  146. package/dest/sandbox/sponsored_fpc.d.ts.map +0 -1
  147. package/dest/sandbox/sponsored_fpc.js +0 -26
  148. package/src/cli/chain_l2_config.ts +0 -74
  149. package/src/cli/cmds/start_blob_sink.ts +0 -31
  150. package/src/cli/cmds/start_faucet.ts +0 -34
  151. package/src/cli/cmds/start_pxe.ts +0 -129
  152. package/src/cli/get_l1_config.ts +0 -18
  153. package/src/sandbox/index.ts +0 -5
  154. package/src/sandbox/sandbox.ts +0 -229
  155. package/src/sandbox/sponsored_fee_payment_method.ts +0 -46
  156. package/src/sandbox/sponsored_fpc.ts +0 -38
@@ -0,0 +1,62 @@
1
+ import { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
2
+ import { retryUntil } from '@aztec/foundation/retry';
3
+ /**
4
+ * A class that provides utility functions for interacting with the chain.
5
+ * @deprecated There used to be 3 kinds of cheat codes: eth, rollup and aztec. We have nuked the Aztec ones because
6
+ * they became unused (we now have better testing tools). If you are introducing a new functionality to the cheat
7
+ * codes, please consider whether it makes sense to just introduce new utils in your tests instead.
8
+ */ export class CheatCodes {
9
+ eth;
10
+ rollup;
11
+ constructor(/** Cheat codes for L1.*/ eth, /** Cheat codes for the Aztec Rollup contract on L1. */ rollup){
12
+ this.eth = eth;
13
+ this.rollup = rollup;
14
+ }
15
+ static async create(rpcUrls, node, dateProvider) {
16
+ const ethCheatCodes = new EthCheatCodes(rpcUrls, dateProvider);
17
+ const rollupCheatCodes = new RollupCheatCodes(ethCheatCodes, await node.getNodeInfo().then((n)=>n.l1ContractAddresses));
18
+ return new CheatCodes(ethCheatCodes, rollupCheatCodes);
19
+ }
20
+ /**
21
+ * Warps the L1 timestamp to a target timestamp and mines an L2 block that advances the L2 timestamp to at least
22
+ * the target timestamp. L2 timestamp is not advanced exactly to the target timestamp because it is determined
23
+ * by the slot number, which advances in fixed intervals.
24
+ * This is useful for testing time-dependent contract behavior.
25
+ * @param sequencerClient - The sequencer client to use to force an empty block to be mined.
26
+ * @param node - The Aztec node used to query if a new block has been mined.
27
+ * @param targetTimestamp - The target timestamp to warp to (in seconds)
28
+ */ async warpL2TimeAtLeastTo(sequencerClient, node, targetTimestamp) {
29
+ const currentL2BlockNumber = await node.getBlockNumber();
30
+ // We warp the L1 timestamp
31
+ await this.eth.warp(targetTimestamp, {
32
+ resetBlockInterval: true
33
+ });
34
+ // Wait until an L2 block is mined
35
+ const sequencer = sequencerClient.getSequencer();
36
+ const minTxsPerBlock = sequencer.getConfig().minTxsPerBlock;
37
+ sequencer.updateConfig({
38
+ minTxsPerBlock: 0
39
+ });
40
+ await retryUntil(async ()=>{
41
+ const newL2BlockNumber = await node.getBlockNumber();
42
+ return newL2BlockNumber > currentL2BlockNumber;
43
+ }, 'new block after warping L2 time', 36, 1);
44
+ // Restore original minTxsPerBlock
45
+ sequencer.updateConfig({
46
+ minTxsPerBlock
47
+ });
48
+ }
49
+ /**
50
+ * Warps the L1 timestamp forward by a specified duration and mines an L2 block that advances the L2 timestamp at
51
+ * least by the duration. L2 timestamp is not advanced exactly by the duration because it is determined by the slot
52
+ * number, which advances in fixed intervals.
53
+ * This is useful for testing time-dependent contract behavior.
54
+ * @param sequencerClient - The sequencer client to use to force an empty block to be mined.
55
+ * @param node - The Aztec node used to query if a new block has been mined.
56
+ * @param duration - The duration to advance time by (in seconds)
57
+ */ async warpL2TimeAtLeastBy(sequencerClient, node, duration) {
58
+ const currentTimestamp = await this.eth.timestamp();
59
+ const targetTimestamp = BigInt(currentTimestamp) + BigInt(duration);
60
+ await this.warpL2TimeAtLeastTo(sequencerClient, node, targetTimestamp);
61
+ }
62
+ }
@@ -0,0 +1,19 @@
1
+ import { type EthCheatCodes } from '@aztec/ethereum/test';
2
+ import { type EpochNumber } from '@aztec/foundation/branded-types';
3
+ import type { Logger } from '@aztec/foundation/log';
4
+ import type { EthAddress, L2BlockSource } from '@aztec/stdlib/block';
5
+ export declare class EpochTestSettler {
6
+ private l2BlockSource;
7
+ private log;
8
+ private options;
9
+ private rollupCheatCodes;
10
+ private epochMonitor?;
11
+ constructor(cheatcodes: EthCheatCodes, rollupAddress: EthAddress, l2BlockSource: L2BlockSource, log: Logger, options: {
12
+ pollingIntervalMs: number;
13
+ provingDelayMs?: number;
14
+ });
15
+ start(): Promise<void>;
16
+ stop(): Promise<void>;
17
+ handleEpochReadyToProve(epoch: EpochNumber): Promise<boolean>;
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXBvY2hfdGVzdF9zZXR0bGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdGluZy9lcG9jaF90ZXN0X3NldHRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssYUFBYSxFQUFvQixNQUFNLHNCQUFzQixDQUFDO0FBQzVFLE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBYyxNQUFNLGlDQUFpQyxDQUFDO0FBQy9FLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRXBELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUdyRSxxQkFBYSxnQkFBZ0I7SUFPekIsT0FBTyxDQUFDLGFBQWE7SUFDckIsT0FBTyxDQUFDLEdBQUc7SUFDWCxPQUFPLENBQUMsT0FBTztJQVJqQixPQUFPLENBQUMsZ0JBQWdCLENBQW1CO0lBQzNDLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0FBZTtJQUVwQyxZQUNFLFVBQVUsRUFBRSxhQUFhLEVBQ3pCLGFBQWEsRUFBRSxVQUFVLEVBQ2pCLGFBQWEsRUFBRSxhQUFhLEVBQzVCLEdBQUcsRUFBRSxNQUFNLEVBQ1gsT0FBTyxFQUFFO1FBQUUsaUJBQWlCLEVBQUUsTUFBTSxDQUFDO1FBQUMsY0FBYyxDQUFDLEVBQUUsTUFBTSxDQUFBO0tBQUUsRUFHeEU7SUFFSyxLQUFLLGtCQUlWO0lBRUssSUFBSSxrQkFFVDtJQUVLLHVCQUF1QixDQUFDLEtBQUssRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQXFDbEU7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"epoch_test_settler.d.ts","sourceRoot":"","sources":["../../src/testing/epoch_test_settler.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,aAAa,EAAoB,MAAM,sBAAsB,CAAC;AAC5E,OAAO,EAAE,KAAK,WAAW,EAAc,MAAM,iCAAiC,CAAC;AAC/E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,OAAO,KAAK,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGrE,qBAAa,gBAAgB;IAOzB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,OAAO;IARjB,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,YAAY,CAAC,CAAe;IAEpC,YACE,UAAU,EAAE,aAAa,EACzB,aAAa,EAAE,UAAU,EACjB,aAAa,EAAE,aAAa,EAC5B,GAAG,EAAE,MAAM,EACX,OAAO,EAAE;QAAE,iBAAiB,EAAE,MAAM,CAAC;QAAC,cAAc,CAAC,EAAE,MAAM,CAAA;KAAE,EAGxE;IAEK,KAAK,kBAIV;IAEK,IAAI,kBAET;IAEK,uBAAuB,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAqClE;CACF"}
@@ -0,0 +1,62 @@
1
+ import { RollupCheatCodes } from '@aztec/ethereum/test';
2
+ import { SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { EpochMonitor } from '@aztec/prover-node';
4
+ import { computeL2ToL1MembershipWitnessFromMessagesInEpoch } from '@aztec/stdlib/messaging';
5
+ export class EpochTestSettler {
6
+ l2BlockSource;
7
+ log;
8
+ options;
9
+ rollupCheatCodes;
10
+ epochMonitor;
11
+ constructor(cheatcodes, rollupAddress, l2BlockSource, log, options){
12
+ this.l2BlockSource = l2BlockSource;
13
+ this.log = log;
14
+ this.options = options;
15
+ this.rollupCheatCodes = new RollupCheatCodes(cheatcodes, {
16
+ rollupAddress
17
+ });
18
+ }
19
+ async start() {
20
+ const { epochDuration } = await this.rollupCheatCodes.getConfig();
21
+ this.epochMonitor = new EpochMonitor(this.l2BlockSource, {
22
+ epochDuration: Number(epochDuration)
23
+ }, this.options);
24
+ this.epochMonitor.start(this);
25
+ }
26
+ async stop() {
27
+ await this.epochMonitor?.stop();
28
+ }
29
+ async handleEpochReadyToProve(epoch) {
30
+ const checkpointedBlocks = await this.l2BlockSource.getCheckpointedBlocksForEpoch(epoch);
31
+ const blocks = checkpointedBlocks.map((b)=>b.block);
32
+ this.log.info(`Settling epoch ${epoch} with blocks ${blocks[0]?.header.getBlockNumber()} to ${blocks.at(-1)?.header.getBlockNumber()}`, {
33
+ blocks: blocks.map((b)=>b.toBlockInfo())
34
+ });
35
+ const messagesInEpoch = [];
36
+ let previousSlotNumber = SlotNumber.ZERO;
37
+ let checkpointIndex = -1;
38
+ for (const block of blocks){
39
+ const slotNumber = block.header.globalVariables.slotNumber;
40
+ if (slotNumber !== previousSlotNumber) {
41
+ checkpointIndex++;
42
+ messagesInEpoch[checkpointIndex] = [];
43
+ previousSlotNumber = slotNumber;
44
+ }
45
+ messagesInEpoch[checkpointIndex].push(block.body.txEffects.map((txEffect)=>txEffect.l2ToL1Msgs));
46
+ }
47
+ const [firstMessage] = messagesInEpoch.flat(3);
48
+ if (firstMessage) {
49
+ const { root: outHash } = computeL2ToL1MembershipWitnessFromMessagesInEpoch(messagesInEpoch, firstMessage);
50
+ await this.rollupCheatCodes.insertOutbox(epoch, outHash.toBigInt());
51
+ } else {
52
+ this.log.info(`No L2 to L1 messages in epoch ${epoch}`);
53
+ }
54
+ const lastCheckpoint = checkpointedBlocks.at(-1)?.checkpointNumber;
55
+ if (lastCheckpoint !== undefined) {
56
+ await this.rollupCheatCodes.markAsProven(lastCheckpoint);
57
+ } else {
58
+ this.log.warn(`No checkpoint found for epoch ${epoch}`);
59
+ }
60
+ return true;
61
+ }
62
+ }
@@ -0,0 +1,5 @@
1
+ export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
+ export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
+ export { CheatCodes } from './cheat_codes.js';
4
+ export { EpochTestSettler } from './epoch_test_settler.js';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUMifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/testing/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
+ export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
+ export { CheatCodes } from './cheat_codes.js';
4
+ export { EpochTestSettler } from './epoch_test_settler.js';
package/package.json CHANGED
@@ -1,11 +1,12 @@
1
1
  {
2
2
  "name": "@aztec/aztec",
3
- "version": "0.0.0-test.1",
3
+ "version": "0.0.1-commit.0b941701",
4
4
  "type": "module",
5
5
  "exports": {
6
- ".": "./dest/index.js"
6
+ ".": "./dest/index.js",
7
+ "./testing": "./dest/testing/index.js"
7
8
  },
8
- "bin": "./dest/bin/index.js",
9
+ "bin": "./scripts/aztec.sh",
9
10
  "typedocOptions": {
10
11
  "entryPoints": [
11
12
  "./src/index.ts"
@@ -14,14 +15,12 @@
14
15
  "tsconfig": "./tsconfig.json"
15
16
  },
16
17
  "scripts": {
17
- "build": "yarn clean && tsc -b",
18
+ "build": "yarn clean && ../scripts/tsc.sh",
18
19
  "start": "node --no-warnings ./dest/bin",
19
20
  "start:debug": "node --inspect=0.0.0.0:9221 --no-warnings ./dest/bin",
20
- "start:sandbox": "ETHEREUM_HOSTS=http://0.0.0.0:8545/ && yarn start start --sandbox",
21
+ "start:local-network": "ETHEREUM_HOSTS=http://0.0.0.0:8545/ && yarn start start --local-network",
21
22
  "clean": "rm -rf ./dest .tsbuildinfo",
22
- "formatting": "run -T prettier --check ./src && run -T eslint ./src",
23
- "formatting:fix": "run -T eslint --fix ./src && run -T prettier -w ./src",
24
- "build:dev": "tsc -b --watch",
23
+ "build:dev": "../scripts/tsc.sh --watch",
25
24
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}",
26
25
  "run:example:token": "LOG_LEVEL='verbose' node ./dest/examples/token.js"
27
26
  },
@@ -29,55 +28,62 @@
29
28
  "../package.common.json"
30
29
  ],
31
30
  "dependencies": {
32
- "@aztec/accounts": "0.0.0-test.1",
33
- "@aztec/archiver": "0.0.0-test.1",
34
- "@aztec/aztec-faucet": "0.0.0-test.1",
35
- "@aztec/aztec-node": "0.0.0-test.1",
36
- "@aztec/aztec.js": "0.0.0-test.1",
37
- "@aztec/bb-prover": "0.0.0-test.1",
38
- "@aztec/blob-sink": "0.0.0-test.1",
39
- "@aztec/bot": "0.0.0-test.1",
40
- "@aztec/builder": "0.0.0-test.1",
41
- "@aztec/cli": "0.0.0-test.1",
42
- "@aztec/cli-wallet": "0.0.0-test.1",
43
- "@aztec/constants": "0.0.0-test.1",
44
- "@aztec/entrypoints": "0.0.0-test.1",
45
- "@aztec/ethereum": "0.0.0-test.1",
46
- "@aztec/foundation": "0.0.0-test.1",
47
- "@aztec/kv-store": "0.0.0-test.1",
48
- "@aztec/noir-contracts.js": "0.0.0-test.1",
49
- "@aztec/noir-protocol-circuits-types": "0.0.0-test.1",
50
- "@aztec/p2p": "0.0.0-test.1",
51
- "@aztec/p2p-bootstrap": "0.0.0-test.1",
52
- "@aztec/protocol-contracts": "0.0.0-test.1",
53
- "@aztec/prover-client": "0.0.0-test.1",
54
- "@aztec/prover-node": "0.0.0-test.1",
55
- "@aztec/pxe": "0.0.0-test.1",
56
- "@aztec/stdlib": "0.0.0-test.1",
57
- "@aztec/telemetry-client": "0.0.0-test.1",
58
- "@aztec/txe": "0.0.0-test.1",
59
- "@aztec/world-state": "0.0.0-test.1",
31
+ "@aztec/accounts": "0.0.1-commit.0b941701",
32
+ "@aztec/archiver": "0.0.1-commit.0b941701",
33
+ "@aztec/aztec-faucet": "0.0.1-commit.0b941701",
34
+ "@aztec/aztec-node": "0.0.1-commit.0b941701",
35
+ "@aztec/aztec.js": "0.0.1-commit.0b941701",
36
+ "@aztec/bb-prover": "0.0.1-commit.0b941701",
37
+ "@aztec/bb.js": "0.0.1-commit.0b941701",
38
+ "@aztec/blob-client": "0.0.1-commit.0b941701",
39
+ "@aztec/bot": "0.0.1-commit.0b941701",
40
+ "@aztec/builder": "0.0.1-commit.0b941701",
41
+ "@aztec/cli": "0.0.1-commit.0b941701",
42
+ "@aztec/constants": "0.0.1-commit.0b941701",
43
+ "@aztec/entrypoints": "0.0.1-commit.0b941701",
44
+ "@aztec/ethereum": "0.0.1-commit.0b941701",
45
+ "@aztec/foundation": "0.0.1-commit.0b941701",
46
+ "@aztec/kv-store": "0.0.1-commit.0b941701",
47
+ "@aztec/l1-artifacts": "0.0.1-commit.0b941701",
48
+ "@aztec/node-lib": "0.0.1-commit.0b941701",
49
+ "@aztec/noir-contracts.js": "0.0.1-commit.0b941701",
50
+ "@aztec/noir-protocol-circuits-types": "0.0.1-commit.0b941701",
51
+ "@aztec/p2p": "0.0.1-commit.0b941701",
52
+ "@aztec/p2p-bootstrap": "0.0.1-commit.0b941701",
53
+ "@aztec/protocol-contracts": "0.0.1-commit.0b941701",
54
+ "@aztec/prover-client": "0.0.1-commit.0b941701",
55
+ "@aztec/prover-node": "0.0.1-commit.0b941701",
56
+ "@aztec/pxe": "0.0.1-commit.0b941701",
57
+ "@aztec/sequencer-client": "0.0.1-commit.0b941701",
58
+ "@aztec/stdlib": "0.0.1-commit.0b941701",
59
+ "@aztec/telemetry-client": "0.0.1-commit.0b941701",
60
+ "@aztec/test-wallet": "0.0.1-commit.0b941701",
61
+ "@aztec/txe": "0.0.1-commit.0b941701",
62
+ "@aztec/validator-ha-signer": "0.0.1-commit.0b941701",
63
+ "@aztec/world-state": "0.0.1-commit.0b941701",
60
64
  "@types/chalk": "^2.2.0",
61
65
  "abitype": "^0.8.11",
62
66
  "chalk": "^5.3.0",
63
67
  "commander": "^12.1.0",
64
- "koa": "^2.14.2",
65
- "koa-router": "^12.0.0",
66
- "viem": "2.22.8"
68
+ "koa": "^2.16.1",
69
+ "koa-router": "^13.1.1",
70
+ "viem": "npm:@aztec/viem@2.38.2"
67
71
  },
68
72
  "files": [
69
73
  "dest",
74
+ "scripts",
70
75
  "src",
71
76
  "!*.test.*"
72
77
  ],
73
78
  "types": "./dest/index.d.ts",
74
79
  "devDependencies": {
75
- "@jest/globals": "^29.5.0",
76
- "@types/jest": "^29.5.0",
77
- "@types/koa": "^2.13.6",
78
- "jest": "^29.5.0",
80
+ "@jest/globals": "^30.0.0",
81
+ "@types/jest": "^30.0.0",
82
+ "@types/koa": "^2.15.0",
83
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
84
+ "jest": "^30.0.0",
79
85
  "ts-node": "^10.9.1",
80
- "typescript": "^5.0.4"
86
+ "typescript": "^5.3.3"
81
87
  },
82
88
  "jest": {
83
89
  "moduleNameMapper": {
@@ -110,9 +116,13 @@
110
116
  "testTimeout": 120000,
111
117
  "setupFiles": [
112
118
  "../../foundation/src/jest/setup.mjs"
119
+ ],
120
+ "testEnvironment": "../../foundation/src/jest/env.mjs",
121
+ "setupFilesAfterEnv": [
122
+ "../../foundation/src/jest/setupAfterEnv.mjs"
113
123
  ]
114
124
  },
115
125
  "engines": {
116
- "node": ">=18"
126
+ "node": ">=20.10"
117
127
  }
118
128
  }
@@ -0,0 +1,63 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ shopt -s inherit_errexit
4
+
5
+ # Re-execute using correct version if we have an .aztecrc file.
6
+ if [ "${AZTEC_VERSIONED:-0}" -eq 0 ] && [ -f .aztecrc ] && command -v aztec-up &>/dev/null; then
7
+ env_setup=$(aztec-up env)
8
+ eval "$env_setup"
9
+ AZTEC_VERSIONED=1 exec aztec "$@"
10
+ fi
11
+
12
+ cmd=${1:-}
13
+ [ -n "$cmd" ] && shift
14
+
15
+ script_dir="$(dirname "$(realpath "$0")")"
16
+
17
+ function aztec {
18
+ export AZTEC_SHELL_WRAPPER=1
19
+ exec node --no-warnings $script_dir/../dest/bin/index.js "$@"
20
+ }
21
+
22
+ case $cmd in
23
+ test)
24
+ export LOG_LEVEL="${LOG_LEVEL:-error}"
25
+ aztec start --txe --port 8081 &
26
+ server_pid=$!
27
+ trap 'kill $server_pid &>/dev/null || true' EXIT
28
+ while ! nc -z 127.0.0.1 8081 &>/dev/null; do sleep 0.2; done
29
+ export NARGO_FOREIGN_CALL_TIMEOUT=300000
30
+ nargo test --silence-warnings --oracle-resolver http://127.0.0.1:8081 "$@"
31
+ ;;
32
+ start)
33
+ if [ "${1:-}" == "--local-network" ]; then
34
+ # TODO: Can these just be set in TS?
35
+ export ARCHIVER_POLLING_INTERVAL_MS=500
36
+ export P2P_BLOCK_CHECK_INTERVAL_MS=500
37
+ export SEQ_TX_POLLING_INTERVAL_MS=500
38
+ export WS_BLOCK_CHECK_INTERVAL_MS=500
39
+ export ARCHIVER_VIEM_POLLING_INTERVAL_MS=500
40
+ export TEST_ACCOUNTS=${TEST_ACCOUNTS:-true}
41
+ export LOG_LEVEL=${LOG_LEVEL:-info;silent:sequencer;verbose:debug_log}
42
+ export DEPLOY_AZTEC_CONTRACTS_SALT=${DEPLOY_AZTEC_CONTRACTS_SALT:-$RANDOM}
43
+
44
+ ANVIL_PORT=${ANVIL_PORT:-8545}
45
+
46
+ export L1_CHAIN_ID=${L1_CHAIN_ID:-31337}
47
+ export ETHEREUM_HOSTS=${ETHEREUM_HOSTS:-"http://127.0.0.1:${ANVIL_PORT}"}
48
+
49
+ anvil --version
50
+ anvil --silent &
51
+ anvil_pid=$!
52
+ trap 'kill $anvil_pid &>/dev/null' EXIT
53
+ fi
54
+
55
+ aztec start "$@"
56
+ ;;
57
+ compile|new|init|flamegraph)
58
+ $script_dir/${cmd}.sh "$@"
59
+ ;;
60
+ *)
61
+ aztec $cmd "$@"
62
+ ;;
63
+ esac
@@ -0,0 +1,44 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ NARGO=${NARGO:-nargo}
5
+ BB=${BB:-bb}
6
+
7
+ # If help is requested, show Aztec-specific info then run nargo compile help and then exit in order to not trigger
8
+ # transpilation
9
+ for arg in "$@"; do
10
+ if [ "$arg" == "--help" ] || [ "$arg" == "-h" ]; then
11
+ cat << 'EOF'
12
+ Aztec Compile - Compile Aztec Noir contracts
13
+
14
+ This command compiles Aztec Noir contracts using nargo and then automatically
15
+ postprocesses them to generate Aztec specific artifacts including:
16
+ - Transpiled contract artifacts
17
+ - Verification keys
18
+
19
+ The compiled contracts will be placed in the target/ directory by default.
20
+
21
+ ---
22
+ Underlying nargo compile options:
23
+
24
+ EOF
25
+ nargo compile --help
26
+ exit 0
27
+ fi
28
+ done
29
+
30
+ # Run nargo compile.
31
+ $NARGO compile "$@"
32
+
33
+ echo "Postprocessing contract..."
34
+ $BB aztec_process
35
+
36
+ # Strip internal prefixes from all compiled contract JSONs in target directory
37
+ # TODO: This should be part of bb aztec_process!
38
+ for json in target/*.json; do
39
+ temp_file="${json}.tmp"
40
+ jq '.functions |= map(.name |= sub("^__aztec_nr_internals__"; ""))' "$json" > "$temp_file"
41
+ mv "$temp_file" "$json"
42
+ done
43
+
44
+ echo "Compilation complete!"
@@ -0,0 +1,47 @@
1
+ #!/usr/bin/env node
2
+ import fs from 'fs/promises';
3
+ import path from 'path';
4
+
5
+ // Simple script to extract a contract function as a separate Noir artifact.
6
+ // We need to use this since the transpiling that we do on public functions make the contract artifacts
7
+ // unreadable by noir tooling, since they are no longer following the noir artifact format.
8
+ async function main() {
9
+ let [contractArtifactPath, functionName] = process.argv.slice(2);
10
+ if (!contractArtifactPath || !functionName) {
11
+ console.log('Usage: node extractFunctionAsNoirArtifact.js <contractArtifactPath> <functionName>');
12
+ return;
13
+ }
14
+
15
+ const contractArtifact = JSON.parse(await fs.readFile(contractArtifactPath, 'utf8'));
16
+ const func = contractArtifact.functions.find(f => f.name === functionName);
17
+ if (!func) {
18
+ console.error(`Function ${functionName} not found in ${contractArtifactPath}`);
19
+ return;
20
+ }
21
+
22
+ const artifact = {
23
+ noir_version: contractArtifact.noir_version,
24
+ hash: 0,
25
+ abi: func.abi,
26
+ bytecode: func.bytecode,
27
+ debug_symbols: func.debug_symbols,
28
+ file_map: contractArtifact.file_map,
29
+ expression_width: {
30
+ Bounded: {
31
+ width: 4,
32
+ },
33
+ },
34
+ };
35
+
36
+ const outputDir = path.dirname(contractArtifactPath);
37
+ const outputName = path.basename(contractArtifactPath, '.json') + `-${functionName}.json`;
38
+
39
+ const outPath = path.join(outputDir, outputName);
40
+
41
+ await fs.writeFile(outPath, JSON.stringify(artifact, null, 2));
42
+ }
43
+
44
+ main().catch(err => {
45
+ console.error(err);
46
+ process.exit(1);
47
+ });
@@ -0,0 +1,59 @@
1
+ #!/usr/bin/env bash
2
+ set -eu
3
+
4
+ # If first arg is -h or --help, print usage.
5
+ if [ $# -lt 2 ] || [ "$1" == "-h" ] || [ "$1" == "--help" ]; then
6
+ cat << 'EOF'
7
+ Aztec Flamegraph - Generate a gate count flamegraph for an aztec contract function.
8
+
9
+ Usage: aztec flamegraph <contract_artifact> <function>
10
+
11
+ Options:
12
+ -h, --help Print help
13
+
14
+ Will output an svg at <artifact_path>/<contract>-<function>-flamegraph.svg.
15
+ You can open it in your browser to view it.
16
+
17
+ EOF
18
+ exit 0
19
+ fi
20
+
21
+ cleanup() {
22
+ set +e
23
+ if [ -f "$function_artifact" ]; then
24
+ rm -f "$function_artifact"
25
+ fi
26
+ }
27
+
28
+ trap cleanup EXIT
29
+
30
+ # Get the directory of the script
31
+ script_dir=$(realpath $(dirname $0))
32
+
33
+ PROFILER=${PROFILER_PATH:-noir-profiler}
34
+ BB=${BB:-bb}
35
+
36
+ # first console arg is contract name in camel case or path to contract artifact
37
+ contract=$1
38
+
39
+ # second console arg is the contract function
40
+ function=$2
41
+
42
+ if [ ! -f "$contract" ]; then
43
+ echo "Error: Contract artifact not found at: $contract"
44
+ exit 1
45
+ fi
46
+ artifact_path=$contract
47
+ function_artifact="${artifact_path%%.json}-${function}.json"
48
+ output_dir=$(dirname "$artifact_path")
49
+
50
+ # Extract artifact for the specific function.
51
+ node $script_dir/extract_function.js "$artifact_path" $function
52
+
53
+ # Generate the flamegraph
54
+ $PROFILER gates --artifact-path "$function_artifact" --backend-path "$BB" --backend-gates-command "gates" --output "$output_dir" --scheme chonk --include_gates_per_opcode
55
+
56
+ # Save as $artifact_name-$function-flamegraph.svg
57
+ output_file="${function_artifact%%.json}-flamegraph.svg"
58
+ mv "$output_dir/__aztec_nr_internals__${function}_gates.svg" "$output_file"
59
+ echo "Flamegraph generated at: $output_file"
@@ -0,0 +1,35 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ NARGO=${NARGO:-nargo}
5
+ script_path=$(realpath $(dirname "$0"))
6
+
7
+ for arg in "$@"; do
8
+ if [ "$arg" == "--help" ] || [ "$arg" == "-h" ]; then
9
+ cat << 'EOF'
10
+ Aztec Init - Create a new Aztec Noir project in the current directory
11
+
12
+ Usage: aztec init [OPTIONS]
13
+
14
+ Options:
15
+ --name <NAME> Name of the package [default: current directory name]
16
+ --lib Use a library template
17
+ -h, --help Print help
18
+
19
+ This command creates a new Aztec Noir project in the current directory using nargo
20
+ and automatically adds the Aztec.nr dependency to your Nargo.toml file.
21
+
22
+ EOF
23
+ exit 0
24
+ fi
25
+ if [ "$arg" == "--lib" ]; then
26
+ is_contract=0
27
+ fi
28
+ done
29
+
30
+ echo "Initializing Noir project..."
31
+ $NARGO init "$@"
32
+
33
+ if [ "${is_contract:-1}" -eq 1 ]; then
34
+ $script_path/setup_project.sh
35
+ fi
package/scripts/new.sh ADDED
@@ -0,0 +1,59 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ NARGO=${NARGO:-nargo}
5
+ script_path=$(realpath $(dirname "$0"))
6
+
7
+ type_arg="--contract"
8
+
9
+ while [[ $# -gt 0 ]]; do
10
+ case $1 in
11
+ --help|-h)
12
+ cat << 'EOF'
13
+ Aztec New - Create a new Aztec Noir project in a new directory
14
+
15
+ Usage: aztec new [OPTIONS] <PATH>
16
+
17
+ Arguments:
18
+ <PATH> The path to save the new project
19
+
20
+ Options:
21
+ --name <NAME> Name of the package [default: package directory name]
22
+ --lib Create a library template instead of a contract
23
+ -h, --help Print help
24
+
25
+ This command creates a new Aztec Noir project using nargo and automatically
26
+ adds the Aztec.nr dependency to your Nargo.toml file.
27
+ EOF
28
+ exit 0
29
+ ;;
30
+ --lib)
31
+ type_arg="--lib"
32
+ shift
33
+ ;;
34
+ --name)
35
+ name_arg="--name $2"
36
+ shift 2
37
+ ;;
38
+ *)
39
+ project_path=$1
40
+ shift
41
+ break
42
+ ;;
43
+ esac
44
+ done
45
+
46
+ if [ -z "$project_path" ]; then
47
+ echo "Error: PATH argument is required"
48
+ echo "Usage: aztec new [OPTIONS] <PATH>"
49
+ echo "Run 'aztec new --help' for more information"
50
+ exit 1
51
+ fi
52
+
53
+ echo "Creating new Noir project at $project_path..."
54
+ $NARGO new $type_arg ${name_arg:-} $project_path
55
+
56
+ if [ "$type_arg" == "--contract" ]; then
57
+ cd $project_path
58
+ $script_path/setup_project.sh
59
+ fi
@@ -0,0 +1,31 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ # Get the actual aztec version for the git tag.
5
+ AZTEC_VERSION=$(jq -r '.version' $(dirname $0)/../package.json)
6
+ NARGO_TOML_PATH="Nargo.toml"
7
+ MAIN_NR_PATH="src/main.nr"
8
+
9
+ if [ ! -f "$NARGO_TOML_PATH" ]; then
10
+ >&2 echo "Warning: Could not find Nargo.toml at $NARGO_TOML_PATH to add aztec dependency"
11
+ exit 1
12
+ fi
13
+
14
+ if [ ! -f "$MAIN_NR_PATH" ]; then
15
+ >&2 echo "Warning: Could not find main.nr at $MAIN_NR_PATH"
16
+ exit 1
17
+ fi
18
+
19
+ # Add aztec dependency to Nargo.toml
20
+ echo "" >> "$NARGO_TOML_PATH"
21
+ echo "aztec = { git=\"https://github.com/AztecProtocol/aztec-nr\", tag=\"v${AZTEC_VERSION}\", directory=\"aztec\" }" >> "$NARGO_TOML_PATH"
22
+ echo "Added aztec dependency (v${AZTEC_VERSION}) to Nargo.toml"
23
+
24
+ # Replace the contents of main.nr with the Aztec contract template
25
+ cat > "$MAIN_NR_PATH" << 'EOF'
26
+ use aztec::macros::aztec;
27
+
28
+ #[aztec]
29
+ contract Main {}
30
+ EOF
31
+ echo "Created main.nr with Aztec contract template"