@aztec/archiver 0.0.1-commit.5daedc8 → 0.0.1-commit.6201a7b05

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (218) hide show
  1. package/README.md +162 -22
  2. package/dest/archiver.d.ts +147 -0
  3. package/dest/archiver.d.ts.map +1 -0
  4. package/dest/archiver.js +788 -0
  5. package/dest/config.d.ts +32 -0
  6. package/dest/config.d.ts.map +1 -0
  7. package/dest/config.js +83 -0
  8. package/dest/errors.d.ts +92 -0
  9. package/dest/errors.d.ts.map +1 -0
  10. package/dest/errors.js +136 -0
  11. package/dest/factory.d.ts +8 -7
  12. package/dest/factory.d.ts.map +1 -1
  13. package/dest/factory.js +100 -15
  14. package/dest/index.d.ts +12 -4
  15. package/dest/index.d.ts.map +1 -1
  16. package/dest/index.js +10 -3
  17. package/dest/interfaces.d.ts +9 -0
  18. package/dest/interfaces.d.ts.map +1 -0
  19. package/dest/interfaces.js +3 -0
  20. package/dest/l1/bin/retrieve-calldata.d.ts +3 -0
  21. package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
  22. package/dest/l1/bin/retrieve-calldata.js +152 -0
  23. package/dest/l1/calldata_retriever.d.ts +136 -0
  24. package/dest/l1/calldata_retriever.d.ts.map +1 -0
  25. package/dest/l1/calldata_retriever.js +408 -0
  26. package/dest/l1/data_retrieval.d.ts +97 -0
  27. package/dest/l1/data_retrieval.d.ts.map +1 -0
  28. package/dest/{archiver → l1}/data_retrieval.js +86 -165
  29. package/dest/l1/debug_tx.d.ts +19 -0
  30. package/dest/l1/debug_tx.d.ts.map +1 -0
  31. package/dest/l1/debug_tx.js +73 -0
  32. package/dest/l1/spire_proposer.d.ts +70 -0
  33. package/dest/l1/spire_proposer.d.ts.map +1 -0
  34. package/dest/l1/spire_proposer.js +149 -0
  35. package/dest/l1/trace_tx.d.ts +97 -0
  36. package/dest/l1/trace_tx.d.ts.map +1 -0
  37. package/dest/l1/trace_tx.js +91 -0
  38. package/dest/l1/types.d.ts +12 -0
  39. package/dest/l1/types.d.ts.map +1 -0
  40. package/dest/l1/types.js +3 -0
  41. package/dest/l1/validate_historical_logs.d.ts +23 -0
  42. package/dest/l1/validate_historical_logs.d.ts.map +1 -0
  43. package/dest/l1/validate_historical_logs.js +108 -0
  44. package/dest/l1/validate_trace.d.ts +32 -0
  45. package/dest/l1/validate_trace.d.ts.map +1 -0
  46. package/dest/l1/validate_trace.js +154 -0
  47. package/dest/modules/data_source_base.d.ts +95 -0
  48. package/dest/modules/data_source_base.d.ts.map +1 -0
  49. package/dest/modules/data_source_base.js +234 -0
  50. package/dest/modules/data_store_updater.d.ts +93 -0
  51. package/dest/modules/data_store_updater.d.ts.map +1 -0
  52. package/dest/modules/data_store_updater.js +345 -0
  53. package/dest/modules/instrumentation.d.ts +55 -0
  54. package/dest/modules/instrumentation.d.ts.map +1 -0
  55. package/dest/modules/instrumentation.js +143 -0
  56. package/dest/modules/l1_synchronizer.d.ts +77 -0
  57. package/dest/modules/l1_synchronizer.d.ts.map +1 -0
  58. package/dest/modules/l1_synchronizer.js +1265 -0
  59. package/dest/modules/validation.d.ts +18 -0
  60. package/dest/modules/validation.d.ts.map +1 -0
  61. package/dest/{archiver → modules}/validation.js +13 -7
  62. package/dest/store/block_store.d.ts +262 -0
  63. package/dest/store/block_store.d.ts.map +1 -0
  64. package/dest/store/block_store.js +1048 -0
  65. package/dest/store/contract_class_store.d.ts +17 -0
  66. package/dest/store/contract_class_store.d.ts.map +1 -0
  67. package/dest/store/contract_class_store.js +64 -0
  68. package/dest/store/contract_instance_store.d.ts +24 -0
  69. package/dest/store/contract_instance_store.d.ts.map +1 -0
  70. package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +7 -3
  71. package/dest/store/kv_archiver_store.d.ts +401 -0
  72. package/dest/store/kv_archiver_store.d.ts.map +1 -0
  73. package/dest/store/kv_archiver_store.js +525 -0
  74. package/dest/store/l2_tips_cache.d.ts +20 -0
  75. package/dest/store/l2_tips_cache.d.ts.map +1 -0
  76. package/dest/store/l2_tips_cache.js +109 -0
  77. package/dest/store/log_store.d.ts +57 -0
  78. package/dest/store/log_store.d.ts.map +1 -0
  79. package/dest/store/log_store.js +531 -0
  80. package/dest/store/message_store.d.ts +44 -0
  81. package/dest/store/message_store.d.ts.map +1 -0
  82. package/dest/{archiver/kv_archiver_store → store}/message_store.js +36 -23
  83. package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
  84. package/dest/structs/data_retrieval.d.ts.map +1 -0
  85. package/dest/structs/inbox_message.d.ts +15 -0
  86. package/dest/structs/inbox_message.d.ts.map +1 -0
  87. package/dest/{archiver/structs → structs}/inbox_message.js +6 -5
  88. package/dest/structs/published.d.ts +2 -0
  89. package/dest/structs/published.d.ts.map +1 -0
  90. package/dest/test/fake_l1_state.d.ts +214 -0
  91. package/dest/test/fake_l1_state.d.ts.map +1 -0
  92. package/dest/test/fake_l1_state.js +517 -0
  93. package/dest/test/index.d.ts +2 -1
  94. package/dest/test/index.d.ts.map +1 -1
  95. package/dest/test/index.js +4 -1
  96. package/dest/test/mock_archiver.d.ts +16 -8
  97. package/dest/test/mock_archiver.d.ts.map +1 -1
  98. package/dest/test/mock_archiver.js +19 -14
  99. package/dest/test/mock_l1_to_l2_message_source.d.ts +7 -6
  100. package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
  101. package/dest/test/mock_l1_to_l2_message_source.js +23 -12
  102. package/dest/test/mock_l2_block_source.d.ts +68 -20
  103. package/dest/test/mock_l2_block_source.d.ts.map +1 -1
  104. package/dest/test/mock_l2_block_source.js +298 -85
  105. package/dest/test/mock_structs.d.ts +83 -4
  106. package/dest/test/mock_structs.d.ts.map +1 -1
  107. package/dest/test/mock_structs.js +157 -11
  108. package/dest/test/noop_l1_archiver.d.ts +26 -0
  109. package/dest/test/noop_l1_archiver.d.ts.map +1 -0
  110. package/dest/test/noop_l1_archiver.js +74 -0
  111. package/package.json +20 -20
  112. package/src/archiver.ts +566 -0
  113. package/src/{archiver/config.ts → config.ts} +51 -14
  114. package/src/errors.ts +213 -0
  115. package/src/factory.ts +155 -17
  116. package/src/index.ts +12 -3
  117. package/src/interfaces.ts +9 -0
  118. package/src/l1/README.md +55 -0
  119. package/src/l1/bin/retrieve-calldata.ts +194 -0
  120. package/src/l1/calldata_retriever.ts +523 -0
  121. package/src/{archiver → l1}/data_retrieval.ts +155 -247
  122. package/src/l1/debug_tx.ts +99 -0
  123. package/src/l1/spire_proposer.ts +152 -0
  124. package/src/l1/trace_tx.ts +128 -0
  125. package/src/l1/types.ts +13 -0
  126. package/src/l1/validate_historical_logs.ts +140 -0
  127. package/src/l1/validate_trace.ts +229 -0
  128. package/src/modules/data_source_base.ts +364 -0
  129. package/src/modules/data_store_updater.ts +465 -0
  130. package/src/modules/instrumentation.ts +204 -0
  131. package/src/modules/l1_synchronizer.ts +1126 -0
  132. package/src/{archiver → modules}/validation.ts +21 -15
  133. package/src/store/block_store.ts +1361 -0
  134. package/src/store/contract_class_store.ts +82 -0
  135. package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +10 -7
  136. package/src/store/kv_archiver_store.ts +765 -0
  137. package/src/store/l2_tips_cache.ts +134 -0
  138. package/src/store/log_store.ts +733 -0
  139. package/src/{archiver/kv_archiver_store → store}/message_store.ts +48 -28
  140. package/src/{archiver/structs → structs}/inbox_message.ts +7 -7
  141. package/src/{archiver/structs → structs}/published.ts +0 -1
  142. package/src/test/fake_l1_state.ts +770 -0
  143. package/src/test/fixtures/debug_traceTransaction-multicall3.json +88 -0
  144. package/src/test/fixtures/debug_traceTransaction-multiplePropose.json +153 -0
  145. package/src/test/fixtures/debug_traceTransaction-proxied.json +122 -0
  146. package/src/test/fixtures/trace_transaction-multicall3.json +65 -0
  147. package/src/test/fixtures/trace_transaction-multiplePropose.json +319 -0
  148. package/src/test/fixtures/trace_transaction-proxied.json +128 -0
  149. package/src/test/fixtures/trace_transaction-randomRevert.json +216 -0
  150. package/src/test/index.ts +4 -0
  151. package/src/test/mock_archiver.ts +23 -16
  152. package/src/test/mock_l1_to_l2_message_source.ts +19 -11
  153. package/src/test/mock_l2_block_source.ts +367 -93
  154. package/src/test/mock_structs.ts +289 -13
  155. package/src/test/noop_l1_archiver.ts +117 -0
  156. package/dest/archiver/archiver.d.ts +0 -287
  157. package/dest/archiver/archiver.d.ts.map +0 -1
  158. package/dest/archiver/archiver.js +0 -1408
  159. package/dest/archiver/archiver_store.d.ts +0 -255
  160. package/dest/archiver/archiver_store.d.ts.map +0 -1
  161. package/dest/archiver/archiver_store.js +0 -4
  162. package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
  163. package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
  164. package/dest/archiver/archiver_store_test_suite.js +0 -1289
  165. package/dest/archiver/config.d.ts +0 -21
  166. package/dest/archiver/config.d.ts.map +0 -1
  167. package/dest/archiver/config.js +0 -55
  168. package/dest/archiver/data_retrieval.d.ts +0 -79
  169. package/dest/archiver/data_retrieval.d.ts.map +0 -1
  170. package/dest/archiver/errors.d.ts +0 -12
  171. package/dest/archiver/errors.d.ts.map +0 -1
  172. package/dest/archiver/errors.js +0 -17
  173. package/dest/archiver/index.d.ts +0 -7
  174. package/dest/archiver/index.d.ts.map +0 -1
  175. package/dest/archiver/index.js +0 -4
  176. package/dest/archiver/instrumentation.d.ts +0 -35
  177. package/dest/archiver/instrumentation.d.ts.map +0 -1
  178. package/dest/archiver/instrumentation.js +0 -140
  179. package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -124
  180. package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
  181. package/dest/archiver/kv_archiver_store/block_store.js +0 -370
  182. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
  183. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
  184. package/dest/archiver/kv_archiver_store/contract_class_store.js +0 -120
  185. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -24
  186. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
  187. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -168
  188. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
  189. package/dest/archiver/kv_archiver_store/kv_archiver_store.js +0 -296
  190. package/dest/archiver/kv_archiver_store/log_store.d.ts +0 -49
  191. package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
  192. package/dest/archiver/kv_archiver_store/log_store.js +0 -336
  193. package/dest/archiver/kv_archiver_store/message_store.d.ts +0 -39
  194. package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
  195. package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
  196. package/dest/archiver/structs/inbox_message.d.ts +0 -15
  197. package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
  198. package/dest/archiver/structs/published.d.ts +0 -3
  199. package/dest/archiver/structs/published.d.ts.map +0 -1
  200. package/dest/archiver/validation.d.ts +0 -17
  201. package/dest/archiver/validation.d.ts.map +0 -1
  202. package/dest/rpc/index.d.ts +0 -9
  203. package/dest/rpc/index.d.ts.map +0 -1
  204. package/dest/rpc/index.js +0 -15
  205. package/src/archiver/archiver.ts +0 -1858
  206. package/src/archiver/archiver_store.ts +0 -305
  207. package/src/archiver/archiver_store_test_suite.ts +0 -1264
  208. package/src/archiver/errors.ts +0 -26
  209. package/src/archiver/index.ts +0 -6
  210. package/src/archiver/instrumentation.ts +0 -187
  211. package/src/archiver/kv_archiver_store/block_store.ts +0 -481
  212. package/src/archiver/kv_archiver_store/contract_class_store.ts +0 -176
  213. package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -422
  214. package/src/archiver/kv_archiver_store/log_store.ts +0 -406
  215. package/src/rpc/index.ts +0 -16
  216. /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
  217. /package/dest/{archiver/structs → structs}/published.js +0 -0
  218. /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
