@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.5daedc8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -0
- package/dest/client.d.ts +6 -4
- package/dest/client.d.ts.map +1 -1
- package/dest/client.js +4 -2
- package/dest/common/errors.d.ts +5 -14
- package/dest/common/errors.d.ts.map +1 -1
- package/dest/common/errors.js +51 -32
- package/dest/common/index.d.ts +1 -2
- package/dest/common/index.d.ts.map +1 -1
- package/dest/common/index.js +0 -1
- package/dest/common/stats/index.d.ts +1 -1
- package/dest/common/stats/stats.d.ts +1 -1
- package/dest/private/acvm/acvm.d.ts +12 -6
- package/dest/private/acvm/acvm.d.ts.map +1 -1
- package/dest/private/acvm/acvm.js +10 -16
- package/dest/private/acvm/acvm_types.d.ts +2 -2
- package/dest/private/acvm/acvm_types.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.d.ts +18 -19
- package/dest/private/acvm/deserialize.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.js +31 -23
- package/dest/private/acvm/index.d.ts +1 -2
- package/dest/private/acvm/index.d.ts.map +1 -1
- package/dest/private/acvm/index.js +0 -1
- package/dest/private/acvm/serialize.d.ts +20 -3
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +53 -0
- package/dest/private/acvm_native.d.ts +39 -0
- package/dest/private/acvm_native.d.ts.map +1 -0
- package/dest/private/{providers/acvm_native.js → acvm_native.js} +26 -20
- package/dest/private/acvm_wasm.d.ts +15 -0
- package/dest/private/acvm_wasm.d.ts.map +1 -0
- package/dest/private/{providers/acvm_wasm.js → acvm_wasm.js} +22 -19
- package/dest/private/acvm_wasm_with_blobs.d.ts +20 -0
- package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -0
- package/dest/private/acvm_wasm_with_blobs.js +35 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts +108 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/circuit_recorder.js +209 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts +31 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/file_circuit_recorder.js +135 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +5 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.js +9 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +21 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.js +44 -0
- package/dest/private/circuit_simulator.d.ts +35 -0
- package/dest/private/circuit_simulator.d.ts.map +1 -0
- package/dest/private/circuit_simulator.js +43 -0
- package/dest/private/factory.d.ts +12 -0
- package/dest/private/factory.d.ts.map +1 -0
- package/dest/private/{providers/factory.js → factory.js} +2 -2
- package/dest/public/avm/avm_context.d.ts +6 -6
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +5 -3
- package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.js +11 -7
- package/dest/public/avm/avm_execution_environment.d.ts +4 -2
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +4 -2
- package/dest/public/avm/avm_gas.d.ts +5 -21
- package/dest/public/avm/avm_gas.d.ts.map +1 -1
- package/dest/public/avm/avm_gas.js +27 -35
- package/dest/public/avm/avm_machine_state.d.ts +3 -1
- package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.js +2 -0
- package/dest/public/avm/avm_memory_types.d.ts +99 -88
- package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.js +17 -6
- package/dest/public/avm/avm_simulator.d.ts +6 -6
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +23 -35
- package/dest/public/avm/avm_simulator_interface.d.ts +9 -0
- package/dest/public/avm/avm_simulator_interface.d.ts.map +1 -0
- package/dest/public/avm/avm_simulator_interface.js +3 -0
- package/dest/public/avm/errors.d.ts +7 -31
- package/dest/public/avm/errors.d.ts.map +1 -1
- package/dest/public/avm/errors.js +7 -57
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +6 -5
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.js +22 -15
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +7 -5
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/base_avm_simulation_tester.js +37 -14
- package/dest/public/avm/fixtures/initializers.d.ts +42 -0
- package/dest/public/avm/fixtures/initializers.d.ts.map +1 -0
- package/dest/public/avm/fixtures/initializers.js +44 -0
- package/dest/public/avm/fixtures/utils.d.ts +38 -0
- package/dest/public/avm/fixtures/utils.d.ts.map +1 -0
- package/dest/public/avm/fixtures/utils.js +95 -0
- package/dest/public/avm/index.d.ts +1 -3
- package/dest/public/avm/index.d.ts.map +1 -1
- package/dest/public/avm/index.js +0 -2
- package/dest/public/avm/opcodes/accrued_substate.d.ts +3 -3
- package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
- package/dest/public/avm/opcodes/accrued_substate.js +28 -25
- package/dest/public/avm/opcodes/addressing_mode.d.ts +12 -8
- package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
- package/dest/public/avm/opcodes/addressing_mode.js +46 -26
- package/dest/public/avm/opcodes/arithmetic.d.ts +17 -7
- package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
- package/dest/public/avm/opcodes/arithmetic.js +16 -2
- package/dest/public/avm/opcodes/bitwise.d.ts +10 -18
- package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
- package/dest/public/avm/opcodes/bitwise.js +19 -26
- package/dest/public/avm/opcodes/comparators.d.ts +4 -4
- package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
- package/dest/public/avm/opcodes/comparators.js +3 -3
- package/dest/public/avm/opcodes/contract.d.ts +2 -3
- package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
- package/dest/public/avm/opcodes/contract.js +9 -10
- package/dest/public/avm/opcodes/control_flow.d.ts +1 -1
- package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
- package/dest/public/avm/opcodes/control_flow.js +10 -8
- package/dest/public/avm/opcodes/conversion.d.ts +2 -1
- package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
- package/dest/public/avm/opcodes/conversion.js +267 -3
- package/dest/public/avm/opcodes/ec_add.d.ts +2 -2
- package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
- package/dest/public/avm/opcodes/ec_add.js +6 -6
- package/dest/public/avm/opcodes/environment_getters.d.ts +3 -3
- package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
- package/dest/public/avm/opcodes/environment_getters.js +17 -19
- package/dest/public/avm/opcodes/external_calls.d.ts +9 -8
- package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
- package/dest/public/avm/opcodes/external_calls.js +39 -34
- package/dest/public/avm/opcodes/hashing.d.ts +2 -2
- package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
- package/dest/public/avm/opcodes/hashing.js +6 -6
- package/dest/public/avm/opcodes/index.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction.d.ts +15 -11
- package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction.js +23 -19
- package/dest/public/avm/opcodes/instruction_impl.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.d.ts +6 -6
- package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.js +37 -33
- package/dest/public/avm/opcodes/misc.d.ts +3 -2
- package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
- package/dest/public/avm/opcodes/misc.js +41 -16
- package/dest/public/avm/opcodes/storage.d.ts +3 -3
- package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
- package/dest/public/avm/opcodes/storage.js +7 -5
- package/dest/public/avm/revert_reason.d.ts +18 -0
- package/dest/public/avm/revert_reason.d.ts.map +1 -0
- package/dest/public/avm/revert_reason.js +38 -0
- package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -3
- package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts +3 -7
- package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.js +70 -69
- package/dest/public/avm/serialization/instruction_serialization.d.ts +14 -5
- package/dest/public/avm/serialization/instruction_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/instruction_serialization.js +70 -35
- package/dest/public/avm/test_utils.d.ts +11 -14
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +16 -24
- package/dest/public/contracts_db_checkpoint.d.ts +16 -0
- package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
- package/dest/public/contracts_db_checkpoint.js +30 -0
- package/dest/public/db_interfaces.d.ts +68 -0
- package/dest/public/db_interfaces.d.ts.map +1 -0
- package/dest/public/db_interfaces.js +3 -0
- package/dest/public/debug_fn_name.d.ts +5 -0
- package/dest/public/debug_fn_name.d.ts.map +1 -0
- package/dest/public/debug_fn_name.js +9 -0
- package/dest/public/executor_metrics.d.ts +12 -4
- package/dest/public/executor_metrics.d.ts.map +1 -1
- package/dest/public/executor_metrics.js +37 -6
- package/dest/public/executor_metrics_interface.d.ts +10 -0
- package/dest/public/executor_metrics_interface.d.ts.map +1 -0
- package/dest/public/executor_metrics_interface.js +1 -0
- package/dest/public/fixtures/amm_test.d.ts +10 -0
- package/dest/public/fixtures/amm_test.d.ts.map +1 -0
- package/dest/public/fixtures/amm_test.js +213 -0
- package/dest/public/fixtures/bulk_test.d.ts +6 -0
- package/dest/public/fixtures/bulk_test.d.ts.map +1 -0
- package/dest/public/fixtures/bulk_test.js +326 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts +12 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tester.js +29 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts +9 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tests.js +109 -0
- package/dest/public/fixtures/index.d.ts +8 -1
- package/dest/public/fixtures/index.d.ts.map +1 -1
- package/dest/public/fixtures/index.js +7 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts +9 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
- package/dest/public/fixtures/minimal_public_tx.js +29 -0
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts +35 -14
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +100 -71
- package/dest/public/fixtures/simple_contract_data_source.d.ts +35 -0
- package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -0
- package/dest/public/{avm/fixtures → fixtures}/simple_contract_data_source.js +31 -10
- package/dest/public/fixtures/token_test.d.ts +8 -0
- package/dest/public/fixtures/token_test.d.ts.map +1 -0
- package/dest/public/fixtures/token_test.js +94 -0
- package/dest/public/fixtures/utils.d.ts +17 -4
- package/dest/public/fixtures/utils.d.ts.map +1 -1
- package/dest/public/fixtures/utils.js +100 -58
- package/dest/public/hinting_db_sources.d.ts +78 -0
- package/dest/public/hinting_db_sources.d.ts.map +1 -0
- package/dest/public/hinting_db_sources.js +350 -0
- package/dest/public/index.d.ts +6 -9
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +4 -7
- package/dest/public/public_db_sources.d.ts +51 -101
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +219 -192
- package/dest/public/public_errors.d.ts +12 -0
- package/dest/public/public_errors.d.ts.map +1 -0
- package/dest/public/public_errors.js +13 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts +49 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -0
- package/dest/public/public_processor/guarded_merkle_tree.js +108 -0
- package/dest/public/public_processor/public_processor.d.ts +25 -37
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +154 -111
- package/dest/public/public_processor/public_processor_metrics.d.ts +3 -3
- package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor_metrics.js +1 -1
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +30 -0
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +133 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +66 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +210 -0
- package/dest/public/public_tx_simulator/index.d.ts +5 -0
- package/dest/public/public_tx_simulator/index.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/index.js +2 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +31 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +51 -0
- package/dest/public/public_tx_simulator/public_tx_context.d.ts +23 -30
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +71 -91
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +36 -58
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_simulator.js +208 -206
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +9 -0
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.js +1 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +21 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +39 -0
- package/dest/public/side_effect_errors.d.ts +42 -2
- package/dest/public/side_effect_errors.d.ts.map +1 -1
- package/dest/public/side_effect_errors.js +70 -1
- package/dest/public/side_effect_trace.d.ts +21 -67
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +71 -121
- package/dest/public/side_effect_trace_interface.d.ts +12 -24
- package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
- package/dest/public/state_manager/index.d.ts +2 -0
- package/dest/public/state_manager/index.d.ts.map +1 -0
- package/dest/public/state_manager/index.js +1 -0
- package/dest/public/{avm/journal → state_manager}/nullifiers.d.ts +3 -6
- package/dest/public/state_manager/nullifiers.d.ts.map +1 -0
- package/dest/public/{avm/journal → state_manager}/nullifiers.js +3 -8
- package/dest/public/{avm/journal → state_manager}/public_storage.d.ts +3 -3
- package/dest/public/state_manager/public_storage.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.d.ts +159 -0
- package/dest/public/state_manager/state_manager.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.js +392 -0
- package/dest/public/test_executor_metrics.d.ts +55 -0
- package/dest/public/test_executor_metrics.d.ts.map +1 -0
- package/dest/public/test_executor_metrics.js +307 -0
- package/dest/public/unique_class_ids.d.ts +1 -1
- package/dest/public/unique_class_ids.d.ts.map +1 -1
- package/dest/public/utils.d.ts +3 -5
- package/dest/public/utils.d.ts.map +1 -1
- package/dest/public/utils.js +4 -21
- package/dest/server.d.ts +7 -4
- package/dest/server.d.ts.map +1 -1
- package/dest/server.js +5 -2
- package/dest/testing.d.ts +2 -0
- package/dest/testing.d.ts.map +1 -0
- package/dest/testing.js +1 -0
- package/package.json +39 -33
- package/src/client.ts +5 -3
- package/src/common/errors.ts +79 -44
- package/src/common/index.ts +0 -1
- package/src/private/acvm/acvm.ts +17 -32
- package/src/private/acvm/acvm_types.ts +1 -1
- package/src/private/acvm/deserialize.ts +35 -29
- package/src/private/acvm/index.ts +0 -1
- package/src/private/acvm/serialize.ts +63 -0
- package/src/private/{providers/acvm_native.ts → acvm_native.ts} +47 -24
- package/src/private/acvm_wasm.ts +72 -0
- package/src/private/acvm_wasm_with_blobs.ts +54 -0
- package/src/private/circuit_recording/circuit_recorder.ts +260 -0
- package/src/private/circuit_recording/file_circuit_recorder.ts +158 -0
- package/src/private/circuit_recording/memory_circuit_recorder.ts +11 -0
- package/src/private/circuit_recording/simulator_recorder_wrapper.ts +91 -0
- package/src/private/circuit_simulator.ts +90 -0
- package/src/private/{providers/factory.ts → factory.ts} +6 -6
- package/src/public/avm/avm_context.ts +4 -4
- package/src/public/avm/avm_contract_call_result.ts +17 -5
- package/src/public/avm/avm_execution_environment.ts +8 -1
- package/src/public/avm/avm_gas.ts +23 -35
- package/src/public/avm/avm_machine_state.ts +5 -0
- package/src/public/avm/avm_memory_types.ts +19 -6
- package/src/public/avm/avm_simulator.ts +43 -54
- package/src/public/avm/avm_simulator_interface.ts +8 -0
- package/src/public/avm/errors.ts +8 -77
- package/src/public/avm/fixtures/avm_simulation_tester.ts +32 -21
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +45 -12
- package/src/public/avm/fixtures/initializers.ts +102 -0
- package/src/public/avm/fixtures/utils.ts +150 -0
- package/src/public/avm/index.ts +0 -2
- package/src/public/avm/opcodes/accrued_substate.ts +64 -29
- package/src/public/avm/opcodes/addressing_mode.ts +56 -32
- package/src/public/avm/opcodes/arithmetic.ts +24 -2
- package/src/public/avm/opcodes/bitwise.ts +33 -29
- package/src/public/avm/opcodes/comparators.ts +6 -3
- package/src/public/avm/opcodes/contract.ts +10 -7
- package/src/public/avm/opcodes/control_flow.ts +19 -10
- package/src/public/avm/opcodes/conversion.ts +27 -3
- package/src/public/avm/opcodes/ec_add.ts +9 -6
- package/src/public/avm/opcodes/environment_getters.ts +27 -22
- package/src/public/avm/opcodes/external_calls.ts +61 -29
- package/src/public/avm/opcodes/hashing.ts +28 -8
- package/src/public/avm/opcodes/instruction.ts +31 -21
- package/src/public/avm/opcodes/memory.ts +71 -32
- package/src/public/avm/opcodes/misc.ts +60 -18
- package/src/public/avm/opcodes/storage.ts +22 -6
- package/src/public/avm/revert_reason.ts +55 -0
- package/src/public/avm/serialization/buffer_cursor.ts +4 -1
- package/src/public/avm/serialization/bytecode_serialization.ts +72 -74
- package/src/public/avm/serialization/instruction_serialization.ts +75 -34
- package/src/public/avm/test_utils.ts +24 -41
- package/src/public/contracts_db_checkpoint.ts +41 -0
- package/src/public/db_interfaces.ts +76 -0
- package/src/{common → public}/debug_fn_name.ts +7 -7
- package/src/public/executor_metrics.ts +56 -6
- package/src/public/executor_metrics_interface.ts +15 -0
- package/src/public/fixtures/amm_test.ts +331 -0
- package/src/public/fixtures/bulk_test.ts +169 -0
- package/src/public/fixtures/custom_bytecode_tester.ts +49 -0
- package/src/public/fixtures/custom_bytecode_tests.ts +135 -0
- package/src/public/fixtures/index.ts +7 -0
- package/src/public/fixtures/minimal_public_tx.ts +35 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +166 -113
- package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +36 -18
- package/src/public/fixtures/token_test.ts +139 -0
- package/src/public/fixtures/utils.ts +141 -68
- package/src/public/hinting_db_sources.ts +602 -0
- package/src/public/index.ts +5 -8
- package/src/public/public_db_sources.ts +278 -258
- package/src/public/public_errors.ts +14 -0
- package/src/public/public_processor/guarded_merkle_tree.ts +153 -0
- package/src/public/public_processor/public_processor.ts +212 -164
- package/src/public/public_processor/public_processor_metrics.ts +2 -2
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +162 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +306 -0
- package/src/public/public_tx_simulator/index.ts +4 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +105 -0
- package/src/public/public_tx_simulator/public_tx_context.ts +167 -194
- package/src/public/public_tx_simulator/public_tx_simulator.ts +292 -265
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +10 -0
- package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +63 -0
- package/src/public/side_effect_errors.ts +91 -1
- package/src/public/side_effect_trace.ts +94 -320
- package/src/public/side_effect_trace_interface.ts +10 -58
- package/src/public/state_manager/index.ts +1 -0
- package/src/public/{avm/journal → state_manager}/nullifiers.ts +5 -11
- package/src/public/{avm/journal → state_manager}/public_storage.ts +2 -2
- package/src/public/state_manager/state_manager.ts +553 -0
- package/src/public/test_executor_metrics.ts +397 -0
- package/src/public/utils.ts +5 -21
- package/src/server.ts +6 -3
- package/src/testing.ts +1 -0
- package/dest/common/db_interfaces.d.ts +0 -80
- package/dest/common/db_interfaces.d.ts.map +0 -1
- package/dest/common/db_interfaces.js +0 -1
- package/dest/common/debug_fn_name.d.ts +0 -5
- package/dest/common/debug_fn_name.d.ts.map +0 -1
- package/dest/common/debug_fn_name.js +0 -6
- package/dest/common/message_load_oracle_inputs.d.ts +0 -15
- package/dest/common/message_load_oracle_inputs.d.ts.map +0 -1
- package/dest/common/message_load_oracle_inputs.js +0 -15
- package/dest/private/acvm/oracle/index.d.ts +0 -14
- package/dest/private/acvm/oracle/index.d.ts.map +0 -1
- package/dest/private/acvm/oracle/index.js +0 -2
- package/dest/private/acvm/oracle/oracle.d.ts +0 -49
- package/dest/private/acvm/oracle/oracle.d.ts.map +0 -1
- package/dest/private/acvm/oracle/oracle.js +0 -263
- package/dest/private/acvm/oracle/typed_oracle.d.ts +0 -83
- package/dest/private/acvm/oracle/typed_oracle.d.ts.map +0 -1
- package/dest/private/acvm/oracle/typed_oracle.js +0 -132
- package/dest/private/execution_data_provider.d.ts +0 -261
- package/dest/private/execution_data_provider.d.ts.map +0 -1
- package/dest/private/execution_data_provider.js +0 -14
- package/dest/private/execution_note_cache.d.ts +0 -93
- package/dest/private/execution_note_cache.d.ts.map +0 -1
- package/dest/private/execution_note_cache.js +0 -180
- package/dest/private/hashed_values_cache.d.ts +0 -28
- package/dest/private/hashed_values_cache.d.ts.map +0 -1
- package/dest/private/hashed_values_cache.js +0 -46
- package/dest/private/index.d.ts +0 -13
- package/dest/private/index.d.ts.map +0 -1
- package/dest/private/index.js +0 -12
- package/dest/private/pick_notes.d.ts +0 -85
- package/dest/private/pick_notes.d.ts.map +0 -1
- package/dest/private/pick_notes.js +0 -51
- package/dest/private/private_execution.d.ts +0 -25
- package/dest/private/private_execution.d.ts.map +0 -1
- package/dest/private/private_execution.js +0 -92
- package/dest/private/private_execution_oracle.d.ts +0 -215
- package/dest/private/private_execution_oracle.d.ts.map +0 -1
- package/dest/private/private_execution_oracle.js +0 -382
- package/dest/private/providers/acvm_native.d.ts +0 -40
- package/dest/private/providers/acvm_native.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm.d.ts +0 -15
- package/dest/private/providers/acvm_wasm.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm_with_blobs.d.ts +0 -19
- package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm_with_blobs.js +0 -32
- package/dest/private/providers/factory.d.ts +0 -12
- package/dest/private/providers/factory.d.ts.map +0 -1
- package/dest/private/providers/simulation_provider.d.ts +0 -19
- package/dest/private/providers/simulation_provider.d.ts.map +0 -1
- package/dest/private/providers/simulation_provider.js +0 -24
- package/dest/private/simulator.d.ts +0 -34
- package/dest/private/simulator.d.ts.map +0 -1
- package/dest/private/simulator.js +0 -76
- package/dest/private/unconstrained_execution.d.ts +0 -10
- package/dest/private/unconstrained_execution.d.ts.map +0 -1
- package/dest/private/unconstrained_execution.js +0 -27
- package/dest/private/unconstrained_execution_oracle.d.ts +0 -161
- package/dest/private/unconstrained_execution_oracle.d.ts.map +0 -1
- package/dest/private/unconstrained_execution_oracle.js +0 -258
- package/dest/public/avm/bytecode_utils.d.ts +0 -5
- package/dest/public/avm/bytecode_utils.d.ts.map +0 -1
- package/dest/public/avm/bytecode_utils.js +0 -17
- package/dest/public/avm/fixtures/index.d.ts +0 -84
- package/dest/public/avm/fixtures/index.d.ts.map +0 -1
- package/dest/public/avm/fixtures/index.js +0 -175
- package/dest/public/avm/fixtures/simple_contract_data_source.d.ts +0 -35
- package/dest/public/avm/fixtures/simple_contract_data_source.d.ts.map +0 -1
- package/dest/public/avm/journal/index.d.ts +0 -2
- package/dest/public/avm/journal/index.d.ts.map +0 -1
- package/dest/public/avm/journal/index.js +0 -1
- package/dest/public/avm/journal/journal.d.ts +0 -209
- package/dest/public/avm/journal/journal.d.ts.map +0 -1
- package/dest/public/avm/journal/journal.js +0 -486
- package/dest/public/avm/journal/nullifiers.d.ts.map +0 -1
- package/dest/public/avm/journal/public_storage.d.ts.map +0 -1
- package/dest/public/bytecode_errors.d.ts +0 -4
- package/dest/public/bytecode_errors.d.ts.map +0 -1
- package/dest/public/bytecode_errors.js +0 -6
- package/dest/public/execution.d.ts +0 -108
- package/dest/public/execution.d.ts.map +0 -1
- package/dest/public/execution.js +0 -9
- package/dest/public/tx_contract_cache.d.ts +0 -41
- package/dest/public/tx_contract_cache.d.ts.map +0 -1
- package/dest/public/tx_contract_cache.js +0 -49
- package/dest/test/utils.d.ts +0 -13
- package/dest/test/utils.d.ts.map +0 -1
- package/dest/test/utils.js +0 -22
- package/src/common/db_interfaces.ts +0 -94
- package/src/common/message_load_oracle_inputs.ts +0 -15
- package/src/private/acvm/oracle/index.ts +0 -16
- package/src/private/acvm/oracle/oracle.ts +0 -455
- package/src/private/acvm/oracle/typed_oracle.ts +0 -259
- package/src/private/execution_data_provider.ts +0 -323
- package/src/private/execution_note_cache.ts +0 -217
- package/src/private/hashed_values_cache.ts +0 -55
- package/src/private/index.ts +0 -16
- package/src/private/pick_notes.ts +0 -141
- package/src/private/private_execution.ts +0 -151
- package/src/private/private_execution_oracle.ts +0 -614
- package/src/private/providers/acvm_wasm.ts +0 -63
- package/src/private/providers/acvm_wasm_with_blobs.ts +0 -50
- package/src/private/providers/simulation_provider.ts +0 -45
- package/src/private/simulator.ts +0 -147
- package/src/private/unconstrained_execution.ts +0 -50
- package/src/private/unconstrained_execution_oracle.ts +0 -373
- package/src/public/avm/bytecode_utils.ts +0 -17
- package/src/public/avm/fixtures/index.ts +0 -296
- package/src/public/avm/journal/index.ts +0 -1
- package/src/public/avm/journal/journal.ts +0 -742
- package/src/public/avm/opcodes/.eslintrc.cjs +0 -8
- package/src/public/bytecode_errors.ts +0 -6
- package/src/public/execution.ts +0 -140
- package/src/public/tx_contract_cache.ts +0 -69
- package/src/test/utils.ts +0 -36
- /package/dest/public/{avm/journal → state_manager}/public_storage.js +0 -0
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { AvmCircuitInputs, type PublicTxResult } from '@aztec/stdlib/avm';
|
|
2
|
+
import { ProtocolContracts } from '@aztec/stdlib/tx';
|
|
3
|
+
|
|
4
|
+
import avmMinimalCircuitInputsJson from '../../../artifacts/avm_minimal_inputs.json' with { type: 'json' };
|
|
5
|
+
import { TypeTag } from '../avm/avm_memory_types.js';
|
|
6
|
+
import { Add, Return, Set } from '../avm/opcodes/index.js';
|
|
7
|
+
import { encodeToBytecode } from '../avm/serialization/bytecode_serialization.js';
|
|
8
|
+
import { Opcode } from '../avm/serialization/instruction_serialization.js';
|
|
9
|
+
import { testCustomBytecode } from './custom_bytecode_tester.js';
|
|
10
|
+
import { PublicTxSimulationTester } from './public_tx_simulation_tester.js';
|
|
11
|
+
|
|
12
|
+
export async function executeAvmMinimalPublicTx(tester: PublicTxSimulationTester): Promise<PublicTxResult> {
|
|
13
|
+
const minimalBytecode = encodeToBytecode([
|
|
14
|
+
new Set(/*indirect*/ 0, /*dstOffset*/ 0, TypeTag.UINT32, /*value*/ 1).as(Opcode.SET_8, Set.wireFormat8),
|
|
15
|
+
new Set(/*indirect*/ 0, /*dstOffset*/ 1, TypeTag.UINT32, /*value*/ 2).as(Opcode.SET_8, Set.wireFormat8),
|
|
16
|
+
new Add(/*indirect=*/ 0, /*aOffset=*/ 0, /*bOffset=*/ 1, /*dstOffset=*/ 2).as(Opcode.ADD_8, Add.wireFormat8),
|
|
17
|
+
new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 2),
|
|
18
|
+
]);
|
|
19
|
+
|
|
20
|
+
const result = await testCustomBytecode(minimalBytecode, tester, 'MinimalTx', 'AvmMinimalContract');
|
|
21
|
+
|
|
22
|
+
// Modify the protocol contracts to be all zeros
|
|
23
|
+
result.hints!.protocolContracts = ProtocolContracts.empty();
|
|
24
|
+
result.publicInputs.protocolContracts = ProtocolContracts.empty();
|
|
25
|
+
|
|
26
|
+
return result;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Reads the AVM circuit inputs for the minimal public tx from a pre-generated JSON file.
|
|
31
|
+
* @returns The AvmCircuitInputs for the minimal public tx.
|
|
32
|
+
*/
|
|
33
|
+
export function readAvmMinimalPublicTxInputsFromFile(): AvmCircuitInputs {
|
|
34
|
+
return AvmCircuitInputs.schema.parse(avmMinimalCircuitInputsJson);
|
|
35
|
+
}
|
|
@@ -1,25 +1,34 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { DEFAULT_TEARDOWN_DA_GAS_LIMIT, DEFAULT_TEARDOWN_L2_GAS_LIMIT } from '@aztec/constants';
|
|
2
|
+
import { asyncMap } from '@aztec/foundation/async-map';
|
|
2
3
|
import { Fr } from '@aztec/foundation/fields';
|
|
3
|
-
import { type ContractArtifact,
|
|
4
|
+
import { type ContractArtifact, encodeArguments } from '@aztec/stdlib/abi';
|
|
5
|
+
import { PublicSimulatorConfig, type PublicTxResult } from '@aztec/stdlib/avm';
|
|
4
6
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
5
|
-
import { GasFees } from '@aztec/stdlib/gas';
|
|
7
|
+
import { Gas, GasFees } from '@aztec/stdlib/gas';
|
|
6
8
|
import type { MerkleTreeWriteOperations } from '@aztec/stdlib/interfaces/server';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
+
import { PublicCallRequest } from '@aztec/stdlib/kernel';
|
|
10
|
+
import { GlobalVariables, PublicCallRequestWithCalldata, type Tx } from '@aztec/stdlib/tx';
|
|
9
11
|
import { NativeWorldStateService } from '@aztec/world-state';
|
|
10
12
|
|
|
11
13
|
import { BaseAvmSimulationTester } from '../avm/fixtures/base_avm_simulation_tester.js';
|
|
12
|
-
import {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
14
|
+
import {
|
|
15
|
+
DEFAULT_BLOCK_NUMBER,
|
|
16
|
+
DEFAULT_TIMESTAMP,
|
|
17
|
+
getContractFunctionAbi,
|
|
18
|
+
getFunctionSelector,
|
|
19
|
+
} from '../avm/fixtures/utils.js';
|
|
20
|
+
import { PublicContractsDB } from '../public_db_sources.js';
|
|
21
|
+
import { MeasuredCppPublicTxSimulator } from '../public_tx_simulator/cpp_public_tx_simulator.js';
|
|
22
|
+
import { MeasuredPublicTxSimulator } from '../public_tx_simulator/measured_public_tx_simulator.js';
|
|
23
|
+
import type { MeasuredPublicTxSimulatorInterface } from '../public_tx_simulator/public_tx_simulator_interface.js';
|
|
24
|
+
import { TestExecutorMetrics } from '../test_executor_metrics.js';
|
|
25
|
+
import { SimpleContractDataSource } from './simple_contract_data_source.js';
|
|
26
|
+
import { type TestPrivateInsertions, createTxForPublicCalls } from './utils.js';
|
|
17
27
|
|
|
18
|
-
const TIMESTAMP = new Fr(99833);
|
|
19
28
|
const DEFAULT_GAS_FEES = new GasFees(2, 3);
|
|
20
|
-
export const DEFAULT_BLOCK_NUMBER = 42;
|
|
21
29
|
|
|
22
30
|
export type TestEnqueuedCall = {
|
|
31
|
+
sender?: AztecAddress;
|
|
23
32
|
address: AztecAddress;
|
|
24
33
|
fnName: string;
|
|
25
34
|
args: any[];
|
|
@@ -27,27 +36,54 @@ export type TestEnqueuedCall = {
|
|
|
27
36
|
contractArtifact?: ContractArtifact;
|
|
28
37
|
};
|
|
29
38
|
|
|
39
|
+
const defaultConfig: PublicSimulatorConfig = PublicSimulatorConfig.from({
|
|
40
|
+
skipFeeEnforcement: false,
|
|
41
|
+
collectCallMetadata: true,
|
|
42
|
+
collectDebugLogs: true,
|
|
43
|
+
collectHints: false,
|
|
44
|
+
collectStatistics: false,
|
|
45
|
+
});
|
|
46
|
+
|
|
30
47
|
/**
|
|
31
48
|
* A test class that extends the BaseAvmSimulationTester to enable real-app testing of the PublicTxSimulator.
|
|
32
49
|
* It provides an interface for simulating one transaction at a time and maintains state between subsequent
|
|
33
50
|
* transactions.
|
|
34
51
|
*/
|
|
35
52
|
export class PublicTxSimulationTester extends BaseAvmSimulationTester {
|
|
36
|
-
|
|
53
|
+
protected txCount: number = 0;
|
|
54
|
+
private simulator: MeasuredPublicTxSimulatorInterface;
|
|
55
|
+
private metricsPrefix?: string;
|
|
37
56
|
|
|
38
57
|
constructor(
|
|
39
|
-
|
|
58
|
+
merkleTree: MerkleTreeWriteOperations,
|
|
40
59
|
contractDataSource: SimpleContractDataSource,
|
|
41
|
-
|
|
60
|
+
globals: GlobalVariables = defaultGlobals(),
|
|
61
|
+
private metrics: TestExecutorMetrics = new TestExecutorMetrics(),
|
|
62
|
+
useCppSimulator: boolean = false,
|
|
63
|
+
config: PublicSimulatorConfig = defaultConfig,
|
|
42
64
|
) {
|
|
43
|
-
super(contractDataSource,
|
|
65
|
+
super(contractDataSource, merkleTree);
|
|
66
|
+
|
|
67
|
+
const contractsDB = new PublicContractsDB(contractDataSource);
|
|
68
|
+
this.simulator = useCppSimulator
|
|
69
|
+
? new MeasuredCppPublicTxSimulator(merkleTree, contractsDB, globals, this.metrics, config)
|
|
70
|
+
: new MeasuredPublicTxSimulator(merkleTree, contractsDB, globals, this.metrics, config);
|
|
44
71
|
}
|
|
45
72
|
|
|
46
|
-
public static async create(
|
|
73
|
+
public static async create(
|
|
74
|
+
worldStateService: NativeWorldStateService, // make sure to close this later
|
|
75
|
+
globals: GlobalVariables = defaultGlobals(),
|
|
76
|
+
metrics: TestExecutorMetrics = new TestExecutorMetrics(),
|
|
77
|
+
useCppSimulator = false,
|
|
78
|
+
config: PublicSimulatorConfig = defaultConfig,
|
|
79
|
+
): Promise<PublicTxSimulationTester> {
|
|
47
80
|
const contractDataSource = new SimpleContractDataSource();
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
|
|
81
|
+
const merkleTree = await worldStateService.fork();
|
|
82
|
+
return new PublicTxSimulationTester(merkleTree, contractDataSource, globals, metrics, useCppSimulator, config);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
public setMetricsPrefix(prefix: string) {
|
|
86
|
+
this.metricsPrefix = prefix;
|
|
51
87
|
}
|
|
52
88
|
|
|
53
89
|
public async createTx(
|
|
@@ -57,69 +93,29 @@ export class PublicTxSimulationTester extends BaseAvmSimulationTester {
|
|
|
57
93
|
teardownCall?: TestEnqueuedCall,
|
|
58
94
|
feePayer: AztecAddress = sender,
|
|
59
95
|
/* need some unique first nullifier for note-nonce computations */
|
|
60
|
-
|
|
96
|
+
privateInsertions: TestPrivateInsertions = { nonRevertible: { nullifiers: [new Fr(420000 + this.txCount)] } },
|
|
61
97
|
): Promise<Tx> {
|
|
62
|
-
const
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
setupExecutionRequests.push(req);
|
|
79
|
-
}
|
|
80
|
-
const appExecutionRequests: PublicExecutionRequest[] = [];
|
|
81
|
-
for (let i = 0; i < appCalls.length; i++) {
|
|
82
|
-
const address = appCalls[i].address;
|
|
83
|
-
const contractArtifact =
|
|
84
|
-
appCalls[i].contractArtifact || (await this.contractDataSource.getContractArtifact(address));
|
|
85
|
-
if (!contractArtifact) {
|
|
86
|
-
throw new Error(`Contract artifact not found for address: ${address}`);
|
|
87
|
-
}
|
|
88
|
-
const req = await executionRequestForCall(
|
|
89
|
-
contractArtifact,
|
|
90
|
-
sender,
|
|
91
|
-
address,
|
|
92
|
-
appCalls[i].fnName,
|
|
93
|
-
appCalls[i].args,
|
|
94
|
-
appCalls[i].isStaticCall,
|
|
95
|
-
);
|
|
96
|
-
appExecutionRequests.push(req);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
let teardownExecutionRequest: PublicExecutionRequest | undefined = undefined;
|
|
100
|
-
if (teardownCall) {
|
|
101
|
-
const address = teardownCall.address;
|
|
102
|
-
const contractArtifact =
|
|
103
|
-
teardownCall.contractArtifact || (await this.contractDataSource.getContractArtifact(address));
|
|
104
|
-
if (!contractArtifact) {
|
|
105
|
-
throw new Error(`Contract artifact not found for address: ${address}`);
|
|
106
|
-
}
|
|
107
|
-
teardownExecutionRequest = await executionRequestForCall(
|
|
108
|
-
contractArtifact,
|
|
109
|
-
sender,
|
|
110
|
-
address,
|
|
111
|
-
teardownCall.fnName,
|
|
112
|
-
teardownCall.args,
|
|
113
|
-
teardownCall.isStaticCall,
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
return await createTxForPublicCalls(
|
|
118
|
-
firstNullifier,
|
|
119
|
-
setupExecutionRequests,
|
|
120
|
-
appExecutionRequests,
|
|
121
|
-
teardownExecutionRequest,
|
|
98
|
+
const setupCallRequests = await asyncMap(setupCalls, call =>
|
|
99
|
+
this.#createPubicCallRequestForCall(call, call.sender ?? sender),
|
|
100
|
+
);
|
|
101
|
+
const appCallRequests = await asyncMap(appCalls, call =>
|
|
102
|
+
this.#createPubicCallRequestForCall(call, call.sender ?? sender),
|
|
103
|
+
);
|
|
104
|
+
const teardownCallRequest = teardownCall
|
|
105
|
+
? await this.#createPubicCallRequestForCall(teardownCall, teardownCall.sender ?? sender)
|
|
106
|
+
: undefined;
|
|
107
|
+
|
|
108
|
+
this.txCount++;
|
|
109
|
+
return createTxForPublicCalls(
|
|
110
|
+
privateInsertions,
|
|
111
|
+
setupCallRequests,
|
|
112
|
+
appCallRequests,
|
|
113
|
+
teardownCallRequest,
|
|
122
114
|
feePayer,
|
|
115
|
+
/*gasUsedByPrivate*/ teardownCall
|
|
116
|
+
? new Gas(DEFAULT_TEARDOWN_DA_GAS_LIMIT, DEFAULT_TEARDOWN_L2_GAS_LIMIT)
|
|
117
|
+
: Gas.empty(),
|
|
118
|
+
defaultGlobals(),
|
|
123
119
|
);
|
|
124
120
|
}
|
|
125
121
|
|
|
@@ -130,50 +126,107 @@ export class PublicTxSimulationTester extends BaseAvmSimulationTester {
|
|
|
130
126
|
teardownCall?: TestEnqueuedCall,
|
|
131
127
|
feePayer: AztecAddress = sender,
|
|
132
128
|
/* need some unique first nullifier for note-nonce computations */
|
|
133
|
-
|
|
134
|
-
|
|
129
|
+
privateInsertions?: TestPrivateInsertions,
|
|
130
|
+
txLabel: string = 'unlabeledTx',
|
|
135
131
|
): Promise<PublicTxResult> {
|
|
136
|
-
const tx = await this.createTx(sender, setupCalls, appCalls, teardownCall, feePayer,
|
|
132
|
+
const tx = await this.createTx(sender, setupCalls, appCalls, teardownCall, feePayer, privateInsertions);
|
|
137
133
|
|
|
138
134
|
await this.setFeePayerBalance(feePayer);
|
|
139
135
|
|
|
140
|
-
const
|
|
136
|
+
const txLabelWithCount = `${txLabel}/${this.txCount - 1}`;
|
|
137
|
+
const fullTxLabel = this.metricsPrefix ? `${this.metricsPrefix}/${txLabelWithCount}` : txLabelWithCount;
|
|
138
|
+
|
|
139
|
+
const avmResult = await this.simulator.simulate(tx, fullTxLabel);
|
|
140
|
+
|
|
141
|
+
// Something like this is often useful for debugging:
|
|
142
|
+
//if (avmResult.revertReason) {
|
|
143
|
+
// // resolve / enrich revert reason
|
|
144
|
+
// const lastAppCall = appCalls[appCalls.length - 1];
|
|
141
145
|
|
|
142
|
-
const
|
|
143
|
-
|
|
144
|
-
const
|
|
145
|
-
|
|
146
|
+
// const contractArtifact =
|
|
147
|
+
// lastAppCall.contractArtifact || (await this.contractDataSource.getContractArtifact(lastAppCall.address));
|
|
148
|
+
// const fnAbi = getContractFunctionAbi(lastAppCall.fnName, contractArtifact!);
|
|
149
|
+
// const revertReason = resolveAssertionMessageFromRevertData(avmResult.revertReason.revertData, fnAbi!);
|
|
150
|
+
// this.logger.debug(`Revert reason: ${revertReason}`);
|
|
151
|
+
//}
|
|
146
152
|
|
|
147
153
|
return avmResult;
|
|
148
154
|
}
|
|
149
|
-
}
|
|
150
155
|
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
156
|
+
/**
|
|
157
|
+
* Just simulate the transaction and return the result.
|
|
158
|
+
*
|
|
159
|
+
* This wrapper around simulation allows for easy labeling of a TX
|
|
160
|
+
* which is especially useful when reporting benchmarks or metrics.
|
|
161
|
+
*/
|
|
162
|
+
public async simulateTxWithLabel(
|
|
163
|
+
txLabel: string,
|
|
164
|
+
sender: AztecAddress,
|
|
165
|
+
setupCalls?: TestEnqueuedCall[],
|
|
166
|
+
appCalls?: TestEnqueuedCall[],
|
|
167
|
+
teardownCall?: TestEnqueuedCall,
|
|
168
|
+
feePayer?: AztecAddress,
|
|
169
|
+
privateInsertions?: TestPrivateInsertions,
|
|
170
|
+
): Promise<PublicTxResult> {
|
|
171
|
+
return await this.simulateTx(sender, setupCalls, appCalls, teardownCall, feePayer, privateInsertions, txLabel);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
/**
|
|
175
|
+
* Execute a transaction and return the result.
|
|
176
|
+
*
|
|
177
|
+
* This function can be (it is) overridden by a subclass (AvmProvingTester)
|
|
178
|
+
* to do more work (like prove and verify) while still reusing existing
|
|
179
|
+
* test fixtures (like amm_test). That is why it is not named "simulate*".
|
|
180
|
+
*/
|
|
181
|
+
public async executeTxWithLabel(
|
|
182
|
+
txLabel: string,
|
|
183
|
+
sender: AztecAddress,
|
|
184
|
+
setupCalls?: TestEnqueuedCall[],
|
|
185
|
+
appCalls?: TestEnqueuedCall[],
|
|
186
|
+
teardownCall?: TestEnqueuedCall,
|
|
187
|
+
feePayer?: AztecAddress,
|
|
188
|
+
privateInsertions?: TestPrivateInsertions,
|
|
189
|
+
): Promise<PublicTxResult> {
|
|
190
|
+
return await this.simulateTxWithLabel(
|
|
191
|
+
txLabel,
|
|
192
|
+
sender,
|
|
193
|
+
setupCalls,
|
|
194
|
+
appCalls,
|
|
195
|
+
teardownCall,
|
|
196
|
+
feePayer,
|
|
197
|
+
privateInsertions,
|
|
198
|
+
);
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
public prettyPrintMetrics() {
|
|
202
|
+
this.metrics.prettyPrint();
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
async #createPubicCallRequestForCall(
|
|
206
|
+
call: TestEnqueuedCall,
|
|
207
|
+
sender: AztecAddress,
|
|
208
|
+
): Promise<PublicCallRequestWithCalldata> {
|
|
209
|
+
const address = call.address;
|
|
210
|
+
const contractArtifact = call.contractArtifact || (await this.contractDataSource.getContractArtifact(address));
|
|
211
|
+
if (!contractArtifact) {
|
|
212
|
+
throw new Error(`Contract artifact not found for address: ${address}`);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
const fnSelector = await getFunctionSelector(call.fnName, contractArtifact);
|
|
216
|
+
const fnAbi = getContractFunctionAbi(call.fnName, contractArtifact)!;
|
|
217
|
+
const encodedArgs = encodeArguments(fnAbi, call.args);
|
|
218
|
+
const calldata = [fnSelector.toField(), ...encodedArgs];
|
|
219
|
+
const isStaticCall = call.isStaticCall ?? false;
|
|
220
|
+
const request = await PublicCallRequest.fromCalldata(sender, address, isStaticCall, calldata);
|
|
221
|
+
|
|
222
|
+
return new PublicCallRequestWithCalldata(request, calldata);
|
|
223
|
+
}
|
|
171
224
|
}
|
|
172
225
|
|
|
173
|
-
function defaultGlobals() {
|
|
226
|
+
export function defaultGlobals() {
|
|
174
227
|
const globals = GlobalVariables.empty();
|
|
175
|
-
globals.timestamp =
|
|
228
|
+
globals.timestamp = DEFAULT_TIMESTAMP;
|
|
176
229
|
globals.gasFees = DEFAULT_GAS_FEES; // apply some nonzero default gas fees
|
|
177
|
-
globals.blockNumber =
|
|
230
|
+
globals.blockNumber = DEFAULT_BLOCK_NUMBER;
|
|
178
231
|
return globals;
|
|
179
232
|
}
|
|
@@ -1,15 +1,10 @@
|
|
|
1
1
|
import type { Fr } from '@aztec/foundation/fields';
|
|
2
2
|
import { createLogger } from '@aztec/foundation/log';
|
|
3
|
-
import {
|
|
3
|
+
import type { ContractArtifact, FunctionSelector } from '@aztec/stdlib/abi';
|
|
4
4
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
5
|
-
import type {
|
|
6
|
-
ContractClassPublic,
|
|
7
|
-
ContractDataSource,
|
|
8
|
-
ContractInstanceWithAddress,
|
|
9
|
-
PublicFunction,
|
|
10
|
-
} from '@aztec/stdlib/contract';
|
|
5
|
+
import type { ContractClassPublic, ContractDataSource, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
11
6
|
|
|
12
|
-
import {
|
|
7
|
+
import { getFunctionSelector } from '../avm/fixtures/utils.js';
|
|
13
8
|
|
|
14
9
|
/**
|
|
15
10
|
* This class is used during public/avm testing to function as a database of
|
|
@@ -27,6 +22,8 @@ export class SimpleContractDataSource implements ContractDataSource {
|
|
|
27
22
|
private contractInstances: Map<string, ContractInstanceWithAddress> = new Map();
|
|
28
23
|
// maps contract instance address to address
|
|
29
24
|
private contractArtifacts: Map<string, ContractArtifact> = new Map();
|
|
25
|
+
// maps `${classID}:${fnSelector}` to name
|
|
26
|
+
private debugFunctionName: Map<string, string> = new Map();
|
|
30
27
|
|
|
31
28
|
/////////////////////////////////////////////////////////////
|
|
32
29
|
// Helper functions not in the contract data source interface
|
|
@@ -39,21 +36,29 @@ export class SimpleContractDataSource implements ContractDataSource {
|
|
|
39
36
|
contractClass: ContractClassPublic,
|
|
40
37
|
contractInstance: ContractInstanceWithAddress,
|
|
41
38
|
) {
|
|
42
|
-
this.addContractArtifact(contractClass.id, contractArtifact);
|
|
39
|
+
await this.addContractArtifact(contractClass.id, contractArtifact);
|
|
43
40
|
await this.addContractClass(contractClass);
|
|
44
41
|
await this.addContractInstance(contractInstance);
|
|
45
42
|
}
|
|
46
43
|
|
|
47
|
-
addContractArtifact(classId: Fr, artifact: ContractArtifact)
|
|
44
|
+
async addContractArtifact(classId: Fr, artifact: ContractArtifact) {
|
|
48
45
|
this.contractArtifacts.set(classId.toString(), artifact);
|
|
46
|
+
const classIdStr = classId.toString();
|
|
47
|
+
const publicFns = artifact.nonDispatchPublicFunctions;
|
|
48
|
+
if (publicFns.length !== 0) {
|
|
49
|
+
for (const fn of publicFns) {
|
|
50
|
+
const actualFnName = `${fn.name}`;
|
|
51
|
+
const fnSelector = await getFunctionSelector(actualFnName, artifact);
|
|
52
|
+
const key = `${classIdStr}:${fnSelector.toString()}`;
|
|
53
|
+
|
|
54
|
+
const longFnName = `${artifact.name}.${actualFnName}`;
|
|
55
|
+
this.debugFunctionName.set(key, longFnName);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
49
58
|
}
|
|
50
59
|
|
|
51
60
|
/////////////////////////////////////////////////////////////
|
|
52
61
|
// ContractDataSource function implementations
|
|
53
|
-
getPublicFunction(_address: AztecAddress, _selector: FunctionSelector): Promise<PublicFunction> {
|
|
54
|
-
throw new Error('Method not implemented.');
|
|
55
|
-
}
|
|
56
|
-
|
|
57
62
|
getBlockNumber(): Promise<number> {
|
|
58
63
|
throw new Error('Method not implemented.');
|
|
59
64
|
}
|
|
@@ -82,14 +87,27 @@ export class SimpleContractDataSource implements ContractDataSource {
|
|
|
82
87
|
}
|
|
83
88
|
this.logger.debug(`Retrieved contract artifact for address: ${address}`);
|
|
84
89
|
this.logger.debug(`Contract class ID: ${contractInstance.currentContractClassId}`);
|
|
85
|
-
return
|
|
90
|
+
return this.contractArtifacts.get(contractInstance!.currentContractClassId.toString());
|
|
86
91
|
}
|
|
87
92
|
|
|
88
|
-
|
|
89
|
-
|
|
93
|
+
async getDebugFunctionName(address: AztecAddress, selector: FunctionSelector): Promise<string> {
|
|
94
|
+
const contractInstance = await this.getContract(address);
|
|
95
|
+
if (!contractInstance) {
|
|
96
|
+
this.logger.warn(
|
|
97
|
+
`Couldn't get fn name for debugging. Contract not in tester's ContractDataSource. Using selector:${selector} instead...`,
|
|
98
|
+
);
|
|
99
|
+
return `selector:${selector.toString()}`;
|
|
100
|
+
}
|
|
101
|
+
const key = `${contractInstance.currentContractClassId.toString()}:${selector.toString()}`;
|
|
102
|
+
const fnName = this.debugFunctionName.get(key);
|
|
103
|
+
if (!fnName) {
|
|
104
|
+
this.logger.warn(`Couldn't get fn name for debugging. Using selector:${selector} instead...`);
|
|
105
|
+
return selector.toString();
|
|
106
|
+
}
|
|
107
|
+
return fnName;
|
|
90
108
|
}
|
|
91
109
|
|
|
92
|
-
registerContractFunctionSignatures(
|
|
110
|
+
registerContractFunctionSignatures(_signatures: string[]): Promise<void> {
|
|
93
111
|
return Promise.resolve();
|
|
94
112
|
}
|
|
95
113
|
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
|
+
import type { Logger } from '@aztec/foundation/log';
|
|
3
|
+
import { Timer } from '@aztec/foundation/timer';
|
|
4
|
+
import type { ContractArtifact } from '@aztec/stdlib/abi';
|
|
5
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
6
|
+
import type { ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
7
|
+
|
|
8
|
+
import { PublicTxSimulationTester } from './public_tx_simulation_tester.js';
|
|
9
|
+
|
|
10
|
+
export async function tokenTest(
|
|
11
|
+
tester: PublicTxSimulationTester,
|
|
12
|
+
logger: Logger,
|
|
13
|
+
tokenArtifact: ContractArtifact,
|
|
14
|
+
expectToBeTrue: (x: boolean) => void,
|
|
15
|
+
) {
|
|
16
|
+
const timer = new Timer();
|
|
17
|
+
|
|
18
|
+
const admin = AztecAddress.fromNumber(42);
|
|
19
|
+
const sender = AztecAddress.fromNumber(111);
|
|
20
|
+
const receiver = AztecAddress.fromNumber(222);
|
|
21
|
+
|
|
22
|
+
const token = await setUpToken(tester, tokenArtifact, admin, expectToBeTrue);
|
|
23
|
+
|
|
24
|
+
const mintAmount = 100n;
|
|
25
|
+
// EXECUTE! This means that if using AvmProvingTester subclass, it will PROVE the transaction!
|
|
26
|
+
const mintResult = await tester.executeTxWithLabel(
|
|
27
|
+
/*txLabel=*/ 'Token/mint_to_public',
|
|
28
|
+
/*sender=*/ admin,
|
|
29
|
+
/*setupCalls=*/ [],
|
|
30
|
+
/*appCalls=*/ [
|
|
31
|
+
{
|
|
32
|
+
address: token.address,
|
|
33
|
+
fnName: 'mint_to_public',
|
|
34
|
+
args: [/*to=*/ sender, mintAmount],
|
|
35
|
+
},
|
|
36
|
+
],
|
|
37
|
+
);
|
|
38
|
+
expectToBeTrue(mintResult.revertCode.isOK());
|
|
39
|
+
await checkBalance(tester, token, sender, sender, mintAmount, expectToBeTrue);
|
|
40
|
+
|
|
41
|
+
const authwitNonce = new Fr(0);
|
|
42
|
+
const transferAmount = 50n;
|
|
43
|
+
// EXECUTE! This means that if using AvmProvingTester subclass, it will PROVE the transaction!
|
|
44
|
+
const transferResult = await tester.executeTxWithLabel(
|
|
45
|
+
/*txLabel=*/ 'Token/transfer_in_public',
|
|
46
|
+
/*sender=*/ sender,
|
|
47
|
+
/*setupCalls=*/ [],
|
|
48
|
+
/*appCalls=*/ [
|
|
49
|
+
{
|
|
50
|
+
address: token.address,
|
|
51
|
+
fnName: 'transfer_in_public',
|
|
52
|
+
args: [/*from=*/ sender, /*to=*/ receiver, transferAmount, authwitNonce],
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
);
|
|
56
|
+
expectToBeTrue(transferResult.revertCode.isOK());
|
|
57
|
+
await checkBalance(tester, token, sender, receiver, mintAmount - transferAmount, expectToBeTrue);
|
|
58
|
+
await checkBalance(tester, token, sender, receiver, transferAmount, expectToBeTrue);
|
|
59
|
+
|
|
60
|
+
// EXECUTE! This means that if using AvmProvingTester subclass, it will PROVE the transaction!
|
|
61
|
+
const burnResult = await tester.executeTxWithLabel(
|
|
62
|
+
/*txLabel=*/ 'Token/burn_public',
|
|
63
|
+
/*sender=*/ receiver,
|
|
64
|
+
/*setupCalls=*/ [],
|
|
65
|
+
/*appCalls=*/ [
|
|
66
|
+
{
|
|
67
|
+
address: token.address,
|
|
68
|
+
fnName: 'burn_public',
|
|
69
|
+
args: [/*from=*/ receiver, transferAmount, authwitNonce],
|
|
70
|
+
},
|
|
71
|
+
],
|
|
72
|
+
);
|
|
73
|
+
expectToBeTrue(burnResult.revertCode.isOK());
|
|
74
|
+
await checkBalance(tester, token, sender, receiver, 0n, expectToBeTrue);
|
|
75
|
+
|
|
76
|
+
logger.info(`TokenContract test took ${timer.ms()}ms\n`);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
export async function setUpToken(
|
|
80
|
+
tester: PublicTxSimulationTester,
|
|
81
|
+
tokenArtifact: ContractArtifact,
|
|
82
|
+
admin: AztecAddress,
|
|
83
|
+
expectToBeTrue: (x: boolean) => void,
|
|
84
|
+
seed = 0,
|
|
85
|
+
) {
|
|
86
|
+
const constructorArgs = [admin, /*name=*/ 'Token', /*symbol=*/ 'TOK', /*decimals=*/ new Fr(18)];
|
|
87
|
+
const token = await tester.registerAndDeployContract(
|
|
88
|
+
constructorArgs,
|
|
89
|
+
/*deployer=*/ admin,
|
|
90
|
+
tokenArtifact,
|
|
91
|
+
/*skipNullifierInsertion=*/ false,
|
|
92
|
+
seed,
|
|
93
|
+
);
|
|
94
|
+
|
|
95
|
+
// EXECUTE! This means that if using AvmProvingTester subclass, it will PROVE the transaction!
|
|
96
|
+
const result = await tester.executeTxWithLabel(
|
|
97
|
+
/*txLabel=*/ 'Token/constructor',
|
|
98
|
+
/*sender=*/ admin,
|
|
99
|
+
/*setupCalls=*/ [],
|
|
100
|
+
/*appCalls=*/ [
|
|
101
|
+
{
|
|
102
|
+
fnName: 'constructor',
|
|
103
|
+
args: constructorArgs,
|
|
104
|
+
address: token.address,
|
|
105
|
+
},
|
|
106
|
+
],
|
|
107
|
+
);
|
|
108
|
+
expectToBeTrue(result.revertCode.isOK());
|
|
109
|
+
return token;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
async function checkBalance(
|
|
113
|
+
tester: PublicTxSimulationTester,
|
|
114
|
+
token: ContractInstanceWithAddress,
|
|
115
|
+
sender: AztecAddress,
|
|
116
|
+
account: AztecAddress,
|
|
117
|
+
expectedBalance: bigint,
|
|
118
|
+
expectToBeTrue: (x: boolean) => void,
|
|
119
|
+
) {
|
|
120
|
+
// Strictly simulate this! No need to "execute" (aka prove if using AvmProvingTester subclass).
|
|
121
|
+
const balResult = await tester.simulateTxWithLabel(
|
|
122
|
+
/*txLabel=*/ 'Token/balance_of_public',
|
|
123
|
+
sender,
|
|
124
|
+
/*setupCalls=*/ [],
|
|
125
|
+
/*appCalls=*/ [
|
|
126
|
+
{
|
|
127
|
+
address: token.address,
|
|
128
|
+
fnName: 'balance_of_public',
|
|
129
|
+
args: [/*owner=*/ account],
|
|
130
|
+
isStaticCall: true,
|
|
131
|
+
},
|
|
132
|
+
],
|
|
133
|
+
);
|
|
134
|
+
expectToBeTrue(balResult.revertCode.isOK());
|
|
135
|
+
// should be 1 call with 1 return value that is expectedBalance
|
|
136
|
+
expectToBeTrue(balResult.appLogicReturnValues.length == 1);
|
|
137
|
+
expectToBeTrue(balResult.appLogicReturnValues[0].values!.length == 1);
|
|
138
|
+
expectToBeTrue(balResult.appLogicReturnValues[0].values![0].toBigInt() == expectedBalance);
|
|
139
|
+
}
|