@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.24de95ac
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 +5 -3
- package/dest/client.d.ts.map +1 -1
- package/dest/client.js +4 -2
- package/dest/common/errors.d.ts +4 -7
- package/dest/common/errors.d.ts.map +1 -1
- package/dest/common/errors.js +51 -32
- package/dest/common/index.d.ts +0 -1
- package/dest/common/index.d.ts.map +1 -1
- package/dest/common/index.js +0 -1
- package/dest/private/acvm/acvm.d.ts +11 -5
- 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 +1 -1
- package/dest/private/acvm/acvm_types.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.d.ts +17 -18
- 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 +0 -1
- 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 +19 -2
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +53 -0
- package/dest/private/{providers/acvm_native.d.ts → acvm_native.d.ts} +9 -10
- 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 +5 -5
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +4 -2
- 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 +3 -1
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +7 -2
- package/dest/public/avm/avm_gas.d.ts +4 -20
- 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 +2 -0
- 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 +98 -87
- 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 +4 -5
- 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 +6 -30
- 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 +5 -4
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.js +12 -14
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +6 -4
- 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 +43 -0
- package/dest/public/avm/fixtures/initializers.d.ts.map +1 -0
- package/dest/public/avm/fixtures/initializers.js +42 -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 +0 -2
- 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 +2 -2
- 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 +11 -7
- 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 +11 -1
- 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 +5 -13
- 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.map +1 -1
- package/dest/public/avm/opcodes/comparators.js +3 -3
- package/dest/public/avm/opcodes/contract.d.ts +1 -2
- 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.map +1 -1
- package/dest/public/avm/opcodes/control_flow.js +10 -8
- package/dest/public/avm/opcodes/conversion.d.ts +1 -0
- 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.map +1 -1
- package/dest/public/avm/opcodes/ec_add.js +6 -6
- package/dest/public/avm/opcodes/environment_getters.d.ts +2 -2
- 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 +8 -7
- 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.map +1 -1
- package/dest/public/avm/opcodes/hashing.js +6 -6
- package/dest/public/avm/opcodes/instruction.d.ts +14 -10
- 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/memory.d.ts +4 -4
- 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 +2 -1
- 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.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 +0 -2
- package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts +2 -6
- 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 +13 -4
- 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 +10 -13
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +16 -24
- package/dest/public/db_interfaces.d.ts +56 -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 +10 -3
- 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 +9 -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 +7 -0
- 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 +10 -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 -13
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +96 -71
- package/dest/public/{avm/fixtures → fixtures}/simple_contract_data_source.d.ts +6 -6
- 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 +95 -0
- package/dest/public/fixtures/utils.d.ts +16 -3
- 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 +70 -0
- package/dest/public/hinting_db_sources.d.ts.map +1 -0
- package/dest/public/hinting_db_sources.js +297 -0
- package/dest/public/index.d.ts +4 -8
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +4 -7
- package/dest/public/public_db_sources.d.ts +30 -39
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +151 -67
- 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 -30
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +141 -96
- package/dest/public/public_processor/public_processor_metrics.d.ts +2 -2
- 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/cpp_public_tx_simulator.d.ts +41 -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 +89 -0
- package/dest/public/public_tx_simulator/index.d.ts +4 -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 +24 -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 +19 -29
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +63 -91
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +45 -47
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_simulator.js +209 -184
- 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 +41 -1
- 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 +20 -65
- 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 +11 -22
- 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 +2 -5
- 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 +2 -2
- package/dest/public/state_manager/public_storage.d.ts.map +1 -0
- package/dest/public/{avm/journal/journal.d.ts → state_manager/state_manager.d.ts} +42 -85
- package/dest/public/state_manager/state_manager.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.js +391 -0
- package/dest/public/test_executor_metrics.d.ts +54 -0
- package/dest/public/test_executor_metrics.d.ts.map +1 -0
- package/dest/public/test_executor_metrics.js +306 -0
- package/dest/public/unique_class_ids.d.ts.map +1 -1
- package/dest/public/utils.d.ts +2 -4
- package/dest/public/utils.d.ts.map +1 -1
- package/dest/public/utils.js +4 -21
- package/dest/server.d.ts +6 -3
- 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 +36 -31
- 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 +10 -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 +44 -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 +23 -20
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +45 -12
- package/src/public/avm/fixtures/initializers.ts +104 -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/db_interfaces.ts +61 -0
- package/src/{common → public}/debug_fn_name.ts +7 -7
- package/src/public/executor_metrics.ts +55 -6
- package/src/public/executor_metrics_interface.ts +14 -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 +36 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +158 -113
- package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +36 -18
- package/src/public/fixtures/token_test.ts +140 -0
- package/src/public/fixtures/utils.ts +141 -68
- package/src/public/hinting_db_sources.ts +505 -0
- package/src/public/index.ts +9 -8
- package/src/public/public_db_sources.ts +196 -97
- 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 +191 -153
- package/src/public/public_processor/public_processor_metrics.ts +2 -2
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +128 -0
- package/src/public/public_tx_simulator/index.ts +3 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +109 -0
- package/src/public/public_tx_simulator/public_tx_context.ts +160 -193
- package/src/public/public_tx_simulator/public_tx_simulator.ts +294 -220
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +11 -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 +560 -0
- package/src/public/test_executor_metrics.ts +395 -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.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.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.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/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/test/utils.ts +0 -36
- /package/dest/public/{avm/journal → state_manager}/public_storage.js +0 -0
|
@@ -0,0 +1,326 @@
|
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
|
+
import { Timer } from '@aztec/foundation/timer';
|
|
3
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
4
|
+
export async function bulkTest(tester, logger, avmTestContractArtifact) {
|
|
5
|
+
const timer = new Timer();
|
|
6
|
+
const deployer = AztecAddress.fromNumber(42);
|
|
7
|
+
const avmTestContract = await tester.registerAndDeployContract(/*constructorArgs=*/ [], deployer, avmTestContractArtifact);
|
|
8
|
+
// Needed since we invoke the Fee Juice Contract in the bulk test.registerFeeJuiceContract
|
|
9
|
+
await tester.registerFeeJuiceContract();
|
|
10
|
+
// Register multiple different protocol contracts (to ensure we don't dedup bytecode hashing events):
|
|
11
|
+
await tester.registerAuthContract();
|
|
12
|
+
await tester.registerInstanceRegistryContract();
|
|
13
|
+
// Get a deployed contract instance to pass to the contract
|
|
14
|
+
// for it to use as "expected" values when testing contract instance retrieval.
|
|
15
|
+
const expectContractInstance = avmTestContract;
|
|
16
|
+
const argsField = [
|
|
17
|
+
1,
|
|
18
|
+
2,
|
|
19
|
+
3,
|
|
20
|
+
4,
|
|
21
|
+
5,
|
|
22
|
+
6,
|
|
23
|
+
7,
|
|
24
|
+
8,
|
|
25
|
+
9,
|
|
26
|
+
10
|
|
27
|
+
].map((x)=>new Fr(x));
|
|
28
|
+
const argsU8 = [
|
|
29
|
+
1,
|
|
30
|
+
2,
|
|
31
|
+
3,
|
|
32
|
+
4,
|
|
33
|
+
5,
|
|
34
|
+
6,
|
|
35
|
+
7,
|
|
36
|
+
8
|
|
37
|
+
].map((x)=>new Fr(x));
|
|
38
|
+
argsU8.push(new Fr(2n ** 128n + 9n)); // Trigger truncation from large (> 128 bits) value (canonical decomposition event)
|
|
39
|
+
argsU8.push(new Fr(2n ** 125n + 10n)); // Trigger truncation from small (< 128 bits) value (no canonical decomposition event)
|
|
40
|
+
const args = [
|
|
41
|
+
argsField,
|
|
42
|
+
argsU8,
|
|
43
|
+
/*getInstanceForAddress=*/ expectContractInstance.address,
|
|
44
|
+
/*expectedDeployer=*/ expectContractInstance.deployer,
|
|
45
|
+
/*expectedClassId=*/ expectContractInstance.currentContractClassId,
|
|
46
|
+
/*expectedInitializationHash=*/ expectContractInstance.initializationHash,
|
|
47
|
+
/*skip_strictly_limited_side_effects=*/ false
|
|
48
|
+
];
|
|
49
|
+
const bulkResult = await tester.executeTxWithLabel(/*txLabel=*/ 'AvmTest/bulk_testing', /*sender=*/ deployer, /*setupCalls=*/ [], /*appCalls=*/ [
|
|
50
|
+
{
|
|
51
|
+
address: avmTestContract.address,
|
|
52
|
+
fnName: 'bulk_testing',
|
|
53
|
+
args
|
|
54
|
+
},
|
|
55
|
+
// 3 calls creating calldata + asserting calldata copy:
|
|
56
|
+
{
|
|
57
|
+
address: avmTestContract.address,
|
|
58
|
+
fnName: 'assert_calldata_copy_large',
|
|
59
|
+
args: [
|
|
60
|
+
Array.from({
|
|
61
|
+
length: 300
|
|
62
|
+
}, ()=>Fr.random()),
|
|
63
|
+
/* with_selector: */ true
|
|
64
|
+
]
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
address: avmTestContract.address,
|
|
68
|
+
fnName: 'assert_calldata_copy',
|
|
69
|
+
args: [
|
|
70
|
+
argsField.slice(3),
|
|
71
|
+
/* with_selector: */ true
|
|
72
|
+
]
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
address: avmTestContract.address,
|
|
76
|
+
fnName: 'assert_calldata_copy_large',
|
|
77
|
+
args: [
|
|
78
|
+
Array.from({
|
|
79
|
+
length: 300
|
|
80
|
+
}, ()=>Fr.random()),
|
|
81
|
+
/* with_selector: */ true
|
|
82
|
+
]
|
|
83
|
+
},
|
|
84
|
+
// 3 calls to external contracts
|
|
85
|
+
{
|
|
86
|
+
address: avmTestContract.address,
|
|
87
|
+
fnName: 'call_fee_juice',
|
|
88
|
+
args: []
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
address: avmTestContract.address,
|
|
92
|
+
fnName: 'call_auth_registry',
|
|
93
|
+
args: []
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
address: avmTestContract.address,
|
|
97
|
+
fnName: 'call_instance_registry',
|
|
98
|
+
args: []
|
|
99
|
+
}
|
|
100
|
+
], /*teardownCall=*/ undefined, /*feePayer*/ undefined, /*privateInsertions=*/ {
|
|
101
|
+
nonRevertible: {
|
|
102
|
+
nullifiers: [
|
|
103
|
+
new Fr(420000)
|
|
104
|
+
],
|
|
105
|
+
noteHashes: [
|
|
106
|
+
new Fr(420001)
|
|
107
|
+
]
|
|
108
|
+
},
|
|
109
|
+
revertible: {
|
|
110
|
+
nullifiers: [
|
|
111
|
+
new Fr(420002)
|
|
112
|
+
],
|
|
113
|
+
noteHashes: [
|
|
114
|
+
new Fr(420003)
|
|
115
|
+
]
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
logger.info(`Bulk test took ${timer.ms()}ms\n`);
|
|
119
|
+
return bulkResult;
|
|
120
|
+
}
|
|
121
|
+
export async function megaBulkTest(tester, logger, avmTestContractArtifact) {
|
|
122
|
+
const timer = new Timer();
|
|
123
|
+
const deployer = AztecAddress.fromNumber(42);
|
|
124
|
+
const avmTestContract = await tester.registerAndDeployContract(/*constructorArgs=*/ [], deployer, avmTestContractArtifact);
|
|
125
|
+
// Needed since we invoke the Fee Juice Contract in the bulk test.registerFeeJuiceContract
|
|
126
|
+
await tester.registerFeeJuiceContract();
|
|
127
|
+
// Get a deployed contract instance to pass to the contract
|
|
128
|
+
// for it to use as "expected" values when testing contract instance retrieval.
|
|
129
|
+
const expectContractInstance = avmTestContract;
|
|
130
|
+
const argsField0 = [
|
|
131
|
+
1,
|
|
132
|
+
2,
|
|
133
|
+
3,
|
|
134
|
+
4,
|
|
135
|
+
5,
|
|
136
|
+
6,
|
|
137
|
+
7,
|
|
138
|
+
8,
|
|
139
|
+
9,
|
|
140
|
+
10
|
|
141
|
+
].map((x)=>new Fr(x));
|
|
142
|
+
const argsField1 = [
|
|
143
|
+
3,
|
|
144
|
+
2,
|
|
145
|
+
3,
|
|
146
|
+
4,
|
|
147
|
+
5,
|
|
148
|
+
6,
|
|
149
|
+
7,
|
|
150
|
+
8,
|
|
151
|
+
9,
|
|
152
|
+
10
|
|
153
|
+
].map((x)=>new Fr(x));
|
|
154
|
+
const argsField2 = [
|
|
155
|
+
5,
|
|
156
|
+
2,
|
|
157
|
+
3,
|
|
158
|
+
4,
|
|
159
|
+
5,
|
|
160
|
+
6,
|
|
161
|
+
7,
|
|
162
|
+
8,
|
|
163
|
+
9,
|
|
164
|
+
10
|
|
165
|
+
].map((x)=>new Fr(x));
|
|
166
|
+
const argsField3 = [
|
|
167
|
+
7,
|
|
168
|
+
2,
|
|
169
|
+
3,
|
|
170
|
+
4,
|
|
171
|
+
5,
|
|
172
|
+
6,
|
|
173
|
+
7,
|
|
174
|
+
8,
|
|
175
|
+
9,
|
|
176
|
+
10
|
|
177
|
+
].map((x)=>new Fr(x));
|
|
178
|
+
const argsField4 = [
|
|
179
|
+
9,
|
|
180
|
+
2,
|
|
181
|
+
3,
|
|
182
|
+
4,
|
|
183
|
+
5,
|
|
184
|
+
6,
|
|
185
|
+
7,
|
|
186
|
+
8,
|
|
187
|
+
9,
|
|
188
|
+
10
|
|
189
|
+
].map((x)=>new Fr(x));
|
|
190
|
+
const argsField5 = [
|
|
191
|
+
11,
|
|
192
|
+
2,
|
|
193
|
+
3,
|
|
194
|
+
4,
|
|
195
|
+
5,
|
|
196
|
+
6,
|
|
197
|
+
7,
|
|
198
|
+
8,
|
|
199
|
+
9,
|
|
200
|
+
10
|
|
201
|
+
].map((x)=>new Fr(x));
|
|
202
|
+
const argsField6 = [
|
|
203
|
+
13,
|
|
204
|
+
2,
|
|
205
|
+
3,
|
|
206
|
+
4,
|
|
207
|
+
5,
|
|
208
|
+
6,
|
|
209
|
+
7,
|
|
210
|
+
8,
|
|
211
|
+
9,
|
|
212
|
+
10
|
|
213
|
+
].map((x)=>new Fr(x));
|
|
214
|
+
const argsField7 = [
|
|
215
|
+
15,
|
|
216
|
+
2,
|
|
217
|
+
3,
|
|
218
|
+
4,
|
|
219
|
+
5,
|
|
220
|
+
6,
|
|
221
|
+
7,
|
|
222
|
+
8,
|
|
223
|
+
9,
|
|
224
|
+
10
|
|
225
|
+
].map((x)=>new Fr(x));
|
|
226
|
+
const argsField8 = [
|
|
227
|
+
17,
|
|
228
|
+
2,
|
|
229
|
+
3,
|
|
230
|
+
4,
|
|
231
|
+
5,
|
|
232
|
+
6,
|
|
233
|
+
7,
|
|
234
|
+
8,
|
|
235
|
+
9,
|
|
236
|
+
10
|
|
237
|
+
].map((x)=>new Fr(x));
|
|
238
|
+
const argsU8 = [
|
|
239
|
+
1,
|
|
240
|
+
2,
|
|
241
|
+
3,
|
|
242
|
+
4,
|
|
243
|
+
5,
|
|
244
|
+
6,
|
|
245
|
+
7,
|
|
246
|
+
8,
|
|
247
|
+
9,
|
|
248
|
+
10
|
|
249
|
+
].map((x)=>new Fr(x));
|
|
250
|
+
const genArgs = (argsField)=>[
|
|
251
|
+
argsField,
|
|
252
|
+
argsU8,
|
|
253
|
+
/*getInstanceForAddress=*/ expectContractInstance.address.toField(),
|
|
254
|
+
/*expectedDeployer=*/ expectContractInstance.deployer.toField(),
|
|
255
|
+
/*expectedClassId=*/ expectContractInstance.currentContractClassId.toField(),
|
|
256
|
+
/*expectedInitializationHash=*/ expectContractInstance.initializationHash.toField(),
|
|
257
|
+
// Must skip strictly limited side effects (logs, messages) so we can spam the bulk test several times.
|
|
258
|
+
/*skip_strictly_limited_side_effects=*/ true
|
|
259
|
+
];
|
|
260
|
+
const bulkResult = await tester.executeTxWithLabel(/*txLabel=*/ 'AvmTest/mega_bulk_testing', /*sender=*/ deployer, /*setupCalls=*/ [], /*appCalls=*/ [
|
|
261
|
+
{
|
|
262
|
+
address: avmTestContract.address,
|
|
263
|
+
fnName: 'bulk_testing',
|
|
264
|
+
args: genArgs(argsField0)
|
|
265
|
+
},
|
|
266
|
+
{
|
|
267
|
+
address: avmTestContract.address,
|
|
268
|
+
fnName: 'bulk_testing',
|
|
269
|
+
args: genArgs(argsField1)
|
|
270
|
+
},
|
|
271
|
+
{
|
|
272
|
+
address: avmTestContract.address,
|
|
273
|
+
fnName: 'bulk_testing',
|
|
274
|
+
args: genArgs(argsField2)
|
|
275
|
+
},
|
|
276
|
+
{
|
|
277
|
+
address: avmTestContract.address,
|
|
278
|
+
fnName: 'bulk_testing',
|
|
279
|
+
args: genArgs(argsField3)
|
|
280
|
+
},
|
|
281
|
+
{
|
|
282
|
+
address: avmTestContract.address,
|
|
283
|
+
fnName: 'bulk_testing',
|
|
284
|
+
args: genArgs(argsField4)
|
|
285
|
+
},
|
|
286
|
+
{
|
|
287
|
+
address: avmTestContract.address,
|
|
288
|
+
fnName: 'bulk_testing',
|
|
289
|
+
args: genArgs(argsField5)
|
|
290
|
+
},
|
|
291
|
+
{
|
|
292
|
+
address: avmTestContract.address,
|
|
293
|
+
fnName: 'bulk_testing',
|
|
294
|
+
args: genArgs(argsField6)
|
|
295
|
+
},
|
|
296
|
+
{
|
|
297
|
+
address: avmTestContract.address,
|
|
298
|
+
fnName: 'bulk_testing',
|
|
299
|
+
args: genArgs(argsField7)
|
|
300
|
+
},
|
|
301
|
+
{
|
|
302
|
+
address: avmTestContract.address,
|
|
303
|
+
fnName: 'bulk_testing',
|
|
304
|
+
args: genArgs(argsField8)
|
|
305
|
+
}
|
|
306
|
+
], /*teardownCall=*/ undefined, /*feePayer*/ undefined, /*privateInsertions=*/ {
|
|
307
|
+
nonRevertible: {
|
|
308
|
+
nullifiers: [
|
|
309
|
+
new Fr(420000)
|
|
310
|
+
],
|
|
311
|
+
noteHashes: [
|
|
312
|
+
new Fr(420001)
|
|
313
|
+
]
|
|
314
|
+
},
|
|
315
|
+
revertible: {
|
|
316
|
+
nullifiers: [
|
|
317
|
+
new Fr(420002)
|
|
318
|
+
],
|
|
319
|
+
noteHashes: [
|
|
320
|
+
new Fr(420003)
|
|
321
|
+
]
|
|
322
|
+
}
|
|
323
|
+
});
|
|
324
|
+
logger.info(`Mega bulk test took ${timer.ms()}ms\n`);
|
|
325
|
+
return bulkResult;
|
|
326
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { PublicTxResult } from '../public_tx_simulator/public_tx_simulator.js';
|
|
2
|
+
import { PublicTxSimulationTester } from './public_tx_simulation_tester.js';
|
|
3
|
+
/**
|
|
4
|
+
*
|
|
5
|
+
* Test custom bytecode (simulation or proving) with the provided bytecode.
|
|
6
|
+
* @param bytecode - The bytecode buffer to use
|
|
7
|
+
* @param tester - The tester to use (simulation or proving)
|
|
8
|
+
* @param txLabel - The label of the transaction
|
|
9
|
+
* @param contractName - The name of the contract (default: 'CustomBytecodeContract')
|
|
10
|
+
*/
|
|
11
|
+
export declare function testCustomBytecode(bytecode: Buffer, tester: PublicTxSimulationTester, txLabel: string, contractName?: string): Promise<PublicTxResult>;
|
|
12
|
+
//# sourceMappingURL=custom_bytecode_tester.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom_bytecode_tester.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/custom_bytecode_tester.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+CAA+C,CAAC;AACpF,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAE5E;;;;;;;GAOG;AACH,wBAAsB,kBAAkB,CACtC,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,wBAAwB,EAChC,OAAO,EAAE,MAAM,EACf,YAAY,GAAE,MAAiC,GAC9C,OAAO,CAAC,cAAc,CAAC,CA6BzB"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { FunctionType, emptyContractArtifact, emptyFunctionArtifact } from '@aztec/stdlib/abi';
|
|
2
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
3
|
+
/**
|
|
4
|
+
*
|
|
5
|
+
* Test custom bytecode (simulation or proving) with the provided bytecode.
|
|
6
|
+
* @param bytecode - The bytecode buffer to use
|
|
7
|
+
* @param tester - The tester to use (simulation or proving)
|
|
8
|
+
* @param txLabel - The label of the transaction
|
|
9
|
+
* @param contractName - The name of the contract (default: 'CustomBytecodeContract')
|
|
10
|
+
*/ export async function testCustomBytecode(bytecode, tester, txLabel, contractName = 'CustomBytecodeContract') {
|
|
11
|
+
const deployer = AztecAddress.fromNumber(42);
|
|
12
|
+
const contractArtifact = emptyContractArtifact();
|
|
13
|
+
contractArtifact.name = contractName;
|
|
14
|
+
contractArtifact.functions = [
|
|
15
|
+
emptyFunctionArtifact()
|
|
16
|
+
];
|
|
17
|
+
contractArtifact.functions[0].name = 'public_dispatch';
|
|
18
|
+
contractArtifact.functions[0].functionType = FunctionType.PUBLIC;
|
|
19
|
+
contractArtifact.functions[0].bytecode = bytecode;
|
|
20
|
+
const testContract = await tester.registerAndDeployContract(/*constructorArgs=*/ [], deployer, /*contractArtifact=*/ contractArtifact);
|
|
21
|
+
// EXECUTE! This means that if using AvmProvingTester subclass, it will PROVE the transaction!
|
|
22
|
+
return await tester.executeTxWithLabel(/*txLabel=*/ txLabel, /*sender=*/ deployer, /*setupCalls=*/ [], /*appCalls=*/ [
|
|
23
|
+
{
|
|
24
|
+
address: testContract.address,
|
|
25
|
+
fnName: 'public_dispatch',
|
|
26
|
+
args: []
|
|
27
|
+
}
|
|
28
|
+
]);
|
|
29
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { PublicTxSimulationTester } from './public_tx_simulation_tester.js';
|
|
2
|
+
export declare function addressingWithBaseTagIssueTest(isIndirect: boolean, tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
3
|
+
export declare function pcOutOfRangeTest(tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
4
|
+
export declare function invalidOpcodeTest(tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
5
|
+
export declare function invalidByteTest(tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
6
|
+
export declare function instructionTruncatedTest(tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
7
|
+
export declare function invalidTagValueTest(tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
8
|
+
export declare function invalidTagValueAndInstructionTruncatedTest(tester: PublicTxSimulationTester): Promise<import("../index.js").PublicTxResult>;
|
|
9
|
+
//# sourceMappingURL=custom_bytecode_tests.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom_bytecode_tests.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/custom_bytecode_tests.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAI5E,wBAAsB,8BAA8B,CAAC,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,wBAAwB,iDAczG;AAED,wBAAsB,gBAAgB,CAAC,MAAM,EAAE,wBAAwB,iDAQtE;AAED,wBAAsB,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,iDAiBvE;AAGD,wBAAsB,eAAe,CAAC,MAAM,EAAE,wBAAwB,iDAOrE;AAGD,wBAAsB,wBAAwB,CAAC,MAAM,EAAE,wBAAwB,iDAU9E;AAGD,wBAAsB,mBAAmB,CAAC,MAAM,EAAE,wBAAwB,iDAYzE;AAGD,wBAAsB,0CAA0C,CAAC,MAAM,EAAE,wBAAwB,iDAchG"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { strict as assert } from 'assert';
|
|
2
|
+
import { TypeTag } from '../avm/avm_memory_types.js';
|
|
3
|
+
import { Addressing, AddressingMode } from '../avm/opcodes/addressing_mode.js';
|
|
4
|
+
import { CalldataCopy, Jump, Return, Set } from '../avm/opcodes/index.js';
|
|
5
|
+
import { encodeToBytecode } from '../avm/serialization/bytecode_serialization.js';
|
|
6
|
+
import { MAX_OPCODE_VALUE, Opcode, OperandType, getOperandSize } from '../avm/serialization/instruction_serialization.js';
|
|
7
|
+
import { testCustomBytecode } from './custom_bytecode_tester.js';
|
|
8
|
+
// First instruction resolved a base address (offset 0) which is uninitialized and therefore
|
|
9
|
+
// of invalid tag (FF). This will trigger an exceptional halt.
|
|
10
|
+
export async function addressingWithBaseTagIssueTest(isIndirect, tester) {
|
|
11
|
+
const addressingMode = Addressing.fromModes([
|
|
12
|
+
isIndirect ? AddressingMode.INDIRECT_RELATIVE : AddressingMode.RELATIVE,
|
|
13
|
+
AddressingMode.DIRECT,
|
|
14
|
+
AddressingMode.DIRECT
|
|
15
|
+
]);
|
|
16
|
+
const bytecode = encodeToBytecode([
|
|
17
|
+
new CalldataCopy(/*indirect=*/ addressingMode.toWire(), /*copySize=*/ 1, /*cdOffset=*/ 0, /*dstOffset=*/ 0),
|
|
18
|
+
new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 0)
|
|
19
|
+
]);
|
|
20
|
+
const txLabel = isIndirect ? 'AddressingWithBaseTagInvalidIndirect' : 'AddressingWithBaseTagInvalidDirect';
|
|
21
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
22
|
+
}
|
|
23
|
+
export async function pcOutOfRangeTest(tester) {
|
|
24
|
+
const bytecode = encodeToBytecode([
|
|
25
|
+
new Jump(/*jumpOffset=*/ 123),
|
|
26
|
+
new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 0)
|
|
27
|
+
]);
|
|
28
|
+
const txLabel = 'PcOutOfRange';
|
|
29
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
30
|
+
}
|
|
31
|
+
export async function invalidOpcodeTest(tester) {
|
|
32
|
+
let bytecode = encodeToBytecode([
|
|
33
|
+
new Set(/*indirect=*/ 0, /*dstOffset=*/ 0, TypeTag.UINT32, /*value=*/ 0).as(Opcode.SET_8, Set.wireFormat8)
|
|
34
|
+
]);
|
|
35
|
+
const offsetReturnOpcodeByte = bytecode.length;
|
|
36
|
+
bytecode = Buffer.concat([
|
|
37
|
+
bytecode,
|
|
38
|
+
encodeToBytecode([
|
|
39
|
+
new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 0)
|
|
40
|
+
])
|
|
41
|
+
]);
|
|
42
|
+
// Manipulate the Return opcode to make the opcode invalid (out of range).
|
|
43
|
+
bytecode[offsetReturnOpcodeByte] = MAX_OPCODE_VALUE + 1; // opcode is invalid.
|
|
44
|
+
const txLabel = 'InvalidOpcode';
|
|
45
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
46
|
+
}
|
|
47
|
+
// Single invalid byte in the bytecode.
|
|
48
|
+
export async function invalidByteTest(tester) {
|
|
49
|
+
const invalidOpcode = MAX_OPCODE_VALUE + 7;
|
|
50
|
+
assert(invalidOpcode < 256, 'Invalid opcode must fit in a single byte');
|
|
51
|
+
const bytecode = Buffer.from([
|
|
52
|
+
invalidOpcode
|
|
53
|
+
]);
|
|
54
|
+
const txLabel = 'InvalidByte';
|
|
55
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
56
|
+
}
|
|
57
|
+
// Truncate the last instruction in the bytecode.
|
|
58
|
+
export async function instructionTruncatedTest(tester) {
|
|
59
|
+
let bytecode = encodeToBytecode([
|
|
60
|
+
new Set(/*indirect=*/ 0, /*dstOffset=*/ 0, TypeTag.UINT32, /*value=*/ 0).as(Opcode.SET_8, Set.wireFormat8)
|
|
61
|
+
]);
|
|
62
|
+
// Truncate the bytecode.
|
|
63
|
+
bytecode = bytecode.subarray(0, -1);
|
|
64
|
+
const txLabel = 'InstructionTruncated';
|
|
65
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
66
|
+
}
|
|
67
|
+
// Invalid tag value byte in an instruction.
|
|
68
|
+
export async function invalidTagValueTest(tester) {
|
|
69
|
+
const bytecode = encodeToBytecode([
|
|
70
|
+
new Set(/*indirect=*/ 0, /*dstOffset=*/ 0, TypeTag.UINT32, /*value=*/ 0).as(Opcode.SET_8, Set.wireFormat8),
|
|
71
|
+
new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 0)
|
|
72
|
+
]);
|
|
73
|
+
const tagOffset = getTagOffsetInInstruction(Set.wireFormat8);
|
|
74
|
+
assert(bytecode[tagOffset].valueOf() == TypeTag.UINT32.valueOf(), 'Set instruction tag should be UINT32 in test');
|
|
75
|
+
bytecode[tagOffset] = TypeTag.INVALID;
|
|
76
|
+
const txLabel = 'InvalidTagValue';
|
|
77
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
78
|
+
}
|
|
79
|
+
// Combine an invalid tag in the last instruction that is truncated.
|
|
80
|
+
export async function invalidTagValueAndInstructionTruncatedTest(tester) {
|
|
81
|
+
let bytecode = encodeToBytecode([
|
|
82
|
+
// Important: value argument must be a bigint otherwise a type error will be thrown.
|
|
83
|
+
new Set(/*indirect=*/ 0, /*dstOffset=*/ 0, TypeTag.UINT128, /*value=*/ 0n).as(Opcode.SET_128, Set.wireFormat128)
|
|
84
|
+
]);
|
|
85
|
+
// Truncate the bytecode.
|
|
86
|
+
bytecode = bytecode.subarray(0, -5);
|
|
87
|
+
const tagOffset = getTagOffsetInInstruction(Set.wireFormat128);
|
|
88
|
+
assert(bytecode[tagOffset].valueOf() == TypeTag.UINT128.valueOf(), 'Set instruction tag should be UINT128 in test');
|
|
89
|
+
bytecode[tagOffset] = 0x6f; // Invalid tag value.
|
|
90
|
+
const txLabel = 'InvalidTagValueAndInstructionTruncated';
|
|
91
|
+
return await testCustomBytecode(bytecode, tester, txLabel);
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Returns the offset of the tag in an instruction.
|
|
95
|
+
* @details Loops over the wire format operand type entries until it finds the tag.
|
|
96
|
+
* Returns the byte offset of the tag based on each operand size that is passed.
|
|
97
|
+
*
|
|
98
|
+
* @param wireFormat array of operand types
|
|
99
|
+
* @returns byte offset of the tag
|
|
100
|
+
*/ function getTagOffsetInInstruction(wireFormat) {
|
|
101
|
+
let offset = 0;
|
|
102
|
+
for (const operand of wireFormat){
|
|
103
|
+
if (operand === OperandType.TAG) {
|
|
104
|
+
break;
|
|
105
|
+
}
|
|
106
|
+
offset += getOperandSize(operand);
|
|
107
|
+
}
|
|
108
|
+
return offset;
|
|
109
|
+
}
|
|
@@ -1,3 +1,10 @@
|
|
|
1
1
|
export * from './public_tx_simulation_tester.js';
|
|
2
2
|
export * from './utils.js';
|
|
3
|
+
export * from './simple_contract_data_source.js';
|
|
4
|
+
export { readAvmMinimalPublicTxInputsFromFile, executeAvmMinimalPublicTx } from './minimal_public_tx.js';
|
|
5
|
+
export { TestExecutorMetrics } from '../test_executor_metrics.js';
|
|
6
|
+
export { ammTest } from './amm_test.js';
|
|
7
|
+
export { bulkTest, megaBulkTest } from './bulk_test.js';
|
|
8
|
+
export { tokenTest } from './token_test.js';
|
|
9
|
+
export * from './custom_bytecode_tests.js';
|
|
3
10
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/index.ts"],"names":[],"mappings":"AAAA,cAAc,kCAAkC,CAAC;AACjD,cAAc,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/index.ts"],"names":[],"mappings":"AAAA,cAAc,kCAAkC,CAAC;AACjD,cAAc,YAAY,CAAC;AAC3B,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,oCAAoC,EAAE,yBAAyB,EAAE,MAAM,wBAAwB,CAAC;AACzG,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,cAAc,4BAA4B,CAAC"}
|
|
@@ -1,2 +1,9 @@
|
|
|
1
1
|
export * from './public_tx_simulation_tester.js';
|
|
2
2
|
export * from './utils.js';
|
|
3
|
+
export * from './simple_contract_data_source.js';
|
|
4
|
+
export { readAvmMinimalPublicTxInputsFromFile, executeAvmMinimalPublicTx } from './minimal_public_tx.js';
|
|
5
|
+
export { TestExecutorMetrics } from '../test_executor_metrics.js';
|
|
6
|
+
export { ammTest } from './amm_test.js';
|
|
7
|
+
export { bulkTest, megaBulkTest } from './bulk_test.js';
|
|
8
|
+
export { tokenTest } from './token_test.js';
|
|
9
|
+
export * from './custom_bytecode_tests.js';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { AvmCircuitInputs } from '@aztec/stdlib/avm';
|
|
2
|
+
import type { PublicTxResult } from '../public_tx_simulator/public_tx_simulator.js';
|
|
3
|
+
import { PublicTxSimulationTester } from './public_tx_simulation_tester.js';
|
|
4
|
+
export declare function executeAvmMinimalPublicTx(tester: PublicTxSimulationTester): Promise<PublicTxResult>;
|
|
5
|
+
/**
|
|
6
|
+
* Reads the AVM circuit inputs for the minimal public tx from a pre-generated JSON file.
|
|
7
|
+
* @returns The AvmCircuitInputs for the minimal public tx.
|
|
8
|
+
*/
|
|
9
|
+
export declare function readAvmMinimalPublicTxInputsFromFile(): AvmCircuitInputs;
|
|
10
|
+
//# sourceMappingURL=minimal_public_tx.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"minimal_public_tx.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/minimal_public_tx.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAQrD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+CAA+C,CAAC;AAEpF,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAE5E,wBAAsB,yBAAyB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,cAAc,CAAC,CAezG;AAED;;;GAGG;AACH,wBAAgB,oCAAoC,IAAI,gBAAgB,CAEvE"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { AvmCircuitInputs } from '@aztec/stdlib/avm';
|
|
2
|
+
import { ProtocolContracts } from '@aztec/stdlib/tx';
|
|
3
|
+
import avmMinimalCircuitInputsJson from '../../../artifacts/avm_minimal_inputs.json' with {
|
|
4
|
+
type: 'json'
|
|
5
|
+
};
|
|
6
|
+
import { TypeTag } from '../avm/avm_memory_types.js';
|
|
7
|
+
import { Add, Return, Set } from '../avm/opcodes/index.js';
|
|
8
|
+
import { encodeToBytecode } from '../avm/serialization/bytecode_serialization.js';
|
|
9
|
+
import { Opcode } from '../avm/serialization/instruction_serialization.js';
|
|
10
|
+
import { testCustomBytecode } from './custom_bytecode_tester.js';
|
|
11
|
+
export async function executeAvmMinimalPublicTx(tester) {
|
|
12
|
+
const minimalBytecode = encodeToBytecode([
|
|
13
|
+
new Set(/*indirect*/ 0, /*dstOffset*/ 0, TypeTag.UINT32, /*value*/ 1).as(Opcode.SET_8, Set.wireFormat8),
|
|
14
|
+
new Set(/*indirect*/ 0, /*dstOffset*/ 1, TypeTag.UINT32, /*value*/ 2).as(Opcode.SET_8, Set.wireFormat8),
|
|
15
|
+
new Add(/*indirect=*/ 0, /*aOffset=*/ 0, /*bOffset=*/ 1, /*dstOffset=*/ 2).as(Opcode.ADD_8, Add.wireFormat8),
|
|
16
|
+
new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 2)
|
|
17
|
+
]);
|
|
18
|
+
const result = await testCustomBytecode(minimalBytecode, tester, 'MinimalTx', 'AvmMinimalContract');
|
|
19
|
+
// Modify the protocol contracts to be all zeros
|
|
20
|
+
result.avmProvingRequest.inputs.hints.protocolContracts = ProtocolContracts.empty();
|
|
21
|
+
result.avmProvingRequest.inputs.publicInputs.protocolContracts = ProtocolContracts.empty();
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Reads the AVM circuit inputs for the minimal public tx from a pre-generated JSON file.
|
|
26
|
+
* @returns The AvmCircuitInputs for the minimal public tx.
|
|
27
|
+
*/ export function readAvmMinimalPublicTxInputsFromFile() {
|
|
28
|
+
return AvmCircuitInputs.schema.parse(avmMinimalCircuitInputsJson);
|
|
29
|
+
}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { Fr } from '@aztec/foundation/fields';
|
|
2
1
|
import { type ContractArtifact } from '@aztec/stdlib/abi';
|
|
3
2
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
4
3
|
import type { MerkleTreeWriteOperations } from '@aztec/stdlib/interfaces/server';
|
|
5
|
-
import { type Tx } from '@aztec/stdlib/tx';
|
|
6
|
-
import {
|
|
4
|
+
import { GlobalVariables, type Tx } from '@aztec/stdlib/tx';
|
|
5
|
+
import { NativeWorldStateService } from '@aztec/world-state';
|
|
7
6
|
import { BaseAvmSimulationTester } from '../avm/fixtures/base_avm_simulation_tester.js';
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
|
|
7
|
+
import type { PublicTxResult } from '../public_tx_simulator/public_tx_simulator.js';
|
|
8
|
+
import { TestExecutorMetrics } from '../test_executor_metrics.js';
|
|
9
|
+
import { SimpleContractDataSource } from './simple_contract_data_source.js';
|
|
10
|
+
import { type TestPrivateInsertions } from './utils.js';
|
|
12
11
|
export type TestEnqueuedCall = {
|
|
12
|
+
sender?: AztecAddress;
|
|
13
13
|
address: AztecAddress;
|
|
14
14
|
fnName: string;
|
|
15
15
|
args: any[];
|
|
@@ -22,11 +22,33 @@ export type TestEnqueuedCall = {
|
|
|
22
22
|
* transactions.
|
|
23
23
|
*/
|
|
24
24
|
export declare class PublicTxSimulationTester extends BaseAvmSimulationTester {
|
|
25
|
-
private
|
|
26
|
-
private
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
25
|
+
#private;
|
|
26
|
+
private metrics;
|
|
27
|
+
protected txCount: number;
|
|
28
|
+
private simulator;
|
|
29
|
+
private metricsPrefix?;
|
|
30
|
+
constructor(merkleTree: MerkleTreeWriteOperations, contractDataSource: SimpleContractDataSource, globals?: GlobalVariables, metrics?: TestExecutorMetrics, useCppSimulator?: boolean);
|
|
31
|
+
static create(worldStateService: NativeWorldStateService, // make sure to close this later
|
|
32
|
+
globals?: GlobalVariables, metrics?: TestExecutorMetrics, useCppSimulator?: boolean): Promise<PublicTxSimulationTester>;
|
|
33
|
+
setMetricsPrefix(prefix: string): void;
|
|
34
|
+
createTx(sender: AztecAddress, setupCalls?: TestEnqueuedCall[], appCalls?: TestEnqueuedCall[], teardownCall?: TestEnqueuedCall, feePayer?: AztecAddress, privateInsertions?: TestPrivateInsertions): Promise<Tx>;
|
|
35
|
+
simulateTx(sender: AztecAddress, setupCalls?: TestEnqueuedCall[], appCalls?: TestEnqueuedCall[], teardownCall?: TestEnqueuedCall, feePayer?: AztecAddress, privateInsertions?: TestPrivateInsertions, txLabel?: string): Promise<PublicTxResult>;
|
|
36
|
+
/**
|
|
37
|
+
* Just simulate the transaction and return the result.
|
|
38
|
+
*
|
|
39
|
+
* This wrapper around simulation allows for easy labeling of a TX
|
|
40
|
+
* which is especially useful when reporting benchmarks or metrics.
|
|
41
|
+
*/
|
|
42
|
+
simulateTxWithLabel(txLabel: string, sender: AztecAddress, setupCalls?: TestEnqueuedCall[], appCalls?: TestEnqueuedCall[], teardownCall?: TestEnqueuedCall, feePayer?: AztecAddress, privateInsertions?: TestPrivateInsertions): Promise<PublicTxResult>;
|
|
43
|
+
/**
|
|
44
|
+
* Execute a transaction and return the result.
|
|
45
|
+
*
|
|
46
|
+
* This function can be (it is) overridden by a subclass (AvmProvingTester)
|
|
47
|
+
* to do more work (like prove and verify) while still reusing existing
|
|
48
|
+
* test fixtures (like amm_test). That is why it is not named "simulate*".
|
|
49
|
+
*/
|
|
50
|
+
executeTxWithLabel(txLabel: string, sender: AztecAddress, setupCalls?: TestEnqueuedCall[], appCalls?: TestEnqueuedCall[], teardownCall?: TestEnqueuedCall, feePayer?: AztecAddress, privateInsertions?: TestPrivateInsertions): Promise<PublicTxResult>;
|
|
51
|
+
prettyPrintMetrics(): void;
|
|
31
52
|
}
|
|
53
|
+
export declare function defaultGlobals(): GlobalVariables;
|
|
32
54
|
//# sourceMappingURL=public_tx_simulation_tester.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"public_tx_simulation_tester.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/public_tx_simulation_tester.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"public_tx_simulation_tester.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/public_tx_simulation_tester.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,gBAAgB,EAAmB,MAAM,mBAAmB,CAAC;AAC3E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAEjF,OAAO,EAAE,eAAe,EAAiC,KAAK,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAC3F,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAE7D,OAAO,EAAE,uBAAuB,EAAE,MAAM,+CAA+C,CAAC;AAUxF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+CAA+C,CAAC;AAEpF,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAC5E,OAAO,EAAE,KAAK,qBAAqB,EAA0B,MAAM,YAAY,CAAC;AAIhF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,OAAO,EAAE,YAAY,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACrC,CAAC;AAEF;;;;GAIG;AACH,qBAAa,wBAAyB,SAAQ,uBAAuB;;IASjE,OAAO,CAAC,OAAO;IARjB,SAAS,CAAC,OAAO,EAAE,MAAM,CAAK;IAC9B,OAAO,CAAC,SAAS,CAAqC;IACtD,OAAO,CAAC,aAAa,CAAC,CAAS;gBAG7B,UAAU,EAAE,yBAAyB,EACrC,kBAAkB,EAAE,wBAAwB,EAC5C,OAAO,GAAE,eAAkC,EACnC,OAAO,GAAE,mBAA+C,EAChE,eAAe,GAAE,OAAe;WAed,MAAM,CACxB,iBAAiB,EAAE,uBAAuB,EAAE,gCAAgC;IAC5E,OAAO,GAAE,eAAkC,EAC3C,OAAO,GAAE,mBAA+C,EACxD,eAAe,UAAQ,GACtB,OAAO,CAAC,wBAAwB,CAAC;IAM7B,gBAAgB,CAAC,MAAM,EAAE,MAAM;IAIzB,QAAQ,CACnB,MAAM,EAAE,YAAY,EACpB,UAAU,GAAE,gBAAgB,EAAO,EACnC,QAAQ,GAAE,gBAAgB,EAAO,EACjC,YAAY,CAAC,EAAE,gBAAgB,EAC/B,QAAQ,GAAE,YAAqB,EAE/B,iBAAiB,GAAE,qBAA0F,GAC5G,OAAO,CAAC,EAAE,CAAC;IAuBD,UAAU,CACrB,MAAM,EAAE,YAAY,EACpB,UAAU,GAAE,gBAAgB,EAAO,EACnC,QAAQ,GAAE,gBAAgB,EAAO,EACjC,YAAY,CAAC,EAAE,gBAAgB,EAC/B,QAAQ,GAAE,YAAqB,EAE/B,iBAAiB,CAAC,EAAE,qBAAqB,EACzC,OAAO,GAAE,MAAsB,GAC9B,OAAO,CAAC,cAAc,CAAC;IAyB1B;;;;;OAKG;IACU,mBAAmB,CAC9B,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,YAAY,EACpB,UAAU,CAAC,EAAE,gBAAgB,EAAE,EAC/B,QAAQ,CAAC,EAAE,gBAAgB,EAAE,EAC7B,YAAY,CAAC,EAAE,gBAAgB,EAC/B,QAAQ,CAAC,EAAE,YAAY,EACvB,iBAAiB,CAAC,EAAE,qBAAqB,GACxC,OAAO,CAAC,cAAc,CAAC;IAI1B;;;;;;OAMG;IACU,kBAAkB,CAC7B,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,YAAY,EACpB,UAAU,CAAC,EAAE,gBAAgB,EAAE,EAC/B,QAAQ,CAAC,EAAE,gBAAgB,EAAE,EAC7B,YAAY,CAAC,EAAE,gBAAgB,EAC/B,QAAQ,CAAC,EAAE,YAAY,EACvB,iBAAiB,CAAC,EAAE,qBAAqB,GACxC,OAAO,CAAC,cAAc,CAAC;IAYnB,kBAAkB;CAuB1B;AAED,wBAAgB,cAAc,oBAM7B"}
|