@aztec/end-to-end 1.0.0-nightly.20250618 → 1.0.0-nightly.20250619

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.
@@ -20,6 +20,7 @@ async function createProver(config = {}, log) {
20
20
  prover: await BBNativePrivateKernelProver.new({
21
21
  bbSkipCleanup: false,
22
22
  numConcurrentIVCVerifiers: 1,
23
+ bbIVCConcurrency: 1,
23
24
  ...bbConfig
24
25
  }, simulator, log),
25
26
  type: 'native'
@@ -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' | 'aztecProofSubmissionWindow' | 'aztecEpochDuration' | 'proverTestDelayMs' | 'l1PublishRetryIntervalMS' | 'txPropagationMaxQueryAttempts' | 'proverNodeConfig' | 'ethereumSlotDuration' | 'aztecSlotDuration' | 'initialValidators' | 'mockGossipSubNetwork' | 'disableAnvilTestWatcher'>> & {
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
- aztecProofSubmissionWindow: number;
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 end of the proof submission window for a given epoch. */
59
- waitUntilEndOfProofSubmissionWindow(epochNumber: number | bigint): Promise<void>;
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":"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"}
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 aztecProofSubmissionWindow = opts.aztecProofSubmissionWindow ?? aztecEpochDuration * 2 - 1;
47
+ const aztecProofSubmissionEpochs = opts.aztecProofSubmissionEpochs ?? 1;
48
48
  return {
49
49
  ethereumSlotDuration,
50
50
  aztecSlotDuration,
51
51
  aztecEpochDuration,
52
- aztecProofSubmissionWindow
52
+ aztecProofSubmissionEpochs
53
53
  };
54
54
  }
