@aztec/archiver 0.0.1-commit.c7c42ec → 0.0.1-commit.d1f2d6c
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +156 -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 +7 -7
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +87 -8
- 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}/bin/retrieve-calldata.js +2 -2
- 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 +35 -54
- 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 +84 -0
- package/dest/modules/data_source_base.d.ts.map +1 -0
- package/dest/modules/data_source_base.js +260 -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/store/block_store.d.ts +188 -0
- package/dest/store/block_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/block_store.js +119 -17
- 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/store/kv_archiver_store.d.ts +339 -0
- package/dest/store/kv_archiver_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/kv_archiver_store.js +185 -52
- package/dest/store/log_store.d.ts +54 -0
- package/dest/store/log_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/log_store.js +89 -54
- 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 +161 -55
- 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 +522 -0
- package/src/{archiver/config.ts → config.ts} +13 -2
- package/src/factory.ts +122 -8
- package/src/index.ts +10 -3
- package/src/interfaces.ts +9 -0
- package/src/{archiver/l1 → l1}/bin/retrieve-calldata.ts +7 -2
- package/src/{archiver/l1 → l1}/calldata_retriever.ts +3 -3
- package/src/{archiver/l1 → l1}/data_retrieval.ts +56 -73
- package/src/{archiver/l1 → l1}/validate_trace.ts +1 -1
- package/src/modules/data_source_base.ts +367 -0
- package/src/modules/data_store_updater.ts +419 -0
- package/src/{archiver → modules}/instrumentation.ts +16 -65
- 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 +170 -35
- 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 +224 -24
- package/src/{archiver/kv_archiver_store → store}/log_store.ts +145 -86
- 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 +171 -65
- 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 +0 -308
- 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 +0 -157
- 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 +0 -45
- 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}/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}/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,18 +8,17 @@ 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
|
+
CheckpointedL2Block,
|
|
11
12
|
L2Block,
|
|
12
13
|
L2BlockHash,
|
|
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
|
-
import { type BlockHeader, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
21
|
+
import { type BlockHeader, TxExecutionResult, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
23
22
|
import type { UInt64 } from '@aztec/stdlib/types';
|
|
24
23
|
|
|
25
24
|
/**
|
|
@@ -30,13 +29,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
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 L2Block.random(BlockNumber(blockNum));
|
|
39
|
+
const block = await L2Block.random(BlockNumber(blockNum), { slotNumber: SlotNumber(blockNum) });
|
|
40
40
|
this.l2Blocks.push(block);
|
|
41
41
|
}
|
|
42
42
|
|
|
@@ -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,44 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
92
96
|
return Promise.resolve(BlockNumber(this.provenBlockNumber));
|
|
93
97
|
}
|
|
94
98
|
|
|
95
|
-
public
|
|
96
|
-
|
|
97
|
-
|
|
99
|
+
public getCheckpointedL2BlockNumber() {
|
|
100
|
+
return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
public getFinalizedL2BlockNumber() {
|
|
104
|
+
return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
public getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined> {
|
|
108
|
+
if (number > this.checkpointedBlockNumber) {
|
|
109
|
+
return Promise.resolve(undefined);
|
|
110
|
+
}
|
|
111
|
+
const block = this.l2Blocks[number - 1];
|
|
112
|
+
if (!block) {
|
|
113
|
+
return Promise.resolve(undefined);
|
|
114
|
+
}
|
|
115
|
+
const checkpointedBlock = new CheckpointedL2Block(
|
|
116
|
+
CheckpointNumber.fromBlockNumber(number),
|
|
117
|
+
block,
|
|
118
|
+
new L1PublishedData(BigInt(number), BigInt(number), `0x${number.toString(16).padStart(64, '0')}`),
|
|
119
|
+
[],
|
|
120
|
+
);
|
|
121
|
+
return Promise.resolve(checkpointedBlock);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
public async getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]> {
|
|
125
|
+
const result: CheckpointedL2Block[] = [];
|
|
126
|
+
for (let i = 0; i < limit; i++) {
|
|
127
|
+
const blockNum = from + i;
|
|
128
|
+
if (blockNum > this.checkpointedBlockNumber) {
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
|
|
132
|
+
if (block) {
|
|
133
|
+
result.push(block);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
return result;
|
|
98
137
|
}
|
|
99
138
|
|
|
100
139
|
/**
|
|
@@ -102,8 +141,9 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
102
141
|
* @param number - The block number to return (inclusive).
|
|
103
142
|
* @returns The requested L2 block.
|
|
104
143
|
*/
|
|
105
|
-
public getBlock(number: number) {
|
|
106
|
-
|
|
144
|
+
public getBlock(number: number): Promise<L2Block | undefined> {
|
|
145
|
+
const block = this.l2Blocks[number - 1];
|
|
146
|
+
return Promise.resolve(block);
|
|
107
147
|
}
|
|
108
148
|
|
|
109
149
|
/**
|
|
@@ -111,9 +151,9 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
111
151
|
* @param number - The block number to return.
|
|
112
152
|
* @returns The requested L2 block.
|
|
113
153
|
*/
|
|
114
|
-
public
|
|
154
|
+
public getL2Block(number: BlockNumber): Promise<L2Block | undefined> {
|
|
115
155
|
const block = this.l2Blocks[number - 1];
|
|
116
|
-
return Promise.resolve(block
|
|
156
|
+
return Promise.resolve(block);
|
|
117
157
|
}
|
|
118
158
|
|
|
119
159
|
/**
|
|
@@ -122,40 +162,45 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
122
162
|
* @param limit - The maximum number of blocks to return.
|
|
123
163
|
* @returns The requested mocked L2 blocks.
|
|
124
164
|
*/
|
|
125
|
-
public getBlocks(from: number, limit: number
|
|
126
|
-
return Promise.resolve(
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
165
|
+
public getBlocks(from: number, limit: number): Promise<L2Block[]> {
|
|
166
|
+
return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
public getCheckpoints(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 L2Block 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
|
+
}),
|
|
130
183
|
);
|
|
131
184
|
}
|
|
132
185
|
|
|
133
|
-
public async getPublishedCheckpoints(from: CheckpointNumber, limit: number) {
|
|
134
|
-
// TODO: Implement this properly. This only works when we have one block per checkpoint.
|
|
135
|
-
return (await this.getPublishedBlocks(from, limit)).map(block => block.toPublishedCheckpoint());
|
|
136
|
-
}
|
|
137
|
-
|
|
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
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
149
|
-
attestations: [],
|
|
150
|
-
}),
|
|
151
|
-
);
|
|
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 L2Block doesn't have toCheckpoint()
|
|
193
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, { numBlocks: 1 });
|
|
194
|
+
checkpoint.blocks = [block];
|
|
195
|
+
return checkpoint;
|
|
152
196
|
}
|
|
153
197
|
|
|
154
|
-
public async
|
|
198
|
+
public async getCheckpointedBlockByHash(blockHash: Fr): Promise<CheckpointedL2Block | undefined> {
|
|
155
199
|
for (const block of this.l2Blocks) {
|
|
156
200
|
const hash = await block.hash();
|
|
157
201
|
if (hash.equals(blockHash)) {
|
|
158
|
-
return
|
|
202
|
+
return CheckpointedL2Block.fromFields({
|
|
203
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(block.number),
|
|
159
204
|
block,
|
|
160
205
|
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
161
206
|
attestations: [],
|
|
@@ -165,13 +210,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
165
210
|
return undefined;
|
|
166
211
|
}
|
|
167
212
|
|
|
168
|
-
public
|
|
213
|
+
public getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
|
|
169
214
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
170
215
|
if (!block) {
|
|
171
216
|
return Promise.resolve(undefined);
|
|
172
217
|
}
|
|
173
218
|
return Promise.resolve(
|
|
174
|
-
|
|
219
|
+
CheckpointedL2Block.fromFields({
|
|
220
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(block.number),
|
|
175
221
|
block,
|
|
176
222
|
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
177
223
|
attestations: [],
|
|
@@ -179,11 +225,26 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
179
225
|
);
|
|
180
226
|
}
|
|
181
227
|
|
|
228
|
+
public async getL2BlockByHash(blockHash: Fr): Promise<L2Block | undefined> {
|
|
229
|
+
for (const block of this.l2Blocks) {
|
|
230
|
+
const hash = await block.hash();
|
|
231
|
+
if (hash.equals(blockHash)) {
|
|
232
|
+
return block;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return undefined;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
public getL2BlockByArchive(archive: Fr): Promise<L2Block | undefined> {
|
|
239
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
240
|
+
return Promise.resolve(block);
|
|
241
|
+
}
|
|
242
|
+
|
|
182
243
|
public async getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined> {
|
|
183
244
|
for (const block of this.l2Blocks) {
|
|
184
245
|
const hash = await block.hash();
|
|
185
246
|
if (hash.equals(blockHash)) {
|
|
186
|
-
return block.
|
|
247
|
+
return block.header;
|
|
187
248
|
}
|
|
188
249
|
}
|
|
189
250
|
return undefined;
|
|
@@ -191,31 +252,58 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
191
252
|
|
|
192
253
|
public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
|
|
193
254
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
194
|
-
return Promise.resolve(block?.
|
|
255
|
+
return Promise.resolve(block?.header);
|
|
195
256
|
}
|
|
196
257
|
|
|
197
258
|
getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
|
|
198
|
-
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.
|
|
259
|
+
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
|
|
199
260
|
}
|
|
200
261
|
|
|
201
262
|
getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]> {
|
|
202
|
-
// TODO: Implement this properly. This only works when we have one block per checkpoint.
|
|
203
|
-
|
|
263
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
264
|
+
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
265
|
+
const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
|
|
266
|
+
const blocks = this.l2Blocks.filter(b => {
|
|
267
|
+
const slot = b.header.globalVariables.slotNumber;
|
|
268
|
+
return slot >= start && slot <= end;
|
|
269
|
+
});
|
|
270
|
+
// Create checkpoints from blocks - manually construct since L2Block doesn't have toCheckpoint()
|
|
271
|
+
return Promise.all(
|
|
272
|
+
blocks.map(async block => {
|
|
273
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, { numBlocks: 1 });
|
|
274
|
+
checkpoint.blocks = [block];
|
|
275
|
+
return checkpoint;
|
|
276
|
+
}),
|
|
277
|
+
);
|
|
204
278
|
}
|
|
205
279
|
|
|
206
|
-
|
|
280
|
+
getCheckpointedBlocksForEpoch(epochNumber: EpochNumber): Promise<CheckpointedL2Block[]> {
|
|
207
281
|
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
208
282
|
const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
|
|
209
283
|
const blocks = this.l2Blocks.filter(b => {
|
|
210
284
|
const slot = b.header.globalVariables.slotNumber;
|
|
211
285
|
return slot >= start && slot <= end;
|
|
212
286
|
});
|
|
287
|
+
return Promise.resolve(
|
|
288
|
+
blocks.map(block =>
|
|
289
|
+
CheckpointedL2Block.fromFields({
|
|
290
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(block.number),
|
|
291
|
+
block,
|
|
292
|
+
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
293
|
+
attestations: [],
|
|
294
|
+
}),
|
|
295
|
+
),
|
|
296
|
+
);
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
getBlocksForSlot(slotNumber: SlotNumber): Promise<L2Block[]> {
|
|
300
|
+
const blocks = this.l2Blocks.filter(b => b.header.globalVariables.slotNumber === slotNumber);
|
|
213
301
|
return Promise.resolve(blocks);
|
|
214
302
|
}
|
|
215
303
|
|
|
216
|
-
async
|
|
217
|
-
const
|
|
218
|
-
return
|
|
304
|
+
async getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
|
|
305
|
+
const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
|
|
306
|
+
return checkpointedBlocks.map(b => b.block.header);
|
|
219
307
|
}
|
|
220
308
|
|
|
221
309
|
/**
|
|
@@ -248,10 +336,12 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
248
336
|
for (const block of this.l2Blocks) {
|
|
249
337
|
for (const txEffect of block.body.txEffects) {
|
|
250
338
|
if (txEffect.txHash.equals(txHash)) {
|
|
339
|
+
// In mock, assume all txs are checkpointed with successful execution
|
|
251
340
|
return new TxReceipt(
|
|
252
341
|
txHash,
|
|
253
|
-
TxStatus.
|
|
254
|
-
|
|
342
|
+
TxStatus.CHECKPOINTED,
|
|
343
|
+
TxExecutionResult.SUCCESS,
|
|
344
|
+
undefined,
|
|
255
345
|
txEffect.transactionFee.toBigInt(),
|
|
256
346
|
L2BlockHash.fromField(await block.hash()),
|
|
257
347
|
block.number,
|
|
@@ -263,29 +353,45 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
263
353
|
}
|
|
264
354
|
|
|
265
355
|
async getL2Tips(): Promise<L2Tips> {
|
|
266
|
-
const [latest, proven, finalized] = [
|
|
356
|
+
const [latest, proven, finalized, checkpointed] = [
|
|
267
357
|
await this.getBlockNumber(),
|
|
268
358
|
await this.getProvenBlockNumber(),
|
|
269
359
|
this.finalizedBlockNumber,
|
|
360
|
+
this.checkpointedBlockNumber,
|
|
270
361
|
] as const;
|
|
271
362
|
|
|
272
363
|
const latestBlock = this.l2Blocks[latest - 1];
|
|
273
364
|
const provenBlock = this.l2Blocks[proven - 1];
|
|
274
365
|
const finalizedBlock = this.l2Blocks[finalized - 1];
|
|
366
|
+
const checkpointedBlock = this.l2Blocks[checkpointed - 1];
|
|
367
|
+
|
|
368
|
+
const latestBlockId = {
|
|
369
|
+
number: BlockNumber(latest),
|
|
370
|
+
hash: (await latestBlock?.hash())?.toString(),
|
|
371
|
+
};
|
|
372
|
+
const provenBlockId = {
|
|
373
|
+
number: BlockNumber(proven),
|
|
374
|
+
hash: (await provenBlock?.hash())?.toString(),
|
|
375
|
+
};
|
|
376
|
+
const finalizedBlockId = {
|
|
377
|
+
number: BlockNumber(finalized),
|
|
378
|
+
hash: (await finalizedBlock?.hash())?.toString(),
|
|
379
|
+
};
|
|
380
|
+
const checkpointedBlockId = {
|
|
381
|
+
number: BlockNumber(checkpointed),
|
|
382
|
+
hash: (await checkpointedBlock?.hash())?.toString(),
|
|
383
|
+
};
|
|
384
|
+
|
|
385
|
+
const makeTipId = (blockId: typeof latestBlockId) => ({
|
|
386
|
+
block: blockId,
|
|
387
|
+
checkpoint: { number: CheckpointNumber.fromBlockNumber(blockId.number), hash: blockId.hash },
|
|
388
|
+
});
|
|
275
389
|
|
|
276
390
|
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
|
-
},
|
|
391
|
+
proposed: latestBlockId,
|
|
392
|
+
checkpointed: makeTipId(checkpointedBlockId),
|
|
393
|
+
proven: makeTipId(provenBlockId),
|
|
394
|
+
finalized: makeTipId(finalizedBlockId),
|
|
289
395
|
};
|
|
290
396
|
}
|
|
291
397
|
|
|
@@ -363,7 +469,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
363
469
|
return Promise.resolve(false);
|
|
364
470
|
}
|
|
365
471
|
|
|
366
|
-
getPendingChainValidationStatus(): Promise<
|
|
472
|
+
getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
|
|
367
473
|
return Promise.resolve({ valid: true });
|
|
368
474
|
}
|
|
369
475
|
}
|
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, L2Block } 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 L2Block.random(BlockNumber(blockNumber), {
|
|
272
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(BlockNumber(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.fromBlockNumber(BlockNumber(blockNumber)),
|
|
293
|
+
);
|
|
294
|
+
return makePublishedCheckpoint(checkpoint, blockNumber);
|
|
295
|
+
}
|