diff --git a/docs/coverage.md b/docs/coverage.md index db774574..be5bcda5 100644 --- a/docs/coverage.md +++ b/docs/coverage.md @@ -40,6 +40,7 @@ See which `algorand-python` stubs are implemented by the `algorand-python-testin | algopy.ensure_budget | Emulated | | algopy.log | Emulated | | algopy.logicsig | Emulated | +| algopy.public | Emulated | | algopy.size_of | Emulated | | algopy.subroutine | Native | | algopy.uenumerate | Native | diff --git a/docs/index.md b/docs/index.md index 7d101f13..9c5df25d 100644 --- a/docs/index.md +++ b/docs/index.md @@ -62,7 +62,7 @@ class VotingContract(algopy.ARC4Contract): ) self.voted = algopy.LocalState(algopy.UInt64, key="voted", description="Tracks if an account has voted") - @arc4.abimethod + @algopy.public def set_topic(self, topic: arc4.String) -> None: self.topic.value = topic.bytes @@ -79,7 +79,7 @@ class VotingContract(algopy.ARC4Contract): self.voted[algopy.Txn.sender] = algopy.UInt64(1) return arc4.Bool(True) - @arc4.abimethod(readonly=True) + @algopy.public(readonly=True) def get_votes(self) -> arc4.UInt64: return arc4.UInt64(self.votes.value) @@ -141,9 +141,9 @@ This example demonstrates key aspects of testing with `algorand-python-testing` 1. ARC4 Contract Features: - Use of `algopy.ARC4Contract` as the base class for the contract. - - ABI methods defined using the `@arc4.abimethod` decorator. + - ABI methods defined using the `@arc4.abimethod`, or its alias `@algopy.public`, decorator. - Use of ARC4-specific types like `arc4.String`, `arc4.Bool`, and `arc4.UInt64`. - - Readonly method annotation with `@arc4.abimethod(readonly=True)`. + - Readonly method annotation with `@arc4.abimethod(readonly=True)` or `@algopy.public(readonly=True)` . 2. Testing ARC4 Contracts: diff --git a/docs/testing-guide/concepts.md b/docs/testing-guide/concepts.md index f476c1d1..47f81d81 100644 --- a/docs/testing-guide/concepts.md +++ b/docs/testing-guide/concepts.md @@ -61,5 +61,5 @@ For a full list of all public `algopy` types and their corresponding implementat ## Data Validation -Algorand Python and the puya compiler have functionality to perform validation of transaction inputs via the `--validate-abi-args`, `--validate-abi-return` CLI arguments, `arc4.abimethod(validate_encoding=...)` decorator and `.validate()` methods. -The Algorand Python Testing library does *NOT* implement this validation behaviour, as you should test invalid inputs using an integrated test against a real Algorand network. +Algorand Python and the puya compiler have functionality to perform validation of transaction inputs via the `--validate-abi-args`, `--validate-abi-return` CLI arguments, `arc4.abimethod(validate_encoding=...)` decorator (or its alias, `algopy.public`) and `.validate()` methods. +The Algorand Python Testing library does _NOT_ implement this validation behaviour, as you should test invalid inputs using an integrated test against a real Algorand network. diff --git a/docs/testing-guide/contract-testing.md b/docs/testing-guide/contract-testing.md index 9c28d331..df057dad 100644 --- a/docs/testing-guide/contract-testing.md +++ b/docs/testing-guide/contract-testing.md @@ -1,6 +1,6 @@ # Smart Contract Testing -This guide provides an overview of how to test smart contracts using the Algorand Python SDK (`algopy`). It covers the basics of testing `ARC4Contract` and `Contract` classes, focusing on the `abimethod` and `baremethod` decorators. +This guide provides an overview of how to test smart contracts using the Algorand Python SDK (`algopy`). It covers the basics of testing `ARC4Contract` and `Contract` classes, focusing on the `baremethod`, `abimethod` and `public` (an alias of `abimethod`) decorators. ![](https://mermaid.ink/img/pako:eNqVkrFugzAQhl_Fujnp1ImhEiJrJNREWeoOV9sNVsFG9iEVBd69R5w0JE2llsk2n7-7_-AAymsDGewDtpXYrqQT_GyKFwl5vfcBnRZlT5V3IjYYSCjvKKAiCa-JzXfrObyzgTqsxRpVZZ25YOX2nnRrIomCneZzpszLkllktu0f8ratrUKyjFsXCZ1K2gTH7i01_8dGUjOT_55YeLdUFVr3zRunf5b6R5hZoFnBq9cX72_Br_Cj8bl4vJCHaVucvowYxHk5Xg_sfPkY6SbbphDL5dMgQZu29n0U5DMJwzTVGyApySKZKFSNMXKVxPJYYAGNCQ1azX_VYboqgSrTcAcZLzWGDwnSjcxhR37TOwUZhc4sIPhuX0H2jnXkXddqrrCyyKNpTqfjF5m74B8?type=png) @@ -24,7 +24,7 @@ context = ctx_manager.__enter__() Subclasses of `algopy.ARC4Contract` are **required** to be instantiated with an active test context. As part of instantiation, the test context will automatically create a matching `algopy.Application` object instance. -Within the class implementation, methods decorated with `algopy.arc4.abimethod` and `algopy.arc4.baremethod` will automatically assemble an `algopy.gtxn.ApplicationCallTransaction` to emulate the AVM application call. This behaviour can be overridden by setting the transaction group manually as part of test setup; this is done via implicit invocation of the `algopy_testing.context.any_application()` _value generator_ (refer to the [API](../api.md) for more details). +Within the class implementation, methods decorated with `algopy.arc4.abimethod` (or its alias, `algopy.public`) and `algopy.arc4.baremethod` will automatically assemble an `algopy.gtxn.ApplicationCallTransaction` to emulate the AVM application call. This behaviour can be overridden by setting the transaction group manually as part of test setup; this is done via implicit invocation of the `algopy_testing.context.any_application()` _value generator_ (refer to the [API](../api.md) for more details). ```{testcode} class SimpleVotingContract(algopy.ARC4Contract): @@ -42,14 +42,14 @@ class SimpleVotingContract(algopy.ARC4Contract): self.topic.value = initial_topic self.votes.value = algopy.UInt64(0) - @algopy.arc4.abimethod + @algopy.public def vote(self) -> algopy.UInt64: assert self.voted[algopy.Txn.sender] == algopy.UInt64(0), "Account has already voted" self.votes.value += algopy.UInt64(1) self.voted[algopy.Txn.sender] = algopy.UInt64(1) return self.votes.value - @algopy.arc4.abimethod(readonly=True) + @algopy.public(readonly=True) def get_votes(self) -> algopy.UInt64: return self.votes.value @@ -74,7 +74,7 @@ assert contract.topic.value == initial_topic assert contract.votes.value == algopy.UInt64(0) # Act - Vote -# The method `.vote()` is decorated with `algopy.arc4.abimethod`, which means it will assemble a transaction to emulate the AVM application call +# The method `.vote()` is decorated with `algopy.public`, an alias of `algopy.arc4.abimethod`, which means it will assemble a transaction to emulate the AVM application call result = contract.vote() # Assert - you can access the corresponding auto generated application call transaction via test context diff --git a/docs/testing-guide/subroutines.md b/docs/testing-guide/subroutines.md index 403d78b9..2dc13383 100644 --- a/docs/testing-guide/subroutines.md +++ b/docs/testing-guide/subroutines.md @@ -18,6 +18,8 @@ context = ctx_manager.__enter__() The `@algopy.subroutine` decorator exposes contract methods for isolated testing within the Algorand Python Testing framework. This enables focused validation of core business logic without the overhead of full application deployment and execution. +`@algopy.subroutine` decorator is optional for the methods in a contract which are not callable externally. + ## Usage 1. Decorate internal methods with `@algopy.subroutine`: @@ -26,7 +28,7 @@ The `@algopy.subroutine` decorator exposes contract methods for isolated testing from algopy import subroutine, UInt64 class MyContract: - @subroutine + @subroutine # optional def calculate_value(self, input: UInt64) -> UInt64: return input * UInt64(2) ``` diff --git a/docs/testing-guide/transactions.md b/docs/testing-guide/transactions.md index 27805811..1ab50dea 100644 --- a/docs/testing-guide/transactions.md +++ b/docs/testing-guide/transactions.md @@ -143,7 +143,7 @@ When testing smart contracts, to stay consistent with AVM, the framework _does n ```{testcode} class MyContract(algopy.ARC4Contract): - @algopy.arc4.abimethod + @algopy.public def pay_via_itxn(self, asset: algopy.Asset) -> None: algopy.itxn.Payment( receiver=algopy.Txn.sender, @@ -180,7 +180,7 @@ first_payment_txn = first_itxn_group.payment(0) In this example, we define a contract method `pay_via_itxn` that creates and submits an inner payment transaction. The test context automatically captures and stores the inner transactions submitted by the contract method. -Note that we don't need to wrap the execution in a `create_group` context manager because the method is decorated with `@algopy.arc4.abimethod`, which automatically creates a transaction group for the method. The `create_group` context manager is only needed when you want to create more complex transaction groups or patch transaction fields for various transaction-related opcodes in AVM. +Note that we don't need to wrap the execution in a `create_group` context manager because the method is decorated with `@algopy.public`, an alias of `@algopy.arc4.abimethod`, which automatically creates a transaction group for the method. The `create_group` context manager is only needed when you want to create more complex transaction groups or patch transaction fields for various transaction-related opcodes in AVM. To access the submitted inner transactions: diff --git a/examples/marketplace/contract.py b/examples/marketplace/contract.py index 63900506..eb18fd9c 100644 --- a/examples/marketplace/contract.py +++ b/examples/marketplace/contract.py @@ -9,7 +9,6 @@ gtxn, itxn, op, - subroutine, ) from algopy.arc4 import abimethod @@ -32,7 +31,6 @@ class DigitalMarketplace(ARC4Contract): def __init__(self) -> None: self.listings = BoxMap(ListingKey, ListingValue) - @subroutine def listings_box_mbr(self) -> UInt64: return ( 2_500 @@ -55,7 +53,6 @@ def listings_box_mbr(self) -> UInt64: * 400 ) - @subroutine def quantity_price(self, quantity: UInt64, price: UInt64, asset_decimals: UInt64) -> UInt64: amount_not_scaled_high, amount_not_scaled_low = op.mulw(price, quantity) scaling_factor_high, scaling_factor_low = op.expw(10, asset_decimals) diff --git a/examples/proof_of_attendance/contract.py b/examples/proof_of_attendance/contract.py index 4aefeb5e..d80e990f 100644 --- a/examples/proof_of_attendance/contract.py +++ b/examples/proof_of_attendance/contract.py @@ -8,12 +8,12 @@ def __init__(self) -> None: self.total_attendees = algopy.UInt64(0) self.box_map = algopy.BoxMap(algopy.Bytes, algopy.UInt64) - @algopy.arc4.abimethod(create="require") + @algopy.public(create="require") def init(self, max_attendees: algopy.UInt64) -> None: assert algopy.Txn.sender == algopy.Global.creator_address, "Only creator can initialize" self.max_attendees = max_attendees - @algopy.arc4.abimethod() + @algopy.public() def confirm_attendance(self) -> None: assert self.total_attendees < self.max_attendees, "Max attendees reached" @@ -25,7 +25,7 @@ def confirm_attendance(self) -> None: algopy.op.Box.put(algopy.Txn.sender.bytes, algopy.op.itob(minted_asset.id)) - @algopy.arc4.abimethod() + @algopy.public() def confirm_attendance_with_box(self) -> None: assert self.total_attendees < self.max_attendees, "Max attendees reached" @@ -38,7 +38,7 @@ def confirm_attendance_with_box(self) -> None: box.value = minted_asset.id - @algopy.arc4.abimethod() + @algopy.public() def confirm_attendance_with_box_ref(self) -> None: assert self.total_attendees < self.max_attendees, "Max attendees reached" @@ -51,7 +51,7 @@ def confirm_attendance_with_box_ref(self) -> None: box_ref.value = algopy.op.itob(minted_asset.id) - @algopy.arc4.abimethod() + @algopy.public() def confirm_attendance_with_box_map(self) -> None: assert self.total_attendees < self.max_attendees, "Max attendees reached" @@ -63,33 +63,33 @@ def confirm_attendance_with_box_map(self) -> None: self.box_map[algopy.Txn.sender.bytes] = minted_asset.id - @algopy.arc4.abimethod(readonly=True) + @algopy.public(readonly=True) def get_poa_id(self) -> algopy.UInt64: poa_id, exists = algopy.op.Box.get(algopy.Txn.sender.bytes) assert exists, "POA not found" return algopy.op.btoi(poa_id) - @algopy.arc4.abimethod(readonly=True) + @algopy.public(readonly=True) def get_poa_id_with_box(self) -> algopy.UInt64: box = algopy.Box(algopy.UInt64, key=algopy.Txn.sender.bytes) poa_id, exists = box.maybe() assert exists, "POA not found" return poa_id - @algopy.arc4.abimethod(readonly=True) + @algopy.public(readonly=True) def get_poa_id_with_box_ref(self) -> algopy.UInt64: box_ref = algopy.Box(algopy.Bytes, key=algopy.Txn.sender.bytes) poa_id, exists = box_ref.maybe() assert exists, "POA not found" return algopy.op.btoi(poa_id) - @algopy.arc4.abimethod(readonly=True) + @algopy.public(readonly=True) def get_poa_id_with_box_map(self) -> algopy.UInt64: poa_id, exists = self.box_map.maybe(algopy.Txn.sender.bytes) assert exists, "POA not found" return poa_id - @algopy.arc4.abimethod() + @algopy.public() def claim_poa(self, opt_in_txn: algopy.gtxn.AssetTransferTransaction) -> None: poa_id, exists = algopy.op.Box.get(algopy.Txn.sender.bytes) assert exists, "POA not found, attendance validation failed!" @@ -108,7 +108,7 @@ def claim_poa(self, opt_in_txn: algopy.gtxn.AssetTransferTransaction) -> None: algopy.op.btoi(poa_id), ) - @algopy.arc4.abimethod() + @algopy.public() def claim_poa_with_box(self, opt_in_txn: algopy.gtxn.AssetTransferTransaction) -> None: box = algopy.Box(algopy.UInt64, key=algopy.Txn.sender.bytes) poa_id, exists = box.maybe() @@ -128,7 +128,7 @@ def claim_poa_with_box(self, opt_in_txn: algopy.gtxn.AssetTransferTransaction) - poa_id, ) - @algopy.arc4.abimethod() + @algopy.public() def claim_poa_with_box_ref(self, opt_in_txn: algopy.gtxn.AssetTransferTransaction) -> None: box_ref = algopy.Box(algopy.Bytes, key=algopy.Txn.sender.bytes) poa_id, exists = box_ref.maybe() @@ -148,7 +148,7 @@ def claim_poa_with_box_ref(self, opt_in_txn: algopy.gtxn.AssetTransferTransactio algopy.op.btoi(poa_id), ) - @algopy.arc4.abimethod() + @algopy.public() def claim_poa_with_box_map(self, opt_in_txn: algopy.gtxn.AssetTransferTransaction) -> None: poa_id, exists = self.box_map.maybe(algopy.Txn.sender.bytes) assert exists, "POA not found, attendance validation failed!" diff --git a/examples/simple_voting/contract.py b/examples/simple_voting/contract.py index 4b296fe8..0a4d181a 100644 --- a/examples/simple_voting/contract.py +++ b/examples/simple_voting/contract.py @@ -8,7 +8,6 @@ Txn, UInt64, op, - subroutine, ) VOTE_PRICE = 10_000 @@ -24,11 +23,9 @@ def __init__(self) -> None: ) self.voted = LocalState(UInt64, key="voted", description="Tracks if an account has voted") - @subroutine def set_topic(self, topic: Bytes) -> None: self.topic.value = topic - @subroutine def vote(self, voter: Account) -> bool: assert op.Global.group_size == UInt64(2) assert op.GTxn.amount(1) == UInt64(VOTE_PRICE) @@ -40,7 +37,6 @@ def vote(self, voter: Account) -> bool: self.voted[voter] = UInt64(1) return True - @subroutine def get_votes(self) -> UInt64: return self.votes.value diff --git a/src/_algopy_testing/__init__.py b/src/_algopy_testing/__init__.py index ffe3bbaf..ddd2d293 100644 --- a/src/_algopy_testing/__init__.py +++ b/src/_algopy_testing/__init__.py @@ -1,3 +1,4 @@ +# ruff: noqa: I001 from _algopy_testing import arc4, gtxn, itxn from _algopy_testing.context import AlgopyTestContext from _algopy_testing.context_helpers.context_storage import algopy_testing_context @@ -24,6 +25,9 @@ from _algopy_testing.value_generators.arc4 import ARC4ValueGenerator from _algopy_testing.value_generators.avm import AVMValueGenerator from _algopy_testing.value_generators.txn import TxnValueGenerator +from _algopy_testing.decorators.arc4 import ( + abimethod as public, +) __all__ = [ "ARC4Contract", @@ -60,6 +64,7 @@ "gtxn", "itxn", "logicsig", + "public", "subroutine", "uenumerate", "urange", diff --git a/src/algopy/__init__.py b/src/algopy/__init__.py index cb985807..a2b574d1 100644 --- a/src/algopy/__init__.py +++ b/src/algopy/__init__.py @@ -1,3 +1,4 @@ +# ruff: noqa: I001 from _algopy_testing.compiled import ( CompiledContract, CompiledLogicSig, @@ -33,6 +34,9 @@ from _algopy_testing.utilities import OpUpFeeSource, ensure_budget, log, size_of from . import arc4, gtxn, itxn, op +from _algopy_testing.decorators.arc4 import ( + abimethod as public, +) __all__ = [ "ARC4Contract", @@ -76,6 +80,7 @@ "log", "logicsig", "op", + "public", "size_of", "subroutine", "uenumerate", diff --git a/tests/arc4/test_abi_call.py b/tests/arc4/test_abi_call.py index b5d89209..14709d0e 100644 --- a/tests/arc4/test_abi_call.py +++ b/tests/arc4/test_abi_call.py @@ -4,12 +4,12 @@ import pytest from _algopy_testing import AlgopyTestContext, algopy_testing_context from _algopy_testing.itxn import ApplicationCallInnerTransaction -from algopy import ARC4Contract, arc4 +from algopy import ARC4Contract, arc4, public from pytest_mock import MockerFixture class Logger(ARC4Contract): - @arc4.abimethod + @public def echo(self, value: arc4.String) -> arc4.String: return "echo: " + value diff --git a/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal b/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal index 7d6b884e..eb1d5b8d 100644 --- a/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal +++ b/tests/artifacts/Arrays/data/StaticSizeContract.approval.teal @@ -308,7 +308,7 @@ test_array_after_for@5: pushbytes "a" swap box_put - // tests/artifacts/Arrays/static_size.py:169 + // tests/artifacts/Arrays/static_size.py:168 // last_point = path[0] extract 0 144 // on error: index access is out of bounds dup @@ -319,24 +319,24 @@ test_array_after_for@5: intc_2 // 8 extract_uint64 bury 6 - // tests/artifacts/Arrays/static_size.py:170 + // tests/artifacts/Arrays/static_size.py:169 // length = UInt64() intc_0 // 0 bury 5 - // tests/artifacts/Arrays/static_size.py:171 + // tests/artifacts/Arrays/static_size.py:170 // for point_idx in urange(1, path.length): intc_1 // 1 bury 3 test_array_for_header@7: - // tests/artifacts/Arrays/static_size.py:171 + // tests/artifacts/Arrays/static_size.py:170 // for point_idx in urange(1, path.length): dig 2 dig 8 < bz test_array_after_for@15 dig 1 - // tests/artifacts/Arrays/static_size.py:172 + // tests/artifacts/Arrays/static_size.py:171 // point = path[point_idx] dig 3 intc 4 // 144 @@ -349,45 +349,45 @@ test_array_for_header@7: intc_2 // 8 extract_uint64 bury 6 - // tests/artifacts/Arrays/static_size.py:173 + // tests/artifacts/Arrays/static_size.py:172 // if point.x < last_point.x: dig 10 b< bz test_array_else_body@10 - // tests/artifacts/Arrays/static_size.py:174 + // tests/artifacts/Arrays/static_size.py:173 // dx = last_point.x.as_uint64() - point.x.as_uint64() dig 10 - // tests/artifacts/Arrays/static_size.py:169 + // tests/artifacts/Arrays/static_size.py:168 // last_point = path[0] intc_0 // 0 - // tests/artifacts/Arrays/static_size.py:174 + // tests/artifacts/Arrays/static_size.py:173 // dx = last_point.x.as_uint64() - point.x.as_uint64() extract_uint64 swap - // tests/artifacts/Arrays/static_size.py:172 + // tests/artifacts/Arrays/static_size.py:171 // point = path[point_idx] intc_0 // 0 - // tests/artifacts/Arrays/static_size.py:174 + // tests/artifacts/Arrays/static_size.py:173 // dx = last_point.x.as_uint64() - point.x.as_uint64() extract_uint64 - bury 7 test_array_after_if_else@11: - // tests/artifacts/Arrays/static_size.py:177 + // tests/artifacts/Arrays/static_size.py:176 // if point.y < last_point.y: dig 3 dig 6 < bz test_array_else_body@13 - // tests/artifacts/Arrays/static_size.py:178 + // tests/artifacts/Arrays/static_size.py:177 // dy = last_point.y - point.y dig 5 dig 4 - test_array_after_if_else@14: - // tests/artifacts/Arrays/static_size.py:181 + // tests/artifacts/Arrays/static_size.py:180 // length += op.sqrt(dx * dx + dy * dy) dig 7 dup @@ -400,7 +400,7 @@ test_array_after_if_else@14: dig 5 + bury 5 - // tests/artifacts/Arrays/static_size.py:171 + // tests/artifacts/Arrays/static_size.py:170 // for point_idx in urange(1, path.length): dig 2 intc_1 // 1 @@ -409,7 +409,7 @@ test_array_after_if_else@14: b test_array_for_header@7 test_array_else_body@13: - // tests/artifacts/Arrays/static_size.py:180 + // tests/artifacts/Arrays/static_size.py:179 // dy = point.y - last_point.y dig 3 dig 6 @@ -417,17 +417,17 @@ test_array_else_body@13: b test_array_after_if_else@14 test_array_else_body@10: - // tests/artifacts/Arrays/static_size.py:172 + // tests/artifacts/Arrays/static_size.py:171 // point = path[point_idx] intc_0 // 0 - // tests/artifacts/Arrays/static_size.py:176 + // tests/artifacts/Arrays/static_size.py:175 // dx = point.x.as_uint64() - last_point.x.as_uint64() extract_uint64 dig 10 - // tests/artifacts/Arrays/static_size.py:169 + // tests/artifacts/Arrays/static_size.py:168 // last_point = path[0] intc_0 // 0 - // tests/artifacts/Arrays/static_size.py:176 + // tests/artifacts/Arrays/static_size.py:175 // dx = point.x.as_uint64() - last_point.x.as_uint64() extract_uint64 - @@ -842,7 +842,7 @@ sum_array_after_for@5: // tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool[routing]() -> void: test_arc4_bool: - // tests/artifacts/Arrays/static_size.py:143 + // tests/artifacts/Arrays/static_size.py:142 // arr.append(arc4.Bool(Txn.sender == Txn.receiver)) txn Sender txn Receiver @@ -851,7 +851,7 @@ test_arc4_bool: intc_0 // 0 uncover 2 setbit - // tests/artifacts/Arrays/static_size.py:144 + // tests/artifacts/Arrays/static_size.py:143 // arr.append(arc4.Bool(Txn.sender != Txn.receiver)) txn Sender txn Receiver @@ -862,13 +862,13 @@ test_arc4_bool: setbit concat // on error: max array length exceeded dupn 2 - // tests/artifacts/Arrays/static_size.py:147 + // tests/artifacts/Arrays/static_size.py:146 // dyn_arr.extend(arr) len - // tests/artifacts/Arrays/static_size.py:146 + // tests/artifacts/Arrays/static_size.py:145 // dyn_arr = arc4.DynamicArray[arc4.Bool]() bytec 4 // 0x0000 - // tests/artifacts/Arrays/static_size.py:147 + // tests/artifacts/Arrays/static_size.py:146 // dyn_arr.extend(arr) dig 2 uncover 2 @@ -876,7 +876,7 @@ test_arc4_bool: callsub dynamic_array_concat_bits dup cover 2 - // tests/artifacts/Arrays/static_size.py:148 + // tests/artifacts/Arrays/static_size.py:147 // assert dyn_arr.length == 2, "expected correct length" dup intc_0 // 0 @@ -887,14 +887,14 @@ test_arc4_bool: pushint 2 == assert // expected correct length - // tests/artifacts/Arrays/static_size.py:149 + // tests/artifacts/Arrays/static_size.py:148 // assert dyn_arr.bytes.length == 3, "expected 3 bytes" dig 1 len pushint 3 == assert // expected 3 bytes - // tests/artifacts/Arrays/static_size.py:150 + // tests/artifacts/Arrays/static_size.py:149 // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0" dup assert // index access is out of bounds @@ -912,7 +912,7 @@ test_arc4_bool: == == assert // expected correct value at 0 - // tests/artifacts/Arrays/static_size.py:151 + // tests/artifacts/Arrays/static_size.py:150 // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1" intc_1 // 1 > @@ -933,7 +933,7 @@ test_arc4_bool: intc_0 // 0 test_arc4_bool_for_header@2: - // tests/artifacts/Arrays/static_size.py:154-156 + // tests/artifacts/Arrays/static_size.py:153-155 // # note: not supported currently // # arr2.extend(dyn_array) // for b in dyn_arr: @@ -952,7 +952,7 @@ test_arc4_bool_for_header@2: uncover 2 setbit dig 3 - // tests/artifacts/Arrays/static_size.py:157 + // tests/artifacts/Arrays/static_size.py:156 // arr2.append(b) swap concat // on error: max array length exceeded @@ -964,14 +964,14 @@ test_arc4_bool_for_header@2: test_arc4_bool_after_for@5: dig 1 - // tests/artifacts/Arrays/static_size.py:158 + // tests/artifacts/Arrays/static_size.py:157 // assert arr2.length == 4, "expected correct length" dup len pushint 4 == assert // expected correct length - // tests/artifacts/Arrays/static_size.py:159 + // tests/artifacts/Arrays/static_size.py:158 // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0" dup extract 0 1 // on error: index access is out of bounds @@ -982,7 +982,7 @@ test_arc4_bool_after_for@5: == == assert // expected correct value at 0 - // tests/artifacts/Arrays/static_size.py:160 + // tests/artifacts/Arrays/static_size.py:159 // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1" dup extract 1 1 // on error: index access is out of bounds @@ -993,7 +993,7 @@ test_arc4_bool_after_for@5: != == assert // expected correct value at 1 - // tests/artifacts/Arrays/static_size.py:161 + // tests/artifacts/Arrays/static_size.py:160 // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2" dup extract 2 1 // on error: index access is out of bounds @@ -1004,7 +1004,7 @@ test_arc4_bool_after_for@5: == == assert // expected correct value at 2 - // tests/artifacts/Arrays/static_size.py:162 + // tests/artifacts/Arrays/static_size.py:161 // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3" extract 3 1 // on error: index access is out of bounds intc_0 // 0 @@ -1015,7 +1015,7 @@ test_arc4_bool_after_for@5: == assert // expected correct value at 3 dig 4 - // tests/artifacts/Arrays/static_size.py:164 + // tests/artifacts/Arrays/static_size.py:163 // return arr.freeze() dup len @@ -1023,7 +1023,7 @@ test_arc4_bool_after_for@5: cover 2 intc_2 // 8 callsub dynamic_array_concat_bits - // tests/artifacts/Arrays/static_size.py:140 + // tests/artifacts/Arrays/static_size.py:139 // @arc4.abimethod() bytec_1 // 0x151f7c75 swap @@ -1035,7 +1035,7 @@ test_arc4_bool_after_for@5: // tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes: xtra: - // tests/artifacts/Arrays/static_size.py:127 + // tests/artifacts/Arrays/static_size.py:126 // self.count += 1 intc_0 // 0 bytec_2 // "count" @@ -1046,23 +1046,23 @@ xtra: bytec_2 // "count" dig 1 app_global_put - // tests/artifacts/Arrays/static_size.py:129 + // tests/artifacts/Arrays/static_size.py:128 // a=Txn.num_app_args, txn NumAppArgs - // tests/artifacts/Arrays/static_size.py:131 + // tests/artifacts/Arrays/static_size.py:130 // c=Txn.sender, txn Sender - // tests/artifacts/Arrays/static_size.py:132 + // tests/artifacts/Arrays/static_size.py:131 // d=self.more(), callsub more - // tests/artifacts/Arrays/static_size.py:133 + // tests/artifacts/Arrays/static_size.py:132 // e=BigUInt(self.count), intc_0 // 0 bytec_2 // "count" app_global_get_ex assert // check self.count exists itob - // tests/artifacts/Arrays/static_size.py:128-134 + // tests/artifacts/Arrays/static_size.py:127-133 // return Xtra( // a=Txn.num_app_args, // b=self.count, @@ -1077,7 +1077,7 @@ xtra: // tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes: more: - // tests/artifacts/Arrays/static_size.py:138 + // tests/artifacts/Arrays/static_size.py:137 // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count)) intc_0 // 0 bytec_2 // "count" diff --git a/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json b/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json index 28fa8c41..9d298665 100644 --- a/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json +++ b/tests/artifacts/Arrays/data/StaticSizeContract.arc56.json @@ -302,7 +302,7 @@ } }, "source": { - "approval": "#pragma version 11
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 8 16 144
    bytecblock 0x 0x151f7c75 "count" 0x00 0x0000
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/Arrays/static_size.py:39
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put

