@aztec/archiver 0.0.1-commit.c7c42ec → 0.0.1-commit.f295ac2
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/README.md +147 -22
- package/dest/archiver.d.ts +135 -0
- package/dest/archiver.d.ts.map +1 -0
- package/dest/archiver.js +769 -0
- package/dest/{archiver/config.d.ts → config.d.ts} +9 -1
- package/dest/config.d.ts.map +1 -0
- package/dest/{archiver/config.js → config.js} +11 -2
- package/dest/{archiver/errors.d.ts → errors.d.ts} +1 -1
- package/dest/errors.d.ts.map +1 -0
- package/dest/factory.d.ts +5 -6
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +82 -5
- package/dest/index.d.ts +10 -4
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +8 -3
- package/dest/interfaces.d.ts +9 -0
- package/dest/interfaces.d.ts.map +1 -0
- package/dest/interfaces.js +3 -0
- package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.d.ts +1 -1
- package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/calldata_retriever.d.ts +3 -3
- package/dest/l1/calldata_retriever.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/calldata_retriever.js +2 -2
- package/dest/l1/data_retrieval.d.ts +88 -0
- package/dest/l1/data_retrieval.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/data_retrieval.js +34 -53
- package/dest/{archiver/l1 → l1}/debug_tx.d.ts +1 -1
- package/dest/l1/debug_tx.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/spire_proposer.d.ts +1 -1
- package/dest/l1/spire_proposer.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/trace_tx.d.ts +1 -1
- package/dest/l1/trace_tx.d.ts.map +1 -0
- package/dest/l1/types.d.ts +12 -0
- package/dest/l1/types.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/validate_trace.d.ts +1 -1
- package/dest/l1/validate_trace.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/validate_trace.js +1 -1
- package/dest/modules/data_source_base.d.ts +85 -0
- package/dest/modules/data_source_base.d.ts.map +1 -0
- package/dest/modules/data_source_base.js +291 -0
- package/dest/modules/data_store_updater.d.ts +69 -0
- package/dest/modules/data_store_updater.d.ts.map +1 -0
- package/dest/modules/data_store_updater.js +304 -0
- package/dest/modules/instrumentation.d.ts +37 -0
- package/dest/modules/instrumentation.d.ts.map +1 -0
- package/dest/{archiver → modules}/instrumentation.js +15 -63
- package/dest/modules/l1_synchronizer.d.ts +75 -0
- package/dest/modules/l1_synchronizer.d.ts.map +1 -0
- package/dest/modules/l1_synchronizer.js +1113 -0
- package/dest/modules/validation.d.ts +17 -0
- package/dest/modules/validation.d.ts.map +1 -0
- package/dest/{archiver → modules}/validation.js +7 -1
- package/dest/{archiver/kv_archiver_store → store}/block_store.d.ts +27 -6
- package/dest/store/block_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/block_store.js +87 -14
- package/dest/store/contract_class_store.d.ts +18 -0
- package/dest/store/contract_class_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/contract_class_store.js +1 -1
- package/dest/store/contract_instance_store.d.ts +24 -0
- package/dest/store/contract_instance_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +1 -1
- package/dest/{archiver/archiver_store.d.ts → store/kv_archiver_store.d.ts} +155 -132
- package/dest/store/kv_archiver_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/kv_archiver_store.js +173 -48
- package/dest/{archiver/kv_archiver_store → store}/log_store.d.ts +1 -1
- package/dest/store/log_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/log_store.js +69 -48
- package/dest/{archiver/kv_archiver_store → store}/message_store.d.ts +1 -1
- package/dest/store/message_store.d.ts.map +1 -0
- package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
- package/dest/structs/data_retrieval.d.ts.map +1 -0
- package/dest/structs/inbox_message.d.ts +15 -0
- package/dest/structs/inbox_message.d.ts.map +1 -0
- package/dest/{archiver/structs → structs}/published.d.ts +1 -1
- package/dest/structs/published.d.ts.map +1 -0
- package/dest/test/fake_l1_state.d.ts +190 -0
- package/dest/test/fake_l1_state.d.ts.map +1 -0
- package/dest/test/fake_l1_state.js +383 -0
- package/dest/test/index.d.ts +2 -1
- package/dest/test/index.d.ts.map +1 -1
- package/dest/test/index.js +1 -0
- package/dest/test/mock_archiver.d.ts +2 -2
- package/dest/test/mock_archiver.d.ts.map +1 -1
- package/dest/test/mock_archiver.js +1 -2
- package/dest/test/mock_l1_to_l2_message_source.d.ts +2 -2
- package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/test/mock_l1_to_l2_message_source.js +12 -3
- package/dest/test/mock_l2_block_source.d.ts +21 -14
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +147 -40
- package/dest/test/mock_structs.d.ts +76 -2
- package/dest/test/mock_structs.d.ts.map +1 -1
- package/dest/test/mock_structs.js +133 -2
- package/package.json +15 -17
- package/src/archiver.ts +525 -0
- package/src/{archiver/config.ts → config.ts} +13 -2
- package/src/factory.ts +118 -6
- package/src/index.ts +10 -3
- package/src/interfaces.ts +9 -0
- package/src/{archiver/l1 → l1}/calldata_retriever.ts +3 -3
- package/src/{archiver/l1 → l1}/data_retrieval.ts +54 -71
- package/src/{archiver/l1 → l1}/validate_trace.ts +1 -1
- package/src/modules/data_source_base.ts +414 -0
- package/src/modules/data_store_updater.ts +419 -0
- package/src/{archiver → modules}/instrumentation.ts +14 -63
- package/src/modules/l1_synchronizer.ts +931 -0
- package/src/{archiver → modules}/validation.ts +11 -6
- package/src/{archiver/kv_archiver_store → store}/block_store.ts +116 -19
- package/src/{archiver/kv_archiver_store → store}/contract_class_store.ts +1 -1
- package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +1 -1
- package/src/{archiver/kv_archiver_store → store}/kv_archiver_store.ts +196 -12
- package/src/{archiver/kv_archiver_store → store}/log_store.ts +112 -76
- package/src/test/fake_l1_state.ts +599 -0
- package/src/test/index.ts +1 -0
- package/src/test/mock_archiver.ts +2 -2
- package/src/test/mock_l1_to_l2_message_source.ts +10 -4
- package/src/test/mock_l2_block_source.ts +168 -52
- package/src/test/mock_structs.ts +247 -2
- package/dest/archiver/archiver.d.ts +0 -304
- package/dest/archiver/archiver.d.ts.map +0 -1
- package/dest/archiver/archiver.js +0 -1645
- package/dest/archiver/archiver_store.d.ts.map +0 -1
- package/dest/archiver/archiver_store.js +0 -4
- package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
- package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
- package/dest/archiver/archiver_store_test_suite.js +0 -2770
- package/dest/archiver/config.d.ts.map +0 -1
- package/dest/archiver/errors.d.ts.map +0 -1
- package/dest/archiver/index.d.ts +0 -7
- package/dest/archiver/index.d.ts.map +0 -1
- package/dest/archiver/index.js +0 -4
- package/dest/archiver/instrumentation.d.ts +0 -37
- package/dest/archiver/instrumentation.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -24
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -158
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
- package/dest/archiver/l1/bin/retrieve-calldata.d.ts.map +0 -1
- package/dest/archiver/l1/calldata_retriever.d.ts.map +0 -1
- package/dest/archiver/l1/data_retrieval.d.ts +0 -90
- package/dest/archiver/l1/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/l1/debug_tx.d.ts.map +0 -1
- package/dest/archiver/l1/spire_proposer.d.ts.map +0 -1
- package/dest/archiver/l1/trace_tx.d.ts.map +0 -1
- package/dest/archiver/l1/types.d.ts +0 -12
- package/dest/archiver/l1/types.d.ts.map +0 -1
- package/dest/archiver/l1/validate_trace.d.ts.map +0 -1
- package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/structs/inbox_message.d.ts +0 -15
- package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
- package/dest/archiver/structs/published.d.ts.map +0 -1
- package/dest/archiver/validation.d.ts +0 -17
- package/dest/archiver/validation.d.ts.map +0 -1
- package/dest/rpc/index.d.ts +0 -9
- package/dest/rpc/index.d.ts.map +0 -1
- package/dest/rpc/index.js +0 -15
- package/src/archiver/archiver.ts +0 -2157
- package/src/archiver/archiver_store.ts +0 -372
- package/src/archiver/archiver_store_test_suite.ts +0 -2843
- package/src/archiver/index.ts +0 -6
- package/src/rpc/index.ts +0 -16
- /package/dest/{archiver/errors.js → errors.js} +0 -0
- /package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.js +0 -0
- /package/dest/{archiver/l1 → l1}/debug_tx.js +0 -0
- /package/dest/{archiver/l1 → l1}/spire_proposer.js +0 -0
- /package/dest/{archiver/l1 → l1}/trace_tx.js +0 -0
- /package/dest/{archiver/l1 → l1}/types.js +0 -0
- /package/dest/{archiver/kv_archiver_store → store}/message_store.js +0 -0
- /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
- /package/dest/{archiver/structs → structs}/inbox_message.js +0 -0
- /package/dest/{archiver/structs → structs}/published.js +0 -0
- /package/src/{archiver/errors.ts → errors.ts} +0 -0
- /package/src/{archiver/l1 → l1}/README.md +0 -0
- /package/src/{archiver/l1 → l1}/bin/retrieve-calldata.ts +0 -0
- /package/src/{archiver/l1 → l1}/debug_tx.ts +0 -0
- /package/src/{archiver/l1 → l1}/spire_proposer.ts +0 -0
- /package/src/{archiver/l1 → l1}/trace_tx.ts +0 -0
- /package/src/{archiver/l1 → l1}/types.ts +0 -0
- /package/src/{archiver/kv_archiver_store → store}/message_store.ts +0 -0
- /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
- /package/src/{archiver/structs → structs}/inbox_message.ts +0 -0
- /package/src/{archiver/structs → structs}/published.ts +0 -0
|
@@ -8,15 +8,14 @@ import { createLogger } from '@aztec/foundation/log';
|
|
|
8
8
|
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
9
9
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
10
10
|
import {
|
|
11
|
-
|
|
11
|
+
CheckpointedL2Block,
|
|
12
12
|
L2BlockHash,
|
|
13
13
|
L2BlockNew,
|
|
14
14
|
type L2BlockSource,
|
|
15
15
|
type L2Tips,
|
|
16
|
-
|
|
17
|
-
type ValidateBlockResult,
|
|
16
|
+
type ValidateCheckpointResult,
|
|
18
17
|
} from '@aztec/stdlib/block';
|
|
19
|
-
import {
|
|
18
|
+
import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
20
19
|
import type { ContractClassPublic, ContractDataSource, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
21
20
|
import { EmptyL1RollupConstants, type L1RollupConstants, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
|
|
22
21
|
import { type BlockHeader, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
@@ -26,24 +25,25 @@ import type { UInt64 } from '@aztec/stdlib/types';
|
|
|
26
25
|
* A mocked implementation of L2BlockSource to be used in tests.
|
|
27
26
|
*/
|
|
28
27
|
export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
29
|
-
protected l2Blocks:
|
|
28
|
+
protected l2Blocks: L2BlockNew[] = [];
|
|
30
29
|
|
|
31
30
|
private provenBlockNumber: number = 0;
|
|
32
31
|
private finalizedBlockNumber: number = 0;
|
|
32
|
+
private checkpointedBlockNumber: number = 0;
|
|
33
33
|
|
|
34
34
|
private log = createLogger('archiver:mock_l2_block_source');
|
|
35
35
|
|
|
36
36
|
public async createBlocks(numBlocks: number) {
|
|
37
37
|
for (let i = 0; i < numBlocks; i++) {
|
|
38
38
|
const blockNum = this.l2Blocks.length + 1;
|
|
39
|
-
const block = await
|
|
39
|
+
const block = await L2BlockNew.random(BlockNumber(blockNum), { slotNumber: SlotNumber(blockNum) });
|
|
40
40
|
this.l2Blocks.push(block);
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
this.log.verbose(`Created ${numBlocks} blocks in the mock L2 block source`);
|
|
44
44
|
}
|
|
45
45
|
|
|
46
|
-
public addBlocks(blocks:
|
|
46
|
+
public addBlocks(blocks: L2BlockNew[]) {
|
|
47
47
|
this.l2Blocks.push(...blocks);
|
|
48
48
|
this.log.verbose(`Added ${blocks.length} blocks to the mock L2 block source`);
|
|
49
49
|
}
|
|
@@ -64,6 +64,10 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
64
64
|
this.finalizedBlockNumber = finalizedBlockNumber;
|
|
65
65
|
}
|
|
66
66
|
|
|
67
|
+
public setCheckpointedBlockNumber(checkpointedBlockNumber: number) {
|
|
68
|
+
this.checkpointedBlockNumber = checkpointedBlockNumber;
|
|
69
|
+
}
|
|
70
|
+
|
|
67
71
|
/**
|
|
68
72
|
* Method to fetch the rollup contract address at the base-layer.
|
|
69
73
|
* @returns The rollup address.
|
|
@@ -92,9 +96,40 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
92
96
|
return Promise.resolve(BlockNumber(this.provenBlockNumber));
|
|
93
97
|
}
|
|
94
98
|
|
|
95
|
-
public getCheckpointedBlock(
|
|
96
|
-
|
|
97
|
-
|
|
99
|
+
public getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined> {
|
|
100
|
+
if (number > this.checkpointedBlockNumber) {
|
|
101
|
+
return Promise.resolve(undefined);
|
|
102
|
+
}
|
|
103
|
+
const block = this.l2Blocks[number - 1];
|
|
104
|
+
if (!block) {
|
|
105
|
+
return Promise.resolve(undefined);
|
|
106
|
+
}
|
|
107
|
+
const checkpointedBlock = new CheckpointedL2Block(
|
|
108
|
+
CheckpointNumber(number),
|
|
109
|
+
block,
|
|
110
|
+
new L1PublishedData(BigInt(number), BigInt(number), `0x${number.toString(16).padStart(64, '0')}`),
|
|
111
|
+
[],
|
|
112
|
+
);
|
|
113
|
+
return Promise.resolve(checkpointedBlock);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
public async getCheckpointedBlocks(
|
|
117
|
+
from: BlockNumber,
|
|
118
|
+
limit: number,
|
|
119
|
+
_proven?: boolean,
|
|
120
|
+
): Promise<CheckpointedL2Block[]> {
|
|
121
|
+
const result: CheckpointedL2Block[] = [];
|
|
122
|
+
for (let i = 0; i < limit; i++) {
|
|
123
|
+
const blockNum = from + i;
|
|
124
|
+
if (blockNum > this.checkpointedBlockNumber) {
|
|
125
|
+
break;
|
|
126
|
+
}
|
|
127
|
+
const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
|
|
128
|
+
if (block) {
|
|
129
|
+
result.push(block);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return result;
|
|
98
133
|
}
|
|
99
134
|
|
|
100
135
|
/**
|
|
@@ -102,8 +137,9 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
102
137
|
* @param number - The block number to return (inclusive).
|
|
103
138
|
* @returns The requested L2 block.
|
|
104
139
|
*/
|
|
105
|
-
public getBlock(number: number) {
|
|
106
|
-
|
|
140
|
+
public getBlock(number: number): Promise<L2BlockNew | undefined> {
|
|
141
|
+
const block = this.l2Blocks[number - 1];
|
|
142
|
+
return Promise.resolve(block);
|
|
107
143
|
}
|
|
108
144
|
|
|
109
145
|
/**
|
|
@@ -113,7 +149,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
113
149
|
*/
|
|
114
150
|
public getL2BlockNew(number: BlockNumber): Promise<L2BlockNew | undefined> {
|
|
115
151
|
const block = this.l2Blocks[number - 1];
|
|
116
|
-
return Promise.resolve(block
|
|
152
|
+
return Promise.resolve(block);
|
|
117
153
|
}
|
|
118
154
|
|
|
119
155
|
/**
|
|
@@ -122,7 +158,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
122
158
|
* @param limit - The maximum number of blocks to return.
|
|
123
159
|
* @returns The requested mocked L2 blocks.
|
|
124
160
|
*/
|
|
125
|
-
public getBlocks(from: number, limit: number, proven?: boolean) {
|
|
161
|
+
public getBlocks(from: number, limit: number, proven?: boolean): Promise<L2BlockNew[]> {
|
|
126
162
|
return Promise.resolve(
|
|
127
163
|
this.l2Blocks
|
|
128
164
|
.slice(from - 1, from - 1 + limit)
|
|
@@ -130,32 +166,62 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
130
166
|
);
|
|
131
167
|
}
|
|
132
168
|
|
|
133
|
-
public
|
|
134
|
-
// TODO: Implement this properly. This only works when we have one block per checkpoint.
|
|
135
|
-
|
|
169
|
+
public getPublishedCheckpoints(from: CheckpointNumber, limit: number) {
|
|
170
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
171
|
+
const blocks = this.l2Blocks.slice(from - 1, from - 1 + limit);
|
|
172
|
+
return Promise.all(
|
|
173
|
+
blocks.map(async block => {
|
|
174
|
+
// Create a checkpoint from the block - manually construct since L2BlockNew doesn't have toCheckpoint()
|
|
175
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, { numBlocks: 1 });
|
|
176
|
+
checkpoint.blocks = [block];
|
|
177
|
+
return new PublishedCheckpoint(
|
|
178
|
+
checkpoint,
|
|
179
|
+
new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
180
|
+
[],
|
|
181
|
+
);
|
|
182
|
+
}),
|
|
183
|
+
);
|
|
136
184
|
}
|
|
137
185
|
|
|
138
186
|
public async getCheckpointByArchive(archive: Fr): Promise<Checkpoint | undefined> {
|
|
139
|
-
// TODO: Implement this properly. This only works when we have one block per checkpoint.
|
|
140
|
-
|
|
187
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
188
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
189
|
+
if (!block) {
|
|
190
|
+
return undefined;
|
|
191
|
+
}
|
|
192
|
+
// Create a checkpoint from the block - manually construct since L2BlockNew doesn't have toCheckpoint()
|
|
193
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, { numBlocks: 1 });
|
|
194
|
+
checkpoint.blocks = [block];
|
|
195
|
+
return checkpoint;
|
|
141
196
|
}
|
|
142
197
|
|
|
143
|
-
public
|
|
144
|
-
const blocks =
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
198
|
+
public getPublishedBlocks(from: number, limit: number, proven?: boolean): Promise<CheckpointedL2Block[]> {
|
|
199
|
+
const blocks = this.l2Blocks
|
|
200
|
+
.slice(from - 1, from - 1 + limit)
|
|
201
|
+
.filter(b => !proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber);
|
|
202
|
+
return Promise.resolve(
|
|
203
|
+
blocks.map(block =>
|
|
204
|
+
CheckpointedL2Block.fromFields({
|
|
205
|
+
checkpointNumber: CheckpointNumber(block.number),
|
|
206
|
+
block,
|
|
207
|
+
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
208
|
+
attestations: [],
|
|
209
|
+
}),
|
|
210
|
+
),
|
|
151
211
|
);
|
|
152
212
|
}
|
|
153
213
|
|
|
154
|
-
|
|
214
|
+
getL2BlocksNew(from: BlockNumber, limit: number, proven?: boolean): Promise<L2BlockNew[]> {
|
|
215
|
+
// getBlocks already returns L2BlockNew[], so just return directly
|
|
216
|
+
return this.getBlocks(from, limit, proven);
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
public async getPublishedBlockByHash(blockHash: Fr): Promise<CheckpointedL2Block | undefined> {
|
|
155
220
|
for (const block of this.l2Blocks) {
|
|
156
221
|
const hash = await block.hash();
|
|
157
222
|
if (hash.equals(blockHash)) {
|
|
158
|
-
return
|
|
223
|
+
return CheckpointedL2Block.fromFields({
|
|
224
|
+
checkpointNumber: CheckpointNumber(block.number),
|
|
159
225
|
block,
|
|
160
226
|
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
161
227
|
attestations: [],
|
|
@@ -165,13 +231,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
165
231
|
return undefined;
|
|
166
232
|
}
|
|
167
233
|
|
|
168
|
-
public getPublishedBlockByArchive(archive: Fr): Promise<
|
|
234
|
+
public getPublishedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
|
|
169
235
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
170
236
|
if (!block) {
|
|
171
237
|
return Promise.resolve(undefined);
|
|
172
238
|
}
|
|
173
239
|
return Promise.resolve(
|
|
174
|
-
|
|
240
|
+
CheckpointedL2Block.fromFields({
|
|
241
|
+
checkpointNumber: CheckpointNumber(block.number),
|
|
175
242
|
block,
|
|
176
243
|
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
177
244
|
attestations: [],
|
|
@@ -179,11 +246,26 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
179
246
|
);
|
|
180
247
|
}
|
|
181
248
|
|
|
249
|
+
public async getL2BlockNewByHash(blockHash: Fr): Promise<L2BlockNew | undefined> {
|
|
250
|
+
for (const block of this.l2Blocks) {
|
|
251
|
+
const hash = await block.hash();
|
|
252
|
+
if (hash.equals(blockHash)) {
|
|
253
|
+
return block;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
return undefined;
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
public getL2BlockNewByArchive(archive: Fr): Promise<L2BlockNew | undefined> {
|
|
260
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
261
|
+
return Promise.resolve(block);
|
|
262
|
+
}
|
|
263
|
+
|
|
182
264
|
public async getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined> {
|
|
183
265
|
for (const block of this.l2Blocks) {
|
|
184
266
|
const hash = await block.hash();
|
|
185
267
|
if (hash.equals(blockHash)) {
|
|
186
|
-
return block.
|
|
268
|
+
return block.header;
|
|
187
269
|
}
|
|
188
270
|
}
|
|
189
271
|
return undefined;
|
|
@@ -191,19 +273,32 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
191
273
|
|
|
192
274
|
public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
|
|
193
275
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
194
|
-
return Promise.resolve(block?.
|
|
276
|
+
return Promise.resolve(block?.header);
|
|
195
277
|
}
|
|
196
278
|
|
|
197
279
|
getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
|
|
198
|
-
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.
|
|
280
|
+
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
|
|
199
281
|
}
|
|
200
282
|
|
|
201
283
|
getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]> {
|
|
202
|
-
// TODO: Implement this properly. This only works when we have one block per checkpoint.
|
|
203
|
-
|
|
284
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
285
|
+
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
286
|
+
const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
|
|
287
|
+
const blocks = this.l2Blocks.filter(b => {
|
|
288
|
+
const slot = b.header.globalVariables.slotNumber;
|
|
289
|
+
return slot >= start && slot <= end;
|
|
290
|
+
});
|
|
291
|
+
// Create checkpoints from blocks - manually construct since L2BlockNew doesn't have toCheckpoint()
|
|
292
|
+
return Promise.all(
|
|
293
|
+
blocks.map(async block => {
|
|
294
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, { numBlocks: 1 });
|
|
295
|
+
checkpoint.blocks = [block];
|
|
296
|
+
return checkpoint;
|
|
297
|
+
}),
|
|
298
|
+
);
|
|
204
299
|
}
|
|
205
300
|
|
|
206
|
-
getBlocksForEpoch(epochNumber: EpochNumber): Promise<
|
|
301
|
+
getBlocksForEpoch(epochNumber: EpochNumber): Promise<L2BlockNew[]> {
|
|
207
302
|
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
208
303
|
const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
|
|
209
304
|
const blocks = this.l2Blocks.filter(b => {
|
|
@@ -213,9 +308,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
213
308
|
return Promise.resolve(blocks);
|
|
214
309
|
}
|
|
215
310
|
|
|
311
|
+
getBlocksForSlot(slotNumber: SlotNumber): Promise<L2BlockNew[]> {
|
|
312
|
+
const blocks = this.l2Blocks.filter(b => b.header.globalVariables.slotNumber === slotNumber);
|
|
313
|
+
return Promise.resolve(blocks);
|
|
314
|
+
}
|
|
315
|
+
|
|
216
316
|
async getBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
|
|
217
317
|
const blocks = await this.getBlocksForEpoch(epochNumber);
|
|
218
|
-
return blocks.map(b => b.
|
|
318
|
+
return blocks.map(b => b.header);
|
|
219
319
|
}
|
|
220
320
|
|
|
221
321
|
/**
|
|
@@ -263,29 +363,45 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
263
363
|
}
|
|
264
364
|
|
|
265
365
|
async getL2Tips(): Promise<L2Tips> {
|
|
266
|
-
const [latest, proven, finalized] = [
|
|
366
|
+
const [latest, proven, finalized, checkpointed] = [
|
|
267
367
|
await this.getBlockNumber(),
|
|
268
368
|
await this.getProvenBlockNumber(),
|
|
269
369
|
this.finalizedBlockNumber,
|
|
370
|
+
this.checkpointedBlockNumber,
|
|
270
371
|
] as const;
|
|
271
372
|
|
|
272
373
|
const latestBlock = this.l2Blocks[latest - 1];
|
|
273
374
|
const provenBlock = this.l2Blocks[proven - 1];
|
|
274
375
|
const finalizedBlock = this.l2Blocks[finalized - 1];
|
|
376
|
+
const checkpointedBlock = this.l2Blocks[checkpointed - 1];
|
|
377
|
+
|
|
378
|
+
const latestBlockId = {
|
|
379
|
+
number: BlockNumber(latest),
|
|
380
|
+
hash: (await latestBlock?.hash())?.toString(),
|
|
381
|
+
};
|
|
382
|
+
const provenBlockId = {
|
|
383
|
+
number: BlockNumber(proven),
|
|
384
|
+
hash: (await provenBlock?.hash())?.toString(),
|
|
385
|
+
};
|
|
386
|
+
const finalizedBlockId = {
|
|
387
|
+
number: BlockNumber(finalized),
|
|
388
|
+
hash: (await finalizedBlock?.hash())?.toString(),
|
|
389
|
+
};
|
|
390
|
+
const checkpointedBlockId = {
|
|
391
|
+
number: BlockNumber(checkpointed),
|
|
392
|
+
hash: (await checkpointedBlock?.hash())?.toString(),
|
|
393
|
+
};
|
|
394
|
+
|
|
395
|
+
const makeTipId = (blockId: typeof latestBlockId) => ({
|
|
396
|
+
block: blockId,
|
|
397
|
+
checkpoint: { number: CheckpointNumber(blockId.number), hash: blockId.hash },
|
|
398
|
+
});
|
|
275
399
|
|
|
276
400
|
return {
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
proven: {
|
|
282
|
-
number: BlockNumber(proven),
|
|
283
|
-
hash: (await provenBlock?.hash())?.toString(),
|
|
284
|
-
},
|
|
285
|
-
finalized: {
|
|
286
|
-
number: BlockNumber(finalized),
|
|
287
|
-
hash: (await finalizedBlock?.hash())?.toString(),
|
|
288
|
-
},
|
|
401
|
+
proposed: latestBlockId,
|
|
402
|
+
checkpointed: makeTipId(checkpointedBlockId),
|
|
403
|
+
proven: makeTipId(provenBlockId),
|
|
404
|
+
finalized: makeTipId(finalizedBlockId),
|
|
289
405
|
};
|
|
290
406
|
}
|
|
291
407
|
|
|
@@ -363,7 +479,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
363
479
|
return Promise.resolve(false);
|
|
364
480
|
}
|
|
365
481
|
|
|
366
|
-
getPendingChainValidationStatus(): Promise<
|
|
482
|
+
getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
|
|
367
483
|
return Promise.resolve({ valid: true });
|
|
368
484
|
}
|
|
369
485
|
}
|
package/src/test/mock_structs.ts
CHANGED
|
@@ -1,10 +1,28 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {
|
|
2
|
+
MAX_NOTE_HASHES_PER_TX,
|
|
3
|
+
NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP,
|
|
4
|
+
PRIVATE_LOG_SIZE_IN_FIELDS,
|
|
5
|
+
} from '@aztec/constants';
|
|
6
|
+
import { makeTuple } from '@aztec/foundation/array';
|
|
7
|
+
import { BlockNumber, CheckpointNumber, IndexWithinCheckpoint } from '@aztec/foundation/branded-types';
|
|
2
8
|
import { Buffer16, Buffer32 } from '@aztec/foundation/buffer';
|
|
9
|
+
import { times, timesParallel } from '@aztec/foundation/collection';
|
|
3
10
|
import { randomBigInt, randomInt } from '@aztec/foundation/crypto/random';
|
|
11
|
+
import type { Secp256k1Signer } from '@aztec/foundation/crypto/secp256k1-signer';
|
|
4
12
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
13
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
14
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
15
|
+
import { CommitteeAttestation, L2BlockNew } from '@aztec/stdlib/block';
|
|
16
|
+
import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
17
|
+
import { PrivateLog, PublicLog, SiloedTag, Tag } from '@aztec/stdlib/logs';
|
|
5
18
|
import { InboxLeaf } from '@aztec/stdlib/messaging';
|
|
19
|
+
import { orderAttestations } from '@aztec/stdlib/p2p';
|
|
20
|
+
import { CheckpointHeader } from '@aztec/stdlib/rollup';
|
|
21
|
+
import { makeCheckpointAttestationFromCheckpoint } from '@aztec/stdlib/testing';
|
|
22
|
+
import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
|
|
23
|
+
import { PartialStateReference, StateReference, TxEffect } from '@aztec/stdlib/tx';
|
|
6
24
|
|
|
7
|
-
import { type InboxMessage, updateRollingHash } from '../
|
|
25
|
+
import { type InboxMessage, updateRollingHash } from '../structs/inbox_message.js';
|
|
8
26
|
|
|
9
27
|
export function makeInboxMessage(
|
|
10
28
|
previousRollingHash = Buffer16.ZERO,
|
|
@@ -48,3 +66,230 @@ export function makeInboxMessages(
|
|
|
48
66
|
|
|
49
67
|
return messages;
|
|
50
68
|
}
|
|
69
|
+
|
|
70
|
+
/** Creates inbox messages distributed across multiple blocks with proper checkpoint numbering. */
|
|
71
|
+
export function makeInboxMessagesWithFullBlocks(
|
|
72
|
+
blockCount: number,
|
|
73
|
+
opts: { initialCheckpointNumber?: CheckpointNumber } = {},
|
|
74
|
+
): InboxMessage[] {
|
|
75
|
+
const { initialCheckpointNumber = CheckpointNumber(13) } = opts;
|
|
76
|
+
return makeInboxMessages(NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP * blockCount, {
|
|
77
|
+
overrideFn: (msg, i) => {
|
|
78
|
+
const checkpointNumber = CheckpointNumber(
|
|
79
|
+
initialCheckpointNumber + Math.floor(i / NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP),
|
|
80
|
+
);
|
|
81
|
+
const index =
|
|
82
|
+
InboxLeaf.smallestIndexForCheckpoint(checkpointNumber) + BigInt(i % NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP);
|
|
83
|
+
return { ...msg, checkpointNumber, index };
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/** Creates a deterministic block hash from a block number. */
|
|
89
|
+
export function makeBlockHash(blockNumber: number): `0x${string}` {
|
|
90
|
+
return `0x${blockNumber.toString(16).padStart(64, '0')}`;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* Creates a StateReference with properly calculated noteHashTree.nextAvailableLeafIndex.
|
|
95
|
+
* This ensures LogStore's dataStartIndexForBlock calculation doesn't produce negative values.
|
|
96
|
+
*/
|
|
97
|
+
export function makeStateForBlock(blockNumber: number, txsPerBlock: number): StateReference {
|
|
98
|
+
const noteHashIndex = blockNumber * txsPerBlock * MAX_NOTE_HASHES_PER_TX;
|
|
99
|
+
return new StateReference(
|
|
100
|
+
AppendOnlyTreeSnapshot.random(),
|
|
101
|
+
new PartialStateReference(
|
|
102
|
+
new AppendOnlyTreeSnapshot(Fr.random(), noteHashIndex),
|
|
103
|
+
AppendOnlyTreeSnapshot.random(),
|
|
104
|
+
AppendOnlyTreeSnapshot.random(),
|
|
105
|
+
),
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/** Creates L1PublishedData with deterministic values based on l1BlockNumber. */
|
|
110
|
+
export function makeL1PublishedData(l1BlockNumber: number): L1PublishedData {
|
|
111
|
+
return new L1PublishedData(BigInt(l1BlockNumber), BigInt(l1BlockNumber * 1000), makeBlockHash(l1BlockNumber));
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/** Wraps a Checkpoint with L1 published data and random attestations. */
|
|
115
|
+
export function makePublishedCheckpoint(
|
|
116
|
+
checkpoint: Checkpoint,
|
|
117
|
+
l1BlockNumber: number,
|
|
118
|
+
attestationCount = 3,
|
|
119
|
+
): PublishedCheckpoint {
|
|
120
|
+
return new PublishedCheckpoint(
|
|
121
|
+
checkpoint,
|
|
122
|
+
makeL1PublishedData(l1BlockNumber),
|
|
123
|
+
times(attestationCount, CommitteeAttestation.random),
|
|
124
|
+
);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
export interface MakeChainedCheckpointsOptions {
|
|
128
|
+
/** Number of L2 blocks per checkpoint. Default: 1 */
|
|
129
|
+
blocksPerCheckpoint?: number;
|
|
130
|
+
/** Number of transactions per block. Default: 4 */
|
|
131
|
+
txsPerBlock?: number;
|
|
132
|
+
/** Starting checkpoint number. Default: CheckpointNumber(1) */
|
|
133
|
+
startCheckpointNumber?: CheckpointNumber;
|
|
134
|
+
/** Starting block number. Default: 1 */
|
|
135
|
+
startBlockNumber?: number;
|
|
136
|
+
/** Starting L1 block number. Default: 10 */
|
|
137
|
+
startL1BlockNumber?: number;
|
|
138
|
+
/** Previous archive to chain from. Default: undefined */
|
|
139
|
+
previousArchive?: AppendOnlyTreeSnapshot;
|
|
140
|
+
/** Optional function to provide per-checkpoint overrides */
|
|
141
|
+
makeCheckpointOptions?: (cpNumber: CheckpointNumber) => Partial<Parameters<typeof Checkpoint.random>[1]>;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Creates multiple checkpoints with properly chained archives.
|
|
146
|
+
* Each checkpoint's blocks have their lastArchive set to the previous block's archive,
|
|
147
|
+
* ensuring archive chain continuity for testing.
|
|
148
|
+
*/
|
|
149
|
+
export async function makeChainedCheckpoints(
|
|
150
|
+
count: number,
|
|
151
|
+
options: MakeChainedCheckpointsOptions = {},
|
|
152
|
+
): Promise<PublishedCheckpoint[]> {
|
|
153
|
+
const {
|
|
154
|
+
blocksPerCheckpoint = 1,
|
|
155
|
+
txsPerBlock = 4,
|
|
156
|
+
startCheckpointNumber = CheckpointNumber(1),
|
|
157
|
+
startBlockNumber = 1,
|
|
158
|
+
startL1BlockNumber = 10,
|
|
159
|
+
makeCheckpointOptions,
|
|
160
|
+
} = options;
|
|
161
|
+
|
|
162
|
+
let previousArchive = options.previousArchive;
|
|
163
|
+
const checkpoints: PublishedCheckpoint[] = [];
|
|
164
|
+
|
|
165
|
+
for (let i = 0; i < count; i++) {
|
|
166
|
+
const cpNumber = CheckpointNumber(startCheckpointNumber + i);
|
|
167
|
+
const blockStart = startBlockNumber + i * blocksPerCheckpoint;
|
|
168
|
+
const customOptions = makeCheckpointOptions?.(cpNumber) ?? {};
|
|
169
|
+
|
|
170
|
+
const checkpoint = await Checkpoint.random(cpNumber, {
|
|
171
|
+
numBlocks: blocksPerCheckpoint,
|
|
172
|
+
startBlockNumber: blockStart,
|
|
173
|
+
previousArchive,
|
|
174
|
+
txsPerBlock,
|
|
175
|
+
state: makeStateForBlock(blockStart, txsPerBlock),
|
|
176
|
+
txOptions: { numPublicCallsPerTx: 2, numPublicLogsPerCall: 2 },
|
|
177
|
+
...customOptions,
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
previousArchive = checkpoint.blocks.at(-1)!.archive;
|
|
181
|
+
checkpoints.push(makePublishedCheckpoint(checkpoint, startL1BlockNumber + i * 10));
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
return checkpoints;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
/**
|
|
188
|
+
* Creates a PublishedCheckpoint with attestations signed by the provided signers.
|
|
189
|
+
* Useful for testing attestation validation.
|
|
190
|
+
*/
|
|
191
|
+
export function makeSignedPublishedCheckpoint(
|
|
192
|
+
checkpoint: Checkpoint,
|
|
193
|
+
signers: Secp256k1Signer[],
|
|
194
|
+
committee: EthAddress[],
|
|
195
|
+
l1BlockNumber = 1,
|
|
196
|
+
): PublishedCheckpoint {
|
|
197
|
+
const attestations = signers.map(signer => makeCheckpointAttestationFromCheckpoint(checkpoint, signer));
|
|
198
|
+
const committeeAttestations = orderAttestations(attestations, committee);
|
|
199
|
+
return new PublishedCheckpoint(checkpoint, makeL1PublishedData(l1BlockNumber), committeeAttestations);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
/** Creates a deterministic SiloedTag for private log testing. */
|
|
203
|
+
export function makePrivateLogTag(blockNumber: number, txIndex: number, logIndex: number): SiloedTag {
|
|
204
|
+
return new SiloedTag(
|
|
205
|
+
blockNumber === 1 && txIndex === 0 && logIndex === 0
|
|
206
|
+
? Fr.ZERO
|
|
207
|
+
: new Fr(blockNumber * 100 + txIndex * 10 + logIndex),
|
|
208
|
+
);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
/** Creates a PrivateLog with fields derived from the tag. */
|
|
212
|
+
export function makePrivateLog(tag: SiloedTag): PrivateLog {
|
|
213
|
+
return PrivateLog.from({
|
|
214
|
+
fields: makeTuple(PRIVATE_LOG_SIZE_IN_FIELDS, i => (!i ? tag.value : new Fr(tag.value.toBigInt() + BigInt(i)))),
|
|
215
|
+
emittedLength: PRIVATE_LOG_SIZE_IN_FIELDS,
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
/** Creates multiple private logs for a transaction. */
|
|
220
|
+
export function mockPrivateLogs(blockNumber: number, txIndex: number, numLogsPerTx: number): PrivateLog[] {
|
|
221
|
+
return times(numLogsPerTx, logIndex => {
|
|
222
|
+
const tag = makePrivateLogTag(blockNumber, txIndex, logIndex);
|
|
223
|
+
return makePrivateLog(tag);
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
/** Creates a deterministic Tag for public log testing. */
|
|
228
|
+
export function makePublicLogTag(blockNumber: number, txIndex: number, logIndex: number): Tag {
|
|
229
|
+
return new Tag(
|
|
230
|
+
blockNumber === 1 && txIndex === 0 && logIndex === 0
|
|
231
|
+
? Fr.ZERO
|
|
232
|
+
: new Fr((blockNumber * 100 + txIndex * 10 + logIndex) * 123),
|
|
233
|
+
);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
/** Creates a PublicLog with fields derived from the tag. */
|
|
237
|
+
export function makePublicLog(tag: Tag, contractAddress: AztecAddress = AztecAddress.fromNumber(543254)): PublicLog {
|
|
238
|
+
return PublicLog.from({
|
|
239
|
+
contractAddress,
|
|
240
|
+
fields: new Array(10).fill(null).map((_, i) => (!i ? tag.value : new Fr(tag.value.toBigInt() + BigInt(i)))),
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
/** Creates multiple public logs for a transaction. */
|
|
245
|
+
export function makePublicLogs(
|
|
246
|
+
blockNumber: number,
|
|
247
|
+
txIndex: number,
|
|
248
|
+
numLogsPerTx: number,
|
|
249
|
+
contractAddress: AztecAddress = AztecAddress.fromNumber(543254),
|
|
250
|
+
): PublicLog[] {
|
|
251
|
+
return times(numLogsPerTx, logIndex => {
|
|
252
|
+
const tag = makePublicLogTag(blockNumber, txIndex, logIndex);
|
|
253
|
+
return makePublicLog(tag, contractAddress);
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
export interface MockCheckpointWithLogsOptions {
|
|
258
|
+
previousArchive?: AppendOnlyTreeSnapshot;
|
|
259
|
+
numTxsPerBlock?: number;
|
|
260
|
+
privateLogs?: { numLogsPerTx: number };
|
|
261
|
+
publicLogs?: { numLogsPerTx: number; contractAddress?: AztecAddress };
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
/** Creates a checkpoint with specified logs on each tx effect. */
|
|
265
|
+
export async function makeCheckpointWithLogs(
|
|
266
|
+
blockNumber: number,
|
|
267
|
+
options: MockCheckpointWithLogsOptions = {},
|
|
268
|
+
): Promise<PublishedCheckpoint> {
|
|
269
|
+
const { previousArchive, numTxsPerBlock = 4, privateLogs, publicLogs } = options;
|
|
270
|
+
|
|
271
|
+
const block = await L2BlockNew.random(BlockNumber(blockNumber), {
|
|
272
|
+
checkpointNumber: CheckpointNumber(blockNumber),
|
|
273
|
+
indexWithinCheckpoint: IndexWithinCheckpoint(0),
|
|
274
|
+
state: makeStateForBlock(blockNumber, numTxsPerBlock),
|
|
275
|
+
...(previousArchive ? { lastArchive: previousArchive } : {}),
|
|
276
|
+
});
|
|
277
|
+
block.header.globalVariables.blockNumber = BlockNumber(blockNumber);
|
|
278
|
+
|
|
279
|
+
block.body.txEffects = await timesParallel(numTxsPerBlock, async (txIndex: number) => {
|
|
280
|
+
const txEffect = await TxEffect.random();
|
|
281
|
+
txEffect.privateLogs = privateLogs ? mockPrivateLogs(blockNumber, txIndex, privateLogs.numLogsPerTx) : [];
|
|
282
|
+
txEffect.publicLogs = publicLogs
|
|
283
|
+
? makePublicLogs(blockNumber, txIndex, publicLogs.numLogsPerTx, publicLogs.contractAddress)
|
|
284
|
+
: [];
|
|
285
|
+
return txEffect;
|
|
286
|
+
});
|
|
287
|
+
|
|
288
|
+
const checkpoint = new Checkpoint(
|
|
289
|
+
AppendOnlyTreeSnapshot.random(),
|
|
290
|
+
CheckpointHeader.random(),
|
|
291
|
+
[block],
|
|
292
|
+
CheckpointNumber(blockNumber),
|
|
293
|
+
);
|
|
294
|
+
return makePublishedCheckpoint(checkpoint, blockNumber);
|
|
295
|
+
}
|