@aztec/p2p 3.0.3 → 3.9.9-nightly.20260312

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 (552) hide show
  1. package/dest/bootstrap/bootstrap.d.ts +4 -3
  2. package/dest/bootstrap/bootstrap.d.ts.map +1 -1
  3. package/dest/bootstrap/bootstrap.js +4 -4
  4. package/dest/client/factory.d.ts +10 -10
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +50 -19
  7. package/dest/client/interface.d.ts +61 -35
  8. package/dest/client/interface.d.ts.map +1 -1
  9. package/dest/client/p2p_client.d.ts +47 -60
  10. package/dest/client/p2p_client.d.ts.map +1 -1
  11. package/dest/client/p2p_client.js +602 -333
  12. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  13. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  14. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +304 -0
  15. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  18. package/dest/config.d.ts +60 -17
  19. package/dest/config.d.ts.map +1 -1
  20. package/dest/config.js +104 -44
  21. package/dest/errors/tx-pool.error.d.ts +8 -0
  22. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  23. package/dest/errors/tx-pool.error.js +9 -0
  24. package/dest/index.d.ts +2 -1
  25. package/dest/index.d.ts.map +1 -1
  26. package/dest/index.js +1 -0
  27. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +111 -76
  28. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  29. package/dest/mem_pools/attestation_pool/attestation_pool.js +441 -3
  30. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  31. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +527 -287
  33. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  34. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  35. package/dest/mem_pools/attestation_pool/index.js +1 -2
  36. package/dest/mem_pools/attestation_pool/mocks.d.ts +9 -6
  37. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  38. package/dest/mem_pools/attestation_pool/mocks.js +16 -12
  39. package/dest/mem_pools/index.d.ts +3 -2
  40. package/dest/mem_pools/index.d.ts.map +1 -1
  41. package/dest/mem_pools/index.js +1 -1
  42. package/dest/mem_pools/instrumentation.d.ts +7 -1
  43. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  44. package/dest/mem_pools/instrumentation.js +31 -13
  45. package/dest/mem_pools/interface.d.ts +6 -7
  46. package/dest/mem_pools/interface.d.ts.map +1 -1
  47. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +35 -26
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  49. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +313 -334
  50. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
  51. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
  52. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
  53. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
  54. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
  55. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -0
  56. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  57. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  58. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
  59. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +17 -0
  60. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  61. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
  62. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
  63. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  64. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
  65. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
  66. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  67. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
  68. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  69. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  70. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  71. package/dest/mem_pools/tx_pool/index.d.ts +1 -2
  72. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
  73. package/dest/mem_pools/tx_pool/index.js +0 -1
  74. package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
  75. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  76. package/dest/mem_pools/tx_pool/priority.js +8 -3
  77. package/dest/mem_pools/tx_pool/tx_pool.d.ts +8 -4
  78. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
  79. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  80. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  81. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +28 -21
  82. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  83. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  84. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  85. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  86. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  87. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  88. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  89. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  90. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  91. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +93 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +180 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  105. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  106. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  107. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  108. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  109. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  110. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  111. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  112. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  113. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  114. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  115. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  116. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  117. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +75 -0
  118. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  119. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  120. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  121. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  122. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  123. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  124. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  125. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  126. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  127. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +211 -0
  128. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  129. package/dest/mem_pools/tx_pool_v2/interfaces.js +9 -0
  130. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +128 -0
  131. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  132. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +210 -0
  133. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  134. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  135. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  136. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  137. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  138. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +354 -0
  139. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +60 -0
  140. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  141. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +161 -0
  142. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +77 -0
  143. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  144. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +899 -0
  145. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +4 -4
  146. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  147. package/dest/msg_validators/attestation_validator/attestation_validator.js +51 -18
  148. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +7 -7
  149. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  150. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +22 -13
  151. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  152. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  153. package/dest/msg_validators/clock_tolerance.js +37 -0
  154. package/dest/msg_validators/index.d.ts +2 -2
  155. package/dest/msg_validators/index.d.ts.map +1 -1
  156. package/dest/msg_validators/index.js +1 -1
  157. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +11 -0
  158. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  159. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +14 -0
  160. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +11 -0
  161. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  162. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +20 -0
  163. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  164. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  165. package/dest/msg_validators/proposal_validator/index.js +3 -0
  166. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +18 -0
  167. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  168. package/dest/msg_validators/proposal_validator/proposal_validator.js +116 -0
  169. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  170. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  171. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  172. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  173. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  174. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  175. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  176. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  177. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  178. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  179. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  180. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  181. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  182. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  183. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  184. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  185. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  186. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  187. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  188. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  189. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  190. package/dest/msg_validators/tx_validator/factory.d.ts +129 -5
  191. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  192. package/dest/msg_validators/tx_validator/factory.js +235 -57
  193. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  194. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  195. package/dest/msg_validators/tx_validator/fee_payer_balance.js +24 -0
  196. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  197. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  198. package/dest/msg_validators/tx_validator/gas_validator.js +114 -52
  199. package/dest/msg_validators/tx_validator/index.d.ts +4 -1
  200. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  201. package/dest/msg_validators/tx_validator/index.js +3 -0
  202. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  203. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  204. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  205. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  206. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  207. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  208. package/dest/msg_validators/tx_validator/phases_validator.d.ts +4 -3
  209. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  210. package/dest/msg_validators/tx_validator/phases_validator.js +47 -26
  211. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  212. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  213. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  214. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  215. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  216. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  217. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  218. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  219. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  220. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  221. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  222. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  223. package/dest/services/data_store.d.ts +1 -1
  224. package/dest/services/data_store.d.ts.map +1 -1
  225. package/dest/services/data_store.js +10 -6
  226. package/dest/services/discv5/discV5_service.js +1 -1
  227. package/dest/services/dummy_service.d.ts +28 -4
  228. package/dest/services/dummy_service.d.ts.map +1 -1
  229. package/dest/services/dummy_service.js +49 -1
  230. package/dest/services/encoding.d.ts +3 -3
  231. package/dest/services/encoding.d.ts.map +1 -1
  232. package/dest/services/encoding.js +16 -14
  233. package/dest/services/gossipsub/index.d.ts +3 -0
  234. package/dest/services/gossipsub/index.d.ts.map +1 -0
  235. package/dest/services/gossipsub/index.js +2 -0
  236. package/dest/services/gossipsub/scoring.d.ts +21 -3
  237. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  238. package/dest/services/gossipsub/scoring.js +24 -7
  239. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  240. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  241. package/dest/services/gossipsub/topic_score_params.js +346 -0
  242. package/dest/services/index.d.ts +2 -1
  243. package/dest/services/index.d.ts.map +1 -1
  244. package/dest/services/index.js +1 -0
  245. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  246. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  247. package/dest/services/libp2p/instrumentation.js +30 -72
  248. package/dest/services/libp2p/libp2p_service.d.ts +117 -42
  249. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  250. package/dest/services/libp2p/libp2p_service.js +1038 -381
  251. package/dest/services/peer-manager/metrics.d.ts +7 -2
  252. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  253. package/dest/services/peer-manager/metrics.js +33 -21
  254. package/dest/services/peer-manager/peer_manager.d.ts +2 -2
  255. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  256. package/dest/services/peer-manager/peer_manager.js +2 -10
  257. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  258. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  259. package/dest/services/peer-manager/peer_scoring.js +32 -6
  260. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +48 -0
  261. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  262. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +562 -0
  263. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  264. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  265. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  266. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +46 -0
  267. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  268. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  269. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +34 -0
  270. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  271. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +130 -0
  272. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
  273. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  274. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
  275. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  276. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  277. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  278. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  279. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  280. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  281. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  282. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  283. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  284. package/dest/services/reqresp/constants.d.ts +12 -0
  285. package/dest/services/reqresp/constants.d.ts.map +1 -0
  286. package/dest/services/reqresp/constants.js +7 -0
  287. package/dest/services/reqresp/interface.d.ts +12 -1
  288. package/dest/services/reqresp/interface.d.ts.map +1 -1
  289. package/dest/services/reqresp/interface.js +15 -1
  290. package/dest/services/reqresp/metrics.d.ts +6 -5
  291. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  292. package/dest/services/reqresp/metrics.js +17 -21
  293. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  294. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  295. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  296. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  297. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  298. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  299. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  300. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  301. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  302. package/dest/services/reqresp/protocols/status.d.ts +1 -1
  303. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  304. package/dest/services/reqresp/protocols/status.js +4 -1
  305. package/dest/services/reqresp/protocols/tx.d.ts +8 -3
  306. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  307. package/dest/services/reqresp/protocols/tx.js +20 -0
  308. package/dest/services/reqresp/reqresp.d.ts +6 -1
  309. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  310. package/dest/services/reqresp/reqresp.js +471 -50
  311. package/dest/services/service.d.ts +56 -4
  312. package/dest/services/service.d.ts.map +1 -1
  313. package/dest/services/tx_collection/config.d.ts +22 -1
  314. package/dest/services/tx_collection/config.d.ts.map +1 -1
  315. package/dest/services/tx_collection/config.js +55 -1
  316. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -4
  317. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  318. package/dest/services/tx_collection/fast_tx_collection.js +71 -44
  319. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  320. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  321. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  322. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  323. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  324. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  325. package/dest/services/tx_collection/index.d.ts +3 -1
  326. package/dest/services/tx_collection/index.d.ts.map +1 -1
  327. package/dest/services/tx_collection/index.js +2 -0
  328. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  329. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  330. package/dest/services/tx_collection/instrumentation.js +11 -13
  331. package/dest/services/tx_collection/missing_txs_tracker.d.ts +32 -0
  332. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +1 -0
  333. package/dest/services/tx_collection/missing_txs_tracker.js +27 -0
  334. package/dest/services/tx_collection/proposal_tx_collector.d.ts +49 -0
  335. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  336. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  337. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -5
  338. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  339. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  340. package/dest/services/tx_collection/tx_collection.d.ts +29 -16
  341. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  342. package/dest/services/tx_collection/tx_collection.js +79 -7
  343. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  344. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  345. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  346. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  347. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  348. package/dest/services/tx_collection/tx_source.js +19 -2
  349. package/dest/services/tx_file_store/config.d.ts +16 -0
  350. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  351. package/dest/services/tx_file_store/config.js +22 -0
  352. package/dest/services/tx_file_store/index.d.ts +4 -0
  353. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  354. package/dest/services/tx_file_store/index.js +3 -0
  355. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  356. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  357. package/dest/services/tx_file_store/instrumentation.js +29 -0
  358. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  359. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  360. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  361. package/dest/services/tx_provider.d.ts +7 -6
  362. package/dest/services/tx_provider.d.ts.map +1 -1
  363. package/dest/services/tx_provider.js +20 -10
  364. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  365. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  366. package/dest/services/tx_provider_instrumentation.js +14 -14
  367. package/dest/test-helpers/index.d.ts +3 -1
  368. package/dest/test-helpers/index.d.ts.map +1 -1
  369. package/dest/test-helpers/index.js +2 -0
  370. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  371. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  372. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  373. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  374. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  375. package/dest/test-helpers/mock-pubsub.js +105 -4
  376. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  377. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  378. package/dest/test-helpers/reqresp-nodes.js +4 -3
  379. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  380. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  381. package/dest/test-helpers/test_tx_provider.js +41 -0
  382. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  383. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  384. package/dest/test-helpers/testbench-utils.js +367 -0
  385. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  386. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  387. package/dest/testbench/p2p_client_testbench_worker.js +226 -130
  388. package/dest/testbench/worker_client_manager.d.ts +53 -6
  389. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  390. package/dest/testbench/worker_client_manager.js +230 -40
  391. package/dest/util.d.ts +2 -2
  392. package/dest/util.d.ts.map +1 -1
  393. package/package.json +16 -16
  394. package/src/bootstrap/bootstrap.ts +7 -4
  395. package/src/client/factory.ts +91 -43
  396. package/src/client/interface.ts +73 -36
  397. package/src/client/p2p_client.ts +259 -390
  398. package/src/client/test/tx_proposal_collector/README.md +227 -0
  399. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +345 -0
  400. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  401. package/src/config.ts +161 -50
  402. package/src/errors/tx-pool.error.ts +12 -0
  403. package/src/index.ts +1 -0
  404. package/src/mem_pools/attestation_pool/attestation_pool.ts +510 -78
  405. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +612 -320
  406. package/src/mem_pools/attestation_pool/index.ts +9 -2
  407. package/src/mem_pools/attestation_pool/mocks.ts +20 -13
  408. package/src/mem_pools/index.ts +4 -1
  409. package/src/mem_pools/instrumentation.ts +39 -14
  410. package/src/mem_pools/interface.ts +5 -7
  411. package/src/mem_pools/tx_pool/README.md +270 -0
  412. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +361 -366
  413. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
  414. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
  415. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
  416. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  417. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
  418. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  419. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  420. package/src/mem_pools/tx_pool/index.ts +0 -1
  421. package/src/mem_pools/tx_pool/priority.ts +10 -3
  422. package/src/mem_pools/tx_pool/tx_pool.ts +8 -3
  423. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +21 -14
  424. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  425. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  426. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  427. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  428. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  429. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +121 -0
  430. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  431. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  432. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  433. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  434. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  435. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  436. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  437. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  438. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  439. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  440. package/src/mem_pools/tx_pool_v2/interfaces.ts +242 -0
  441. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +327 -0
  442. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  443. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +444 -0
  444. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +223 -0
  445. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1079 -0
  446. package/src/msg_validators/attestation_validator/attestation_validator.ts +36 -21
  447. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +21 -18
  448. package/src/msg_validators/clock_tolerance.ts +51 -0
  449. package/src/msg_validators/index.ts +1 -1
  450. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +20 -0
  451. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +26 -0
  452. package/src/msg_validators/proposal_validator/index.ts +3 -0
  453. package/src/msg_validators/proposal_validator/proposal_validator.ts +115 -0
  454. package/src/msg_validators/tx_validator/README.md +115 -0
  455. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  456. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  457. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  458. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  459. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  460. package/src/msg_validators/tx_validator/data_validator.ts +18 -6
  461. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  462. package/src/msg_validators/tx_validator/factory.ts +385 -55
  463. package/src/msg_validators/tx_validator/fee_payer_balance.ts +44 -0
  464. package/src/msg_validators/tx_validator/gas_validator.ts +140 -55
  465. package/src/msg_validators/tx_validator/index.ts +3 -0
  466. package/src/msg_validators/tx_validator/metadata_validator.ts +18 -7
  467. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  468. package/src/msg_validators/tx_validator/phases_validator.ts +56 -29
  469. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  470. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -19
  471. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  472. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  473. package/src/services/data_store.ts +10 -7
  474. package/src/services/discv5/discV5_service.ts +1 -1
  475. package/src/services/dummy_service.ts +65 -2
  476. package/src/services/encoding.ts +13 -12
  477. package/src/services/gossipsub/README.md +641 -0
  478. package/src/services/gossipsub/index.ts +2 -0
  479. package/src/services/gossipsub/scoring.ts +29 -5
  480. package/src/services/gossipsub/topic_score_params.ts +487 -0
  481. package/src/services/index.ts +1 -0
  482. package/src/services/libp2p/instrumentation.ts +32 -73
  483. package/src/services/libp2p/libp2p_service.ts +732 -387
  484. package/src/services/peer-manager/metrics.ts +39 -21
  485. package/src/services/peer-manager/peer_manager.ts +3 -2
  486. package/src/services/peer-manager/peer_scoring.ts +28 -4
  487. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  488. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
  489. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  490. package/src/services/reqresp/batch-tx-requester/interface.ts +53 -0
  491. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +161 -0
  492. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
  493. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  494. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  495. package/src/services/reqresp/connection-sampler/connection_sampler.ts +19 -1
  496. package/src/services/reqresp/constants.ts +14 -0
  497. package/src/services/reqresp/interface.ts +29 -1
  498. package/src/services/reqresp/metrics.ts +36 -27
  499. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  500. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  501. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  502. package/src/services/reqresp/protocols/status.ts +7 -4
  503. package/src/services/reqresp/protocols/tx.ts +23 -2
  504. package/src/services/reqresp/reqresp.ts +79 -22
  505. package/src/services/service.ts +73 -5
  506. package/src/services/tx_collection/config.ts +83 -1
  507. package/src/services/tx_collection/fast_tx_collection.ts +93 -47
  508. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  509. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  510. package/src/services/tx_collection/index.ts +6 -0
  511. package/src/services/tx_collection/instrumentation.ts +11 -13
  512. package/src/services/tx_collection/missing_txs_tracker.ts +52 -0
  513. package/src/services/tx_collection/proposal_tx_collector.ts +113 -0
  514. package/src/services/tx_collection/slow_tx_collection.ts +68 -35
  515. package/src/services/tx_collection/tx_collection.ts +121 -24
  516. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  517. package/src/services/tx_collection/tx_source.ts +22 -3
  518. package/src/services/tx_file_store/config.ts +37 -0
  519. package/src/services/tx_file_store/index.ts +3 -0
  520. package/src/services/tx_file_store/instrumentation.ts +36 -0
  521. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  522. package/src/services/tx_provider.ts +29 -13
  523. package/src/services/tx_provider_instrumentation.ts +24 -14
  524. package/src/test-helpers/index.ts +2 -0
  525. package/src/test-helpers/make-test-p2p-clients.ts +3 -5
  526. package/src/test-helpers/mock-pubsub.ts +147 -10
  527. package/src/test-helpers/reqresp-nodes.ts +5 -7
  528. package/src/test-helpers/test_tx_provider.ts +64 -0
  529. package/src/test-helpers/testbench-utils.ts +431 -0
  530. package/src/testbench/p2p_client_testbench_worker.ts +351 -128
  531. package/src/testbench/worker_client_manager.ts +311 -42
  532. package/src/util.ts +7 -1
  533. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -37
  534. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  535. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -213
  536. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -30
  537. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  538. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -219
  539. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -81
  540. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  541. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -239
  542. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  543. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  544. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -82
  545. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  546. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  547. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  548. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -298
  549. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -287
  550. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -285
  551. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -97
  552. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