main_after_if_else@2:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@16
    txn OnCompletion
    !
    assert
    txn ApplicationID
    assert
    pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]"
    txna ApplicationArgs 0
    match test_array test_extend_from_tuple test_extend_from_arc4_tuple test_bool_array test_arc4_conversion sum_array test_arc4_bool
    err

main___algopy_default_create@16:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_0 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    cover 2
    swap
    pushint 7
    +
    intc_2 // 8
    /
    dup
    uncover 2
    pushint 7
    +
    intc_2 // 8
    /
    dup
    cover 2
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 4

dynamic_array_concat_bits_after_if_else@2:
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    intc_3 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array[routing]() -> void:
test_array:
    intc_0 // 0
    dup
    bytec_0 // ""
    dupn 5
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/Arrays/static_size.py:43
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put
    // tests/artifacts/Arrays/static_size.py:46
    // Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:47
    // Point(x=x1, y=y1, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:48
    // Point(x=x2, y=y2, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:44-50
    // path = ReferenceArray(
    //     (
    //         Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    //         Point(x=x1, y=y1, other=self.xtra()),
    //         Point(x=x2, y=y2, other=self.xtra()),
    //     )
    // )
    uncover 14
    itob
    uncover 14
    itob
    concat
    uncover 13
    concat
    uncover 12
    concat
    dig 11
    len
    pushint 64
    <=
    assert // overflow
    pushint 64
    bzero
    uncover 12
    dig 1
    b|
    uncover 2
    swap
    concat
    pushbytes 0x00000000000000000000000000000000
    swap
    concat
    uncover 14
    itob
    uncover 15
    swap
    concat
    uncover 12
    itob
    uncover 12
    itob
    concat
    uncover 11
    concat
    uncover 10
    concat
    dig 9
    len
    pushint 64
    <=
    assert // overflow
    uncover 9
    dig 4
    b|
    concat
    concat
    concat
    uncover 7
    itob
    uncover 8
    swap
    concat
    uncover 7
    itob
    uncover 7
    itob
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 4
    len
    pushint 64
    <=
    assert // overflow
    uncover 4
    uncover 4
    b|
    concat
    concat
    concat
    // tests/artifacts/Arrays/static_size.py:51
    // for i in urange(3):
    intc_0 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:51
    // for i in urange(3):
    dup
    pushint 3
    <
    bz test_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:52
    // assert path[i].other.b == i + 1
    dup2
    dup
    cover 2
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    extract 16 128
    dup
    intc_2 // 8
    extract_uint64
    dig 2
    intc_1 // 1
    +
    swap
    dig 1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:53
    // assert path[i].other.d.foo == i + 2
    swap
    extract 48 16
    dup
    extract 0 8
    uncover 3
    pushint 2
    +
    itob
    b==
    assert
    // tests/artifacts/Arrays/static_size.py:54
    // assert path[i].other.d.bar == (i + 1) * (i + 1)
    extract 8 8
    dig 1
    dig 2
    *
    itob
    b==
    assert
    bury 1
    b test_array_for_header@2