@@ -1,33 +1,65 @@
1
1
  import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
2
- import { DefaultL1ContractsConfig } from '@aztec/ethereum';
2
+ import { DefaultL1ContractsConfig } from '@aztec/ethereum/config';
3
+ import { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
3
4
  import { Buffer32 } from '@aztec/foundation/buffer';
5
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
6
  import { EthAddress } from '@aztec/foundation/eth-address';
5
- import { Fr } from '@aztec/foundation/fields';
6
7
  import { createLogger } from '@aztec/foundation/log';
7
- import { L2Block, L2BlockHash, PublishedL2Block } from '@aztec/stdlib/block';
8
- import { EmptyL1RollupConstants, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
9
- import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
8
+ import { CheckpointedL2Block } from '@aztec/stdlib/block';
9
+ import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
10
+ import { EmptyL1RollupConstants, getEpochAtSlot, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
11
+ import { computeCheckpointOutHash } from '@aztec/stdlib/messaging';
12
+ import { CheckpointHeader } from '@aztec/stdlib/rollup';
13
+ import { TxExecutionResult, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
10
14
  /**
11
15
  * A mocked implementation of L2BlockSource to be used in tests.
12
16
  */ export class MockL2BlockSource {
13
17
  l2Blocks = [];
18
+ checkpointList = [];
14
19
  provenBlockNumber = 0;
15
20
  finalizedBlockNumber = 0;
21
+ checkpointedBlockNumber = 0;
22
+ proposedCheckpointBlockNumber = 0;
16
23
  log = createLogger('archiver:mock_l2_block_source');
17
- async createBlocks(numBlocks) {
18
- for(let i = 0; i < numBlocks; i++){
19
- const blockNum = this.l2Blocks.length + 1;
20
- const block = await L2Block.random(blockNum);
21
- this.l2Blocks.push(block);
24
+ /** Creates blocks grouped into single-block checkpoints. */ async createBlocks(numBlocks) {
25
+ await this.createCheckpoints(numBlocks, 1);
26
+ }
27
+ getCheckpointNumber() {
28
+ return Promise.resolve(this.checkpointList.length === 0 ? CheckpointNumber.ZERO : CheckpointNumber(this.checkpointList.length));
29
+ }
30
+ /** Creates checkpoints, each containing `blocksPerCheckpoint` blocks. */ async createCheckpoints(numCheckpoints, blocksPerCheckpoint = 1) {
31
+ for(let c = 0; c < numCheckpoints; c++){
32
+ const checkpointNum = CheckpointNumber(this.checkpointList.length + 1);
33
+ const startBlockNum = this.l2Blocks.length + 1;
34
+ const slotNumber = SlotNumber(Number(checkpointNum));
35
+ const checkpoint = await Checkpoint.random(checkpointNum, {
36
+ numBlocks: blocksPerCheckpoint,
37
+ startBlockNumber: startBlockNum,
38
+ slotNumber,
39
+ checkpointNumber: checkpointNum
40
+ });
41
+ this.checkpointList.push(checkpoint);
42
+ this.l2Blocks.push(...checkpoint.blocks);
22
43
  }
23
- this.log.verbose(`Created ${numBlocks} blocks in the mock L2 block source`);
44
+ this.log.verbose(`Created ${numCheckpoints} checkpoints with ${blocksPerCheckpoint} blocks each in the mock L2 block source`);
24
45
  }
25
- addBlocks(blocks) {
46
+ addProposedBlocks(blocks) {
26
47
  this.l2Blocks.push(...blocks);
27
- this.log.verbose(`Added ${blocks.length} blocks to the mock L2 block source`);
48
+ this.log.verbose(`Added ${blocks.length} proposed blocks to the mock L2 block source`);
28
49
  }
29
50
  removeBlocks(numBlocks) {
30
51
  this.l2Blocks = this.l2Blocks.slice(0, -numBlocks);
52
+ const maxBlockNum = this.l2Blocks.length;
53
+ // Remove any checkpoint whose last block is beyond the remaining blocks.
54
+ this.checkpointList = this.checkpointList.filter((c)=>{
55
+ const lastBlockNum = c.blocks[0].number + c.blocks.length - 1;
56
+ return lastBlockNum <= maxBlockNum;
57
+ });
58
+ // Keep tip numbers consistent with remaining blocks.
59
+ this.checkpointedBlockNumber = Math.min(this.checkpointedBlockNumber, maxBlockNum);
60
+ this.proposedCheckpointBlockNumber = Math.min(this.proposedCheckpointBlockNumber, maxBlockNum);
61
+ this.provenBlockNumber = Math.min(this.provenBlockNumber, maxBlockNum);
62
+ this.finalizedBlockNumber = Math.min(this.finalizedBlockNumber, maxBlockNum);
31
63
  this.log.verbose(`Removed ${numBlocks} blocks from the mock L2 block source`);
32
64
  }
33
65
  setProvenBlockNumber(provenBlockNumber) {
@@ -39,6 +71,41 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
39
71
  }
40
72
  this.finalizedBlockNumber = finalizedBlockNumber;
41
73
  }
74
+ setProposedCheckpointBlockNumber(blockNumber) {
75
+ this.proposedCheckpointBlockNumber = blockNumber;
76
+ }
77
+ setCheckpointedBlockNumber(checkpointedBlockNumber) {
78
+ const prevCheckpointed = this.checkpointedBlockNumber;
79
+ this.checkpointedBlockNumber = checkpointedBlockNumber;
80
+ // Proposed checkpoint is always at least as advanced as checkpointed
81
+ if (this.proposedCheckpointBlockNumber < checkpointedBlockNumber) {
82
+ this.proposedCheckpointBlockNumber = checkpointedBlockNumber;
83
+ }
84
+ // Auto-create single-block checkpoints for newly checkpointed blocks that don't have one yet.
85
+ // This handles blocks added via addProposedBlocks that are now being marked as checkpointed.
86
+ const newCheckpoints = [];
87
+ for(let blockNum = prevCheckpointed + 1; blockNum <= checkpointedBlockNumber; blockNum++){
88
+ const block = this.l2Blocks[blockNum - 1];
89
+ if (!block) {
90
+ continue;
91
+ }
92
+ if (this.checkpointList.some((c)=>c.blocks.some((b)=>b.number === block.number))) {
93
+ continue;
94
+ }
95
+ const checkpointNum = CheckpointNumber(this.checkpointList.length + newCheckpoints.length + 1);
96
+ const checkpoint = new Checkpoint(block.archive, CheckpointHeader.random({
97
+ slotNumber: block.header.globalVariables.slotNumber
98
+ }), [
99
+ block
100
+ ], checkpointNum);
101
+ newCheckpoints.push(checkpoint);
102
+ }
103
+ // Insert new checkpoints in order by number.
104
+ if (newCheckpoints.length > 0) {
105
+ this.checkpointList.push(...newCheckpoints);
106
+ this.checkpointList.sort((a, b)=>a.number - b.number);
107
+ }
108
+ }
42
109
  /**
43
110
  * Method to fetch the rollup contract address at the base-layer.
44
111
  * @returns The rollup address.
@@ -55,100 +122,196 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
55
122
  * Gets the number of the latest L2 block processed by the block source implementation.
56
123
  * @returns In this mock instance, returns the number of L2 blocks that we've mocked.
57
124
  */ getBlockNumber() {
58
- return Promise.resolve(this.l2Blocks.length);
125
+ return Promise.resolve(BlockNumber(this.l2Blocks.length));
59
126
  }
60
127
  getProvenBlockNumber() {
61
- return Promise.resolve(this.provenBlockNumber);
128
+ return Promise.resolve(BlockNumber(this.provenBlockNumber));
129
+ }
130
+ getCheckpointedL2BlockNumber() {
131
+ return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
132
+ }
133
+ getFinalizedL2BlockNumber() {
134
+ return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
135
+ }
136
+ getProposedCheckpointL2BlockNumber() {
137
+ return Promise.resolve(BlockNumber(this.proposedCheckpointBlockNumber));
138
+ }
139
+ getCheckpointedBlock(number) {
140
+ if (number > this.checkpointedBlockNumber) {
141
+ return Promise.resolve(undefined);
142
+ }
143
+ const block = this.l2Blocks[number - 1];
144
+ if (!block) {
145
+ return Promise.resolve(undefined);
146
+ }
147
+ return Promise.resolve(this.toCheckpointedBlock(block));
148
+ }
149
+ async getCheckpointedBlocks(from, limit) {
150
+ const result = [];
151
+ for(let i = 0; i < limit; i++){
152
+ const blockNum = from + i;
153
+ if (blockNum > this.checkpointedBlockNumber) {
154
+ break;
155
+ }
156
+ const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
157
+ if (block) {
158
+ result.push(block);
159
+ }
160
+ }
161
+ return result;
62
162
  }
63
163
  /**
64
164
  * Gets an l2 block.
65
165
  * @param number - The block number to return (inclusive).
66
166
  * @returns The requested L2 block.
67
167
  */ getBlock(number) {
68
- return Promise.resolve(this.l2Blocks[number - 1]);
168
+ const block = this.l2Blocks[number - 1];
169
+ return Promise.resolve(block);
170
+ }
171
+ /**
172
+ * Gets an L2 block (new format).
173
+ * @param number - The block number to return.
174
+ * @returns The requested L2 block.
175
+ */ getL2Block(number) {
176
+ const block = this.l2Blocks[number - 1];
177
+ return Promise.resolve(block);
69
178
  }
70
179
  /**
71
180
  * Gets up to `limit` amount of L2 blocks starting from `from`.
72
181
  * @param from - Number of the first block to return (inclusive).
73
182
  * @param limit - The maximum number of blocks to return.
74
183
  * @returns The requested mocked L2 blocks.
75
- */ getBlocks(from, limit, proven) {
76
- return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit).filter((b)=>!proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber));
77
- }
78
- async getPublishedBlocks(from, limit, proven) {
79
- const blocks = await this.getBlocks(from, limit, proven);
80
- return blocks.map((block)=>PublishedL2Block.fromFields({
81
- block,
82
- l1: {
83
- blockNumber: BigInt(block.number),
84
- blockHash: Buffer32.random().toString(),
85
- timestamp: BigInt(block.number)
86
- },
87
- attestations: []
88
- }));
89
- }
90
- async getPublishedBlockByHash(blockHash) {
184
+ */ getBlocks(from, limit) {
185
+ return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
186
+ }
187
+ getCheckpoints(from, limit) {
188
+ const checkpoints = this.checkpointList.slice(from - 1, from - 1 + limit);
189
+ return Promise.resolve(checkpoints.map((checkpoint)=>new PublishedCheckpoint(checkpoint, this.mockL1DataForCheckpoint(checkpoint), [])));
190
+ }
191
+ getCheckpointByArchive(archive) {
192
+ const checkpoint = this.checkpointList.find((c)=>c.archive.root.equals(archive));
193
+ return Promise.resolve(checkpoint);
194
+ }
195
+ async getCheckpointedBlockByHash(blockHash) {
91
196
  for (const block of this.l2Blocks){
92
197
  const hash = await block.hash();
93
198
  if (hash.equals(blockHash)) {
94
- return PublishedL2Block.fromFields({
95
- block,
96
- l1: {
97
- blockNumber: BigInt(block.number),
98
- blockHash: Buffer32.random().toString(),
99
- timestamp: BigInt(block.number)
100
- },
101
- attestations: []
102
- });
199
+ return this.toCheckpointedBlock(block);
103
200
  }
104
201
  }
105
202
  return undefined;
106
203
  }
107
- getPublishedBlockByArchive(archive) {
204
+ getCheckpointedBlockByArchive(archive) {
108
205
  const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
109
206
  if (!block) {
110
207
  return Promise.resolve(undefined);
111
208
  }
112
- return Promise.resolve(PublishedL2Block.fromFields({
113
- block,
114
- l1: {
115
- blockNumber: BigInt(block.number),
116
- blockHash: Buffer32.random().toString(),
117
- timestamp: BigInt(block.number)
118
- },
119
- attestations: []
120
- }));
209
+ return Promise.resolve(this.toCheckpointedBlock(block));
210
+ }
211
+ async getL2BlockByHash(blockHash) {
212
+ for (const block of this.l2Blocks){
213
+ const hash = await block.hash();
214
+ if (hash.equals(blockHash)) {
215
+ return block;
216
+ }
217
+ }
218
+ return undefined;
219
+ }
220
+ getL2BlockByArchive(archive) {
221
+ const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
222
+ return Promise.resolve(block);
121
223
  }
122
224
  async getBlockHeaderByHash(blockHash) {
123
225
  for (const block of this.l2Blocks){
124
226
  const hash = await block.hash();
125
227
  if (hash.equals(blockHash)) {
126
- return block.getBlockHeader();
228
+ return block.header;
127
229
  }
128
230
  }
129
231
  return undefined;
130
232
  }
131
233
  getBlockHeaderByArchive(archive) {
132
234
  const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
133
- return Promise.resolve(block?.getBlockHeader());
235
+ return Promise.resolve(block?.header);
134
236
  }
135
- getBlockHeader(number) {
136
- return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.getBlockHeader());
237
+ async getBlockData(number) {
238
+ const block = this.l2Blocks[number - 1];
239
+ if (!block) {
240
+ return undefined;
241
+ }
242
+ return {
243
+ header: block.header,
244
+ archive: block.archive,
245
+ blockHash: await block.hash(),
246
+ checkpointNumber: block.checkpointNumber,
247
+ indexWithinCheckpoint: block.indexWithinCheckpoint
248
+ };
137
249
  }
138
- getBlocksForEpoch(epochNumber) {
139
- const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
140
- const [start, end] = getSlotRangeForEpoch(epochNumber, {
141
- epochDuration
142
- });
143
- const blocks = this.l2Blocks.filter((b)=>{
144
- const slot = b.header.globalVariables.slotNumber;
145
- return slot >= start && slot <= end;
146
- });
250
+ getCheckpointData(_n) {
251
+ return Promise.resolve(undefined);
252
+ }
253
+ getCheckpointDataRange(_from, _limit) {
254
+ return Promise.resolve([]);
255
+ }
256
+ getCheckpointNumberBySlot(_slot) {
257
+ return Promise.resolve(undefined);
258
+ }
259
+ async getBlockDataWithCheckpointContext(number) {
260
+ const data = await this.getBlockData(number);
261
+ if (!data) {
262
+ return undefined;
263
+ }
264
+ return {
265
+ data,
266
+ checkpoint: undefined,
267
+ l1: undefined,
268
+ attestations: []
269
+ };
270
+ }
271
+ async getBlockDataByArchive(archive) {
272
+ const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
273
+ if (!block) {
274
+ return undefined;
275
+ }
276
+ return {
277
+ header: block.header,
278
+ archive: block.archive,
279
+ blockHash: await block.hash(),
280
+ checkpointNumber: block.checkpointNumber,
281
+ indexWithinCheckpoint: block.indexWithinCheckpoint
282
+ };
283
+ }
284
+ getBlockHeader(number) {
285
+ return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
286
+ }
287
+ getCheckpointsForEpoch(epochNumber) {
288
+ return Promise.resolve(this.getCheckpointsInEpoch(epochNumber));
289
+ }
290
+ getCheckpointsDataForEpoch(epochNumber) {
291
+ const checkpoints = this.getCheckpointsInEpoch(epochNumber);
292
+ return Promise.resolve(checkpoints.map((checkpoint)=>({
293
+ checkpointNumber: checkpoint.number,
294
+ header: checkpoint.header,
295
+ archive: checkpoint.archive,
296
+ checkpointOutHash: computeCheckpointOutHash(checkpoint.blocks.map((b)=>b.body.txEffects.map((tx)=>tx.l2ToL1Msgs))),
297
+ startBlock: checkpoint.blocks[0].number,
298
+ blockCount: checkpoint.blocks.length,
299
+ feeAssetPriceModifier: checkpoint.feeAssetPriceModifier,
300
+ attestations: [],
301
+ l1: this.mockL1DataForCheckpoint(checkpoint)
302
+ })));
303
+ }
304
+ getCheckpointedBlocksForEpoch(epochNumber) {
305
+ const checkpoints = this.getCheckpointsInEpoch(epochNumber);
306
+ return Promise.resolve(checkpoints.flatMap((checkpoint)=>checkpoint.blocks.map((block)=>this.toCheckpointedBlock(block))));
307
+ }
308
+ getBlocksForSlot(slotNumber) {
309
+ const blocks = this.l2Blocks.filter((b)=>b.header.globalVariables.slotNumber === slotNumber);
147
310
  return Promise.resolve(blocks);
148
311
  }
149
- async getBlockHeadersForEpoch(epochNumber) {
150
- const blocks = await this.getBlocksForEpoch(epochNumber);
151
- return blocks.map((b)=>b.getBlockHeader());
312
+ async getCheckpointedBlockHeadersForEpoch(epochNumber) {
313
+ const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
314
+ return checkpointedBlocks.map((b)=>b.block.header);
152
315
  }
153
316
  /**
154
317
  * Gets a tx effect.
@@ -166,7 +329,7 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
166
329
  return {
167
330
  data: txEffect,
168
331
  l2BlockNumber: block.number,
169
- l2BlockHash: L2BlockHash.fromField(await block.hash()),
332
+ l2BlockHash: await block.hash(),
170
333
  txIndexInBlock: block.body.txEffects.indexOf(txEffect)
171
334
  };
172
335
  }
@@ -178,40 +341,65 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
178
341
  for (const block of this.l2Blocks){
179
342
  for (const txEffect of block.body.txEffects){
180
343
  if (txEffect.txHash.equals(txHash)) {
181
- return new TxReceipt(txHash, TxStatus.SUCCESS, '', txEffect.transactionFee.toBigInt(), L2BlockHash.fromField(await block.hash()), block.number);
344
+ // In mock, assume all txs are checkpointed with successful execution
345
+ return new TxReceipt(txHash, TxStatus.CHECKPOINTED, TxExecutionResult.SUCCESS, undefined, txEffect.transactionFee.toBigInt(), await block.hash(), block.number, getEpochAtSlot(block.slot, EmptyL1RollupConstants));
182
346
  }
183
347
  }
184
348
  }
185
349
  return undefined;
186
350
  }
187
351
  async getL2Tips() {
188
- const [latest, proven, finalized] = [
352
+ const [latest, proven, finalized, checkpointed, proposedCheckpoint] = [
189
353
  await this.getBlockNumber(),
190
354
  await this.getProvenBlockNumber(),
191
- this.finalizedBlockNumber
355
+ this.finalizedBlockNumber,
356
+ this.checkpointedBlockNumber,
357
+ await this.getProposedCheckpointL2BlockNumber()
192
358
  ];
193
359
  const latestBlock = this.l2Blocks[latest - 1];
194
360
  const provenBlock = this.l2Blocks[proven - 1];
195
361
  const finalizedBlock = this.l2Blocks[finalized - 1];
362
+ const checkpointedBlock = this.l2Blocks[checkpointed - 1];
363
+ const proposedCheckpointBlock = this.l2Blocks[proposedCheckpoint - 1];
364
+ const latestBlockId = {
365
+ number: BlockNumber(latest),
366
+ hash: (await latestBlock?.hash())?.toString()
367
+ };
368
+ const provenBlockId = {
369
+ number: BlockNumber(proven),
370
+ hash: (await provenBlock?.hash())?.toString()
371
+ };
372
+ const finalizedBlockId = {
373
+ number: BlockNumber(finalized),
374
+ hash: (await finalizedBlock?.hash())?.toString()
375
+ };
376
+ const checkpointedBlockId = {
377
+ number: BlockNumber(checkpointed),
378
+ hash: (await checkpointedBlock?.hash())?.toString()
379
+ };
380
+ const proposedCheckpointBlockId = {
381
+ number: BlockNumber(proposedCheckpoint),
382
+ hash: (await proposedCheckpointBlock?.hash())?.toString()
383
+ };
384
+ const makeTipId = (blockId)=>({
385
+ block: blockId,
386
+ checkpoint: {
387
+ number: this.findCheckpointNumberForBlock(blockId.number) ?? CheckpointNumber(0),
388
+ hash: blockId.hash
389
+ }
390
+ });
196
391
  return {
197
- latest: {
198
- number: latest,
199
- hash: (await latestBlock?.hash())?.toString()
200
- },
201
- proven: {
202
- number: proven,
203
- hash: (await provenBlock?.hash())?.toString()
204
- },
205
- finalized: {
206
- number: finalized,
207
- hash: (await finalizedBlock?.hash())?.toString()
208
- }
392
+ proposed: latestBlockId,
393
+ checkpointed: makeTipId(checkpointedBlockId),
394
+ proven: makeTipId(provenBlockId),
395
+ finalized: makeTipId(finalizedBlockId),
396
+ proposedCheckpoint: makeTipId(proposedCheckpointBlockId)
209
397
  };
210
398
  }
211
- getL2EpochNumber() {
399
+ getSyncedL2EpochNumber() {
212
400
  throw new Error('Method not implemented.');
213
401
  }
214
- getL2SlotNumber() {
402
+ getSyncedL2SlotNumber() {
215
403
  throw new Error('Method not implemented.');
216
404
  }
217
405
  isEpochComplete(_epochNumber) {
@@ -271,4 +459,29 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
271
459
  valid: true
272
460
  });
273
461
  }
462
+ getLastCheckpoint() {
463
+ return Promise.resolve(undefined);
464
+ }
465
+ getLastProposedCheckpoint() {
466
+ return Promise.resolve(undefined);
467
+ }
468
+ /** Returns checkpoints whose slot falls within the given epoch. */ getCheckpointsInEpoch(epochNumber) {
469
+ const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
470
+ const [start, end] = getSlotRangeForEpoch(epochNumber, {
471
+ epochDuration
472
+ });
473
+ return this.checkpointList.filter((c)=>c.header.slotNumber >= start && c.header.slotNumber <= end);
474
+ }
475
+ /** Creates a mock L1PublishedData for a checkpoint. */ mockL1DataForCheckpoint(checkpoint) {
476
+ return new L1PublishedData(BigInt(checkpoint.number), BigInt(checkpoint.number), Buffer32.random().toString());
477
+ }
478
+ /** Creates a CheckpointedL2Block from a block using stored checkpoint info. */ toCheckpointedBlock(block) {
479
+ const checkpoint = this.checkpointList.find((c)=>c.blocks.some((b)=>b.number === block.number));
480
+ const checkpointNumber = checkpoint?.number ?? block.checkpointNumber;
481
+ return new CheckpointedL2Block(checkpointNumber, block, new L1PublishedData(BigInt(block.number), BigInt(block.number), `0x${block.number.toString(16).padStart(64, '0')}`), []);
482
+ }
483
+ /** Finds the checkpoint number for a block, or undefined if the block is not in any checkpoint. */ findCheckpointNumberForBlock(blockNumber) {
484
+ const checkpoint = this.checkpointList.find((c)=>c.blocks.some((b)=>b.number === blockNumber));
485
+ return checkpoint?.number;
486
+ }
274
487
  }
@@ -1,9 +1,88 @@
1
+ import { CheckpointNumber } from '@aztec/foundation/branded-types';
1
2
  import { Buffer16 } from '@aztec/foundation/buffer';
2
- import { type InboxMessage } from '../archiver/structs/inbox_message.js';
3
+ import type { Secp256k1Signer } from '@aztec/foundation/crypto/secp256k1-signer';
4
+ import { EthAddress } from '@aztec/foundation/eth-address';
5
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
6
+ import { L2Block } from '@aztec/stdlib/block';
7
+ import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
8
+ import { PrivateLog, PublicLog, SiloedTag, Tag } from '@aztec/stdlib/logs';
9
+ import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
10
+ import { StateReference } from '@aztec/stdlib/tx';
11
+ import { type InboxMessage } from '../structs/inbox_message.js';
3
12
  export declare function makeInboxMessage(previousRollingHash?: Buffer16, overrides?: Partial<InboxMessage>): InboxMessage;
4
- export declare function makeInboxMessages(count: number, opts?: {
13
+ export declare function makeInboxMessages(totalCount: number, opts?: {
5
14
  initialHash?: Buffer16;
6
- initialL2BlockNumber?: number;
15
+ initialCheckpointNumber?: CheckpointNumber;
16
+ messagesPerCheckpoint?: number;
7
17
  overrideFn?: (msg: InboxMessage, index: number) => InboxMessage;
8
18
  }): InboxMessage[];
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ja19zdHJ1Y3RzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC9tb2NrX3N0cnVjdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBWSxNQUFNLDBCQUEwQixDQUFDO0FBSzlELE9BQU8sRUFBRSxLQUFLLFlBQVksRUFBcUIsTUFBTSxzQ0FBc0MsQ0FBQztBQUU1Rix3QkFBZ0IsZ0JBQWdCLENBQzlCLG1CQUFtQixXQUFnQixFQUNuQyxTQUFTLEdBQUUsT0FBTyxDQUFDLFlBQVksQ0FBTSxHQUNwQyxZQUFZLENBZ0JkO0FBRUQsd0JBQWdCLGlCQUFpQixDQUMvQixLQUFLLEVBQUUsTUFBTSxFQUNiLElBQUksR0FBRTtJQUNKLFdBQVcsQ0FBQyxFQUFFLFFBQVEsQ0FBQztJQUN2QixvQkFBb0IsQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUM5QixVQUFVLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sS0FBSyxZQUFZLENBQUM7Q0FDNUQsR0FDTCxZQUFZLEVBQUUsQ0FhaEIifQ==
19
+ /** Creates inbox messages distributed across multiple blocks with proper checkpoint numbering. */
20
+ export declare function makeInboxMessagesWithFullBlocks(blockCount: number, opts?: {
21
+ initialCheckpointNumber?: CheckpointNumber;
22
+ }): InboxMessage[];
23
+ /** Creates a deterministic block hash from a block number. */
24
+ export declare function makeBlockHash(blockNumber: number): `0x${string}`;
25
+ /**
26
+ * Creates a StateReference with properly calculated noteHashTree.nextAvailableLeafIndex.
27
+ * This ensures LogStore's dataStartIndexForBlock calculation doesn't produce negative values.
28
+ */
29
+ export declare function makeStateForBlock(blockNumber: number, txsPerBlock: number): StateReference;
30
+ /** Creates L1PublishedData with deterministic values based on l1BlockNumber. */
31
+ export declare function makeL1PublishedData(l1BlockNumber: number): L1PublishedData;
32
+ /** Creates a Checkpoint from a list of blocks with a header that matches the blocks' structure. */
33
+ export declare function makeCheckpoint(blocks: L2Block[], checkpointNumber?: CheckpointNumber): Checkpoint;
34
+ /** Wraps a Checkpoint with L1 published data and random attestations. */
35
+ export declare function makePublishedCheckpoint(checkpoint: Checkpoint, l1BlockNumber: number, attestationCount?: number): PublishedCheckpoint;
36
+ export interface MakeChainedCheckpointsOptions {
37
+ /** Number of L2 blocks per checkpoint. Default: 1 */
38
+ blocksPerCheckpoint?: number;
39
+ /** Number of transactions per block. Default: 4 */
40
+ txsPerBlock?: number;
41
+ /** Starting checkpoint number. Default: CheckpointNumber(1) */
42
+ startCheckpointNumber?: CheckpointNumber;
43
+ /** Starting block number. Default: 1 */
44
+ startBlockNumber?: number;
45
+ /** Starting L1 block number. Default: 10 */
46
+ startL1BlockNumber?: number;
47
+ /** Previous archive to chain from. Default: undefined */
48
+ previousArchive?: AppendOnlyTreeSnapshot;
49
+ /** Optional function to provide per-checkpoint overrides */
50
+ makeCheckpointOptions?: (cpNumber: CheckpointNumber) => Partial<Parameters<typeof Checkpoint.random>[1]>;
51
+ }
52
+ /**
53
+ * Creates multiple checkpoints with properly chained archives.
54
+ * Each checkpoint's blocks have their lastArchive set to the previous block's archive,
55
+ * ensuring archive chain continuity for testing.
56
+ */
57
+ export declare function makeChainedCheckpoints(count: number, options?: MakeChainedCheckpointsOptions): Promise<PublishedCheckpoint[]>;
58
+ /**
59
+ * Creates a PublishedCheckpoint with attestations signed by the provided signers.
60
+ * Useful for testing attestation validation.
61
+ */
62
+ export declare function makeSignedPublishedCheckpoint(checkpoint: Checkpoint, signers: Secp256k1Signer[], committee: EthAddress[], l1BlockNumber?: number): PublishedCheckpoint;
63
+ /** Creates a deterministic SiloedTag for private log testing. */
64
+ export declare function makePrivateLogTag(blockNumber: number, txIndex: number, logIndex: number): SiloedTag;
65
+ /** Creates a PrivateLog with fields derived from the tag. */
66
+ export declare function makePrivateLog(tag: SiloedTag): PrivateLog;
67
+ /** Creates multiple private logs for a transaction. */
68
+ export declare function mockPrivateLogs(blockNumber: number, txIndex: number, numLogsPerTx: number): PrivateLog[];
69
+ /** Creates a deterministic Tag for public log testing. */
70
+ export declare function makePublicLogTag(blockNumber: number, txIndex: number, logIndex: number): Tag;
71
+ /** Creates a PublicLog with fields derived from the tag. */
72
+ export declare function makePublicLog(tag: Tag, contractAddress?: AztecAddress): PublicLog;
73
+ /** Creates multiple public logs for a transaction. */
74
+ export declare function makePublicLogs(blockNumber: number, txIndex: number, numLogsPerTx: number, contractAddress?: AztecAddress): PublicLog[];
75
+ export interface MockCheckpointWithLogsOptions {
76
+ previousArchive?: AppendOnlyTreeSnapshot;
77
+ numTxsPerBlock?: number;
78
+ privateLogs?: {
79
+ numLogsPerTx: number;
80
+ };
81
+ publicLogs?: {
82
+ numLogsPerTx: number;
83
+ contractAddress?: AztecAddress;
84
+ };
85
+ }
86
+ /** Creates a checkpoint with specified logs on each tx effect. */
87
+ export declare function makeCheckpointWithLogs(blockNumber: number, options?: MockCheckpointWithLogsOptions): Promise<PublishedCheckpoint>;
88
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ja19zdHJ1Y3RzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC9tb2NrX3N0cnVjdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUEsT0FBTyxFQUFlLGdCQUFnQixFQUF5QixNQUFNLGlDQUFpQyxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSxRQUFRLEVBQVksTUFBTSwwQkFBMEIsQ0FBQztBQUc5RCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUVqRixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzNELE9BQU8sRUFBd0IsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM1RixPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsR0FBRyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFLM0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDN0QsT0FBTyxFQUF5QixjQUFjLEVBQVksTUFBTSxrQkFBa0IsQ0FBQztBQUVuRixPQUFPLEVBQUUsS0FBSyxZQUFZLEVBQXFCLE1BQU0sNkJBQTZCLENBQUM7QUFFbkYsd0JBQWdCLGdCQUFnQixDQUM5QixtQkFBbUIsV0FBZ0IsRUFDbkMsU0FBUyxHQUFFLE9BQU8sQ0FBQyxZQUFZLENBQU0sR0FDcEMsWUFBWSxDQWdCZDtBQUVELHdCQUFnQixpQkFBaUIsQ0FDL0IsVUFBVSxFQUFFLE1BQU0sRUFDbEIsSUFBSSxHQUFFO0lBQ0osV0FBVyxDQUFDLEVBQUUsUUFBUSxDQUFDO0lBQ3ZCLHVCQUF1QixDQUFDLEVBQUUsZ0JBQWdCLENBQUM7SUFDM0MscUJBQXFCLENBQUMsRUFB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
@@ -1 +1 @@
1
- {"version":3,"file":"mock_structs.d.ts","sourceRoot":"","sources":["../../src/test/mock_structs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAY,MAAM,0BAA0B,CAAC;AAK9D,OAAO,EAAE,KAAK,YAAY,EAAqB,MAAM,sCAAsC,CAAC;AAE5F,wBAAgB,gBAAgB,CAC9B,mBAAmB,WAAgB,EACnC,SAAS,GAAE,OAAO,CAAC,YAAY,CAAM,GACpC,YAAY,CAgBd;AAED,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,MAAM,EACb,IAAI,GAAE;IACJ,WAAW,CAAC,EAAE,QAAQ,CAAC;IACvB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,KAAK,YAAY,CAAC;CAC5D,GACL,YAAY,EAAE,CAahB"}
1
+ {"version":3,"file":"mock_structs.d.ts","sourceRoot":"","sources":["../../src/test/mock_structs.ts"],"names":[],"mappings":"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"}