@@ -1,132 +1,102 @@
1
1
  /**
2
2
  * A testbench worker that creates a p2p client and listens for commands from the parent.
3
3
  *
4
- * Used when running testbench commands
4
+ * Used when running testbench commands.
5
5
  */
6
6
  import { MockL2BlockSource } from '@aztec/archiver/test';
7
7
  import type { EpochCacheInterface } from '@aztec/epoch-cache';
8
- import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
9
- import { EthAddress } from '@aztec/foundation/eth-address';
10
- import { createLogger } from '@aztec/foundation/log';
8
+ import { BlockNumber } from '@aztec/foundation/branded-types';
9
+ import { SecretValue } from '@aztec/foundation/config';
10
+ import { Secp256k1Signer } from '@aztec/foundation/crypto/secp256k1-signer';
11
+ import { Fr } from '@aztec/foundation/curves/bn254';
12
+ import { type Logger, createLogger } from '@aztec/foundation/log';
11
13
  import { sleep } from '@aztec/foundation/sleep';
14
+ import { DateProvider, Timer } from '@aztec/foundation/timer';
12
15
  import type { DataStoreConfig } from '@aztec/kv-store/config';
13
16
  import { openTmpStore } from '@aztec/kv-store/lmdb-v2';
17
+ import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
18
+ import { protocolContractsHash } from '@aztec/protocol-contracts';
14
19
  import type { L2BlockSource } from '@aztec/stdlib/block';