test_array_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:56
    // Box(ImmutableArray[Point], key="a").value = path.freeze()
    dup
    len
    intc 4 // 144
    /
    dup
    bury 10
    itob
    extract 6 2
    dig 1
    concat
    pushbytes "a"
    box_del
    pop
    pushbytes "a"
    swap
    box_put
    // tests/artifacts/Arrays/static_size.py:169
    // last_point = path[0]
    extract 0 144 // on error: index access is out of bounds
    dup
    bury 11
    dup
    extract 0 8
    bury 10
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:170
    // length = UInt64()
    intc_0 // 0
    bury 5
    // tests/artifacts/Arrays/static_size.py:171
    // for point_idx in urange(1, path.length):
    intc_1 // 1
    bury 3

test_array_for_header@7:
    // tests/artifacts/Arrays/static_size.py:171
    // for point_idx in urange(1, path.length):
    dig 2
    dig 8
    <
    bz test_array_after_for@15
    dig 1
    // tests/artifacts/Arrays/static_size.py:172
    // point = path[point_idx]
    dig 3
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    dupn 2
    extract 0 8
    swap
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:173
    // if point.x < last_point.x:
    dig 10
    b<
    bz test_array_else_body@10
    // tests/artifacts/Arrays/static_size.py:174
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    dig 10
    // tests/artifacts/Arrays/static_size.py:169
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    swap
    // tests/artifacts/Arrays/static_size.py:172
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:174
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    -
    bury 7

