@aztec/end-to-end 1.0.0-nightly.20250618 → 1.0.0-nightly.20250620
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.
- package/dest/bench/client_flows/data_extractor.js +1 -0
- package/dest/e2e_epochs/epochs_test.d.ts +4 -4
- package/dest/e2e_epochs/epochs_test.d.ts.map +1 -1
- package/dest/e2e_epochs/epochs_test.js +11 -10
- package/dest/e2e_p2p/p2p_network.js +2 -2
- package/dest/e2e_p2p/shared.d.ts.map +1 -1
- package/dest/e2e_p2p/shared.js +3 -0
- package/dest/fixtures/e2e_prover_test.d.ts.map +1 -1
- package/dest/fixtures/e2e_prover_test.js +3 -2
- package/dest/fixtures/get_bb_config.d.ts.map +1 -1
- package/dest/fixtures/get_bb_config.js +5 -2
- package/package.json +42 -42
- package/src/bench/client_flows/data_extractor.ts +1 -1
- package/src/e2e_epochs/epochs_test.ts +14 -11
- package/src/e2e_p2p/p2p_network.ts +4 -4
- package/src/e2e_p2p/shared.ts +3 -0
- package/src/fixtures/e2e_prover_test.ts +8 -2
- package/src/fixtures/get_bb_config.ts +13 -1
|
@@ -11,7 +11,7 @@ import { type EndToEndContext, type SetupOptions } from '../fixtures/utils.js';
|
|
|
11
11
|
export declare const WORLD_STATE_BLOCK_HISTORY = 2;
|
|
12
12
|
export declare const WORLD_STATE_BLOCK_CHECK_INTERVAL = 50;
|
|
13
13
|
export declare const ARCHIVER_POLL_INTERVAL = 50;
|
|
14
|
-
export type EpochsTestOpts = Partial<Pick<SetupOptions, 'startProverNode' | '
|
|
14
|
+
export type EpochsTestOpts = Partial<Pick<SetupOptions, 'startProverNode' | 'aztecProofSubmissionEpochs' | 'aztecEpochDuration' | 'proverTestDelayMs' | 'l1PublishRetryIntervalMS' | 'txPropagationMaxQueryAttempts' | 'proverNodeConfig' | 'ethereumSlotDuration' | 'aztecSlotDuration' | 'initialValidators' | 'mockGossipSubNetwork' | 'disableAnvilTestWatcher'>> & {
|
|
15
15
|
numberOfAccounts?: number;
|
|
16
16
|
};
|
|
17
17
|
/**
|
|
@@ -38,7 +38,7 @@ export declare class EpochsTestContext {
|
|
|
38
38
|
ethereumSlotDuration: number;
|
|
39
39
|
aztecSlotDuration: number;
|
|
40
40
|
aztecEpochDuration: number;
|
|
41
|
-
|
|
41
|
+
aztecProofSubmissionEpochs: number;
|
|
42
42
|
};
|
|
43
43
|
setup(opts?: EpochsTestOpts): Promise<void>;
|
|
44
44
|
teardown(): Promise<void>;
|
|
@@ -55,8 +55,8 @@ export declare class EpochsTestContext {
|
|
|
55
55
|
waitUntilL2BlockNumber(target: number, timeout?: number): Promise<void>;
|
|
56
56
|
/** Waits until the given L2 block number is marked as proven. */
|
|
57
57
|
waitUntilProvenL2BlockNumber(t: number, timeout?: number): Promise<number>;
|
|
58
|
-
/** Waits until the
|
|
59
|
-
|
|
58
|
+
/** Waits until the last slot of the proof submission window for a given epoch. */
|
|
59
|
+
waitUntilLastSlotOfProofSubmissionWindow(epochNumber: number | bigint): Promise<void>;
|
|
60
60
|
/** Waits for the aztec node to sync to the target block number. */
|
|
61
61
|
waitForNodeToSync(blockNumber: number, type: 'proven' | 'finalised' | 'historic'): Promise<void>;
|
|
62
62
|
/** Registers the SpamContract on the given wallet. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"epochs_test.d.ts","sourceRoot":"","sources":["../../src/e2e_epochs/epochs_test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,eAAe,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC3E,OAAO,EACL,EAAE,EACF,KAAK,MAAM,EAEX,KAAK,MAAM,EAKZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,KAAK,wBAAwB,EAA0B,MAAM,iBAAiB,CAAC;AACxF,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAkB,KAAK,OAAO,EAAqC,MAAM,sBAAsB,CAAC;AAIrH,OAAO,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAElE,OAAO,EAAE,UAAU,EAAuB,MAAM,oBAAoB,CAAC;AAIrE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,KAAK,iBAAiB,EAAuC,MAAM,6BAA6B,CAAC;AAO1G,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,YAAY,EAIlB,MAAM,sBAAsB,CAAC;AAE9B,eAAO,MAAM,yBAAyB,IAAI,CAAC;AAC3C,eAAO,MAAM,gCAAgC,KAAK,CAAC;AACnD,eAAO,MAAM,sBAAsB,KAAK,CAAC;AAEzC,MAAM,MAAM,cAAc,GAAG,OAAO,CAClC,IAAI,CACF,YAAY,EACV,iBAAiB,GACjB,4BAA4B,GAC5B,oBAAoB,GACpB,mBAAmB,GACnB,0BAA0B,GAC1B,+BAA+B,GAC/B,kBAAkB,GAClB,sBAAsB,GACtB,mBAAmB,GACnB,mBAAmB,GACnB,sBAAsB,GACtB,yBAAyB,CAC5B,CACF,GAAG;IAAE,gBAAgB,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAElC;;;;GAIG;AACH,qBAAa,iBAAiB;IACrB,OAAO,EAAG,eAAe,CAAC;IAC1B,QAAQ,EAAG,wBAAwB,CAAC;IACpC,MAAM,EAAG,cAAc,CAAC;IACxB,SAAS,EAAG,iBAAiB,CAAC;IAC9B,MAAM,EAAG,MAAM,CAAC;IAChB,OAAO,EAAG,YAAY,CAAC;IACvB,aAAa,EAAG,OAAO,CAAC;IACxB,gBAAgB,EAAG,OAAO,CAAC;IAE3B,WAAW,EAAE,UAAU,EAAE,CAAM;IAC/B,KAAK,EAAE,gBAAgB,EAAE,CAAM;IAE/B,aAAa,EAAG,MAAM,CAAC;IAEvB,kBAAkB,EAAG,MAAM,CAAC;IAC5B,qBAAqB,EAAG,MAAM,CAAC;WAElB,KAAK,CAAC,IAAI,GAAE,cAAmB;WAMrC,gBAAgB,CAAC,IAAI,GAAE,cAAmB;;;;;;IAS3C,KAAK,CAAC,IAAI,GAAE,cAAmB;IA6E/B,QAAQ;IAOR,gBAAgB;IAgBtB,sBAAsB,CAAC,IAAI,GAAE,OAAO,CAAC,eAAe,CAAM;IAK1D,mBAAmB,CACxB,WAAW,EAAE,KAAK,MAAM,EAAE,EAAE,EAC5B,IAAI,GAAE,OAAO,CAAC,eAAe,CAAC,GAAG;QAAE,kBAAkB,CAAC,EAAE,OAAO,CAAA;KAAO;YAM1D,UAAU;IA+BxB,OAAO,CAAC,iBAAiB;IAKzB,0FAA0F;IAC7E,oBAAoB,CAAC,KAAK,EAAE,MAAM;IAO/C,sDAAsD;IACzC,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,SAAK;IAShE,iEAAiE;IACpD,4BAA4B,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,SAAK;IAUjE,
|
|
1
|
+
{"version":3,"file":"epochs_test.d.ts","sourceRoot":"","sources":["../../src/e2e_epochs/epochs_test.ts"],"names":[],"mappings":"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"}
|
|
@@ -44,16 +44,16 @@ export const ARCHIVER_POLL_INTERVAL = 50;
|
|
|
44
44
|
const ethereumSlotDuration = opts.ethereumSlotDuration ?? envEthereumSlotDuration;
|
|
45
45
|
const aztecSlotDuration = opts.aztecSlotDuration ?? ethereumSlotDuration * 2;
|
|
46
46
|
const aztecEpochDuration = opts.aztecEpochDuration ?? 4;
|
|
47
|
-
const
|
|
47
|
+
const aztecProofSubmissionEpochs = opts.aztecProofSubmissionEpochs ?? 1;
|
|
48
48
|
return {
|
|
49
49
|
ethereumSlotDuration,
|
|
50
50
|
aztecSlotDuration,
|
|
51
51
|
aztecEpochDuration,
|
|
52
|
-
|
|
52
|
+
aztecProofSubmissionEpochs
|
|
53
53
|
};
|
|
54
54
|
}
|
|
55
55
|
async setup(opts = {}) {
|
|
56
|
-
const { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration,
|
|
56
|
+
const { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration, aztecProofSubmissionEpochs } = EpochsTestContext.getSlotDurations(opts);
|
|
57
57
|
this.L1_BLOCK_TIME_IN_S = ethereumSlotDuration;
|
|
58
58
|
this.L2_SLOT_DURATION_IN_S = aztecSlotDuration;
|
|
59
59
|
// Set up system without any account nor protocol contracts
|
|
@@ -68,7 +68,7 @@ export const ARCHIVER_POLL_INTERVAL = 50;
|
|
|
68
68
|
aztecEpochDuration,
|
|
69
69
|
aztecSlotDuration,
|
|
70
70
|
ethereumSlotDuration,
|
|
71
|
-
|
|
71
|
+
aztecProofSubmissionEpochs,
|
|
72
72
|
aztecTargetCommitteeSize: opts.initialValidators?.length ?? 0,
|
|
73
73
|
minTxsPerBlock: 0,
|
|
74
74
|
realProofs: false,
|
|
@@ -110,7 +110,7 @@ export const ARCHIVER_POLL_INTERVAL = 50;
|
|
|
110
110
|
l1StartBlock: await this.rollup.getL1StartBlock(),
|
|
111
111
|
l1GenesisTime: await this.rollup.getL1GenesisTime(),
|
|
112
112
|
ethereumSlotDuration,
|
|
113
|
-
|
|
113
|
+
proofSubmissionEpochs: Number(await this.rollup.getProofSubmissionEpochs())
|
|
114
114
|
};
|
|
115
115
|
this.logger.info(`L2 genesis at L1 block ${this.constants.l1StartBlock} (timestamp ${this.constants.l1GenesisTime})`);
|
|
116
116
|
}
|
|
@@ -192,13 +192,14 @@ export const ARCHIVER_POLL_INTERVAL = 50;
|
|
|
192
192
|
await retryUntil(()=>Promise.resolve(t <= this.monitor.l2ProvenBlockNumber), `Wait proven L2 block ${t}`, timeout, 0.1);
|
|
193
193
|
return this.monitor.l2ProvenBlockNumber;
|
|
194
194
|
}
|
|
195
|
-
/** Waits until the
|
|
195
|
+
/** Waits until the last slot of the proof submission window for a given epoch. */ async waitUntilLastSlotOfProofSubmissionWindow(epochNumber) {
|
|
196
196
|
const deadline = getProofSubmissionDeadlineTimestamp(BigInt(epochNumber), this.constants);
|
|
197
|
-
const
|
|
198
|
-
|
|
199
|
-
|
|
197
|
+
const oneSlotBefore = deadline - BigInt(this.constants.slotDuration);
|
|
198
|
+
const date = new Date(Number(oneSlotBefore) * 1000);
|
|
199
|
+
this.logger.info(`Waiting until last slot of submission window for epoch ${epochNumber} at ${date}`, {
|
|
200
|
+
oneSlotBefore
|
|
200
201
|
});
|
|
201
|
-
await waitUntilL1Timestamp(this.l1Client,
|
|
202
|
+
await waitUntilL1Timestamp(this.l1Client, oneSlotBefore);
|
|
202
203
|
}
|
|
203
204
|
/** Waits for the aztec node to sync to the target block number. */ async waitForNodeToSync(blockNumber, type) {
|
|
204
205
|
const waitTime = ARCHIVER_POLL_INTERVAL + WORLD_STATE_BLOCK_CHECK_INTERVAL;
|
|
@@ -68,7 +68,7 @@ export class P2PNetworkTest {
|
|
|
68
68
|
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
69
69
|
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
70
70
|
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
71
|
-
|
|
71
|
+
aztecProofSubmissionEpochs: initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
72
72
|
aztecTargetCommitteeSize: numberOfNodes,
|
|
73
73
|
salt: 420,
|
|
74
74
|
metricsPort: metricsPort,
|
|
@@ -79,7 +79,7 @@ export class P2PNetworkTest {
|
|
|
79
79
|
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
80
80
|
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
81
81
|
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
82
|
-
|
|
82
|
+
aztecProofSubmissionEpochs: initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
83
83
|
aztecTargetCommitteeSize: numberOfNodes,
|
|
84
84
|
initialValidators: [],
|
|
85
85
|
zkPassportArgs: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../src/e2e_p2p/shared.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAEL,KAAK,MAAM,EACX,QAAQ,EACR,KAAK,MAAM,EAIZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAElE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AACnF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAEvE,OAAO,EAAE,UAAU,EAAyD,MAAM,mBAAmB,CAAC;AACtG,OAAO,EAAE,OAAO,EAAmB,MAAM,gBAAgB,CAAC;AAE1D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,MAAM,CAAC;AAElD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAIjE,eAAO,MAAM,kBAAkB,GAC7B,QAAQ,MAAM,EACd,cAAc,YAAY,EAC1B,QAAQ,MAAM,EACd,OAAM;IAAE,UAAU,CAAC,EAAE,OAAO,CAAA;CAAO,sBAsBpC,CAAC;AAGF,eAAO,MAAM,qCAAqC,GAChD,QAAQ,MAAM,EACd,MAAM,gBAAgB,EACtB,QAAQ,MAAM,EACd,eAAe,kBAAkB,KAChC,OAAO,CAAC,WAAW,CAgBrB,CAAC;AAEF,wBAAsB,sCAAsC,CAC1D,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,gBAAgB,EACtB,MAAM,EAAE,MAAM,EACd,aAAa,EAAE,kBAAkB,GAChC,OAAO,CAAC;IAAE,UAAU,EAAE,UAAU,CAAC;IAAC,GAAG,EAAE,QAAQ,EAAE,CAAC;IAAC,IAAI,EAAE,gBAAgB,CAAA;CAAE,CAAC,CAqB9E;AAED,wBAAsB,sBAAsB,CAC1C,gBAAgB,EAAE,qBAAqB,CAAC,OAAO,mBAAmB,EAAE,UAAU,CAAC,EAC/E,cAAc,EAAE,MAAM,iBAiBvB;AAED,wBAAsB,oBAAoB,CAAC,EACzC,MAAM,EACN,MAAM,GACP,EAAE;IACD,MAAM,EAAE,cAAc,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;CAChB,GAAG,OAAO,CAAC,SAAS,KAAK,MAAM,EAAE,EAAE,CAAC,CAYpC;AAED;;;GAGG;AACH,wBAAsB,oBAAoB,CAAC,EACzC,OAAO,EACP,MAAM,EACN,UAAU,EACV,SAAS,EACT,cAAc,EACd,YAAY,EACZ,gBAAgB,EAChB,iBAAiB,EACjB,iBAAiB,EACjB,MAAM,EACN,WAAW,GACZ,EAAE;IACD,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,cAAc,CAAC;IACvB,UAAU,EAAE,gBAAgB,CAAC;IAC7B,SAAS,EAAE,SAAS,KAAK,MAAM,EAAE,EAAE,CAAC;IACpC,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,qBAAqB,CAAC,OAAO,eAAe,EAAE,UAAU,CAAC,CAAC;IACxE,gBAAgB,EAAE,qBAAqB,CAAC,OAAO,mBAAmB,EAAE,UAAU,CAAC,CAAC;IAChF,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAClC,
|
|
1
|
+
{"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../src/e2e_p2p/shared.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAEL,KAAK,MAAM,EACX,QAAQ,EACR,KAAK,MAAM,EAIZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAElE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AACnF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAEvE,OAAO,EAAE,UAAU,EAAyD,MAAM,mBAAmB,CAAC;AACtG,OAAO,EAAE,OAAO,EAAmB,MAAM,gBAAgB,CAAC;AAE1D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,MAAM,CAAC;AAElD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAIjE,eAAO,MAAM,kBAAkB,GAC7B,QAAQ,MAAM,EACd,cAAc,YAAY,EAC1B,QAAQ,MAAM,EACd,OAAM;IAAE,UAAU,CAAC,EAAE,OAAO,CAAA;CAAO,sBAsBpC,CAAC;AAGF,eAAO,MAAM,qCAAqC,GAChD,QAAQ,MAAM,EACd,MAAM,gBAAgB,EACtB,QAAQ,MAAM,EACd,eAAe,kBAAkB,KAChC,OAAO,CAAC,WAAW,CAgBrB,CAAC;AAEF,wBAAsB,sCAAsC,CAC1D,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,gBAAgB,EACtB,MAAM,EAAE,MAAM,EACd,aAAa,EAAE,kBAAkB,GAChC,OAAO,CAAC;IAAE,UAAU,EAAE,UAAU,CAAC;IAAC,GAAG,EAAE,QAAQ,EAAE,CAAC;IAAC,IAAI,EAAE,gBAAgB,CAAA;CAAE,CAAC,CAqB9E;AAED,wBAAsB,sBAAsB,CAC1C,gBAAgB,EAAE,qBAAqB,CAAC,OAAO,mBAAmB,EAAE,UAAU,CAAC,EAC/E,cAAc,EAAE,MAAM,iBAiBvB;AAED,wBAAsB,oBAAoB,CAAC,EACzC,MAAM,EACN,MAAM,GACP,EAAE;IACD,MAAM,EAAE,cAAc,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;CAChB,GAAG,OAAO,CAAC,SAAS,KAAK,MAAM,EAAE,EAAE,CAAC,CAYpC;AAED;;;GAGG;AACH,wBAAsB,oBAAoB,CAAC,EACzC,OAAO,EACP,MAAM,EACN,UAAU,EACV,SAAS,EACT,cAAc,EACd,YAAY,EACZ,gBAAgB,EAChB,iBAAiB,EACjB,iBAAiB,EACjB,MAAM,EACN,WAAW,GACZ,EAAE;IACD,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,cAAc,CAAC;IACvB,UAAU,EAAE,gBAAgB,CAAC;IAC7B,SAAS,EAAE,SAAS,KAAK,MAAM,EAAE,EAAE,CAAC;IACpC,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,qBAAqB,CAAC,OAAO,eAAe,EAAE,UAAU,CAAC,CAAC;IACxE,gBAAgB,EAAE,qBAAqB,CAAC,OAAO,mBAAmB,EAAE,UAAU,CAAC,CAAC;IAChF,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAClC,iBAgEA"}
|
package/dest/e2e_p2p/shared.js
CHANGED
|
@@ -133,6 +133,9 @@ export async function awaitCommitteeExists({ rollup, logger }) {
|
|
|
133
133
|
// Check that status is Living
|
|
134
134
|
expect(attesterInfo.status).toEqual(2);
|
|
135
135
|
}
|
|
136
|
+
await cheatCodes.debugRollup();
|
|
137
|
+
await cheatCodes.advanceToNextEpoch();
|
|
138
|
+
await sendDummyTx();
|
|
136
139
|
await cheatCodes.advanceToNextEpoch();
|
|
137
140
|
await sendDummyTx();
|
|
138
141
|
await cheatCodes.debugRollup();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"e2e_prover_test.d.ts","sourceRoot":"","sources":["../../src/fixtures/e2e_prover_test.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAElE,OAAO,EACL,KAAK,0BAA0B,EAC/B,KAAK,SAAS,EACd,KAAK,eAAe,EACpB,UAAU,EACV,KAAK,MAAM,EAGZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,
|
|
1
|
+
{"version":3,"file":"e2e_prover_test.d.ts","sourceRoot":"","sources":["../../src/fixtures/e2e_prover_test.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAElE,OAAO,EACL,KAAK,0BAA0B,EAC/B,KAAK,SAAS,EACd,KAAK,eAAe,EACpB,UAAU,EACV,KAAK,MAAM,EAGZ,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAEL,KAAK,6BAA6B,EAGnC,MAAM,kBAAkB,CAAC;AAE1B,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,iBAAiB,CAAC;AAInE,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAE/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAMtE,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAGlE,OAAO,EAEL,KAAK,iBAAiB,EAIvB,MAAM,uBAAuB,CAAC;AAU/B;;;;;GAKG;AAEH,qBAAa,cAAc;IA6BvB,OAAO,CAAC,sBAAsB;IAE9B,OAAO,CAAC,UAAU;IA9BpB,MAAM,CAAC,UAAU,SAAU;IAC3B,MAAM,CAAC,YAAY,SAAS;IAC5B,MAAM,CAAC,cAAc,SAAO;IAC5B,OAAO,CAAC,eAAe,CAAmB;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,gBAAgB,EAAE,kBAAkB,EAAE,CAAM;IAC5C,OAAO,EAAE,0BAA0B,EAAE,CAAM;IAC3C,QAAQ,EAAE,eAAe,EAAE,CAAM;IACjC,eAAe,EAAG,aAAa,CAAC;IAChC,QAAQ,EAAG,cAAc,CAAC;IAC1B,SAAS,EAAG,SAAS,CAAC;IACtB,cAAc,EAAG,cAAc,CAAC;IAChC,GAAG,EAAG,UAAU,CAAC;IACjB,UAAU,EAAG,UAAU,CAAC;IACxB,QAAQ,EAAG,cAAc,CAAC;IAC1B,OAAO,CAAC,gBAAgB,CAAqB;IAC7C,OAAO,CAAC,eAAe,CAAC,CAAsB;IAC9C,OAAO,CAAC,iBAAiB,CAAC,CAAsB;IAChD,oBAAoB,CAAC,EAAE,6BAA6B,CAAC;IACrD,YAAY,EAAE,aAAa,EAAE,CAAM;IACnC,OAAO,CAAC,OAAO,CAAqB;IACpC,OAAO,CAAC,UAAU,CAAc;IAChC,OAAO,CAAC,mBAAmB,CAAc;IAClC,WAAW,EAAG,2BAA2B,CAAC;IAC1C,aAAa,EAAG,UAAU,CAAC;gBAGhC,QAAQ,EAAE,MAAM,EACR,sBAAsB,EAAE,MAAM,EACtC,QAAQ,EAAE,UAAU,EACZ,UAAU,UAAO;IAa3B;;;;OAIG;IACG,kBAAkB;IAqDlB,KAAK;YAgKG,WAAW;IAQzB,QAAQ,GAAI,CAAC,EACX,MAAM,MAAM,EACZ,OAAO,CAAC,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,CAAC,CAAC,EACjD,UAAS,CAAC,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,IAAI,CAA2B,KAChG,OAAO,CAAC,IAAI,CAAC,CAAwD;IAElE,QAAQ;IAeR,iBAAiB;CA8CxB"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { SchnorrAccountContractArtifact, getSchnorrAccount, getSchnorrWalletWithSecretKey } from '@aztec/accounts/schnorr';
|
|
2
2
|
import { createArchiver } from '@aztec/archiver';
|
|
3
3
|
import { EthAddress, createLogger } from '@aztec/aztec.js';
|
|
4
|
-
import { BBCircuitVerifier, TestCircuitVerifier } from '@aztec/bb-prover';
|
|
4
|
+
import { BBCircuitVerifier, QueuedIVCVerifier, TestCircuitVerifier } from '@aztec/bb-prover';
|
|
5
5
|
import { createBlobSinkClient } from '@aztec/blob-sink/client';
|
|
6
6
|
import { Buffer32 } from '@aztec/foundation/buffer';
|
|
7
7
|
import { SecretValue } from '@aztec/foundation/config';
|
|
@@ -124,7 +124,8 @@ const { E2E_DATA_PATH: dataPath } = process.env;
|
|
|
124
124
|
if (!bbConfig?.bbWorkingDirectory || !bbConfig?.bbBinaryPath) {
|
|
125
125
|
throw new Error(`Test must be run with BB native configuration`);
|
|
126
126
|
}
|
|
127
|
-
|
|
127
|
+
const verifier = await BBCircuitVerifier.new(bbConfig);
|
|
128
|
+
this.circuitProofVerifier = new QueuedIVCVerifier(bbConfig, verifier);
|
|
128
129
|
this.logger.debug(`Configuring the node for real proofs...`);
|
|
129
130
|
await this.aztecNodeAdmin.setConfig({
|
|
130
131
|
realProofs: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get_bb_config.d.ts","sourceRoot":"","sources":["../../src/fixtures/get_bb_config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAiB,MAAM,iBAAiB,CAAC;AAC7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"get_bb_config.d.ts","sourceRoot":"","sources":["../../src/fixtures/get_bb_config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAiB,MAAM,iBAAiB,CAAC;AAC7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAiBjD,eAAO,MAAM,WAAW,GACtB,QAAQ,MAAM,KACb,OAAO,CAAC,CAAC,QAAQ,GAAG;IAAE,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAAE,CAAC,GAAG,SAAS,CAqCnE,CAAC"}
|
|
@@ -3,7 +3,7 @@ import { tryRmDir } from '@aztec/foundation/fs';
|
|
|
3
3
|
import fs from 'node:fs/promises';
|
|
4
4
|
import { tmpdir } from 'node:os';
|
|
5
5
|
import path from 'path';
|
|
6
|
-
const { BB_RELEASE_DIR = 'barretenberg/cpp/build/bin', BB_BINARY_PATH, BB_SKIP_CLEANUP = '', TEMP_DIR = tmpdir(), BB_WORKING_DIRECTORY = '' } = process.env;
|
|
6
|
+
const { BB_RELEASE_DIR = 'barretenberg/cpp/build/bin', BB_BINARY_PATH, BB_SKIP_CLEANUP = '', TEMP_DIR = tmpdir(), BB_WORKING_DIRECTORY = '', BB_NUM_IVC_VERIFIERS = '1', BB_IVC_CONCURRENCY = '1' } = process.env;
|
|
7
7
|
export const getBBConfig = async (logger)=>{
|
|
8
8
|
try {
|
|
9
9
|
const bbBinaryPath = BB_BINARY_PATH ?? path.resolve(path.dirname(fileURLToPath(import.meta.url)), '../../../../', BB_RELEASE_DIR, 'bb');
|
|
@@ -24,12 +24,15 @@ export const getBBConfig = async (logger)=>{
|
|
|
24
24
|
'true'
|
|
25
25
|
].includes(BB_SKIP_CLEANUP);
|
|
26
26
|
const cleanup = bbSkipCleanup ? ()=>Promise.resolve() : ()=>tryRmDir(directoryToCleanup);
|
|
27
|
+
const numIvcVerifiers = Number(BB_NUM_IVC_VERIFIERS);
|
|
28
|
+
const ivcConcurrency = Number(BB_IVC_CONCURRENCY);
|
|
27
29
|
return {
|
|
28
30
|
bbSkipCleanup,
|
|
29
31
|
bbBinaryPath,
|
|
30
32
|
bbWorkingDirectory,
|
|
31
33
|
cleanup,
|
|
32
|
-
numConcurrentIVCVerifiers:
|
|
34
|
+
numConcurrentIVCVerifiers: numIvcVerifiers,
|
|
35
|
+
bbIVCConcurrency: ivcConcurrency
|
|
33
36
|
};
|
|
34
37
|
} catch (err) {
|
|
35
38
|
logger.error(`Native BB not available, error: ${err}`);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/end-to-end",
|
|
3
|
-
"version": "1.0.0-nightly.
|
|
3
|
+
"version": "1.0.0-nightly.20250620",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": "./dest/index.js",
|
|
6
6
|
"inherits": [
|
|
@@ -25,47 +25,47 @@
|
|
|
25
25
|
"formatting": "run -T prettier --check ./src && run -T eslint ./src"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
|
-
"@aztec/accounts": "1.0.0-nightly.
|
|
29
|
-
"@aztec/archiver": "1.0.0-nightly.
|
|
30
|
-
"@aztec/aztec": "1.0.0-nightly.
|
|
31
|
-
"@aztec/aztec-node": "1.0.0-nightly.
|
|
32
|
-
"@aztec/aztec.js": "1.0.0-nightly.
|
|
33
|
-
"@aztec/bb-prover": "1.0.0-nightly.
|
|
34
|
-
"@aztec/blob-lib": "1.0.0-nightly.
|
|
35
|
-
"@aztec/blob-sink": "1.0.0-nightly.
|
|
36
|
-
"@aztec/bot": "1.0.0-nightly.
|
|
37
|
-
"@aztec/cli": "1.0.0-nightly.
|
|
38
|
-
"@aztec/constants": "1.0.0-nightly.
|
|
39
|
-
"@aztec/entrypoints": "1.0.0-nightly.
|
|
40
|
-
"@aztec/epoch-cache": "1.0.0-nightly.
|
|
41
|
-
"@aztec/ethereum": "1.0.0-nightly.
|
|
42
|
-
"@aztec/foundation": "1.0.0-nightly.
|
|
43
|
-
"@aztec/kv-store": "1.0.0-nightly.
|
|
44
|
-
"@aztec/l1-artifacts": "1.0.0-nightly.
|
|
45
|
-
"@aztec/merkle-tree": "1.0.0-nightly.
|
|
46
|
-
"@aztec/noir-contracts.js": "1.0.0-nightly.
|
|
47
|
-
"@aztec/noir-noirc_abi": "1.0.0-nightly.
|
|
48
|
-
"@aztec/noir-protocol-circuits-types": "1.0.0-nightly.
|
|
49
|
-
"@aztec/noir-test-contracts.js": "1.0.0-nightly.
|
|
50
|
-
"@aztec/p2p": "1.0.0-nightly.
|
|
51
|
-
"@aztec/protocol-contracts": "1.0.0-nightly.
|
|
52
|
-
"@aztec/prover-client": "1.0.0-nightly.
|
|
53
|
-
"@aztec/prover-node": "1.0.0-nightly.
|
|
54
|
-
"@aztec/pxe": "1.0.0-nightly.
|
|
55
|
-
"@aztec/sequencer-client": "1.0.0-nightly.
|
|
56
|
-
"@aztec/simulator": "1.0.0-nightly.
|
|
57
|
-
"@aztec/slasher": "1.0.0-nightly.
|
|
58
|
-
"@aztec/stdlib": "1.0.0-nightly.
|
|
59
|
-
"@aztec/telemetry-client": "1.0.0-nightly.
|
|
60
|
-
"@aztec/validator-client": "1.0.0-nightly.
|
|
61
|
-
"@aztec/world-state": "1.0.0-nightly.
|
|
28
|
+
"@aztec/accounts": "1.0.0-nightly.20250620",
|
|
29
|
+
"@aztec/archiver": "1.0.0-nightly.20250620",
|
|
30
|
+
"@aztec/aztec": "1.0.0-nightly.20250620",
|
|
31
|
+
"@aztec/aztec-node": "1.0.0-nightly.20250620",
|
|
32
|
+
"@aztec/aztec.js": "1.0.0-nightly.20250620",
|
|
33
|
+
"@aztec/bb-prover": "1.0.0-nightly.20250620",
|
|
34
|
+
"@aztec/blob-lib": "1.0.0-nightly.20250620",
|
|
35
|
+
"@aztec/blob-sink": "1.0.0-nightly.20250620",
|
|
36
|
+
"@aztec/bot": "1.0.0-nightly.20250620",
|
|
37
|
+
"@aztec/cli": "1.0.0-nightly.20250620",
|
|
38
|
+
"@aztec/constants": "1.0.0-nightly.20250620",
|
|
39
|
+
"@aztec/entrypoints": "1.0.0-nightly.20250620",
|
|
40
|
+
"@aztec/epoch-cache": "1.0.0-nightly.20250620",
|
|
41
|
+
"@aztec/ethereum": "1.0.0-nightly.20250620",
|
|
42
|
+
"@aztec/foundation": "1.0.0-nightly.20250620",
|
|
43
|
+
"@aztec/kv-store": "1.0.0-nightly.20250620",
|
|
44
|
+
"@aztec/l1-artifacts": "1.0.0-nightly.20250620",
|
|
45
|
+
"@aztec/merkle-tree": "1.0.0-nightly.20250620",
|
|
46
|
+
"@aztec/noir-contracts.js": "1.0.0-nightly.20250620",
|
|
47
|
+
"@aztec/noir-noirc_abi": "1.0.0-nightly.20250620",
|
|
48
|
+
"@aztec/noir-protocol-circuits-types": "1.0.0-nightly.20250620",
|
|
49
|
+
"@aztec/noir-test-contracts.js": "1.0.0-nightly.20250620",
|
|
50
|
+
"@aztec/p2p": "1.0.0-nightly.20250620",
|
|
51
|
+
"@aztec/protocol-contracts": "1.0.0-nightly.20250620",
|
|
52
|
+
"@aztec/prover-client": "1.0.0-nightly.20250620",
|
|
53
|
+
"@aztec/prover-node": "1.0.0-nightly.20250620",
|
|
54
|
+
"@aztec/pxe": "1.0.0-nightly.20250620",
|
|
55
|
+
"@aztec/sequencer-client": "1.0.0-nightly.20250620",
|
|
56
|
+
"@aztec/simulator": "1.0.0-nightly.20250620",
|
|
57
|
+
"@aztec/slasher": "1.0.0-nightly.20250620",
|
|
58
|
+
"@aztec/stdlib": "1.0.0-nightly.20250620",
|
|
59
|
+
"@aztec/telemetry-client": "1.0.0-nightly.20250620",
|
|
60
|
+
"@aztec/validator-client": "1.0.0-nightly.20250620",
|
|
61
|
+
"@aztec/world-state": "1.0.0-nightly.20250620",
|
|
62
62
|
"@iarna/toml": "^2.2.5",
|
|
63
|
-
"@jest/globals": "^
|
|
63
|
+
"@jest/globals": "^30.0.0",
|
|
64
64
|
"@noble/curves": "^1.0.0",
|
|
65
65
|
"@swc/core": "^1.4.11",
|
|
66
66
|
"@swc/jest": "^0.2.36",
|
|
67
67
|
"@types/fs-extra": "^11.0.2",
|
|
68
|
-
"@types/jest": "^
|
|
68
|
+
"@types/jest": "^30.0.0",
|
|
69
69
|
"@types/koa": "^2.15.0",
|
|
70
70
|
"@types/koa-static": "^4.0.2",
|
|
71
71
|
"@types/lodash.every": "^4.6.7",
|
|
@@ -76,9 +76,9 @@
|
|
|
76
76
|
"fs-extra": "^11.2.0",
|
|
77
77
|
"get-port": "^7.1.0",
|
|
78
78
|
"glob": "^10.3.10",
|
|
79
|
-
"jest": "^
|
|
80
|
-
"jest-extended": "^
|
|
81
|
-
"jest-mock-extended": "^
|
|
79
|
+
"jest": "^30.0.0",
|
|
80
|
+
"jest-extended": "^6.0.0",
|
|
81
|
+
"jest-mock-extended": "^4.0.0",
|
|
82
82
|
"koa": "^2.16.1",
|
|
83
83
|
"koa-static": "^5.0.0",
|
|
84
84
|
"lodash.chunk": "^4.2.0",
|
|
@@ -101,12 +101,12 @@
|
|
|
101
101
|
"devDependencies": {
|
|
102
102
|
"0x": "^5.7.0",
|
|
103
103
|
"@jest/globals": "^30.0.0",
|
|
104
|
-
"@types/jest": "^
|
|
104
|
+
"@types/jest": "^30.0.0",
|
|
105
105
|
"@types/js-yaml": "^4.0.9",
|
|
106
106
|
"@types/lodash.chunk": "^4.2.9",
|
|
107
107
|
"concurrently": "^7.6.0",
|
|
108
108
|
"jest": "^30.0.0",
|
|
109
|
-
"jest-extended": "^
|
|
109
|
+
"jest-extended": "^6.0.0",
|
|
110
110
|
"js-yaml": "^4.1.0",
|
|
111
111
|
"ts-node": "^10.9.1",
|
|
112
112
|
"typescript": "^5.3.3"
|
|
@@ -23,7 +23,7 @@ async function createProver(config: NativeProverConfig = {}, log: Logger) {
|
|
|
23
23
|
const bbConfig = config as Required<NativeProverConfig>;
|
|
24
24
|
return {
|
|
25
25
|
prover: await BBNativePrivateKernelProver.new(
|
|
26
|
-
{ bbSkipCleanup: false, numConcurrentIVCVerifiers: 1, ...bbConfig },
|
|
26
|
+
{ bbSkipCleanup: false, numConcurrentIVCVerifiers: 1, bbIVCConcurrency: 1, ...bbConfig },
|
|
27
27
|
simulator,
|
|
28
28
|
log,
|
|
29
29
|
),
|
|
@@ -45,7 +45,7 @@ export type EpochsTestOpts = Partial<
|
|
|
45
45
|
Pick<
|
|
46
46
|
SetupOptions,
|
|
47
47
|
| 'startProverNode'
|
|
48
|
-
| '
|
|
48
|
+
| 'aztecProofSubmissionEpochs'
|
|
49
49
|
| 'aztecEpochDuration'
|
|
50
50
|
| 'proverTestDelayMs'
|
|
51
51
|
| 'l1PublishRetryIntervalMS'
|
|
@@ -93,12 +93,12 @@ export class EpochsTestContext {
|
|
|
93
93
|
const ethereumSlotDuration = opts.ethereumSlotDuration ?? envEthereumSlotDuration;
|
|
94
94
|
const aztecSlotDuration = opts.aztecSlotDuration ?? ethereumSlotDuration * 2;
|
|
95
95
|
const aztecEpochDuration = opts.aztecEpochDuration ?? 4;
|
|
96
|
-
const
|
|
97
|
-
return { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration,
|
|
96
|
+
const aztecProofSubmissionEpochs = opts.aztecProofSubmissionEpochs ?? 1;
|
|
97
|
+
return { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration, aztecProofSubmissionEpochs };
|
|
98
98
|
}
|
|
99
99
|
|
|
100
100
|
public async setup(opts: EpochsTestOpts = {}) {
|
|
101
|
-
const { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration,
|
|
101
|
+
const { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration, aztecProofSubmissionEpochs } =
|
|
102
102
|
EpochsTestContext.getSlotDurations(opts);
|
|
103
103
|
|
|
104
104
|
this.L1_BLOCK_TIME_IN_S = ethereumSlotDuration;
|
|
@@ -116,7 +116,7 @@ export class EpochsTestContext {
|
|
|
116
116
|
aztecEpochDuration,
|
|
117
117
|
aztecSlotDuration,
|
|
118
118
|
ethereumSlotDuration,
|
|
119
|
-
|
|
119
|
+
aztecProofSubmissionEpochs,
|
|
120
120
|
aztecTargetCommitteeSize: opts.initialValidators?.length ?? 0,
|
|
121
121
|
minTxsPerBlock: 0,
|
|
122
122
|
realProofs: false,
|
|
@@ -166,7 +166,7 @@ export class EpochsTestContext {
|
|
|
166
166
|
l1StartBlock: await this.rollup.getL1StartBlock(),
|
|
167
167
|
l1GenesisTime: await this.rollup.getL1GenesisTime(),
|
|
168
168
|
ethereumSlotDuration,
|
|
169
|
-
|
|
169
|
+
proofSubmissionEpochs: Number(await this.rollup.getProofSubmissionEpochs()),
|
|
170
170
|
};
|
|
171
171
|
|
|
172
172
|
this.logger.info(
|
|
@@ -275,12 +275,15 @@ export class EpochsTestContext {
|
|
|
275
275
|
return this.monitor.l2ProvenBlockNumber;
|
|
276
276
|
}
|
|
277
277
|
|
|
278
|
-
/** Waits until the
|
|
279
|
-
public async
|
|
278
|
+
/** Waits until the last slot of the proof submission window for a given epoch. */
|
|
279
|
+
public async waitUntilLastSlotOfProofSubmissionWindow(epochNumber: number | bigint) {
|
|
280
280
|
const deadline = getProofSubmissionDeadlineTimestamp(BigInt(epochNumber), this.constants);
|
|
281
|
-
const
|
|
282
|
-
|
|
283
|
-
|
|
281
|
+
const oneSlotBefore = deadline - BigInt(this.constants.slotDuration);
|
|
282
|
+
const date = new Date(Number(oneSlotBefore) * 1000);
|
|
283
|
+
this.logger.info(`Waiting until last slot of submission window for epoch ${epochNumber} at ${date}`, {
|
|
284
|
+
oneSlotBefore,
|
|
285
|
+
});
|
|
286
|
+
await waitUntilL1Timestamp(this.l1Client, oneSlotBefore);
|
|
284
287
|
}
|
|
285
288
|
|
|
286
289
|
/** Waits for the aztec node to sync to the target block number. */
|
|
@@ -100,8 +100,8 @@ export class P2PNetworkTest {
|
|
|
100
100
|
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
101
101
|
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
102
102
|
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
103
|
-
|
|
104
|
-
initialValidatorConfig.
|
|
103
|
+
aztecProofSubmissionEpochs:
|
|
104
|
+
initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
105
105
|
aztecTargetCommitteeSize: numberOfNodes,
|
|
106
106
|
salt: 420,
|
|
107
107
|
metricsPort: metricsPort,
|
|
@@ -113,8 +113,8 @@ export class P2PNetworkTest {
|
|
|
113
113
|
aztecEpochDuration: initialValidatorConfig.aztecEpochDuration ?? l1ContractsConfig.aztecEpochDuration,
|
|
114
114
|
ethereumSlotDuration: initialValidatorConfig.ethereumSlotDuration ?? l1ContractsConfig.ethereumSlotDuration,
|
|
115
115
|
aztecSlotDuration: initialValidatorConfig.aztecSlotDuration ?? l1ContractsConfig.aztecSlotDuration,
|
|
116
|
-
|
|
117
|
-
initialValidatorConfig.
|
|
116
|
+
aztecProofSubmissionEpochs:
|
|
117
|
+
initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
|
|
118
118
|
aztecTargetCommitteeSize: numberOfNodes,
|
|
119
119
|
initialValidators: [],
|
|
120
120
|
zkPassportArgs: {
|
package/src/e2e_p2p/shared.ts
CHANGED
|
@@ -225,6 +225,9 @@ export async function awaitCommitteeKicked({
|
|
|
225
225
|
expect(attesterInfo.status).toEqual(2);
|
|
226
226
|
}
|
|
227
227
|
|
|
228
|
+
await cheatCodes.debugRollup();
|
|
229
|
+
await cheatCodes.advanceToNextEpoch();
|
|
230
|
+
await sendDummyTx();
|
|
228
231
|
await cheatCodes.advanceToNextEpoch();
|
|
229
232
|
await sendDummyTx();
|
|
230
233
|
await cheatCodes.debugRollup();
|
|
@@ -15,7 +15,12 @@ import {
|
|
|
15
15
|
createLogger,
|
|
16
16
|
} from '@aztec/aztec.js';
|
|
17
17
|
import { CheatCodes } from '@aztec/aztec.js/testing';
|
|
18
|
-
import {
|
|
18
|
+
import {
|
|
19
|
+
BBCircuitVerifier,
|
|
20
|
+
type ClientProtocolCircuitVerifier,
|
|
21
|
+
QueuedIVCVerifier,
|
|
22
|
+
TestCircuitVerifier,
|
|
23
|
+
} from '@aztec/bb-prover';
|
|
19
24
|
import { createBlobSinkClient } from '@aztec/blob-sink/client';
|
|
20
25
|
import type { BlobSinkServer } from '@aztec/blob-sink/server';
|
|
21
26
|
import type { DeployL1ContractsReturnType } from '@aztec/ethereum';
|
|
@@ -193,7 +198,8 @@ export class FullProverTest {
|
|
|
193
198
|
throw new Error(`Test must be run with BB native configuration`);
|
|
194
199
|
}
|
|
195
200
|
|
|
196
|
-
|
|
201
|
+
const verifier = await BBCircuitVerifier.new(bbConfig);
|
|
202
|
+
this.circuitProofVerifier = new QueuedIVCVerifier(bbConfig, verifier);
|
|
197
203
|
|
|
198
204
|
this.logger.debug(`Configuring the node for real proofs...`);
|
|
199
205
|
await this.aztecNodeAdmin.setConfig({
|
|
@@ -12,6 +12,8 @@ const {
|
|
|
12
12
|
BB_SKIP_CLEANUP = '',
|
|
13
13
|
TEMP_DIR = tmpdir(),
|
|
14
14
|
BB_WORKING_DIRECTORY = '',
|
|
15
|
+
BB_NUM_IVC_VERIFIERS = '1',
|
|
16
|
+
BB_IVC_CONCURRENCY = '1',
|
|
15
17
|
} = process.env;
|
|
16
18
|
|
|
17
19
|
export const getBBConfig = async (
|
|
@@ -38,7 +40,17 @@ export const getBBConfig = async (
|
|
|
38
40
|
const bbSkipCleanup = ['1', 'true'].includes(BB_SKIP_CLEANUP);
|
|
39
41
|
const cleanup = bbSkipCleanup ? () => Promise.resolve() : () => tryRmDir(directoryToCleanup);
|
|
40
42
|
|
|
41
|
-
|
|
43
|
+
const numIvcVerifiers = Number(BB_NUM_IVC_VERIFIERS);
|
|
44
|
+
const ivcConcurrency = Number(BB_IVC_CONCURRENCY);
|
|
45
|
+
|
|
46
|
+
return {
|
|
47
|
+
bbSkipCleanup,
|
|
48
|
+
bbBinaryPath,
|
|
49
|
+
bbWorkingDirectory,
|
|
50
|
+
cleanup,
|
|
51
|
+
numConcurrentIVCVerifiers: numIvcVerifiers,
|
|
52
|
+
bbIVCConcurrency: ivcConcurrency,
|
|
53
|
+
};
|
|
42
54
|
} catch (err) {
|
|
43
55
|
logger.error(`Native BB not available, error: ${err}`);
|
|
44
56
|
return undefined;
|