15
20
  import type { ContractDataSource } from '@aztec/stdlib/contract';
16
21
  import type { ClientProtocolCircuitVerifier, WorldStateSynchronizer } from '@aztec/stdlib/interfaces/server';
17
- import { P2PClientType, P2PMessage } from '@aztec/stdlib/p2p';
18
- import { Tx, TxStatus } from '@aztec/stdlib/tx';
22
+ import { type BlockProposal, P2PMessage } from '@aztec/stdlib/p2p';
23
+ import { ChonkProof } from '@aztec/stdlib/proofs';
24
+ import { makeAztecAddress, makeBlockHeader, makeBlockProposal, mockTx } from '@aztec/stdlib/testing';
25
+ import { Tx, TxHash, type TxValidationResult } from '@aztec/stdlib/tx';
19
26
  import { type TelemetryClient, getTelemetryClient } from '@aztec/telemetry-client';
20
27
 
21
28
  import type { Message, PeerId } from '@libp2p/interface';
22
29
  import { TopicValidatorResult } from '@libp2p/interface';
23
- import EventEmitter from 'events';
30
+ import { peerIdFromString } from '@libp2p/peer-id';
24
31
 
32
+ import type { P2PClient } from '../client/index.js';
25
33
  import type { P2PConfig } from '../config.js';