test_array_after_if_else@11:
    // tests/artifacts/Arrays/static_size.py:177
    // if point.y < last_point.y:
    dig 3
    dig 6
    <
    bz test_array_else_body@13
    // tests/artifacts/Arrays/static_size.py:178
    // dy = last_point.y - point.y
    dig 5
    dig 4
    -

test_array_after_if_else@14:
    // tests/artifacts/Arrays/static_size.py:181
    // length += op.sqrt(dx * dx + dy * dy)
    dig 7
    dup
    *
    swap
    dup
    *
    +
    sqrt
    dig 5
    +
    bury 5
    // tests/artifacts/Arrays/static_size.py:171
    // for point_idx in urange(1, path.length):
    dig 2
    intc_1 // 1
    +
    bury 3
    b test_array_for_header@7

test_array_else_body@13:
    // tests/artifacts/Arrays/static_size.py:180
    // dy = point.y - last_point.y
    dig 3
    dig 6
    -
    b test_array_after_if_else@14

test_array_else_body@10:
    // tests/artifacts/Arrays/static_size.py:172
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:176
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    dig 10
    // tests/artifacts/Arrays/static_size.py:169
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:176
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    -
    bury 7
    b test_array_after_if_else@11

test_array_after_for@15:
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    dig 4
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple[routing]() -> void:
test_extend_from_tuple:
    // tests/artifacts/Arrays/static_size.py:59
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    extract 0 16
    swap
    extract 16 16
    // tests/artifacts/Arrays/static_size.py:62
    // arr.extend(some_more)
    swap
    dig 1
    concat
    // tests/artifacts/Arrays/static_size.py:63
    // last = arr[-1]
    dup
    len
    intc_3 // 16
    /
    dup
    intc_1 // 1
    -
    intc_3 // 16
    *
    dig 2
    swap
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:64
    // assert last == some_more[1]
    dup
    uncover 4
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:65
    // result = arr.freeze()
    swap
    itob
    extract 6 2
    uncover 2
    concat
    // tests/artifacts/Arrays/static_size.py:66
    // assert result[-1] == last
    dup
    intc_0 // 0
    extract_uint16 // on error: invalid array length header
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 16
    *
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    uncover 2
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:59
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple[routing]() -> void:
test_extend_from_arc4_tuple:
    // tests/artifacts/Arrays/static_size.py:69
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:75
    // return arr.freeze()
    dup
    len
    intc_3 // 16
    /
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arrays/static_size.py:69
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array[routing]() -> void:
test_bool_array:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:77
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:79
    // arr = ReferenceArray[bool]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:82
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_bool_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:82
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_bool_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:83
    // arr.append(i % 2 == 0)
    dupn 2
    pushint 2
    %
    !
    dig 4
    swap
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:82
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_bool_array_for_header@2

