@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.0b941701

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 (527) hide show
  1. package/README.md +8 -0
  2. package/dest/client.d.ts +6 -4
  3. package/dest/client.d.ts.map +1 -1
  4. package/dest/client.js +4 -2
  5. package/dest/common/errors.d.ts +6 -9
  6. package/dest/common/errors.d.ts.map +1 -1
  7. package/dest/common/errors.js +51 -32
  8. package/dest/common/index.d.ts +1 -2
  9. package/dest/common/index.d.ts.map +1 -1
  10. package/dest/common/index.js +0 -1
  11. package/dest/common/stats/index.d.ts +1 -1
  12. package/dest/common/stats/stats.d.ts +1 -1
  13. package/dest/private/acvm/acvm.d.ts +12 -6
  14. package/dest/private/acvm/acvm.d.ts.map +1 -1
  15. package/dest/private/acvm/acvm.js +10 -16
  16. package/dest/private/acvm/acvm_types.d.ts +2 -2
  17. package/dest/private/acvm/acvm_types.d.ts.map +1 -1
  18. package/dest/private/acvm/deserialize.d.ts +19 -20
  19. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  20. package/dest/private/acvm/deserialize.js +32 -24
  21. package/dest/private/acvm/index.d.ts +1 -2
  22. package/dest/private/acvm/index.d.ts.map +1 -1
  23. package/dest/private/acvm/index.js +0 -1
  24. package/dest/private/acvm/serialize.d.ts +21 -4
  25. package/dest/private/acvm/serialize.d.ts.map +1 -1
  26. package/dest/private/acvm/serialize.js +54 -1
  27. package/dest/private/acvm_native.d.ts +39 -0
  28. package/dest/private/acvm_native.d.ts.map +1 -0
  29. package/dest/private/{providers/acvm_native.js → acvm_native.js} +26 -20
  30. package/dest/private/acvm_wasm.d.ts +15 -0
  31. package/dest/private/acvm_wasm.d.ts.map +1 -0
  32. package/dest/private/{providers/acvm_wasm.js → acvm_wasm.js} +22 -19
  33. package/dest/private/acvm_wasm_with_blobs.d.ts +20 -0
  34. package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -0
  35. package/dest/private/acvm_wasm_with_blobs.js +35 -0
  36. package/dest/private/circuit_recording/circuit_recorder.d.ts +108 -0
  37. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
  38. package/dest/private/circuit_recording/circuit_recorder.js +210 -0
  39. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +31 -0
  40. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -0
  41. package/dest/private/circuit_recording/file_circuit_recorder.js +135 -0
  42. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +5 -0
  43. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -0
  44. package/dest/private/circuit_recording/memory_circuit_recorder.js +9 -0
  45. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +21 -0
  46. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -0
  47. package/dest/private/circuit_recording/simulator_recorder_wrapper.js +44 -0
  48. package/dest/private/circuit_simulator.d.ts +35 -0
  49. package/dest/private/circuit_simulator.d.ts.map +1 -0
  50. package/dest/private/circuit_simulator.js +43 -0
  51. package/dest/private/factory.d.ts +12 -0
  52. package/dest/private/factory.d.ts.map +1 -0
  53. package/dest/private/{providers/factory.js → factory.js} +2 -2
  54. package/dest/public/avm/avm_context.d.ts +8 -8
  55. package/dest/public/avm/avm_context.d.ts.map +1 -1
  56. package/dest/public/avm/avm_contract_call_result.d.ts +8 -6
  57. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  58. package/dest/public/avm/avm_contract_call_result.js +12 -8
  59. package/dest/public/avm/avm_execution_environment.d.ts +9 -6
  60. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  61. package/dest/public/avm/avm_execution_environment.js +5 -3
  62. package/dest/public/avm/avm_gas.d.ts +5 -21
  63. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  64. package/dest/public/avm/avm_gas.js +27 -35
  65. package/dest/public/avm/avm_machine_state.d.ts +9 -6
  66. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  67. package/dest/public/avm/avm_machine_state.js +5 -2
  68. package/dest/public/avm/avm_memory_types.d.ts +100 -89
  69. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  70. package/dest/public/avm/avm_memory_types.js +21 -7
  71. package/dest/public/avm/avm_simulator.d.ts +8 -7
  72. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  73. package/dest/public/avm/avm_simulator.js +32 -42
  74. package/dest/public/avm/avm_simulator_interface.d.ts +9 -0
  75. package/dest/public/avm/avm_simulator_interface.d.ts.map +1 -0
  76. package/dest/public/avm/avm_simulator_interface.js +3 -0
  77. package/dest/public/avm/calldata.d.ts +51 -0
  78. package/dest/public/avm/calldata.d.ts.map +1 -0
  79. package/dest/public/avm/calldata.js +63 -0
  80. package/dest/public/avm/errors.d.ts +11 -29
  81. package/dest/public/avm/errors.d.ts.map +1 -1
  82. package/dest/public/avm/errors.js +19 -57
  83. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +6 -5
  84. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  85. package/dest/public/avm/fixtures/avm_simulation_tester.js +26 -18
  86. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +8 -6
  87. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  88. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +38 -15
  89. package/dest/public/avm/fixtures/initializers.d.ts +42 -0
  90. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -0
  91. package/dest/public/avm/fixtures/initializers.js +45 -0
  92. package/dest/public/avm/fixtures/utils.d.ts +39 -0
  93. package/dest/public/avm/fixtures/utils.d.ts.map +1 -0
  94. package/dest/public/avm/fixtures/utils.js +96 -0
  95. package/dest/public/avm/index.d.ts +1 -3
  96. package/dest/public/avm/index.d.ts.map +1 -1
  97. package/dest/public/avm/index.js +0 -2
  98. package/dest/public/avm/opcodes/accrued_substate.d.ts +16 -16
  99. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  100. package/dest/public/avm/opcodes/accrued_substate.js +52 -45
  101. package/dest/public/avm/opcodes/addressing_mode.d.ts +12 -8
  102. package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
  103. package/dest/public/avm/opcodes/addressing_mode.js +46 -26
  104. package/dest/public/avm/opcodes/arithmetic.d.ts +14 -2
  105. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  106. package/dest/public/avm/opcodes/arithmetic.js +27 -3
  107. package/dest/public/avm/opcodes/bitwise.d.ts +8 -16
  108. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  109. package/dest/public/avm/opcodes/bitwise.js +22 -29
  110. package/dest/public/avm/opcodes/comparators.d.ts +1 -1
  111. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  112. package/dest/public/avm/opcodes/comparators.js +3 -3
  113. package/dest/public/avm/opcodes/contract.d.ts +3 -4
  114. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  115. package/dest/public/avm/opcodes/contract.js +11 -12
  116. package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
  117. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  118. package/dest/public/avm/opcodes/control_flow.js +13 -11
  119. package/dest/public/avm/opcodes/conversion.d.ts +4 -3
  120. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  121. package/dest/public/avm/opcodes/conversion.js +270 -6
  122. package/dest/public/avm/opcodes/ec_add.d.ts +3 -3
  123. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  124. package/dest/public/avm/opcodes/ec_add.js +21 -12
  125. package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
  126. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  127. package/dest/public/avm/opcodes/environment_getters.js +20 -22
  128. package/dest/public/avm/opcodes/external_calls.d.ts +14 -13
  129. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  130. package/dest/public/avm/opcodes/external_calls.js +52 -46
  131. package/dest/public/avm/opcodes/hashing.d.ts +7 -7
  132. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  133. package/dest/public/avm/opcodes/hashing.js +24 -19
  134. package/dest/public/avm/opcodes/index.d.ts +1 -1
  135. package/dest/public/avm/opcodes/instruction.d.ts +15 -11
  136. package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
  137. package/dest/public/avm/opcodes/instruction.js +23 -19
  138. package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
  139. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  140. package/dest/public/avm/opcodes/instruction_impl.js +4 -4
  141. package/dest/public/avm/opcodes/memory.d.ts +15 -15
  142. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  143. package/dest/public/avm/opcodes/memory.js +52 -48
  144. package/dest/public/avm/opcodes/misc.d.ts +4 -3
  145. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  146. package/dest/public/avm/opcodes/misc.js +42 -17
  147. package/dest/public/avm/opcodes/storage.d.ts +14 -13
  148. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  149. package/dest/public/avm/opcodes/storage.js +39 -27
  150. package/dest/public/avm/revert_reason.d.ts +18 -0
  151. package/dest/public/avm/revert_reason.d.ts.map +1 -0
  152. package/dest/public/avm/revert_reason.js +39 -0
  153. package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -3
  154. package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
  155. package/dest/public/avm/serialization/bytecode_serialization.d.ts +3 -7
  156. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  157. package/dest/public/avm/serialization/bytecode_serialization.js +79 -75
  158. package/dest/public/avm/serialization/instruction_serialization.d.ts +14 -5
  159. package/dest/public/avm/serialization/instruction_serialization.d.ts.map +1 -1
  160. package/dest/public/avm/serialization/instruction_serialization.js +70 -35
  161. package/dest/public/avm/test_utils.d.ts +12 -15
  162. package/dest/public/avm/test_utils.d.ts.map +1 -1
  163. package/dest/public/avm/test_utils.js +17 -25
  164. package/dest/public/contracts_db_checkpoint.d.ts +16 -0
  165. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
  166. package/dest/public/contracts_db_checkpoint.js +30 -0
  167. package/dest/public/db_interfaces.d.ts +68 -0
  168. package/dest/public/db_interfaces.d.ts.map +1 -0
  169. package/dest/public/db_interfaces.js +3 -0
  170. package/dest/public/debug_fn_name.d.ts +18 -0
  171. package/dest/public/debug_fn_name.d.ts.map +1 -0
  172. package/dest/public/debug_fn_name.js +37 -0
  173. package/dest/public/executor_metrics.d.ts +12 -4
  174. package/dest/public/executor_metrics.d.ts.map +1 -1
  175. package/dest/public/executor_metrics.js +29 -24
  176. package/dest/public/executor_metrics_interface.d.ts +10 -0
  177. package/dest/public/executor_metrics_interface.d.ts.map +1 -0
  178. package/dest/public/executor_metrics_interface.js +1 -0
  179. package/dest/public/fixtures/amm_test.d.ts +10 -0
  180. package/dest/public/fixtures/amm_test.d.ts.map +1 -0
  181. package/dest/public/fixtures/amm_test.js +213 -0
  182. package/dest/public/fixtures/bulk_test.d.ts +6 -0
  183. package/dest/public/fixtures/bulk_test.d.ts.map +1 -0
  184. package/dest/public/fixtures/bulk_test.js +262 -0
  185. package/dest/public/fixtures/custom_bytecode_tester.d.ts +34 -0
  186. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -0
  187. package/dest/public/fixtures/custom_bytecode_tester.js +53 -0
  188. package/dest/public/fixtures/custom_bytecode_tests.d.ts +12 -0
  189. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -0
  190. package/dest/public/fixtures/custom_bytecode_tests.js +174 -0
  191. package/dest/public/fixtures/index.d.ts +10 -1
  192. package/dest/public/fixtures/index.d.ts.map +1 -1
  193. package/dest/public/fixtures/index.js +9 -0
  194. package/dest/public/fixtures/minimal_public_tx.d.ts +4 -0
  195. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
  196. package/dest/public/fixtures/minimal_public_tx.js +19 -0
  197. package/dest/public/fixtures/opcode_spammer.d.ts +123 -0
  198. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
  199. package/dest/public/fixtures/opcode_spammer.js +1693 -0
  200. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +55 -15
  201. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  202. package/dest/public/fixtures/public_tx_simulation_tester.js +138 -72
  203. package/dest/public/fixtures/simple_contract_data_source.d.ts +36 -0
  204. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -0
  205. package/dest/public/{avm/fixtures → fixtures}/simple_contract_data_source.js +31 -10
  206. package/dest/public/fixtures/token_test.d.ts +12 -0
  207. package/dest/public/fixtures/token_test.d.ts.map +1 -0
  208. package/dest/public/fixtures/token_test.js +96 -0
  209. package/dest/public/fixtures/utils.d.ts +18 -5
  210. package/dest/public/fixtures/utils.d.ts.map +1 -1
  211. package/dest/public/fixtures/utils.js +102 -59
  212. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
  213. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  214. package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
  215. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  216. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  217. package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
  218. package/dest/public/hinting_db_sources.d.ts +80 -0
  219. package/dest/public/hinting_db_sources.d.ts.map +1 -0
  220. package/dest/public/hinting_db_sources.js +355 -0
  221. package/dest/public/index.d.ts +6 -9
  222. package/dest/public/index.d.ts.map +1 -1
  223. package/dest/public/index.js +4 -7
  224. package/dest/public/public_db_sources.d.ts +52 -102
  225. package/dest/public/public_db_sources.d.ts.map +1 -1
  226. package/dest/public/public_db_sources.js +220 -193
  227. package/dest/public/public_errors.d.ts +12 -0
  228. package/dest/public/public_errors.d.ts.map +1 -0
  229. package/dest/public/public_errors.js +13 -0
  230. package/dest/public/public_processor/guarded_merkle_tree.d.ts +51 -0
  231. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -0
  232. package/dest/public/public_processor/guarded_merkle_tree.js +113 -0
  233. package/dest/public/public_processor/public_processor.d.ts +26 -38
  234. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  235. package/dest/public/public_processor/public_processor.js +573 -136
  236. package/dest/public/public_processor/public_processor_metrics.d.ts +3 -3
  237. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  238. package/dest/public/public_processor/public_processor_metrics.js +13 -46
  239. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +18 -0
  240. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
  241. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +98 -0
  242. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +53 -0
  243. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -0
  244. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +132 -0
  245. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
  246. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
  247. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
  248. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
  249. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
  250. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
  251. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +22 -0
  252. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  253. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  254. package/dest/public/public_tx_simulator/factories.d.ts +13 -0
  255. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  256. package/dest/public/public_tx_simulator/factories.js +28 -0
  257. package/dest/public/public_tx_simulator/index.d.ts +8 -0
  258. package/dest/public/public_tx_simulator/index.d.ts.map +1 -0
  259. package/dest/public/public_tx_simulator/index.js +5 -0
  260. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +31 -0
  261. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -0
  262. package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +51 -0
  263. package/dest/public/public_tx_simulator/public_tx_context.d.ts +24 -31
  264. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  265. package/dest/public/public_tx_simulator/public_tx_context.js +72 -92
  266. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +37 -58
  267. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  268. package/dest/public/public_tx_simulator/public_tx_simulator.js +217 -206
  269. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +32 -0
  270. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -0
  271. package/dest/public/public_tx_simulator/public_tx_simulator_interface.js +1 -0
  272. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +21 -0
  273. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -0
  274. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +415 -0
  275. package/dest/public/side_effect_errors.d.ts +42 -2
  276. package/dest/public/side_effect_errors.d.ts.map +1 -1
  277. package/dest/public/side_effect_errors.js +70 -1
  278. package/dest/public/side_effect_trace.d.ts +22 -67
  279. package/dest/public/side_effect_trace.d.ts.map +1 -1
  280. package/dest/public/side_effect_trace.js +72 -122
  281. package/dest/public/side_effect_trace_interface.d.ts +13 -25
  282. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  283. package/dest/public/state_manager/index.d.ts +2 -0
  284. package/dest/public/state_manager/index.d.ts.map +1 -0
  285. package/dest/public/state_manager/index.js +1 -0
  286. package/dest/public/{avm/journal → state_manager}/nullifiers.d.ts +4 -7
  287. package/dest/public/state_manager/nullifiers.d.ts.map +1 -0
  288. package/dest/public/{avm/journal → state_manager}/nullifiers.js +3 -8
  289. package/dest/public/{avm/journal → state_manager}/public_storage.d.ts +4 -4
  290. package/dest/public/state_manager/public_storage.d.ts.map +1 -0
  291. package/dest/public/{avm/journal → state_manager}/public_storage.js +1 -1
  292. package/dest/public/state_manager/state_manager.d.ts +164 -0
  293. package/dest/public/state_manager/state_manager.d.ts.map +1 -0
  294. package/dest/public/state_manager/state_manager.js +395 -0
  295. package/dest/public/test_executor_metrics.d.ts +55 -0
  296. package/dest/public/test_executor_metrics.d.ts.map +1 -0
  297. package/dest/public/test_executor_metrics.js +307 -0
  298. package/dest/public/unique_class_ids.d.ts +1 -1
  299. package/dest/public/unique_class_ids.d.ts.map +1 -1
  300. package/dest/public/utils.d.ts +3 -5
  301. package/dest/public/utils.d.ts.map +1 -1
  302. package/dest/public/utils.js +4 -21
  303. package/dest/server.d.ts +7 -4
  304. package/dest/server.d.ts.map +1 -1
  305. package/dest/server.js +5 -2
  306. package/dest/testing.d.ts +2 -0
  307. package/dest/testing.d.ts.map +1 -0
  308. package/dest/testing.js +1 -0
  309. package/package.json +39 -33
  310. package/src/client.ts +5 -3
  311. package/src/common/errors.ts +80 -45
  312. package/src/common/index.ts +0 -1
  313. package/src/private/acvm/acvm.ts +17 -32
  314. package/src/private/acvm/acvm_types.ts +1 -1
  315. package/src/private/acvm/deserialize.ts +36 -30
  316. package/src/private/acvm/index.ts +0 -1
  317. package/src/private/acvm/serialize.ts +64 -1
  318. package/src/private/{providers/acvm_native.ts → acvm_native.ts} +47 -24
  319. package/src/private/acvm_wasm.ts +72 -0
  320. package/src/private/acvm_wasm_with_blobs.ts +54 -0
  321. package/src/private/circuit_recording/circuit_recorder.ts +261 -0
  322. package/src/private/circuit_recording/file_circuit_recorder.ts +158 -0
  323. package/src/private/circuit_recording/memory_circuit_recorder.ts +11 -0
  324. package/src/private/circuit_recording/simulator_recorder_wrapper.ts +91 -0
  325. package/src/private/circuit_simulator.ts +90 -0
  326. package/src/private/{providers/factory.ts → factory.ts} +6 -6
  327. package/src/public/avm/avm_context.ts +6 -6
  328. package/src/public/avm/avm_contract_call_result.ts +23 -9
  329. package/src/public/avm/avm_execution_environment.ts +17 -5
  330. package/src/public/avm/avm_gas.ts +26 -38
  331. package/src/public/avm/avm_machine_state.ts +12 -6
  332. package/src/public/avm/avm_memory_types.ts +24 -7
  333. package/src/public/avm/avm_simulator.ts +57 -62
  334. package/src/public/avm/avm_simulator_interface.ts +8 -0
  335. package/src/public/avm/calldata.ts +100 -0
  336. package/src/public/avm/errors.ts +20 -75
  337. package/src/public/avm/fixtures/avm_simulation_tester.ts +41 -24
  338. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +46 -13
  339. package/src/public/avm/fixtures/initializers.ts +103 -0
  340. package/src/public/avm/fixtures/utils.ts +151 -0
  341. package/src/public/avm/index.ts +0 -2
  342. package/src/public/avm/opcodes/accrued_substate.ts +74 -33
  343. package/src/public/avm/opcodes/addressing_mode.ts +56 -32
  344. package/src/public/avm/opcodes/arithmetic.ts +37 -3
  345. package/src/public/avm/opcodes/bitwise.ts +33 -29
  346. package/src/public/avm/opcodes/comparators.ts +6 -3
  347. package/src/public/avm/opcodes/contract.ts +10 -10
  348. package/src/public/avm/opcodes/control_flow.ts +19 -10
  349. package/src/public/avm/opcodes/conversion.ts +29 -5
  350. package/src/public/avm/opcodes/ec_add.ts +22 -10
  351. package/src/public/avm/opcodes/environment_getters.ts +28 -23
  352. package/src/public/avm/opcodes/external_calls.ts +70 -36
  353. package/src/public/avm/opcodes/hashing.ts +39 -13
  354. package/src/public/avm/opcodes/instruction.ts +31 -21
  355. package/src/public/avm/opcodes/instruction_impl.ts +2 -2
  356. package/src/public/avm/opcodes/memory.ts +81 -42
  357. package/src/public/avm/opcodes/misc.ts +61 -19
  358. package/src/public/avm/opcodes/storage.ts +47 -23
  359. package/src/public/avm/revert_reason.ts +58 -0
  360. package/src/public/avm/serialization/buffer_cursor.ts +4 -1
  361. package/src/public/avm/serialization/bytecode_serialization.ts +89 -80
  362. package/src/public/avm/serialization/instruction_serialization.ts +75 -34
  363. package/src/public/avm/test_utils.ts +25 -42
  364. package/src/public/contracts_db_checkpoint.ts +41 -0
  365. package/src/public/db_interfaces.ts +76 -0
  366. package/src/public/debug_fn_name.ts +52 -0
  367. package/src/public/executor_metrics.ts +47 -24
  368. package/src/public/executor_metrics_interface.ts +15 -0
  369. package/src/public/fixtures/amm_test.ts +331 -0
  370. package/src/public/fixtures/bulk_test.ts +169 -0
  371. package/src/public/fixtures/custom_bytecode_tester.ts +83 -0
  372. package/src/public/fixtures/custom_bytecode_tests.ts +228 -0
  373. package/src/public/fixtures/index.ts +13 -0
  374. package/src/public/fixtures/minimal_public_tx.ts +26 -0
  375. package/src/public/fixtures/opcode_spammer.ts +1754 -0
  376. package/src/public/fixtures/public_tx_simulation_tester.ts +223 -114
  377. package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +37 -20
  378. package/src/public/fixtures/token_test.ts +148 -0
  379. package/src/public/fixtures/utils.ts +141 -69
  380. package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
  381. package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
  382. package/src/public/hinting_db_sources.ts +607 -0
  383. package/src/public/index.ts +11 -8
  384. package/src/public/public_db_sources.ts +279 -259
  385. package/src/public/public_errors.ts +14 -0
  386. package/src/public/public_processor/guarded_merkle_tree.ts +158 -0
  387. package/src/public/public_processor/public_processor.ts +243 -178
  388. package/src/public/public_processor/public_processor_metrics.ts +13 -47
  389. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +121 -0
  390. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +208 -0
  391. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +132 -0
  392. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +237 -0
  393. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +81 -0
  394. package/src/public/public_tx_simulator/factories.ts +41 -0
  395. package/src/public/public_tx_simulator/index.ts +7 -0
  396. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +105 -0
  397. package/src/public/public_tx_simulator/public_tx_context.ts +168 -195
  398. package/src/public/public_tx_simulator/public_tx_simulator.ts +310 -261
  399. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +33 -0
  400. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +63 -0
  401. package/src/public/side_effect_errors.ts +91 -1
  402. package/src/public/side_effect_trace.ts +95 -321
  403. package/src/public/side_effect_trace_interface.ts +11 -59
  404. package/src/public/state_manager/index.ts +1 -0
  405. package/src/public/{avm/journal → state_manager}/nullifiers.ts +6 -12
  406. package/src/public/{avm/journal → state_manager}/public_storage.ts +3 -3
  407. package/src/public/state_manager/state_manager.ts +546 -0
  408. package/src/public/test_executor_metrics.ts +397 -0
  409. package/src/public/utils.ts +5 -21
  410. package/src/server.ts +6 -3
  411. package/src/testing.ts +1 -0
  412. package/dest/common/db_interfaces.d.ts +0 -80
  413. package/dest/common/db_interfaces.d.ts.map +0 -1
  414. package/dest/common/db_interfaces.js +0 -1
  415. package/dest/common/debug_fn_name.d.ts +0 -5
  416. package/dest/common/debug_fn_name.d.ts.map +0 -1
  417. package/dest/common/debug_fn_name.js +0 -6
  418. package/dest/common/message_load_oracle_inputs.d.ts +0 -15
  419. package/dest/common/message_load_oracle_inputs.d.ts.map +0 -1
  420. package/dest/common/message_load_oracle_inputs.js +0 -15
  421. package/dest/private/acvm/oracle/index.d.ts +0 -14
  422. package/dest/private/acvm/oracle/index.d.ts.map +0 -1
  423. package/dest/private/acvm/oracle/index.js +0 -2
  424. package/dest/private/acvm/oracle/oracle.d.ts +0 -49
  425. package/dest/private/acvm/oracle/oracle.d.ts.map +0 -1
  426. package/dest/private/acvm/oracle/oracle.js +0 -263
  427. package/dest/private/acvm/oracle/typed_oracle.d.ts +0 -83
  428. package/dest/private/acvm/oracle/typed_oracle.d.ts.map +0 -1
  429. package/dest/private/acvm/oracle/typed_oracle.js +0 -132
  430. package/dest/private/execution_data_provider.d.ts +0 -261
  431. package/dest/private/execution_data_provider.d.ts.map +0 -1
  432. package/dest/private/execution_data_provider.js +0 -14
  433. package/dest/private/execution_note_cache.d.ts +0 -93
  434. package/dest/private/execution_note_cache.d.ts.map +0 -1
  435. package/dest/private/execution_note_cache.js +0 -180
  436. package/dest/private/hashed_values_cache.d.ts +0 -28
  437. package/dest/private/hashed_values_cache.d.ts.map +0 -1
  438. package/dest/private/hashed_values_cache.js +0 -46
  439. package/dest/private/index.d.ts +0 -13
  440. package/dest/private/index.d.ts.map +0 -1
  441. package/dest/private/index.js +0 -12
  442. package/dest/private/pick_notes.d.ts +0 -85
  443. package/dest/private/pick_notes.d.ts.map +0 -1
  444. package/dest/private/pick_notes.js +0 -51
  445. package/dest/private/private_execution.d.ts +0 -25
  446. package/dest/private/private_execution.d.ts.map +0 -1
  447. package/dest/private/private_execution.js +0 -92
  448. package/dest/private/private_execution_oracle.d.ts +0 -215
  449. package/dest/private/private_execution_oracle.d.ts.map +0 -1
  450. package/dest/private/private_execution_oracle.js +0 -382
  451. package/dest/private/providers/acvm_native.d.ts +0 -40
  452. package/dest/private/providers/acvm_native.d.ts.map +0 -1
  453. package/dest/private/providers/acvm_wasm.d.ts +0 -15
  454. package/dest/private/providers/acvm_wasm.d.ts.map +0 -1
  455. package/dest/private/providers/acvm_wasm_with_blobs.d.ts +0 -19
  456. package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
  457. package/dest/private/providers/acvm_wasm_with_blobs.js +0 -32
  458. package/dest/private/providers/factory.d.ts +0 -12
  459. package/dest/private/providers/factory.d.ts.map +0 -1
  460. package/dest/private/providers/simulation_provider.d.ts +0 -19
  461. package/dest/private/providers/simulation_provider.d.ts.map +0 -1
  462. package/dest/private/providers/simulation_provider.js +0 -24
  463. package/dest/private/simulator.d.ts +0 -34
  464. package/dest/private/simulator.d.ts.map +0 -1
  465. package/dest/private/simulator.js +0 -76
  466. package/dest/private/unconstrained_execution.d.ts +0 -10
  467. package/dest/private/unconstrained_execution.d.ts.map +0 -1
  468. package/dest/private/unconstrained_execution.js +0 -27
  469. package/dest/private/unconstrained_execution_oracle.d.ts +0 -161
  470. package/dest/private/unconstrained_execution_oracle.d.ts.map +0 -1
  471. package/dest/private/unconstrained_execution_oracle.js +0 -258
  472. package/dest/public/avm/bytecode_utils.d.ts +0 -5
  473. package/dest/public/avm/bytecode_utils.d.ts.map +0 -1
  474. package/dest/public/avm/bytecode_utils.js +0 -17
  475. package/dest/public/avm/fixtures/index.d.ts +0 -84
  476. package/dest/public/avm/fixtures/index.d.ts.map +0 -1
  477. package/dest/public/avm/fixtures/index.js +0 -175
  478. package/dest/public/avm/fixtures/simple_contract_data_source.d.ts +0 -35
  479. package/dest/public/avm/fixtures/simple_contract_data_source.d.ts.map +0 -1
  480. package/dest/public/avm/journal/index.d.ts +0 -2
  481. package/dest/public/avm/journal/index.d.ts.map +0 -1
  482. package/dest/public/avm/journal/index.js +0 -1
  483. package/dest/public/avm/journal/journal.d.ts +0 -209
  484. package/dest/public/avm/journal/journal.d.ts.map +0 -1
  485. package/dest/public/avm/journal/journal.js +0 -486
  486. package/dest/public/avm/journal/nullifiers.d.ts.map +0 -1
  487. package/dest/public/avm/journal/public_storage.d.ts.map +0 -1
  488. package/dest/public/bytecode_errors.d.ts +0 -4
  489. package/dest/public/bytecode_errors.d.ts.map +0 -1
  490. package/dest/public/bytecode_errors.js +0 -6
  491. package/dest/public/execution.d.ts +0 -108
  492. package/dest/public/execution.d.ts.map +0 -1
  493. package/dest/public/execution.js +0 -9
  494. package/dest/public/tx_contract_cache.d.ts +0 -41
  495. package/dest/public/tx_contract_cache.d.ts.map +0 -1
  496. package/dest/public/tx_contract_cache.js +0 -49
  497. package/dest/test/utils.d.ts +0 -13
  498. package/dest/test/utils.d.ts.map +0 -1
  499. package/dest/test/utils.js +0 -22
  500. package/src/common/db_interfaces.ts +0 -94
  501. package/src/common/debug_fn_name.ts +0 -18
  502. package/src/common/message_load_oracle_inputs.ts +0 -15
  503. package/src/private/acvm/oracle/index.ts +0 -16
  504. package/src/private/acvm/oracle/oracle.ts +0 -455
  505. package/src/private/acvm/oracle/typed_oracle.ts +0 -259
  506. package/src/private/execution_data_provider.ts +0 -323
  507. package/src/private/execution_note_cache.ts +0 -217
  508. package/src/private/hashed_values_cache.ts +0 -55
  509. package/src/private/index.ts +0 -16
  510. package/src/private/pick_notes.ts +0 -141
  511. package/src/private/private_execution.ts +0 -151
  512. package/src/private/private_execution_oracle.ts +0 -614
  513. package/src/private/providers/acvm_wasm.ts +0 -63
  514. package/src/private/providers/acvm_wasm_with_blobs.ts +0 -50
  515. package/src/private/providers/simulation_provider.ts +0 -45
  516. package/src/private/simulator.ts +0 -147
  517. package/src/private/unconstrained_execution.ts +0 -50
  518. package/src/private/unconstrained_execution_oracle.ts +0 -373
  519. package/src/public/avm/bytecode_utils.ts +0 -17
  520. package/src/public/avm/fixtures/index.ts +0 -296
  521. package/src/public/avm/journal/index.ts +0 -1
  522. package/src/public/avm/journal/journal.ts +0 -742
  523. package/src/public/avm/opcodes/.eslintrc.cjs +0 -8
  524. package/src/public/bytecode_errors.ts +0 -6
  525. package/src/public/execution.ts +0 -140
  526. package/src/public/tx_contract_cache.ts +0 -69
  527. package/src/test/utils.ts +0 -36