26
34
  import { createP2PClient } from '../index.js';
27
- import type { AttestationPool } from '../mem_pools/attestation_pool/attestation_pool.js';
28
- import type { MemPools } from '../mem_pools/interface.js';
29
- import type { TxPool } from '../mem_pools/tx_pool/index.js';
30
- import { LibP2PService } from '../services/libp2p/libp2p_service.js';
35
+ import type { MemPools } from '../mem_pools/index.js';
36
+ import { BatchTxRequesterCollector, LibP2PService, SendBatchRequestCollector } from '../services/index.js';
31
37
  import type { PeerManager } from '../services/peer-manager/peer_manager.js';
38
+ import type { BatchTxRequesterLibP2PService } from '../services/reqresp/batch-tx-requester/interface.js';
39
+ import type { IBatchRequestTxValidator } from '../services/reqresp/batch-tx-requester/tx_validator.js';
40
+ import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.js';
32
41
  import type { ReqResp } from '../services/reqresp/reqresp.js';
33
42
  import type { PeerDiscoveryService } from '../services/service.js';
34
- import { AlwaysTrueCircuitVerifier } from '../test-helpers/reqresp-nodes.js';
43
+ import { MissingTxsTracker } from '../services/tx_collection/missing_txs_tracker.js';
44
+ import { AlwaysTrueCircuitVerifier } from '../test-helpers/index.js';
45
+ import {
46
+ BENCHMARK_CONSTANTS,
47
+ type CollectorType,
48
+ type DistributionPattern,
49
+ InMemoryAttestationPool,
50
+ InMemoryTxPool,
51
+ UNLIMITED_RATE_LIMIT_QUOTA,
52
+ createMockEpochCache,
53
+ createMockWorldStateSynchronizer,
54
+ filterTxsByDistribution,
55
+ } from '../test-helpers/index.js';
35
56
  import type { PubSubLibp2p } from '../util.js';
36
57
 