test_bool_array_after_for@5:
    dig 2
    dupn 2
    // tests/artifacts/Arrays/static_size.py:84
    // assert arr.length == length, "expected correct length"
    len
    dig 6
    dup
    cover 4
    ==
    assert // expected correct length
    dig 1
    // tests/artifacts/Arrays/static_size.py:87
    // arr2.extend(arr)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/static_size.py:88
    // assert arr2.length == length * 2, "expected correct length"
    len
    uncover 2
    pushint 2
    *
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:90
    // count = UInt64(0)
    intc_0 // 0
    bury 7
    // tests/artifacts/Arrays/static_size.py:91
    // for val in arr:
    len
    bury 7
    intc_0 // 0
    bury 5

test_bool_array_for_header@6:
    // tests/artifacts/Arrays/static_size.py:91
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_bool_array_after_for@11
    dig 2
    dig 5
    intc_1 // 1
    extract3 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    // tests/artifacts/Arrays/static_size.py:92
    // if val:
    bz test_bool_array_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:93
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_bool_array_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_bool_array_for_header@6

test_bool_array_after_for@11:
    // tests/artifacts/Arrays/static_size.py:77
    // @arc4.abimethod()
    dig 5
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion[routing]() -> void:
test_arc4_conversion:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:96
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:98
    // arr = ReferenceArray[arc4.UInt64]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:101
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_arc4_conversion_for_header@2:
    // tests/artifacts/Arrays/static_size.py:101
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_arc4_conversion_after_for@5
    // tests/artifacts/Arrays/static_size.py:102
    // arr.append(arc4.UInt64(i))
    dupn 2
    itob
    dig 4
    swap
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:101
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_arc4_conversion_for_header@2

test_arc4_conversion_after_for@5:
    dig 2
    // tests/artifacts/Arrays/static_size.py:103
    // assert arr.length == length, "expected correct length"
    len
    intc_2 // 8
    /
    dup
    bury 8
    dig 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:104
    // count = UInt64(0)
    intc_0 // 0
    bury 6
    intc_0 // 0
    bury 5

test_arc4_conversion_for_header@6:
    // tests/artifacts/Arrays/static_size.py:105
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_arc4_conversion_after_for@11
    dig 2
    dig 5
    intc_2 // 8
    *
    intc_2 // 8
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:106
    // if val:
    bytec_0 // 0x
    b!=
    bz test_arc4_conversion_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:107
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_arc4_conversion_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_arc4_conversion_for_header@6

test_arc4_conversion_after_for@11:
    // tests/artifacts/Arrays/static_size.py:109
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    bytec 4 // 0x0000
    dig 3
    // tests/artifacts/Arrays/static_size.py:110
    // arc4_arr.extend(arr)
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_2 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/static_size.py:96
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array[routing]() -> void:
sum_array:
    // tests/artifacts/Arrays/static_size.py:114
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:117
    // arr.extend(arc4_arr)
    extract 2 0
    dup
    // tests/artifacts/Arrays/static_size.py:119
    // total = UInt64(0)
    intc_0 // 0
    swap
    // tests/artifacts/Arrays/static_size.py:120
    // for item in arr:
    len
    intc_2 // 8
    /
    intc_0 // 0

sum_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:120
    // for item in arr:
    dup
    dig 2
    <
    bz sum_array_after_for@5
    dig 3
    dig 1
    dup
    cover 2
    intc_2 // 8
    *
    // tests/artifacts/Arrays/static_size.py:121
    // total += item.as_uint64()
    extract_uint64
    dig 4
    +
    bury 4
    intc_1 // 1
    +
    bury 1
    b sum_array_for_header@2

sum_array_after_for@5:
    // tests/artifacts/Arrays/static_size.py:114
    // @arc4.abimethod()
    dig 2
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool[routing]() -> void:
test_arc4_bool:
    // tests/artifacts/Arrays/static_size.py:143
    // arr.append(arc4.Bool(Txn.sender == Txn.receiver))
    txn Sender
    txn Receiver
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/Arrays/static_size.py:144
    // arr.append(arc4.Bool(Txn.sender != Txn.receiver))
    txn Sender
    txn Receiver
    !=
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    dupn 2
    // tests/artifacts/Arrays/static_size.py:147
    // dyn_arr.extend(arr)
    len
    // tests/artifacts/Arrays/static_size.py:146
    // dyn_arr = arc4.DynamicArray[arc4.Bool]()
    bytec 4 // 0x0000
    // tests/artifacts/Arrays/static_size.py:147
    // dyn_arr.extend(arr)
    dig 2
    uncover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    dup
    cover 2
    // tests/artifacts/Arrays/static_size.py:148
    // assert dyn_arr.length == 2, "expected correct length"
    dup
    intc_0 // 0
    extract_uint16 // on error: invalid array length header
    dup
    cover 3
    dup
    pushint 2
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:149
    // assert dyn_arr.bytes.length == 3, "expected 3 bytes"
    dig 1
    len
    pushint 3
    ==
    assert // expected 3 bytes
    // tests/artifacts/Arrays/static_size.py:150
    // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    assert // index access is out of bounds
    dig 1
    intc_3 // 16
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:151
    // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    intc_1 // 1
    >
    assert // index access is out of bounds
    pushint 17
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    intc_0 // 0

test_arc4_bool_for_header@2:
    // tests/artifacts/Arrays/static_size.py:154-156
    // # note: not supported currently
    // # arr2.extend(dyn_array)
    // for b in dyn_arr:
    dup
    dig 3
    <
    bz test_arc4_bool_after_for@5
    dupn 2
    intc_3 // 16
    +
    dig 5
    swap
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    // tests/artifacts/Arrays/static_size.py:157
    // arr2.append(b)
    swap
    concat // on error: max array length exceeded
    bury 3
    intc_1 // 1
    +
    bury 1
    b test_arc4_bool_for_header@2

test_arc4_bool_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:158
    // assert arr2.length == 4, "expected correct length"
    dup
    len
    pushint 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:159
    // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    extract 0 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:160
    // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    dup
    extract 1 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    // tests/artifacts/Arrays/static_size.py:161
    // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2"
    dup
    extract 2 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 2
    // tests/artifacts/Arrays/static_size.py:162
    // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3"
    extract 3 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 3
    dig 4
    // tests/artifacts/Arrays/static_size.py:164
    // return arr.freeze()
    dup
    len
    bytec 4 // 0x0000
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    // tests/artifacts/Arrays/static_size.py:140
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes:
xtra:
    // tests/artifacts/Arrays/static_size.py:127
    // self.count += 1
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    intc_1 // 1
    +
    bytec_2 // "count"
    dig 1
    app_global_put
    // tests/artifacts/Arrays/static_size.py:129
    // a=Txn.num_app_args,
    txn NumAppArgs
    // tests/artifacts/Arrays/static_size.py:131
    // c=Txn.sender,
    txn Sender
    // tests/artifacts/Arrays/static_size.py:132
    // d=self.more(),
    callsub more
    // tests/artifacts/Arrays/static_size.py:133
    // e=BigUInt(self.count),
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    itob
    // tests/artifacts/Arrays/static_size.py:128-134
    // return Xtra(
    //     a=Txn.num_app_args,
    //     b=self.count,
    //     c=Txn.sender,
    //     d=self.more(),
    //     e=BigUInt(self.count),
    // )
    uncover 3
    cover 4
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes:
more:
    // tests/artifacts/Arrays/static_size.py:138
    // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count))
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    dup
    intc_1 // 1
    +
    itob
    dig 1
    uncover 2
    *
    itob
    concat
    retsub
", + "approval": "#pragma version 11
#pragma typetrack false

// algopy.arc4.ARC4Contract.approval_program() -> uint64:
main:
    intcblock 0 1 8 16 144
    bytecblock 0x 0x151f7c75 "count" 0x00 0x0000
    txn ApplicationID
    bnz main_after_if_else@2
    // tests/artifacts/Arrays/static_size.py:39
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put

main_after_if_else@2:
    // tests/artifacts/Arrays/static_size.py:37
    // class StaticSizeContract(arc4.ARC4Contract):
    txn NumAppArgs
    bz main___algopy_default_create@16
    txn OnCompletion
    !
    assert
    txn ApplicationID
    assert
    pushbytess 0x28d7c1b8 0xfa9cb973 0x6039a240 0xf8fd68a7 0x1f028db1 0x096b3a59 0x8d6e3a25 // method "test_array(uint64,uint64,uint64,uint64)uint64", method "test_extend_from_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_extend_from_arc4_tuple(((uint64,uint64),(uint64,uint64)))(uint64,uint64)[]", method "test_bool_array(uint64)uint64", method "test_arc4_conversion(uint64)uint64[]", method "sum_array(uint64[])uint64", method "test_arc4_bool()bool[]"
    txna ApplicationArgs 0
    match test_array test_extend_from_tuple test_extend_from_arc4_tuple test_bool_array test_arc4_conversion sum_array test_arc4_bool
    err