55
55
  async setup(opts = {}) {
56
- const { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration, aztecProofSubmissionWindow } = EpochsTestContext.getSlotDurations(opts);
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
- aztecProofSubmissionWindow,
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
- proofSubmissionWindow: aztecProofSubmissionWindow
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 end of the proof submission window for a given epoch. */ async waitUntilEndOfProofSubmissionWindow(epochNumber) {
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 date = new Date(Number(deadline) * 1000);
198
- this.logger.info(`Waiting until end of submission window for epoch ${epochNumber} at ${date}`, {
199
- deadline
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, deadline);
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
- aztecProofSubmissionWindow: initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
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
- aztecProofSubmissionWindow: initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
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,iBA6DA"}
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"}
@@ -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,EAAqB,KAAK,6BAA6B,EAAuB,MAAM,kBAAkB,CAAC;AAE9G,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;YA+JG,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
+ {"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
- this.circuitProofVerifier = await BBCircuitVerifier.new(bbConfig);
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;AAejD,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,CA2BnE,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: 1
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.20250618",
3
+ "version": "1.0.0-nightly.20250619",
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.20250618",
29
- "@aztec/archiver": "1.0.0-nightly.20250618",
30
- "@aztec/aztec": "1.0.0-nightly.20250618",
31
- "@aztec/aztec-node": "1.0.0-nightly.20250618",
32
- "@aztec/aztec.js": "1.0.0-nightly.20250618",
33
- "@aztec/bb-prover": "1.0.0-nightly.20250618",
34
- "@aztec/blob-lib": "1.0.0-nightly.20250618",
35
- "@aztec/blob-sink": "1.0.0-nightly.20250618",
36
- "@aztec/bot": "1.0.0-nightly.20250618",
37
- "@aztec/cli": "1.0.0-nightly.20250618",
38
- "@aztec/constants": "1.0.0-nightly.20250618",
39
- "@aztec/entrypoints": "1.0.0-nightly.20250618",
40
- "@aztec/epoch-cache": "1.0.0-nightly.20250618",
41
- "@aztec/ethereum": "1.0.0-nightly.20250618",
42
- "@aztec/foundation": "1.0.0-nightly.20250618",
43
- "@aztec/kv-store": "1.0.0-nightly.20250618",
44
- "@aztec/l1-artifacts": "1.0.0-nightly.20250618",
45
- "@aztec/merkle-tree": "1.0.0-nightly.20250618",
46
- "@aztec/noir-contracts.js": "1.0.0-nightly.20250618",
47
- "@aztec/noir-noirc_abi": "1.0.0-nightly.20250618",
48
- "@aztec/noir-protocol-circuits-types": "1.0.0-nightly.20250618",
49
- "@aztec/noir-test-contracts.js": "1.0.0-nightly.20250618",
50
- "@aztec/p2p": "1.0.0-nightly.20250618",
51
- "@aztec/protocol-contracts": "1.0.0-nightly.20250618",
52
- "@aztec/prover-client": "1.0.0-nightly.20250618",
53
- "@aztec/prover-node": "1.0.0-nightly.20250618",
54
- "@aztec/pxe": "1.0.0-nightly.20250618",
55
- "@aztec/sequencer-client": "1.0.0-nightly.20250618",
56
- "@aztec/simulator": "1.0.0-nightly.20250618",
57
- "@aztec/slasher": "1.0.0-nightly.20250618",
58
- "@aztec/stdlib": "1.0.0-nightly.20250618",
59
- "@aztec/telemetry-client": "1.0.0-nightly.20250618",
60
- "@aztec/validator-client": "1.0.0-nightly.20250618",
61
- "@aztec/world-state": "1.0.0-nightly.20250618",
28
+ "@aztec/accounts": "1.0.0-nightly.20250619",
29
+ "@aztec/archiver": "1.0.0-nightly.20250619",
30
+ "@aztec/aztec": "1.0.0-nightly.20250619",
31
+ "@aztec/aztec-node": "1.0.0-nightly.20250619",
32
+ "@aztec/aztec.js": "1.0.0-nightly.20250619",
33
+ "@aztec/bb-prover": "1.0.0-nightly.20250619",
34
+ "@aztec/blob-lib": "1.0.0-nightly.20250619",
35
+ "@aztec/blob-sink": "1.0.0-nightly.20250619",
36
+ "@aztec/bot": "1.0.0-nightly.20250619",
37
+ "@aztec/cli": "1.0.0-nightly.20250619",
38
+ "@aztec/constants": "1.0.0-nightly.20250619",
39
+ "@aztec/entrypoints": "1.0.0-nightly.20250619",
40
+ "@aztec/epoch-cache": "1.0.0-nightly.20250619",
41
+ "@aztec/ethereum": "1.0.0-nightly.20250619",
42
+ "@aztec/foundation": "1.0.0-nightly.20250619",
43
+ "@aztec/kv-store": "1.0.0-nightly.20250619",
44
+ "@aztec/l1-artifacts": "1.0.0-nightly.20250619",
45
+ "@aztec/merkle-tree": "1.0.0-nightly.20250619",
46
+ "@aztec/noir-contracts.js": "1.0.0-nightly.20250619",
47
+ "@aztec/noir-noirc_abi": "1.0.0-nightly.20250619",
48
+ "@aztec/noir-protocol-circuits-types": "1.0.0-nightly.20250619",
49
+ "@aztec/noir-test-contracts.js": "1.0.0-nightly.20250619",
50
+ "@aztec/p2p": "1.0.0-nightly.20250619",
51
+ "@aztec/protocol-contracts": "1.0.0-nightly.20250619",
52
+ "@aztec/prover-client": "1.0.0-nightly.20250619",
53
+ "@aztec/prover-node": "1.0.0-nightly.20250619",
54
+ "@aztec/pxe": "1.0.0-nightly.20250619",
55
+ "@aztec/sequencer-client": "1.0.0-nightly.20250619",
56
+ "@aztec/simulator": "1.0.0-nightly.20250619",
57
+ "@aztec/slasher": "1.0.0-nightly.20250619",
58
+ "@aztec/stdlib": "1.0.0-nightly.20250619",
59
+ "@aztec/telemetry-client": "1.0.0-nightly.20250619",
60
+ "@aztec/validator-client": "1.0.0-nightly.20250619",
61
+ "@aztec/world-state": "1.0.0-nightly.20250619",
62
62
  "@iarna/toml": "^2.2.5",
63
- "@jest/globals": "^29.5.0",
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": "^29.5.0",
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": "^29.5.0",
80
- "jest-extended": "^4.0.2",
81
- "jest-mock-extended": "^3.0.5",
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": "^29.5.0",
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": "^4.0.2",
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
- | 'aztecProofSubmissionWindow'
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 aztecProofSubmissionWindow = opts.aztecProofSubmissionWindow ?? aztecEpochDuration * 2 - 1;
97
- return { ethereumSlotDuration, aztecSlotDuration, aztecEpochDuration, aztecProofSubmissionWindow };
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, aztecProofSubmissionWindow } =
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
- aztecProofSubmissionWindow,
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
- proofSubmissionWindow: aztecProofSubmissionWindow,
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 end of the proof submission window for a given epoch. */
279
- public async waitUntilEndOfProofSubmissionWindow(epochNumber: number | bigint) {
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 date = new Date(Number(deadline) * 1000);
282
- this.logger.info(`Waiting until end of submission window for epoch ${epochNumber} at ${date}`, { deadline });
283
- await waitUntilL1Timestamp(this.l1Client, deadline);
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
- aztecProofSubmissionWindow:
104
- initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
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
- aztecProofSubmissionWindow:
117
- initialValidatorConfig.aztecProofSubmissionWindow ?? l1ContractsConfig.aztecProofSubmissionWindow,
116
+ aztecProofSubmissionEpochs:
117
+ initialValidatorConfig.aztecProofSubmissionEpochs ?? l1ContractsConfig.aztecProofSubmissionEpochs,
118
118
  aztecTargetCommitteeSize: numberOfNodes,
119
119
  initialValidators: [],
120
120
  zkPassportArgs: {
@@ -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 { BBCircuitVerifier, type ClientProtocolCircuitVerifier, TestCircuitVerifier } from '@aztec/bb-prover';
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
- this.circuitProofVerifier = await BBCircuitVerifier.new(bbConfig);
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
- return { bbSkipCleanup, bbBinaryPath, bbWorkingDirectory, cleanup, numConcurrentIVCVerifiers: 1 };
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;