37
- // Simple mock implementation
38
- function mockTxPool(): TxPool {
39
- // Mock all methods
40
- const pool: Omit<TxPool, keyof EventEmitter> = {
41
- isEmpty: () => Promise.resolve(false),
42
- addTxs: () => Promise.resolve(1),
43
- getTxByHash: () => Promise.resolve(undefined),
44
- getArchivedTxByHash: () => Promise.resolve(undefined),
45
- markAsMined: () => Promise.resolve(),
46
- markMinedAsPending: () => Promise.resolve(),
47
- deleteTxs: () => Promise.resolve(),
48
- getAllTxs: () => Promise.resolve([]),
49
- getAllTxHashes: () => Promise.resolve([]),
50
- getPendingTxHashes: () => Promise.resolve([]),
51
- getPendingTxCount: () => Promise.resolve(0),
52
- getMinedTxHashes: () => Promise.resolve([]),
53
- getTxStatus: () => Promise.resolve(TxStatus.PENDING),
54
- getTxsByHash: () => Promise.resolve([]),
55
- hasTxs: () => Promise.resolve([]),
56
- hasTx: () => Promise.resolve(false),
57
- updateConfig: () => {},
58
- markTxsAsNonEvictable: () => Promise.resolve(),
59
- cleanupDeletedMinedTxs: () => Promise.resolve(0),
60
- };
61
- return Object.assign(new EventEmitter(), pool);
62
- }
58
+ export type { DistributionPattern, CollectorType } from '../test-helpers/testbench-utils.js';
59
+ export { COLLECTOR_DISPLAY_NAMES } from '../test-helpers/testbench-utils.js';
63
60
 