main___algopy_default_create@16:
    txn OnCompletion
    !
    txn ApplicationID
    !
    &&
    return


// _puya_lib.arc4.dynamic_array_concat_bits(array: bytes, new_items_bytes: bytes, new_items_count: uint64, read_step: uint64) -> bytes:
dynamic_array_concat_bits:
    proto 4 1
    bytec_0 // ""
    dupn 2
    frame_dig -4
    intc_0 // 0
    extract_uint16
    dupn 2
    frame_dig -2
    +
    dup
    itob
    extract 6 0
    frame_dig -4
    swap
    replace2 0
    cover 2
    swap
    pushint 7
    +
    intc_2 // 8
    /
    dup
    uncover 2
    pushint 7
    +
    intc_2 // 8
    /
    dup
    cover 2
    <
    bz dynamic_array_concat_bits_after_if_else@2
    frame_dig 6
    frame_dig 5
    -
    bzero
    frame_dig 4
    swap
    concat
    frame_bury 4

dynamic_array_concat_bits_after_if_else@2:
    intc_0 // 0
    frame_bury 0
    frame_dig 3
    intc_3 // 16
    +
    dup
    frame_bury 2
    frame_dig -2
    +
    frame_bury 1

dynamic_array_concat_bits_while_top@3:
    frame_dig 2
    frame_dig 1
    <
    bz dynamic_array_concat_bits_after_while@5
    frame_dig -3
    frame_dig 0
    dup
    cover 2
    getbit
    frame_dig 4
    frame_dig 2
    dup
    cover 3
    uncover 2
    setbit
    frame_bury 4
    intc_1 // 1
    +
    frame_bury 2
    frame_dig -1
    +
    frame_bury 0
    b dynamic_array_concat_bits_while_top@3

dynamic_array_concat_bits_after_while@5:
    frame_dig 4
    frame_bury 0
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_array[routing]() -> void:
test_array:
    intc_0 // 0
    dup
    bytec_0 // ""
    dupn 5
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    btoi
    txna ApplicationArgs 3
    txna ApplicationArgs 4
    btoi
    // tests/artifacts/Arrays/static_size.py:43
    // self.count = UInt64(0)
    bytec_2 // "count"
    intc_0 // 0
    app_global_put
    // tests/artifacts/Arrays/static_size.py:46
    // Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:47
    // Point(x=x1, y=y1, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:48
    // Point(x=x2, y=y2, other=self.xtra()),
    callsub xtra
    // tests/artifacts/Arrays/static_size.py:44-50
    // path = ReferenceArray(
    //     (
    //         Point(x=arc4.UInt64(), y=UInt64(), other=self.xtra()),
    //         Point(x=x1, y=y1, other=self.xtra()),
    //         Point(x=x2, y=y2, other=self.xtra()),
    //     )
    // )
    uncover 14
    itob
    uncover 14
    itob
    concat
    uncover 13
    concat
    uncover 12
    concat
    dig 11
    len
    pushint 64
    <=
    assert // overflow
    pushint 64
    bzero
    uncover 12
    dig 1
    b|
    uncover 2
    swap
    concat
    pushbytes 0x00000000000000000000000000000000
    swap
    concat
    uncover 14
    itob
    uncover 15
    swap
    concat
    uncover 12
    itob
    uncover 12
    itob
    concat
    uncover 11
    concat
    uncover 10
    concat
    dig 9
    len
    pushint 64
    <=
    assert // overflow
    uncover 9
    dig 4
    b|
    concat
    concat
    concat
    uncover 7
    itob
    uncover 8
    swap
    concat
    uncover 7
    itob
    uncover 7
    itob
    concat
    uncover 6
    concat
    uncover 5
    concat
    dig 4
    len
    pushint 64
    <=
    assert // overflow
    uncover 4
    uncover 4
    b|
    concat
    concat
    concat
    // tests/artifacts/Arrays/static_size.py:51
    // for i in urange(3):
    intc_0 // 0

test_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:51
    // for i in urange(3):
    dup
    pushint 3
    <
    bz test_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:52
    // assert path[i].other.b == i + 1
    dup2
    dup
    cover 2
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    extract 16 128
    dup
    intc_2 // 8
    extract_uint64
    dig 2
    intc_1 // 1
    +
    swap
    dig 1
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:53
    // assert path[i].other.d.foo == i + 2
    swap
    extract 48 16
    dup
    extract 0 8
    uncover 3
    pushint 2
    +
    itob
    b==
    assert
    // tests/artifacts/Arrays/static_size.py:54
    // assert path[i].other.d.bar == (i + 1) * (i + 1)
    extract 8 8
    dig 1
    dig 2
    *
    itob
    b==
    assert
    bury 1
    b test_array_for_header@2

test_array_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:56
    // Box(ImmutableArray[Point], key="a").value = path.freeze()
    dup
    len
    intc 4 // 144
    /
    dup
    bury 10
    itob
    extract 6 2
    dig 1
    concat
    pushbytes "a"
    box_del
    pop
    pushbytes "a"
    swap
    box_put
    // tests/artifacts/Arrays/static_size.py:168
    // last_point = path[0]
    extract 0 144 // on error: index access is out of bounds
    dup
    bury 11
    dup
    extract 0 8
    bury 10
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:169
    // length = UInt64()
    intc_0 // 0
    bury 5
    // tests/artifacts/Arrays/static_size.py:170
    // for point_idx in urange(1, path.length):
    intc_1 // 1
    bury 3

test_array_for_header@7:
    // tests/artifacts/Arrays/static_size.py:170
    // for point_idx in urange(1, path.length):
    dig 2
    dig 8
    <
    bz test_array_after_for@15
    dig 1
    // tests/artifacts/Arrays/static_size.py:171
    // point = path[point_idx]
    dig 3
    intc 4 // 144
    *
    intc 4 // 144
    extract3 // on error: index access is out of bounds
    dupn 2
    extract 0 8
    swap
    intc_2 // 8
    extract_uint64
    bury 6
    // tests/artifacts/Arrays/static_size.py:172
    // if point.x < last_point.x:
    dig 10
    b<
    bz test_array_else_body@10
    // tests/artifacts/Arrays/static_size.py:173
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    dig 10
    // tests/artifacts/Arrays/static_size.py:168
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:173
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    swap
    // tests/artifacts/Arrays/static_size.py:171
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:173
    // dx = last_point.x.as_uint64() - point.x.as_uint64()
    extract_uint64
    -
    bury 7

test_array_after_if_else@11:
    // tests/artifacts/Arrays/static_size.py:176
    // if point.y < last_point.y:
    dig 3
    dig 6
    <
    bz test_array_else_body@13
    // tests/artifacts/Arrays/static_size.py:177
    // dy = last_point.y - point.y
    dig 5
    dig 4
    -

test_array_after_if_else@14:
    // tests/artifacts/Arrays/static_size.py:180
    // length += op.sqrt(dx * dx + dy * dy)
    dig 7
    dup
    *
    swap
    dup
    *
    +
    sqrt
    dig 5
    +
    bury 5
    // tests/artifacts/Arrays/static_size.py:170
    // for point_idx in urange(1, path.length):
    dig 2
    intc_1 // 1
    +
    bury 3
    b test_array_for_header@7

test_array_else_body@13:
    // tests/artifacts/Arrays/static_size.py:179
    // dy = point.y - last_point.y
    dig 3
    dig 6
    -
    b test_array_after_if_else@14

test_array_else_body@10:
    // tests/artifacts/Arrays/static_size.py:171
    // point = path[point_idx]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:175
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    dig 10
    // tests/artifacts/Arrays/static_size.py:168
    // last_point = path[0]
    intc_0 // 0
    // tests/artifacts/Arrays/static_size.py:175
    // dx = point.x.as_uint64() - last_point.x.as_uint64()
    extract_uint64
    -
    bury 7
    b test_array_after_if_else@11