@@ -1,255 +1,274 @@
1
- import type { Fr } from '@aztec/foundation/fields';
1
+ import { AVM_MAX_PROCESSABLE_L2_GAS } from '@aztec/constants';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
3
  import { type Logger, createLogger } from '@aztec/foundation/log';
3
- import { Timer } from '@aztec/foundation/timer';
4
- import { ProtocolContractAddress } from '@aztec/protocol-contracts';
4
+ import { ProtocolContractAddress, ProtocolContractsList } from '@aztec/protocol-contracts';
5
5
  import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
6
- import type { AvmProvingRequest, RevertCode } from '@aztec/stdlib/avm';
6
+ import { AvmExecutionHints, AvmTxHint, PublicSimulatorConfig, PublicTxEffect, PublicTxResult } from '@aztec/stdlib/avm';
7
7
  import { SimulationError } from '@aztec/stdlib/errors';
8
- import type { Gas, GasUsed } from '@aztec/stdlib/gas';
9
- import type { MerkleTreeReadOperations } from '@aztec/stdlib/interfaces/server';
10
- import type { PublicCallRequest } from '@aztec/stdlib/kernel';
11
- import type { AvmSimulationStats } from '@aztec/stdlib/stats';
8
+ import { Gas } from '@aztec/stdlib/gas';
9
+ import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
12
10
  import {
13
11
  type GlobalVariables,
14
12
  NestedProcessReturnValues,
15
- PublicExecutionRequest,
13
+ ProtocolContracts,
14
+ PublicCallRequestWithCalldata,
16
15
  Tx,
17
16
  TxExecutionPhase,
18
17
  } from '@aztec/stdlib/tx';