64
- function mockAttestationPool(): AttestationPool {
65
- return {
66
- isEmpty: () => Promise.resolve(false),
67
- addAttestations: () => Promise.resolve(),
68
- deleteAttestations: () => Promise.resolve(),
69
- deleteAttestationsOlderThan: () => Promise.resolve(),
70
- deleteAttestationsForSlot: () => Promise.resolve(),
71
- deleteAttestationsForSlotAndProposal: () => Promise.resolve(),
72
- getAttestationsForSlot: () => Promise.resolve([]),
73
- getAttestationsForSlotAndProposal: () => Promise.resolve([]),
74
- addBlockProposal: () => Promise.resolve(),
75
- getBlockProposal: () => Promise.resolve(undefined),
76
- hasBlockProposal: () => Promise.resolve(false),
77
- hasAttestation: () => Promise.resolve(false),
78
- canAddProposal: () => Promise.resolve(true),
79
- canAddAttestation: () => Promise.resolve(true),
80
- };
61
+ export interface BenchReqRespCommand {
62
+ type: 'BENCH_REQRESP';
63
+ txCount: number;
64
+ peerCount: number;
65
+ distribution: DistributionPattern;
66
+ collectorType: CollectorType;
67
+ timeoutMs: number;
68
+ isAggregator: boolean;
69
+ peerIndex: number;
70
+ pinnedPeerIndex?: number;
71
+ pinnedPeerId?: string;
72
+ blockNumber: number;
73
+ seed: number;
81
74
  }
82
75
 
83
- function mockEpochCache(): EpochCacheInterface {
84
- return {
85
- getCommittee: () => Promise.resolve({ committee: [], seed: 1n, epoch: EpochNumber.ZERO }),
86
- getProposerIndexEncoding: () => '0x' as `0x${string}`,
87
- getEpochAndSlotNow: () => ({ epoch: EpochNumber.ZERO, slot: SlotNumber.ZERO, ts: 0n }),
88
- computeProposerIndex: () => 0n,
89
- getProposerAttesterAddressInCurrentOrNextSlot: () =>
90
- Promise.resolve({
91
- currentProposer: EthAddress.ZERO,
92
- nextProposer: EthAddress.ZERO,
93
- currentSlot: SlotNumber.ZERO,
94
- nextSlot: SlotNumber.ZERO,
95
- }),
96
- getEpochAndSlotInNextL1Slot: () => ({ epoch: EpochNumber.ZERO, slot: SlotNumber.ZERO, ts: 0n, now: 0n }),
97
- isInCommittee: () => Promise.resolve(false),
98
- getRegisteredValidators: () => Promise.resolve([]),
99
- filterInCommittee: () => Promise.resolve([]),
100
- };
76
+ export interface BenchResultMessage {
77
+ type: 'BENCH_RESULT';
78
+ durationMs: number;
79
+ fetchedCount: number;
80
+ success: boolean;
81
+ error?: string;
101
82
  }
102
83
 
103
- function mockWorldStateSynchronizer(): WorldStateSynchronizer {
104
- return {
105
- status: () =>
106
- Promise.resolve({
107
- syncSummary: {
108
- latestBlockNumber: 0,
109
- latestBlockHash: '',
110
- finalizedBlockNumber: 0,
111
- treesAreSynched: false,
112
- oldestHistoricBlockNumber: 0,
113
- },
114
- }),
115
- } as WorldStateSynchronizer;
84
+ export interface BenchReadyMessage {
85
+ type: 'BENCH_READY';
116
86
  }
87
+ const txCache = new Map<number, Tx[]>();
117
88
 
118
- class TestLibP2PService<T extends P2PClientType = P2PClientType.Full> extends LibP2PService<T> {
89
+ class TestLibP2PService extends LibP2PService {
119
90
  private disableTxValidation: boolean;
120
- private gossipMessageCount: number = 0;
91
+ private gossipMessageCount = 0;
121
92
 
122
93
  constructor(
123
- clientType: T,
124
94
  config: P2PConfig,
125
95
  node: PubSubLibp2p,
126
96
  peerDiscoveryService: PeerDiscoveryService,
127
97
  reqresp: ReqResp,
128
98
  peerManager: PeerManager,
129
- mempools: MemPools<T>,
99
+ mempools: MemPools,
130
100
  archiver: L2BlockSource & ContractDataSource,
131
101
  epochCache: EpochCacheInterface,
132
102
  proofVerifier: ClientProtocolCircuitVerifier,
@@ -136,7 +106,6 @@ class TestLibP2PService<T extends P2PClientType = P2PClientType.Full> extends Li
136
106
  disableTxValidation = true,
137
107
  ) {
138
108
  super(
139
- clientType,
140
109
  config,
141
110
  node,
142
111
  peerDiscoveryService,
@@ -170,7 +139,7 @@ class TestLibP2PService<T extends P2PClientType = P2PClientType.Full> extends Li
170
139
  const txHash = tx.getTxHash();
171
140
  const txHashString = txHash.toString();
172
141
  this.logger.verbose(`Received tx ${txHashString} from external peer ${source.toString()}.`);
173
- await this.mempools.txPool.addTxs([tx]);
142
+ await this.mempools.txPool.addPendingTxs([tx]);
174
143
  } else {
175
144
  await super.handleGossipedTx(payload, msgId, source);
176
145
  }
@@ -186,90 +155,344 @@ class TestLibP2PService<T extends P2PClientType = P2PClientType.Full> extends Li
186
155
  }
187
156
  }
188
157
 
158
+ async function generateDeterministicTxs(txCount: number, seed: number, config: P2PConfig): Promise<Tx[]> {
159
+ const cached = txCache.get(seed) ?? [];
160
+ if (cached.length >= txCount) {
161
+ return cached.slice(0, txCount);
162
+ }
163
+
164
+ const expirationTimestampBase = BigInt(seed);
165
+ for (let i = cached.length; i < txCount; i++) {
166
+ const txSeed = seed * 10000 + i;
167
+ const tx = await mockTx(txSeed, {
168
+ chainId: new Fr(config.l1ChainId),
169
+ version: new Fr(config.rollupVersion),
170
+ vkTreeRoot: getVKTreeRoot(),
171
+ protocolContractsHash,
172
+ feePayer: makeAztecAddress(txSeed + 1),
173
+ chonkProof: ChonkProof.empty(),
174
+ numberOfNonRevertiblePublicCallRequests: 0,
175
+ numberOfRevertiblePublicCallRequests: 0,
176
+ numberOfRevertibleNullifiers: 0,
177
+ hasPublicTeardownCallRequest: false,
178
+ publicCalldataSize: 0,
179
+ });
180
+ tx.data.expirationTimestamp = expirationTimestampBase + BigInt(i);
181
+ await tx.recomputeHash();
182
+ cached.push(tx);
183
+ }
184
+
185
+ txCache.set(seed, cached);
186
+ return cached.slice(0, txCount);
187
+ }
188
+
189
+ async function createBlockProposal(blockNumber: number, txHashes: TxHash[], seed: number): Promise<BlockProposal> {
190
+ const archiveRoot = new Fr(BigInt(seed) * 1000000n + BigInt(blockNumber));
191
+ return await makeBlockProposal({
192
+ signer: Secp256k1Signer.random(),
193
+ blockHeader: makeBlockHeader(1, { blockNumber: BlockNumber(blockNumber) }),
194
+ archiveRoot,
195
+ txHashes,
196
+ });
197
+ }
198
+
199
+ function installUnlimitedRateLimits(client: P2PClient): void {
200
+ const reqResp = (client as any).p2pService.reqresp as any;
201
+ const rateLimiter = reqResp.rateLimiter as any;
202
+
203
+ rateLimiter.getRateLimits = () => UNLIMITED_RATE_LIMIT_QUOTA;
204
+ rateLimiter.allow = () => RateLimitStatus.Allowed;
205
+ }
206
+
207
+ async function runAggregatorBenchmark(
208
+ client: P2PClient,
209
+ blockProposal: BlockProposal,
210
+ collectorType: CollectorType,
211
+ timeoutMs: number,
212
+ pinnedPeerId: string | undefined,
213
+ pinnedPeerIndex: number | undefined,
214
+ logger: Logger,
215
+ expectedPeerCount: number,
216
+ ): Promise<BenchResultMessage> {
217
+ let timer = new Timer();
218
+ try {
219
+ installUnlimitedRateLimits(client);
220
+
221
+ const txHashes = blockProposal.txHashes;
222
+ logger.info(`[BENCH] Using block proposal with archive ${blockProposal.archive.toString().slice(0, 10)}...`);
223
+
224
+ const p2pService = (client as any).p2pService;
225
+ const batchTxRequesterService: BatchTxRequesterLibP2PService = p2pService.getBatchTxRequesterService();
226
+
227
+ const minPeersRequired = Math.max(1, expectedPeerCount - 1);
228
+ const maxWaitMs = BENCHMARK_CONSTANTS.MAX_PEER_WAIT_MS;
229
+ const waitInterval = BENCHMARK_CONSTANTS.PEER_CHECK_INTERVAL_MS;
230
+ let waited = 0;
231
+
232
+ while (waited < maxWaitMs) {
233
+ const connectedPeers = batchTxRequesterService.connectionSampler.getPeerListSortedByConnectionCountAsc();
234
+ if (connectedPeers.length >= minPeersRequired) {
235
+ logger.info(`[BENCH] Aggregator has ${connectedPeers.length} connected peers, starting benchmark`);
236
+ break;
237
+ }
238
+ logger.debug(`[BENCH] Waiting for peers: ${connectedPeers.length}/${minPeersRequired} (waited ${waited}ms)`);
239
+ await sleep(waitInterval);
240
+ waited += waitInterval;
241
+ }
242
+
243
+ const connectedPeers = batchTxRequesterService.connectionSampler.getPeerListSortedByConnectionCountAsc();
244
+ logger.info(`[BENCH] Aggregator has ${connectedPeers.length} connected peers`);
245
+ logger.info(
246
+ `[BENCH] Requesting ${txHashes.length} tx hashes: ${txHashes
247
+ .slice(0, 3)
248
+ .map(h => h.toString())
249
+ .join(', ')}...`,
250
+ );
251
+
252
+ let pinnedPeer: PeerId | undefined;
253
+ if (pinnedPeerId) {
254
+ pinnedPeer = peerIdFromString(pinnedPeerId);
255
+ } else if (pinnedPeerIndex !== undefined) {
256
+ if (pinnedPeerIndex > 0 && pinnedPeerIndex <= connectedPeers.length) {
257
+ pinnedPeer = connectedPeers[pinnedPeerIndex - 1];
258
+ }
259
+ }
260
+
261
+ const noopTxValidator: IBatchRequestTxValidator = {
262
+ validateRequestedTx: (_tx: Tx): Promise<TxValidationResult> => Promise.resolve({ result: 'valid' }),
263
+ validateRequestedTxs: (txs: Tx[]): Promise<TxValidationResult[]> =>
264
+ Promise.resolve(txs.map(() => ({ result: 'valid' }))),
265
+ };
266
+
267
+ timer = new Timer();
268
+ if (collectorType === 'batch-requester') {
269
+ const collector = new BatchTxRequesterCollector(
270
+ batchTxRequesterService,
271
+ logger,
272
+ new DateProvider(),
273
+ noopTxValidator,
274
+ );
275
+ const fetchedTxs = await collector.collectTxs(
276
+ MissingTxsTracker.fromArray(txHashes),
277
+ blockProposal,
278
+ pinnedPeer,
279
+ timeoutMs,
280
+ );
281
+ const durationMs = timer.ms();
282
+ return {
283
+ type: 'BENCH_RESULT',
284
+ durationMs,
285
+ fetchedCount: fetchedTxs.length,
286
+ success: fetchedTxs.length === txHashes.length,
287
+ };
288
+ }
289
+
290
+ const collector = new SendBatchRequestCollector(
291
+ batchTxRequesterService,
292
+ BENCHMARK_CONSTANTS.FIXED_MAX_PEERS,
293
+ BENCHMARK_CONSTANTS.FIXED_MAX_RETRY_ATTEMPTS,
294
+ );
295
+ const fetchedTxs = await collector.collectTxs(
296
+ MissingTxsTracker.fromArray(txHashes),
297
+ blockProposal,
298
+ pinnedPeer,
299
+ timeoutMs,
300
+ );
301
+ const durationMs = timer.ms();
302
+ return {
303
+ type: 'BENCH_RESULT',
304
+ durationMs,
305
+ fetchedCount: fetchedTxs.length,
306
+ success: fetchedTxs.length === txHashes.length,
307
+ };
308
+ } catch (err: any) {
309
+ return {
310
+ type: 'BENCH_RESULT',
311
+ durationMs: timer.ms(),
312
+ fetchedCount: 0,
313
+ success: false,
314
+ error: err?.message ?? String(err),
315
+ };
316
+ }
317
+ }
318
+
319
+ let workerClient: P2PClient | null = null;
320
+ let workerTxPool: InMemoryTxPool | null = null;
321
+ let workerAttestationPool: InMemoryAttestationPool | null = null;
322
+ let workerConfig: P2PConfig | null = null;
323
+ let workerLogger: Logger | null = null;
324
+ let kvStore: Awaited<ReturnType<typeof openTmpStore>> | null = null;
325
+
189
326
  // eslint-disable-next-line @typescript-eslint/no-misused-promises
190
327
  process.on('message', async msg => {
191
- const { type, config, clientIndex } = msg as { type: string; config: P2PConfig; clientIndex: number };
328
+ const {
329
+ type,
330
+ config: rawConfig,
331
+ clientIndex,
332
+ } = msg as {
333
+ type: string;
334
+ config: Omit<P2PConfig, 'peerIdPrivateKey'> & { peerIdPrivateKey?: string };
335
+ clientIndex: number;
336
+ };
337
+
192
338
  try {
193
339
  if (type === 'START') {
194
- const txPool = mockTxPool();
195
- const attestationPool = mockAttestationPool();
196
- const epochCache = mockEpochCache();
197
- const worldState = mockWorldStateSynchronizer();
340
+ const config: P2PConfig = {
341
+ ...rawConfig,
342
+ peerIdPrivateKey: rawConfig.peerIdPrivateKey ? new SecretValue(rawConfig.peerIdPrivateKey) : undefined,
343
+ priceBumpPercentage: 10n,
344
+ } as P2PConfig;
345
+
346
+ workerConfig = config;
347
+ workerTxPool = new InMemoryTxPool();
348
+ workerAttestationPool = new InMemoryAttestationPool();
349
+ const epochCache = createMockEpochCache();
350
+ const worldState = createMockWorldStateSynchronizer();
198
351
  const l2BlockSource = new MockL2BlockSource();
199
352
 
200
353
  const proofVerifier = new AlwaysTrueCircuitVerifier();
201
- const kvStore = await openTmpStore(`test-${clientIndex}`);
202
- const logger = createLogger(`p2p:${clientIndex}`);
354
+ kvStore = await openTmpStore(`test-${clientIndex}`, true, BENCHMARK_CONSTANTS.KV_STORE_MAP_SIZE_KB);
355
+ workerLogger = createLogger(`p2p:${clientIndex}`);
356
+ workerTxPool.setLogger(workerLogger);
203
357
  const telemetry = getTelemetryClient();
204
358
 
205
359
  const deps = {
206
- txPool,
207
- attestationPool,
360
+ txPool: workerTxPool,
361
+ attestationPool: workerAttestationPool,
208
362
  store: kvStore,
209
- logger,
363
+ logger: workerLogger,
210
364
  };
211
365
 
212
366
  const client = await createP2PClient(
213
- P2PClientType.Full,
214
367
  config as P2PConfig & DataStoreConfig,
215
368
  l2BlockSource,
216
- proofVerifier,
369
+ proofVerifier as ClientProtocolCircuitVerifier,
217
370
  worldState,
218
371
  epochCache,
219
372
  'test-p2p-bench-worker',
220
373
  undefined,
221
- telemetry,
374
+ telemetry as TelemetryClient,
222
375
  deps,
223
376
  );
224
377
 
225
- // Create test service with validation disabled
226
378
  const testService = new TestLibP2PService(
227
- P2PClientType.Full,
228
379
  config,
229
380
  (client as any).p2pService.node,
230
381
  (client as any).p2pService.peerDiscoveryService,
231
- (client as any).p2pService.mempools,
232
382
  (client as any).p2pService.reqresp,
233
383
  (client as any).p2pService.peerManager,
384
+ (client as any).p2pService.mempools,
234
385
  (client as any).p2pService.archiver,
235
386
  epochCache,
236
387
  proofVerifier,
237
388
  worldState,
238
- telemetry,
239
- logger,
240
- true, // disable validation
389
+ telemetry as TelemetryClient,
390
+ workerLogger,
391
+ true,
241
392
  );
242
393
 
243
- // Replace the existing p2pService with our test version
244
394
  (client as any).p2pService = testService;
245
395
 
246
396
  await client.start();
247
- // Wait until the client is ready
248
397
  for (let i = 0; i < 100; i++) {
249
398
  const isReady = client.isReady();
250
- logger.debug(`Client ${clientIndex} isReady: ${isReady}`);
399
+ workerLogger.debug(`Client ${clientIndex} isReady: ${isReady}`);
251
400
  if (isReady) {
252
401
  break;
253
402
  }
254
403
  await sleep(1000);
255
404
  }
256
405
 
257
- // Listen for commands from parent
258
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
259
- process.on('message', async (cmd: any) => {
260
- switch (cmd.type) {
261
- case 'STOP':
262
- await client.stop();
263
- process.exit(0);
264
- break;
265
- case 'SEND_TX':
266
- await client.sendTx(Tx.fromBuffer(Buffer.from(cmd.tx)));
267
- process.send!({ type: 'TX_SENT' });
268
- break;
406
+ workerClient = client;
407
+ const peerId = (client as any).p2pService.node.peerId.toString();
408
+ process.send!({ type: 'READY', peerId });
409
+ return;
410
+ }
411
+
412
+ const cmd = msg as any;
413
+ switch (cmd.type) {
414
+ case 'STOP':
415
+ if (workerClient) {
416
+ await workerClient.stop();
269
417
  }
270
- });
418
+ if (kvStore?.close) {
419
+ await kvStore.close();
420
+ }
421
+ process.exit(0);
422
+ break;
423
+
424
+ case 'SEND_TX':
425
+ if (workerClient) {
426
+ await workerClient.sendTx(Tx.fromBuffer(Buffer.from(cmd.tx)));
427
+ process.send!({ type: 'TX_SENT' });
428
+ }
429
+ break;
430
+
431
+ case 'BENCH_REQRESP': {
432
+ const benchCmd = cmd as BenchReqRespCommand;
433
+ if (!workerClient || !workerTxPool || !workerAttestationPool || !workerConfig || !workerLogger) {
434
+ process.send!({
435
+ type: 'BENCH_RESULT',
436
+ durationMs: 0,
437
+ fetchedCount: 0,
438
+ success: false,
439
+ error: 'Worker not initialized',
440
+ } as BenchResultMessage);
441
+ break;
442
+ }
443
+
444
+ // Reset state before each benchmark run to avoid cross-run contamination
445
+ workerTxPool.resetState();
446
+ workerAttestationPool.resetState();
447
+
448
+ installUnlimitedRateLimits(workerClient);
449
+
450
+ const allTxs = await generateDeterministicTxs(benchCmd.txCount, benchCmd.seed, workerConfig);
451
+ const txHashes = allTxs.map(tx => tx.getTxHash());
452
+ const blockProposal = await createBlockProposal(benchCmd.blockNumber, txHashes, benchCmd.seed);
271
453
 
272
- process.send!({ type: 'READY' });
454
+ await workerAttestationPool.tryAddBlockProposal(blockProposal);
455
+ workerLogger.debug(
456
+ `[BENCH] Added block proposal with archive ${blockProposal.archive.toString().slice(0, 10)}...`,
457
+ );
458
+
459
+ if (benchCmd.isAggregator) {
460
+ workerTxPool.clearTxs();
461
+
462
+ workerLogger.info(
463
+ `[BENCH] Aggregator starting benchmark: txCount=${benchCmd.txCount}, collector=${benchCmd.collectorType}, distribution=${benchCmd.distribution}`,
464
+ );
465
+
466
+ const result = await runAggregatorBenchmark(
467
+ workerClient,
468
+ blockProposal,
469
+ benchCmd.collectorType,
470
+ benchCmd.timeoutMs,
471
+ benchCmd.pinnedPeerId,
472
+ benchCmd.pinnedPeerIndex,
473
+ workerLogger,
474
+ benchCmd.peerCount,
475
+ );
476
+
477
+ process.send!(result);
478
+ } else {
479
+ const myTxs = filterTxsByDistribution(
480
+ allTxs,
481
+ benchCmd.peerIndex,
482
+ benchCmd.peerCount,
483
+ benchCmd.distribution,
484
+ benchCmd.pinnedPeerIndex,
485
+ );
486
+ workerTxPool.setTxs(myTxs);
487
+
488
+ workerLogger.info(
489
+ `[BENCH] Peer ${benchCmd.peerIndex} populated tx pool with ${myTxs.length}/${benchCmd.txCount} txs (${benchCmd.distribution})`,
490
+ );
491
+
492
+ process.send!({ type: 'BENCH_READY' } as BenchReadyMessage);
493
+ }
494
+ break;
495
+ }
273
496
  }
274
497
  } catch (err: any) {
275
498
  process.send!({ type: 'ERROR', error: err.message });