test_array_after_for@15:
    // tests/artifacts/Arrays/static_size.py:41
    // @arc4.abimethod()
    dig 4
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_tuple[routing]() -> void:
test_extend_from_tuple:
    // tests/artifacts/Arrays/static_size.py:59
    // @arc4.abimethod()
    txna ApplicationArgs 1
    dup
    extract 0 16
    swap
    extract 16 16
    // tests/artifacts/Arrays/static_size.py:62
    // arr.extend(some_more)
    swap
    dig 1
    concat
    // tests/artifacts/Arrays/static_size.py:63
    // last = arr[-1]
    dup
    len
    intc_3 // 16
    /
    dup
    intc_1 // 1
    -
    intc_3 // 16
    *
    dig 2
    swap
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:64
    // assert last == some_more[1]
    dup
    uncover 4
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:65
    // result = arr.freeze()
    swap
    itob
    extract 6 2
    uncover 2
    concat
    // tests/artifacts/Arrays/static_size.py:66
    // assert result[-1] == last
    dup
    intc_0 // 0
    extract_uint16 // on error: invalid array length header
    intc_1 // 1
    -
    dig 1
    extract 2 0
    swap
    intc_3 // 16
    *
    intc_3 // 16
    extract3 // on error: index access is out of bounds
    uncover 2
    ==
    assert
    // tests/artifacts/Arrays/static_size.py:59
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_extend_from_arc4_tuple[routing]() -> void:
test_extend_from_arc4_tuple:
    // tests/artifacts/Arrays/static_size.py:69
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:75
    // return arr.freeze()
    dup
    len
    intc_3 // 16
    /
    itob
    extract 6 2
    swap
    concat
    // tests/artifacts/Arrays/static_size.py:69
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_bool_array[routing]() -> void:
test_bool_array:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:77
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:79
    // arr = ReferenceArray[bool]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:82
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_bool_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:82
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_bool_array_after_for@5
    // tests/artifacts/Arrays/static_size.py:83
    // arr.append(i % 2 == 0)
    dupn 2
    pushint 2
    %
    !
    dig 4
    swap
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:82
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_bool_array_for_header@2

test_bool_array_after_for@5:
    dig 2
    dupn 2
    // tests/artifacts/Arrays/static_size.py:84
    // assert arr.length == length, "expected correct length"
    len
    dig 6
    dup
    cover 4
    ==
    assert // expected correct length
    dig 1
    // tests/artifacts/Arrays/static_size.py:87
    // arr2.extend(arr)
    concat // on error: max array length exceeded
    // tests/artifacts/Arrays/static_size.py:88
    // assert arr2.length == length * 2, "expected correct length"
    len
    uncover 2
    pushint 2
    *
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:90
    // count = UInt64(0)
    intc_0 // 0
    bury 7
    // tests/artifacts/Arrays/static_size.py:91
    // for val in arr:
    len
    bury 7
    intc_0 // 0
    bury 5

test_bool_array_for_header@6:
    // tests/artifacts/Arrays/static_size.py:91
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_bool_array_after_for@11
    dig 2
    dig 5
    intc_1 // 1
    extract3 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    // tests/artifacts/Arrays/static_size.py:92
    // if val:
    bz test_bool_array_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:93
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_bool_array_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_bool_array_for_header@6

test_bool_array_after_for@11:
    // tests/artifacts/Arrays/static_size.py:77
    // @arc4.abimethod()
    dig 5
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_conversion[routing]() -> void:
test_arc4_conversion:
    bytec_0 // ""
    dupn 2
    // tests/artifacts/Arrays/static_size.py:96
    // @arc4.abimethod()
    txna ApplicationArgs 1
    btoi
    dup
    // tests/artifacts/Arrays/static_size.py:98
    // arr = ReferenceArray[arc4.UInt64]()
    bytec_0 // 0x
    swap
    // tests/artifacts/Arrays/static_size.py:101
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    intc_1 // 1

test_arc4_conversion_for_header@2:
    // tests/artifacts/Arrays/static_size.py:101
    // for i in urange(1, length + 1):
    dup
    dig 2
    <
    bz test_arc4_conversion_after_for@5
    // tests/artifacts/Arrays/static_size.py:102
    // arr.append(arc4.UInt64(i))
    dupn 2
    itob
    dig 4
    swap
    concat // on error: max array length exceeded
    bury 4
    // tests/artifacts/Arrays/static_size.py:101
    // for i in urange(1, length + 1):
    intc_1 // 1
    +
    bury 1
    b test_arc4_conversion_for_header@2

test_arc4_conversion_after_for@5:
    dig 2
    // tests/artifacts/Arrays/static_size.py:103
    // assert arr.length == length, "expected correct length"
    len
    intc_2 // 8
    /
    dup
    bury 8
    dig 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:104
    // count = UInt64(0)
    intc_0 // 0
    bury 6
    intc_0 // 0
    bury 5

test_arc4_conversion_for_header@6:
    // tests/artifacts/Arrays/static_size.py:105
    // for val in arr:
    dig 4
    dig 7
    <
    bz test_arc4_conversion_after_for@11
    dig 2
    dig 5
    intc_2 // 8
    *
    intc_2 // 8
    extract3 // on error: index access is out of bounds
    // tests/artifacts/Arrays/static_size.py:106
    // if val:
    bytec_0 // 0x
    b!=
    bz test_arc4_conversion_after_if_else@9
    // tests/artifacts/Arrays/static_size.py:107
    // count += 1
    dig 5
    intc_1 // 1
    +
    bury 6

test_arc4_conversion_after_if_else@9:
    dig 4
    intc_1 // 1
    +
    bury 5
    b test_arc4_conversion_for_header@6

test_arc4_conversion_after_for@11:
    // tests/artifacts/Arrays/static_size.py:109
    // arc4_arr = arc4.DynamicArray[arc4.UInt64]()
    bytec 4 // 0x0000
    dig 3
    // tests/artifacts/Arrays/static_size.py:110
    // arc4_arr.extend(arr)
    concat // on error: max array length exceeded
    dup
    extract 2 0
    len
    intc_2 // 8
    /
    itob
    extract 6 2
    replace2 0
    // tests/artifacts/Arrays/static_size.py:96
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.sum_array[routing]() -> void:
sum_array:
    // tests/artifacts/Arrays/static_size.py:114
    // @arc4.abimethod()
    txna ApplicationArgs 1
    // tests/artifacts/Arrays/static_size.py:117
    // arr.extend(arc4_arr)
    extract 2 0
    dup
    // tests/artifacts/Arrays/static_size.py:119
    // total = UInt64(0)
    intc_0 // 0
    swap
    // tests/artifacts/Arrays/static_size.py:120
    // for item in arr:
    len
    intc_2 // 8
    /
    intc_0 // 0

sum_array_for_header@2:
    // tests/artifacts/Arrays/static_size.py:120
    // for item in arr:
    dup
    dig 2
    <
    bz sum_array_after_for@5
    dig 3
    dig 1
    dup
    cover 2
    intc_2 // 8
    *
    // tests/artifacts/Arrays/static_size.py:121
    // total += item.as_uint64()
    extract_uint64
    dig 4
    +
    bury 4
    intc_1 // 1
    +
    bury 1
    b sum_array_for_header@2

sum_array_after_for@5:
    // tests/artifacts/Arrays/static_size.py:114
    // @arc4.abimethod()
    dig 2
    itob
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.test_arc4_bool[routing]() -> void:
test_arc4_bool:
    // tests/artifacts/Arrays/static_size.py:142
    // arr.append(arc4.Bool(Txn.sender == Txn.receiver))
    txn Sender
    txn Receiver
    ==
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    // tests/artifacts/Arrays/static_size.py:143
    // arr.append(arc4.Bool(Txn.sender != Txn.receiver))
    txn Sender
    txn Receiver
    !=
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    concat // on error: max array length exceeded
    dupn 2
    // tests/artifacts/Arrays/static_size.py:146
    // dyn_arr.extend(arr)
    len
    // tests/artifacts/Arrays/static_size.py:145
    // dyn_arr = arc4.DynamicArray[arc4.Bool]()
    bytec 4 // 0x0000
    // tests/artifacts/Arrays/static_size.py:146
    // dyn_arr.extend(arr)
    dig 2
    uncover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    dup
    cover 2
    // tests/artifacts/Arrays/static_size.py:147
    // assert dyn_arr.length == 2, "expected correct length"
    dup
    intc_0 // 0
    extract_uint16 // on error: invalid array length header
    dup
    cover 3
    dup
    pushint 2
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:148
    // assert dyn_arr.bytes.length == 3, "expected 3 bytes"
    dig 1
    len
    pushint 3
    ==
    assert // expected 3 bytes
    // tests/artifacts/Arrays/static_size.py:149
    // assert dyn_arr[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    assert // index access is out of bounds
    dig 1
    intc_3 // 16
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:150
    // assert dyn_arr[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    intc_1 // 1
    >
    assert // index access is out of bounds
    pushint 17
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    intc_0 // 0

test_arc4_bool_for_header@2:
    // tests/artifacts/Arrays/static_size.py:153-155
    // # note: not supported currently
    // # arr2.extend(dyn_array)
    // for b in dyn_arr:
    dup
    dig 3
    <
    bz test_arc4_bool_after_for@5
    dupn 2
    intc_3 // 16
    +
    dig 5
    swap
    getbit
    bytec_3 // 0x00
    intc_0 // 0
    uncover 2
    setbit
    dig 3
    // tests/artifacts/Arrays/static_size.py:156
    // arr2.append(b)
    swap
    concat // on error: max array length exceeded
    bury 3
    intc_1 // 1
    +
    bury 1
    b test_arc4_bool_for_header@2