19
- import { Attributes, type TelemetryClient, type Tracer, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
20
18
 
21
19
  import { strict as assert } from 'assert';
22
20
 
23
- import { getPublicFunctionDebugName } from '../../common/debug_fn_name.js';
24
21
  import type { AvmFinalizedCallResult } from '../avm/avm_contract_call_result.js';
25
- import { type AvmPersistableStateManager, AvmSimulator } from '../avm/index.js';
26
- import { NullifierCollisionError } from '../avm/journal/nullifiers.js';
27
- import { ExecutorMetrics } from '../executor_metrics.js';
28
- import type { WorldStateDB } from '../public_db_sources.js';
22
+ import { CallDataArray } from '../avm/calldata.js';
23
+ import { AvmSimulator } from '../avm/index.js';
24
+ import { getPublicFunctionDebugName } from '../debug_fn_name.js';
25
+ import { HintingMerkleWriteOperations, HintingPublicContractsDB } from '../hinting_db_sources.js';
26
+ import { type PublicContractsDB, PublicTreesDB } from '../public_db_sources.js';
27
+ import {
28
+ L2ToL1MessageLimitReachedError,
29
+ NoteHashLimitReachedError,
30
+ NullifierCollisionError,
31
+ NullifierLimitReachedError,
32
+ } from '../side_effect_errors.js';
33
+ import type { PublicPersistableStateManager } from '../state_manager/state_manager.js';
29
34
  import { PublicTxContext } from './public_tx_context.js';
35
+ import type { PublicTxSimulatorInterface } from './public_tx_simulator_interface.js';
36
+
37
+ // The errors below are only thrown here in the public tx simulator,
38
+ // and only during revertible phases (revertible insertions, app logic and teardown).
39
+ // These are strictly "checked" errors (not exported and never propagated).
40
+ // They are used internally for control flow to trigger rollbacks to the post-setup state.
41
+
42
+ /**
43
+ * Error thrown when public tx simulation reverts in a known/checked way during revertible insertions.
44
+ */
45
+ class TxSimRevertibleInsertionsRevert extends Error {
46
+ constructor() {
47
+ super('Public Tx Simulation reverted during Revertible Insertions');
48
+ this.name = 'TxSimRevertibleInsertionsRevert';
49
+ }
50
+ }
51
+
52
+ /**
53
+ * Error thrown when public tx simulation reverts during app logic.
54
+ */
55
+ class TxSimAppLogicRevert extends Error {
56
+ constructor() {
57
+ super('Public Tx Simulation reverted during App Logic');
58
+ this.name = 'TxSimAppLogicRevert';
59
+ }
60
+ }
61
+
62
+ /**
63
+ * Error thrown when public tx simulation reverts during teardown.
64
+ */
65
+ class TxSimTeardownRevert extends Error {
66
+ constructor() {
67
+ super('Public Tx Simulation reverted during Teardown');
68
+ this.name = 'TxSimTeardownRevert';
69
+ }
70
+ }
30
71
 
31
- export type ProcessedPhase = {
72
+ /** Only used internally. */
73
+ type ProcessedPhase = {
32
74
  phase: TxExecutionPhase;
33
- durationMs: number;
75
+ durationMs?: number;
34
76
  returnValues: NestedProcessReturnValues[];
35
77
  reverted: boolean;
36
78
  revertReason?: SimulationError;
37
79
  };
38
80
 
39
- export type PublicTxResult = {
40
- avmProvingRequest: AvmProvingRequest;
41
- /** Gas used during the execution of this tx */
42
- gasUsed: GasUsed;
43
- revertCode: RevertCode;
44
- /** Revert reason, if any */
45
- revertReason?: SimulationError;
46
- processedPhases: ProcessedPhase[];
47
- };
48
-
49
- export class PublicTxSimulator {
50
- metrics: ExecutorMetrics;
51
-
52
- private log: Logger;
81
+ export class PublicTxSimulator implements PublicTxSimulatorInterface {
82
+ protected log: Logger;
83
+ protected readonly config: PublicSimulatorConfig;
53
84
 
54
85
  constructor(
55
- private db: MerkleTreeReadOperations,
56
- private worldStateDB: WorldStateDB,
57
- private globalVariables: GlobalVariables,
58
- private doMerkleOperations: boolean = false,
59
- private skipFeeEnforcement: boolean = false,
60
- telemetryClient: TelemetryClient = getTelemetryClient(),
86
+ protected merkleTree: MerkleTreeWriteOperations,
87
+ protected contractsDB: PublicContractsDB,
88
+ protected globalVariables: GlobalVariables,
89
+ config?: Partial<PublicSimulatorConfig>,
90
+ protected protocolContracts: ProtocolContracts = ProtocolContractsList,
61
91
  ) {
92
+ this.config = PublicSimulatorConfig.from(config ?? {});
62
93
  this.log = createLogger(`simulator:public_tx_simulator`);
63
- this.metrics = new ExecutorMetrics(telemetryClient, 'PublicTxSimulator');
64
94
  }
65
95
 
66
- get tracer(): Tracer {
67
- return this.metrics.tracer;
68
- }
69
96
  /**
70
97
  * Simulate a transaction's public portion including all of its phases.
71
98
  * @param tx - The transaction to simulate.
72
99
  * @returns The result of the transaction's public execution.
73
100
  */
74
101
  public async simulate(tx: Tx): Promise<PublicTxResult> {
75
- try {
76
- const startTime = process.hrtime.bigint();
102
+ const txHash = this.computeTxHash(tx);
103
+ this.log.debug(`Simulating ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, { txHash });
77
104
 
78
- const txHash = await tx.getTxHash();
79
- this.log.debug(`Simulating ${tx.enqueuedPublicFunctionCalls.length} public calls for tx ${txHash}`, { txHash });
105
+ // Create hinting DBs.
106
+ const hints = new AvmExecutionHints(
107
+ this.globalVariables,
108
+ AvmTxHint.fromTx(tx, this.globalVariables.gasFees),
109
+ this.protocolContracts,
110
+ );
111
+ const hintingMerkleTree = await HintingMerkleWriteOperations.create(this.merkleTree, hints);
112
+ const hintingTreesDB = new PublicTreesDB(hintingMerkleTree);
113
+ const hintingContractsDB = new HintingPublicContractsDB(this.contractsDB, hints);
114
+
115
+ const context = await PublicTxContext.create(
116
+ hintingTreesDB,
117
+ hintingContractsDB,
118
+ tx,
119
+ this.globalVariables,
120
+ this.protocolContracts,
121
+ this.config.proverId,
122
+ );
80
123
 
81
- const context = await PublicTxContext.create(
82
- this.db,
83
- this.worldStateDB,
84
- tx,
85
- this.globalVariables,
86
- this.doMerkleOperations,
87
- );
124
+ // This will throw if there is a nullifier collision.
125
+ // In that case the transaction will be thrown out.
126
+ await this.insertNonRevertiblesFromPrivate(context);
88
127
 
89
- const nonRevertStart = process.hrtime.bigint();
90
- await this.insertNonRevertiblesFromPrivate(context);
91
- // add new contracts to the contracts db so that their functions may be found and called
92
- // TODO(#6464): Should we allow emitting contracts in the private setup phase?
93
- await this.worldStateDB.addNewNonRevertibleContracts(tx);
94
- const nonRevertEnd = process.hrtime.bigint();
95
- this.metrics.recordPrivateEffectsInsertion(Number(nonRevertEnd - nonRevertStart) / 1_000, 'non-revertible');
96
-
97
- const processedPhases: ProcessedPhase[] = [];
98
- if (context.hasPhase(TxExecutionPhase.SETUP)) {
99
- const setupResult: ProcessedPhase = await this.simulateSetupPhase(context);
100
- processedPhases.push(setupResult);
128
+ const processedPhases: ProcessedPhase[] = [];
129
+ if (context.hasPhase(TxExecutionPhase.SETUP)) {
130
+ // This will throw if the setup phase reverts.
131
+ // In that case the transaction will be thrown out.
132
+ const setupResult = await this.simulatePhase(TxExecutionPhase.SETUP, context);
133
+ if (setupResult.reverted) {
134
+ throw new Error(
135
+ `[SETUP] UNRECOVERABLE ERROR! The transaction will be thrown out. ${setupResult.revertReason?.message}`,
136
+ );
101
137
  }
138
+ processedPhases.push(setupResult);
139
+ }
102
140
 
103
- const revertStart = process.hrtime.bigint();
104
- const success = await this.insertRevertiblesFromPrivate(context);
105
- if (success) {
106
- // add new contracts to the contracts db so that their functions may be found and called
107
- await this.worldStateDB.addNewRevertibleContracts(tx);
108
- const revertEnd = process.hrtime.bigint();
109
- this.metrics.recordPrivateEffectsInsertion(Number(revertEnd - revertStart) / 1_000, 'revertible');
110
-
111
- // Only proceed with app logic if there was no revert during revertible insertion
112
- if (context.hasPhase(TxExecutionPhase.APP_LOGIC)) {
113
- const appLogicResult: ProcessedPhase = await this.simulateAppLogicPhase(context);
114
- processedPhases.push(appLogicResult);
141
+ // The checkpoint we should go back to if anything from now on reverts.
142
+ await context.state.fork();
143
+ hintingContractsDB.createCheckpoint();
144
+
145
+ try {
146
+ // This will throw if there is a nullifier collision or other insertion error (limit reached).
147
+ await this.insertRevertiblesFromPrivate(context);
148
+
149
+ // Only proceed with app logic if there was no revert during revertible insertion.
150
+ if (context.hasPhase(TxExecutionPhase.APP_LOGIC)) {
151
+ const appLogicResult = await this.simulatePhase(TxExecutionPhase.APP_LOGIC, context);
152
+ processedPhases.push(appLogicResult);
153
+ if (appLogicResult.reverted) {
154
+ throw new TxSimAppLogicRevert();
115
155
  }
156
+ }
157
+ } catch (e: any) {
158
+ if (e instanceof TxSimRevertibleInsertionsRevert || e instanceof TxSimAppLogicRevert) {
159
+ // We revert to the post-setup state.
160
+ await context.state.discardForkedState();
161
+ hintingContractsDB.revertCheckpoint();
162
+ // But we also create a new fork so that the teardown phase can transparently
163
+ // commit or rollback at the end of teardown.
164
+ await context.state.fork();
165
+ hintingContractsDB.createCheckpoint();
116
166
  } else {
117
- this.log.debug(`Revertible insertions failed. Skipping app logic.`);
167
+ // Unchecked/unknown error - re-throw as-is
168
+ throw e;
118
169
  }
170
+ }
119
171
 
172
+ try {
120
173
  if (context.hasPhase(TxExecutionPhase.TEARDOWN)) {
121
- const teardownResult: ProcessedPhase = await this.simulateTeardownPhase(context);
174
+ const teardownResult = await this.simulatePhase(TxExecutionPhase.TEARDOWN, context);
122
175
  processedPhases.push(teardownResult);
176
+ if (teardownResult.reverted) {
177
+ throw new TxSimTeardownRevert();
178
+ }
123
179
  }
124
-
125
- await context.halt();
126
- await this.payFee(context);
127
-
128
- const endStateReference = await this.db.getStateReference();
129
-
130
- const avmProvingRequest = await context.generateProvingRequest(endStateReference);
131
-
132
- const revertCode = context.getFinalRevertCode();
133
-
134
- if (!revertCode.isOK()) {
135
- await tx.filterRevertedLogs();
180
+ // We commit the forked state and we are done.
181
+ await context.state.mergeForkedState();
182
+ hintingContractsDB.commitCheckpoint();
183
+ } catch (e: any) {
184
+ if (e instanceof TxSimTeardownRevert) {
185
+ // We revert to the post-setup state and we are done.
186
+ await context.state.discardForkedState();
187
+ hintingContractsDB.revertCheckpoint();
188
+ } else {
189
+ // Unchecked/unknown error - re-throw as-is
190
+ throw e;
136
191
  }
137
- // Commit contracts from this TX to the block-level cache and clear tx cache
138
- // If the tx reverted, only commit non-revertible contracts
139
- // NOTE: You can't create contracts in public, so this is only relevant for private-created contracts
140
- this.worldStateDB.commitContractsForTx(/*onlyNonRevertibles=*/ !revertCode.isOK());
141
-
142
- const endTime = process.hrtime.bigint();
143
- this.log.debug(`Public TX simulator took ${Number(endTime - startTime) / 1_000_000} ms\n`);
144
-
145
- return {
146
- avmProvingRequest,
147
- gasUsed: {
148
- totalGas: context.getActualGasUsed(),
149
- teardownGas: context.teardownGasUsed,
150
- publicGas: context.getActualPublicGasUsed(),
151
- billedGas: context.getTotalGasUsed(),
152
- },
153
- revertCode,
154
- revertReason: context.revertReason,
155
- processedPhases: processedPhases,
156
- };
157
- } finally {
158
- // Make sure there are no new contracts in the tx-level cache.
159
- // They should either be committed to block-level cache or cleared.
160
- this.worldStateDB.clearContractsForTx();
161
192
  }
162
- }
163
-
164
- /**
165
- * Simulate the setup phase of a transaction's public execution.
166
- * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
167
- * @returns The phase result.
168
- */
169
- private async simulateSetupPhase(context: PublicTxContext): Promise<ProcessedPhase> {
170
- return await this.simulatePhase(TxExecutionPhase.SETUP, context);
171
- }
172
193
 
173
- /**
174
- * Simulate the app logic phase of a transaction's public execution.
175
- * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
176
- * @returns The phase result.
177
- */
178
- private async simulateAppLogicPhase(context: PublicTxContext): Promise<ProcessedPhase> {
179
- assert(context.state.isForked(), 'App logic phase should operate with forked state.');
194
+ context.halt();
180
195
 
181
- const result = await this.simulatePhase(TxExecutionPhase.APP_LOGIC, context);
196
+ // Such transactions should be filtered by GasTxValidator.
197
+ assert(
198
+ context.getActualGasUsed().l2Gas <= AVM_MAX_PROCESSABLE_L2_GAS,
199
+ `Transaction consumes ${context.getActualGasUsed().l2Gas} L2 gas, which exceeds the AVM maximum processable gas of ${AVM_MAX_PROCESSABLE_L2_GAS}`,
200
+ );
201
+ await this.payFee(context);
182
202
 
183
- if (result.reverted) {
184
- // Drop the currently active forked state manager and rollback to end of setup.
185
- await context.state.discardForkedState();
186
- } else {
187
- if (!context.hasPhase(TxExecutionPhase.TEARDOWN)) {
188
- // Nothing to do after this (no teardown), so merge state updates now instead of letting teardown handle it.
189
- await context.state.mergeForkedState();
190
- }
191
- }
203
+ const publicInputs = await context.generateAvmCircuitPublicInputs();
204
+ const revertCode = context.getFinalRevertCode();
192
205
 
193
- return result;
194
- }
206
+ // We only return the app logic phase information, and only 1 per phase.
207
+ const appLogicReturnValues: NestedProcessReturnValues[] =
208
+ processedPhases.find(({ phase }) => phase === TxExecutionPhase.APP_LOGIC)?.returnValues ?? [];
195
209
 
196
- /**
197
- * Simulate the teardown phase of a transaction's public execution.
198
- * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
199
- * @returns The phase result.
200
- */
201
- private async simulateTeardownPhase(context: PublicTxContext): Promise<ProcessedPhase> {
202
- if (!context.state.isForked()) {
203
- // If state isn't forked (app logic reverted), fork now
204
- // so we can rollback to the end of setup if teardown reverts.
205
- await context.state.fork();
210
+ // TODO(fcarreiro): This is a temporary backwards compatibility layer until we migrate to the C++ simulator.
211
+ if (context.revertReason !== undefined) {
212
+ (appLogicReturnValues as any).revertReason = context.revertReason;
206
213
  }
207
214
 
208
- const result = await this.simulatePhase(TxExecutionPhase.TEARDOWN, context);
215
+ // Create PublicTxEffect from PublicInputs.
216
+ const publicTxEffect = new PublicTxEffect(
217
+ publicInputs.transactionFee,
218
+ publicInputs.accumulatedData.noteHashes.filter(h => !h.isEmpty()),
219
+ publicInputs.accumulatedData.nullifiers.filter(n => !n.isEmpty()),
220
+ publicInputs.accumulatedData.l2ToL1Msgs.filter(m => !m.isEmpty()),
221
+ publicInputs.accumulatedData.publicLogs.toLogs(),
222
+ publicInputs.accumulatedData.publicDataWrites.filter(w => !w.isEmpty()),
223
+ );
209
224
 
210
- if (result.reverted) {
211
- // Drop the currently active forked state manager and rollback to end of setup.
212
- await context.state.discardForkedState();
213
- } else {
214
- // Merge state updates from teardown,
215
- await context.state.mergeForkedState();
216
- }
225
+ return new PublicTxResult(
226
+ /*gasUsed=*/ {
227
+ totalGas: context.getActualGasUsed(),
228
+ teardownGas: context.teardownGasUsed,
229
+ publicGas: context.getActualPublicGasUsed(),
230
+ billedGas: context.getTotalGasUsed(),
231
+ },
232
+ /*revertCode=*/ revertCode,
233
+ /*publicTxEffect=*/ publicTxEffect,
234
+ /*callStackMetadata=*/ appLogicReturnValues,
235
+ /*logs=*/ context.state.getActiveStateManager().getLogs(),
236
+ /*hints=*/ hints,
237
+ /*publicInputs=*/ publicInputs,
238
+ );
239
+ }
217
240
 
218
- return result;
241
+ protected computeTxHash(tx: Tx) {
242
+ return tx.getTxHash();
219
243
  }
220
244
 
221
245
  /**
222
- * Simulate a phase of a transaction's public execution.
223
- * @param phase - The current phase
246
+ * Simulate the setup phase of a transaction's public execution.
224
247
  * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
225
248
  * @returns The phase result.
226
249
  */
227
- private async simulatePhase(phase: TxExecutionPhase, context: PublicTxContext): Promise<ProcessedPhase> {
250
+ protected async simulatePhase(phase: TxExecutionPhase, context: PublicTxContext): Promise<ProcessedPhase> {
228
251
  const callRequests = context.getCallRequestsForPhase(phase);
229
- const executionRequests = context.getExecutionRequestsForPhase(phase);
230
252
 
231
253
  this.log.debug(`Processing phase ${TxExecutionPhase[phase]} for tx ${context.txHash}`, {
232
254
  txHash: context.txHash.toString(),
233
255
  phase: TxExecutionPhase[phase],
234
256
  callRequests: callRequests.length,
235
- executionRequests: executionRequests.length,
236
257
  });
237
258
 
238
259
  const returnValues: NestedProcessReturnValues[] = [];
239
260
  let reverted = false;
240
261
  let revertReason: SimulationError | undefined;
241
- const phaseTimer = new Timer();
242
- for (let i = callRequests.length - 1; i >= 0; i--) {
262
+ for (let i = 0; i < callRequests.length; i++) {
243
263
  if (reverted) {
244
264
  break;
245
265
  }
246
266
 
247
267
  const callRequest = callRequests[i];
248
- const executionRequest = executionRequests[i];
249
268
 
250
- const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest, executionRequest);
269
+ const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest);
251
270
 
252
- returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output));
271
+ returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output.bestEffortReadAll()));
253
272
 
254
273
  if (enqueuedCallResult.reverted) {
255
274
  reverted = true;
@@ -259,7 +278,6 @@ export class PublicTxSimulator {
259
278
 
260
279
  return {
261
280
  phase,
262
- durationMs: phaseTimer.ms(),
263
281
  returnValues,
264
282
  reverted,
265
283
  revertReason,
@@ -270,31 +288,27 @@ export class PublicTxSimulator {
270
288
  * Simulate an enqueued public call.
271
289
  * @param phase - The current phase of public execution
272
290
  * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
273
- * @param callRequest - The enqueued call to execute
274
- * @param executionRequest - The execution request (includes args)
291
+ * @param callRequest - The public function call request, including the calldata.
275
292
  * @returns The result of execution.
276
293
  */
277
- @trackSpan('PublicTxSimulator.simulateEnqueuedCall', (phase, context, _callRequest, executionRequest) => ({
278
- [Attributes.TX_HASH]: context.txHash.toString(),
279
- [Attributes.TARGET_ADDRESS]: executionRequest.callContext.contractAddress.toString(),
280
- [Attributes.SENDER_ADDRESS]: executionRequest.callContext.msgSender.toString(),
281
- [Attributes.SIMULATOR_PHASE]: TxExecutionPhase[phase].toString(),
282
- }))
283
- private async simulateEnqueuedCall(
294
+ protected async simulateEnqueuedCall(
284
295
  phase: TxExecutionPhase,
285
296
  context: PublicTxContext,
286
- callRequest: PublicCallRequest,
287
- executionRequest: PublicExecutionRequest,
297
+ callRequest: PublicCallRequestWithCalldata,
288
298
  ): Promise<AvmFinalizedCallResult> {
289
299
  const stateManager = context.state.getActiveStateManager();
290
- const address = executionRequest.callContext.contractAddress;
291
- const fnName = await getPublicFunctionDebugName(this.worldStateDB, address, executionRequest.args);
300
+ const contractAddress = callRequest.request.contractAddress;
301
+ const fnName = await getPublicFunctionDebugName(
302
+ this.contractsDB,
303
+ contractAddress,
304
+ new CallDataArray(callRequest.calldata),
305
+ );
292
306
 
293
307
  const allocatedGas = context.getGasLeftAtPhase(phase);
294
308
 
295
309
  const result = await this.simulateEnqueuedCallInternal(
296
- context.state.getActiveStateManager(),
297
- executionRequest,
310
+ stateManager,
311
+ callRequest,
298
312
  allocatedGas,
299
313
  /*transactionFee=*/ context.getTransactionFee(phase),
300
314
  fnName,
@@ -306,11 +320,9 @@ export class PublicTxSimulator {
306
320
  `Simulated enqueued public call (${fnName}) consumed ${gasUsed.l2Gas} L2 gas ending with ${result.gasLeft.l2Gas} L2 gas left.`,
307
321
  );
308
322
 
309
- stateManager.traceEnqueuedCall(callRequest, executionRequest.args, result.reverted);
310
-
311
323
  if (result.reverted) {
312
- const culprit = `${executionRequest.callContext.contractAddress}:${executionRequest.callContext.functionSelector}`;
313
- context.revert(phase, result.revertReason, culprit); // throws if in setup (non-revertible) phase
324
+ const culprit = `${contractAddress}:${fnName}`;
325
+ context.revert(phase, result.revertReason, culprit);
314
326
  }
315
327
 
316
328
  return result;
@@ -324,32 +336,24 @@ export class PublicTxSimulator {
324
336
  * while still simulating phases and generating a proving request.
325
337
  *
326
338
  * @param stateManager - The state manager for AvmSimulation
327
- * @param context - The context of the currently executing public transaction portion
328
- * @param executionRequest - The execution request (includes args)
339
+ * @param callRequest - The public function call request, including the calldata.
329
340
  * @param allocatedGas - The gas allocated to the enqueued call
330
341
  * @param fnName - The name of the function
331
342
  * @returns The result of execution.
332
343
  */
333
- @trackSpan(
334
- 'PublicTxSimulator.simulateEnqueuedCallInternal',
335
- (_stateManager, _executionRequest, _allocatedGas, _transactionFee, fnName) => ({
336
- [Attributes.APP_CIRCUIT_NAME]: fnName,
337
- }),
338
- )
339
- private async simulateEnqueuedCallInternal(
340
- stateManager: AvmPersistableStateManager,
341
- executionRequest: PublicExecutionRequest,
344
+ protected async simulateEnqueuedCallInternal(
345
+ stateManager: PublicPersistableStateManager,
346
+ { request, calldata }: PublicCallRequestWithCalldata,
342
347
  allocatedGas: Gas,
343
348
  transactionFee: Fr,
344
349
  fnName: string,
345
350
  ): Promise<AvmFinalizedCallResult> {
346
- const address = executionRequest.callContext.contractAddress;
347
- const sender = executionRequest.callContext.msgSender;
351
+ const address = request.contractAddress;
352
+ const sender = request.msgSender;
348
353
 
349
354
  this.log.debug(
350
355
  `Executing enqueued public call to external function ${fnName}@${address} with ${allocatedGas.l2Gas} allocated L2 gas.`,
351
356
  );
352
- const timer = new Timer();
353
357
 
354
358
  const simulator = await AvmSimulator.create(
355
359
  stateManager,
@@ -357,94 +361,138 @@ export class PublicTxSimulator {
357
361
  sender,
358
362
  transactionFee,
359
363
  this.globalVariables,
360
- executionRequest.callContext.isStaticCall,
361
- executionRequest.args,
364
+ request.isStaticCall,
365
+ new CallDataArray(calldata),
362
366
  allocatedGas,
367
+ this.config,
363
368
  );
364
369
  const avmCallResult = await simulator.execute();
365
- const result = avmCallResult.finalize();
366
-
367
- this.log.verbose(
368
- result.reverted
369
- ? `Simulation of enqueued public call ${fnName} reverted with reason ${result.revertReason}.`
370
- : `Simulation of enqueued public call ${fnName} completed successfully.`,
371
- {
372
- eventName: 'avm-simulation',
373
- appCircuitName: fnName,
374
- duration: timer.ms(),
375
- } satisfies AvmSimulationStats,
376
- );
377
-
378
- if (result.reverted) {
379
- this.metrics.recordFunctionSimulationFailure();
380
- } else {
381
- this.metrics.recordFunctionSimulation(timer.ms(), allocatedGas.sub(result.gasLeft).l2Gas, fnName);
382
- }
383
-
384
- return result;
370
+ return avmCallResult.finalize();
385
371
  }
386
372
 
387
373
  /**
388
374
  * Insert the non-revertible accumulated data from private into the public state.
389
375
  */
390
- public async insertNonRevertiblesFromPrivate(context: PublicTxContext) {
376
+ protected async insertNonRevertiblesFromPrivate(context: PublicTxContext) {
391
377
  const stateManager = context.state.getActiveStateManager();
392
- try {
393
- await stateManager.writeSiloedNullifiersFromPrivate(context.nonRevertibleAccumulatedDataFromPrivate.nullifiers);
394
- } catch (e) {
395
- if (e instanceof NullifierCollisionError) {
396
- throw new NullifierCollisionError(
397
- `Nullifier collision encountered when inserting non-revertible nullifiers from private.\nDetails: ${e.message}\nStack:${e.stack}`,
398
- );
399
- }
378
+
379
+ for (const siloedNullifier of context.nonRevertibleAccumulatedDataFromPrivate.nullifiers.filter(
380
+ n => !n.isEmpty(),
381
+ )) {
382
+ await stateManager.writeSiloedNullifier(siloedNullifier);
400
383
  }
401
384
  for (const noteHash of context.nonRevertibleAccumulatedDataFromPrivate.noteHashes) {
402
385
  if (!noteHash.isEmpty()) {
403
386
  await stateManager.writeUniqueNoteHash(noteHash);
404
387
  }
405
388
  }
389
+ for (const l2ToL1Message of context.nonRevertibleAccumulatedDataFromPrivate.l2ToL1Msgs) {
390
+ if (!l2ToL1Message.isEmpty()) {
391
+ stateManager.writeScopedL2ToL1Message(l2ToL1Message);
392
+ }
393
+ }
394
+
395
+ // add new contracts to the contracts db so that their code may be found and called
396
+ // FIXME(fcarreiro): this should conceptually use the hinting contracts db.
397
+ // However, things work as expected because later calls to getters on the hintingContractsDB
398
+ // will pick up the new contracts and will generate the necessary hints.
399
+ // So, a consumer of the hints will always see the new contracts.
400
+ await this.contractsDB.addContracts(context.nonRevertibleContractDeploymentData);
406
401
  }
407
402
 
408
403
  /**
409
404
  * Insert the revertible accumulated data from private into the public state.
410
- * Start by forking state so we can rollback to the end of setup if app logic or teardown reverts.
405
+ * Throws TxSimRevertibleInsertionsRevert if there is some checked error during revertible insertions.
406
+ * This function checks for the following errors:
407
+ * - NullifierLimitReachedError
408
+ * - NullifierCollisionError
409
+ * - NoteHashLimitReachedError
410
+ * - L2ToL1MessageLimitReachedError
411
411
  */
412
- public async insertRevertiblesFromPrivate(context: PublicTxContext): /*success=*/ Promise<boolean> {
413
- // Fork the state manager so we can rollback to end of setup if app logic reverts.
414
- await context.state.fork();
412
+ protected async insertRevertiblesFromPrivate(context: PublicTxContext) {
415
413
  const stateManager = context.state.getActiveStateManager();
414
+
416
415
  try {
417
- await stateManager.writeSiloedNullifiersFromPrivate(context.revertibleAccumulatedDataFromPrivate.nullifiers);
418
- } catch (e) {
419
- if (e instanceof NullifierCollisionError) {
420
- // Instead of throwing, revert the app_logic phase
416
+ for (const siloedNullifier of context.revertibleAccumulatedDataFromPrivate.nullifiers.filter(n => !n.isEmpty())) {
417
+ await stateManager.writeSiloedNullifier(siloedNullifier);
418
+ }
419
+ } catch (e: any) {
420
+ if (e instanceof NullifierLimitReachedError || e instanceof NullifierCollisionError) {
421
421
  context.revert(
422
422
  TxExecutionPhase.APP_LOGIC,
423
423
  new SimulationError(
424
- `Nullifier collision encountered when inserting revertible nullifiers from private\nDetails: ${e.message}\nError stack: ${e.stack}`,
424
+ `Error encountered when inserting revertible nullifiers from private.\nDetails: ${e.message}`,
425
425
  [],
426
426
  ),
427
- /*culprit=*/ 'insertRevertiblesFromPrivate',
428
427
  );
429
- return /*success=*/ false;
428
+ throw new TxSimRevertibleInsertionsRevert();
430
429
  } else {
430
+ // Unchecked/unknown error - re-throw as-is
431
431
  throw e;
432
432
  }
433
433
  }
434
- for (const noteHash of context.revertibleAccumulatedDataFromPrivate.noteHashes) {
435
- if (!noteHash.isEmpty()) {
436
- // Revertible note hashes from private are not hashed with nonce, since private can't know their final position, only we can.
437
- await stateManager.writeSiloedNoteHash(noteHash);
434
+
435
+ try {
436
+ for (const noteHash of context.revertibleAccumulatedDataFromPrivate.noteHashes) {
437
+ if (!noteHash.isEmpty()) {
438
+ // Revertible note hashes from private are not hashed with nonce, since private can't know their final position, only we can.
439
+ await stateManager.writeSiloedNoteHash(noteHash);
440
+ }
441
+ }
442
+ } catch (e: any) {
443
+ if (e instanceof NoteHashLimitReachedError) {
444
+ context.revert(
445
+ TxExecutionPhase.APP_LOGIC,
446
+ new SimulationError(
447
+ `Error encountered when inserting revertible note hashes from private.\nDetails: ${e.message}`,
448
+ [],
449
+ ),
450
+ );
451
+ throw new TxSimRevertibleInsertionsRevert();
452
+ } else {
453
+ // Unchecked/unknown error - re-throw as-is
454
+ throw e;
455
+ }
456
+ }
457
+
458
+ try {
459
+ for (const l2ToL1Message of context.revertibleAccumulatedDataFromPrivate.l2ToL1Msgs) {
460
+ if (!l2ToL1Message.isEmpty()) {
461
+ stateManager.writeScopedL2ToL1Message(l2ToL1Message);
462
+ }
463
+ }
464
+ } catch (e: any) {
465
+ if (e instanceof L2ToL1MessageLimitReachedError) {
466
+ context.revert(
467
+ TxExecutionPhase.APP_LOGIC,
468
+ new SimulationError(
469
+ `Error encountered when inserting revertible L2-to-L1 messages from private.\nDetails: ${e.message}`,
470
+ [],
471
+ ),
472
+ );
473
+ throw new TxSimRevertibleInsertionsRevert();
474
+ } else {
475
+ // Unchecked/unknown error - re-throw as-is
476
+ throw e;
438
477
  }
439
478
  }
440
- return /*success=*/ true;
479
+
480
+ // add new contracts to the contracts db so that their functions may be found and called
481
+ // FIXME(fcarreiro): this should conceptually use the hinting contracts db.
482
+ // However, things work as expected because later calls to getters on the hintingContractsDB
483
+ // will pick up the new contracts and will generate the necessary hints.
484
+ // So, a consumer of the hints will always see the new contracts.
485
+ await this.contractsDB.addContracts(context.revertibleContractDeploymentData);
441
486
  }
442
487
 
443
488
  private async payFee(context: PublicTxContext) {
444
489
  const txFee = context.getTransactionFee(TxExecutionPhase.TEARDOWN);
445
490
 
446
491
  if (context.feePayer.isZero()) {
447
- this.log.debug(`No one is paying the fee of ${txFee.toBigInt()}`);
492
+ // Real transactions are enforced by private kernel to have nonzero fee payer.
493
+ // Real transactions cannot skip fee enforcement (skipping fee enforcement makes them unprovable).
494
+ assert(this.config.skipFeeEnforcement, 'Fee payer cannot be 0 unless skipping fee enforcement for simulation');
495
+ this.log.debug(`Fee payer is 0. Skipping fee enforcement. No one is paying the fee of ${txFee.toBigInt()}`);
448
496
  return;
449
497
  }
450
498
 
@@ -459,13 +507,14 @@ export class PublicTxSimulator {
459
507
  // When mocking the balance of the fee payer, the circuit should not be able to prove the simulation
460
508
 
461
509
  if (currentBalance.lt(txFee)) {
462
- if (!this.skipFeeEnforcement) {
463
- throw new Error(
464
- `Not enough balance for fee payer to pay for transaction (got ${currentBalance.toBigInt()} needs ${txFee.toBigInt()})`,
465
- );
466
- } else {
467
- currentBalance = txFee;
468
- }
510
+ // Without "skipFeeEnforcement", such transactions should be filtered by GasTxValidator.
511
+ assert(
512
+ this.config.skipFeeEnforcement,
513
+ `Not enough balance for fee payer to pay for transaction (got ${currentBalance.toBigInt()} needs ${txFee.toBigInt()})`,
514
+ );
515
+ this.log.debug(`Fee payer balance insufficient, but we're skipping fee enforcement`);
516
+ // We still proceed and perform the storage write to minimize deviation from normal execution.
517
+ currentBalance = txFee;
469
518
  }
470
519
 
471
520
  const updatedBalance = currentBalance.sub(txFee);