test_arc4_bool_after_for@5:
    dig 1
    // tests/artifacts/Arrays/static_size.py:157
    // assert arr2.length == 4, "expected correct length"
    dup
    len
    pushint 4
    ==
    assert // expected correct length
    // tests/artifacts/Arrays/static_size.py:158
    // assert arr2[0] == (Txn.sender == Txn.receiver), "expected correct value at 0"
    dup
    extract 0 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 0
    // tests/artifacts/Arrays/static_size.py:159
    // assert arr2[1] == (Txn.sender != Txn.receiver), "expected correct value at 1"
    dup
    extract 1 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 1
    // tests/artifacts/Arrays/static_size.py:160
    // assert arr2[2] == (Txn.sender == Txn.receiver), "expected correct value at 2"
    dup
    extract 2 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    ==
    ==
    assert // expected correct value at 2
    // tests/artifacts/Arrays/static_size.py:161
    // assert arr2[3] == (Txn.sender != Txn.receiver), "expected correct value at 3"
    extract 3 1 // on error: index access is out of bounds
    intc_0 // 0
    getbit
    txn Sender
    txn Receiver
    !=
    ==
    assert // expected correct value at 3
    dig 4
    // tests/artifacts/Arrays/static_size.py:163
    // return arr.freeze()
    dup
    len
    bytec 4 // 0x0000
    cover 2
    intc_2 // 8
    callsub dynamic_array_concat_bits
    // tests/artifacts/Arrays/static_size.py:139
    // @arc4.abimethod()
    bytec_1 // 0x151f7c75
    swap
    concat
    log
    intc_1 // 1
    return


// tests.artifacts.Arrays.static_size.StaticSizeContract.xtra() -> uint64, uint64, bytes, bytes, bytes:
xtra:
    // tests/artifacts/Arrays/static_size.py:126
    // self.count += 1
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    intc_1 // 1
    +
    bytec_2 // "count"
    dig 1
    app_global_put
    // tests/artifacts/Arrays/static_size.py:128
    // a=Txn.num_app_args,
    txn NumAppArgs
    // tests/artifacts/Arrays/static_size.py:130
    // c=Txn.sender,
    txn Sender
    // tests/artifacts/Arrays/static_size.py:131
    // d=self.more(),
    callsub more
    // tests/artifacts/Arrays/static_size.py:132
    // e=BigUInt(self.count),
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    itob
    // tests/artifacts/Arrays/static_size.py:127-133
    // return Xtra(
    //     a=Txn.num_app_args,
    //     b=self.count,
    //     c=Txn.sender,
    //     d=self.more(),
    //     e=BigUInt(self.count),
    // )
    uncover 3
    cover 4
    retsub


// tests.artifacts.Arrays.static_size.StaticSizeContract.more() -> bytes:
more:
    // tests/artifacts/Arrays/static_size.py:137
    // return More(foo=arc4.UInt64(self.count + 1), bar=arc4.UInt64(self.count * self.count))
    intc_0 // 0
    bytec_2 // "count"
    app_global_get_ex
    assert // check self.count exists
    dup
    intc_1 // 1
    +
    itob
    dig 1
    uncover 2
    *
    itob
    concat
    retsub
", "clear": "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBhbGdvcHkuYXJjNC5BUkM0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbSgpIC0+IHVpbnQ2NDoKbWFpbjoKICAgIHB1c2hpbnQgMQogICAgcmV0dXJuCg==" }, "byteCode": { diff --git a/tests/artifacts/Arrays/static_size.py b/tests/artifacts/Arrays/static_size.py index cf0d01d3..61a4036f 100644 --- a/tests/artifacts/Arrays/static_size.py +++ b/tests/artifacts/Arrays/static_size.py @@ -122,7 +122,6 @@ def sum_array(self, arc4_arr: arc4.DynamicArray[arc4.UInt64]) -> UInt64: return total - @subroutine def xtra(self) -> Xtra: self.count += 1 return Xtra( diff --git a/tests/artifacts/Contains/contract.py b/tests/artifacts/Contains/contract.py index 886ffbcf..ca506bf4 100644 --- a/tests/artifacts/Contains/contract.py +++ b/tests/artifacts/Contains/contract.py @@ -39,19 +39,15 @@ def approval_program(self) -> UInt64: def clear_state_program(self) -> UInt64: return UInt64(1) - @subroutine def is_in_tuple_1(self, x: UInt64, y: tuple[UInt64, UInt64, Bytes]) -> bool: return x in y - @subroutine def is_in_tuple_2(self, x: Bytes, y: tuple[Bytes, UInt64, Bytes]) -> bool: return x in y - @subroutine def is_in_tuple_3(self, x: BigUInt, y: tuple[BigUInt, BigUInt]) -> bool: return x in y - @subroutine def test_string_types(self) -> None: assert foo_string() in (foo_string(), baz_string()), "foo in (foo, baz)" assert foo_string() not in (bar_string(), baz_string()), "foo not in (bar, baz)" @@ -83,7 +79,6 @@ def test_string_types(self) -> None: Bytes(b"bar"), ), "b'foo' not in (foo, foo, b'bar')" - @subroutine def test_numeric_types(self) -> None: assert one_u64() in (one_u64(), two_u64()), "1 in (1, 2)" assert one_u64() not in (UInt64(3), two_u64()), "1 not in (3, 2)" diff --git a/tests/artifacts/Contains/data/MyContract.approval.teal b/tests/artifacts/Contains/data/MyContract.approval.teal index fa4fd569..441b33cd 100644 --- a/tests/artifacts/Contains/data/MyContract.approval.teal +++ b/tests/artifacts/Contains/data/MyContract.approval.teal @@ -104,11 +104,10 @@ main: // tests.artifacts.Contains.contract.MyContract.is_in_tuple_1(x: uint64, y.0: uint64, y.1: uint64, y.2: bytes) -> uint64: is_in_tuple_1: - // tests/artifacts/Contains/contract.py:42-43 - // @subroutine + // tests/artifacts/Contains/contract.py:42 // def is_in_tuple_1(self, x: UInt64, y: tuple[UInt64, UInt64, Bytes]) -> bool: proto 4 1 - // tests/artifacts/Contains/contract.py:44 + // tests/artifacts/Contains/contract.py:43 // return x in y frame_dig -4 frame_dig -3 @@ -121,24 +120,23 @@ is_in_tuple_1: is_in_tuple_1_bool_true@2: intc_1 // 1 - // tests/artifacts/Contains/contract.py:44 + // tests/artifacts/Contains/contract.py:43 // return x in y retsub is_in_tuple_1_bool_false@3: intc_0 // 0 - // tests/artifacts/Contains/contract.py:44 + // tests/artifacts/Contains/contract.py:43 // return x in y retsub // tests.artifacts.Contains.contract.MyContract.is_in_tuple_2(x: bytes, y.0: bytes, y.1: uint64, y.2: bytes) -> uint64: is_in_tuple_2: - // tests/artifacts/Contains/contract.py:46-47 - // @subroutine + // tests/artifacts/Contains/contract.py:45 // def is_in_tuple_2(self, x: Bytes, y: tuple[Bytes, UInt64, Bytes]) -> bool: proto 4 1 - // tests/artifacts/Contains/contract.py:48 + // tests/artifacts/Contains/contract.py:46 // return x in y frame_dig -4 frame_dig -3 @@ -151,24 +149,23 @@ is_in_tuple_2: is_in_tuple_2_bool_true@2: intc_1 // 1 - // tests/artifacts/Contains/contract.py:48 + // tests/artifacts/Contains/contract.py:46 // return x in y retsub is_in_tuple_2_bool_false@3: intc_0 // 0 - // tests/artifacts/Contains/contract.py:48 + // tests/artifacts/Contains/contract.py:46 // return x in y retsub // tests.artifacts.Contains.contract.MyContract.is_in_tuple_3(x: bytes, y.0: bytes, y.1: bytes) -> uint64: is_in_tuple_3: - // tests/artifacts/Contains/contract.py:50-51 - // @subroutine + // tests/artifacts/Contains/contract.py:48 // def is_in_tuple_3(self, x: BigUInt, y: tuple[BigUInt, BigUInt]) -> bool: proto 3 1 - // tests/artifacts/Contains/contract.py:52 + // tests/artifacts/Contains/contract.py:49 // return x in y frame_dig -3 frame_dig -2 @@ -181,12 +178,12 @@ is_in_tuple_3: is_in_tuple_3_bool_true@2: intc_1 // 1 - // tests/artifacts/Contains/contract.py:52 + // tests/artifacts/Contains/contract.py:49 // return x in y retsub is_in_tuple_3_bool_false@3: intc_0 // 0 - // tests/artifacts/Contains/contract.py:52 + // tests/artifacts/Contains/contract.py:49 // return x in y retsub diff --git a/tests/models/test_contract.py b/tests/models/test_contract.py index aaec2d73..7f97d630 100644 --- a/tests/models/test_contract.py +++ b/tests/models/test_contract.py @@ -11,7 +11,6 @@ class ContractTxnInit(algopy.Contract): - def __init__(self) -> None: self.arg1 = algopy.Txn.app_args(0) if algopy.Txn.num_app_args else algopy.Bytes() self.creator = algopy.Txn.sender @@ -32,14 +31,13 @@ class ContractARC4Create( local_uints=7, ), ): - def __init__(self) -> None: self.creator = algopy.Txn.sender self._name = algopy.String("name") self._scratch_slots = algopy.UInt64() self._state_totals = algopy.UInt64() - @algopy.arc4.abimethod(create="require") + @algopy.public(create="require") def create(self, val: algopy.UInt64) -> None: self.arg1 = val assert algopy.Global.current_application_id.global_num_bytes == 4