diff --git a/src/features/applications/components/application-global-state-table.tsx b/src/features/applications/components/application-global-state-table.tsx index 6eeb2cec..f78c46a2 100644 --- a/src/features/applications/components/application-global-state-table.tsx +++ b/src/features/applications/components/application-global-state-table.tsx @@ -76,6 +76,6 @@ const rawTableColumns: ColumnDef[] = [ { header: 'Value', accessorFn: (item) => item, - cell: (c) => c.getValue().value, + cell: (c) => c.getValue().value.toString(), }, ] diff --git a/src/features/applications/pages/application-page-localnet.test.tsx b/src/features/applications/pages/application-page-localnet.test.tsx new file mode 100644 index 00000000..e4c5bf67 --- /dev/null +++ b/src/features/applications/pages/application-page-localnet.test.tsx @@ -0,0 +1,54 @@ +import Arc32TestContractAppSpec from '@/tests/test-app-specs/test-contract.arc32.json' +import { describe, beforeEach, it, vitest, afterEach, vi } from 'vitest' +import { algorandFixture } from '@algorandfoundation/algokit-utils/testing' +import { ApplicationId } from '../data/types' +import { deploySmartContract } from '@/tests/utils/deploy-smart-contract' +import { AppSpec } from '@algorandfoundation/algokit-utils/types/app-spec' +import { executeComponentTest } from '@/tests/test-component' +import { ApplicationPage } from './application-page' +import { useParams } from 'react-router-dom' +import { tableAssertion } from '@/tests/assertions/table-assertion' +import { applicationGlobalStateLabel } from '../components/labels' +import { render, waitFor } from '@/tests/testing-library' + +describe('application-page on localnet', () => { + describe('when the application that has a global state that is a big int', () => { + const localnet = algorandFixture() + let appId: ApplicationId + + beforeEach(() => { + vitest.clearAllMocks() + }) + + beforeEach(localnet.beforeEach, 10e6) + afterEach(() => { + vitest.clearAllMocks() + }) + + beforeEach(async () => { + const { app } = await deploySmartContract(localnet, Arc32TestContractAppSpec as AppSpec) + appId = Number(app.appId) + }) + + it('should be rendered with the correct data', async () => { + vi.mocked(useParams).mockImplementation(() => ({ applicationId: appId.toString() })) + + return executeComponentTest( + () => { + return render() + }, + async (component) => { + await waitFor(async () => { + const globalStateTab = await component.findByRole('tabpanel', { + name: applicationGlobalStateLabel, + }) + await tableAssertion({ + container: globalStateTab, + rows: [{ cells: ['global_state_big_int', 'Uint', '33399922244455501'] }], + }) + }) + } + ) + }) + }) +}) diff --git a/src/features/common/data/algo-client.ts b/src/features/common/data/algo-client.ts index 67677b50..ae34a103 100644 --- a/src/features/common/data/algo-client.ts +++ b/src/features/common/data/algo-client.ts @@ -16,15 +16,28 @@ const shouldCreateKmdClient = (config: NetworkConfig) => { // Init the network config from local storage const networkConfig = settingsStore.get(networkConfigAtom) + export let indexer = ClientManager.getIndexerClient(networkConfig.indexer) +indexer.setIntEncoding(algosdk.IntDecoding.MIXED) + export let algod = ClientManager.getAlgodClient(networkConfig.algod) +algod.setIntEncoding(algosdk.IntDecoding.MIXED) + export let kmd: algosdk.Kmd | undefined = shouldCreateKmdClient(networkConfig) ? ClientManager.getKmdClient(networkConfig.kmd!) : undefined +kmd?.setIntEncoding(algosdk.IntDecoding.MIXED) + export let algorandClient = AlgorandClient.fromClients({ algod, indexer, kmd }) export const updateClientConfig = (networkConfig: NetworkConfigWithId) => { indexer = ClientManager.getIndexerClient(networkConfig.indexer) + indexer.setIntEncoding(algosdk.IntDecoding.MIXED) + algod = ClientManager.getAlgodClient(networkConfig.algod) + algod.setIntEncoding(algosdk.IntDecoding.MIXED) + kmd = shouldCreateKmdClient(networkConfig) ? ClientManager.getKmdClient(networkConfig.kmd!) : undefined + kmd?.setIntEncoding(algosdk.IntDecoding.MIXED) + algorandClient = AlgorandClient.fromClients({ algod, indexer, kmd }) if (networkConfig.id !== localnetId) { algorandClient.setDefaultValidityWindow(30) diff --git a/src/tests/test-app-specs/test-contract.arc32.json b/src/tests/test-app-specs/test-contract.arc32.json index 9e8e9c8d..2b70aeb7 100644 --- a/src/tests/test-app-specs/test-contract.arc32.json +++ b/src/tests/test-app-specs/test-contract.arc32.json @@ -37,13 +37,13 @@ } }, "source": { - "approval": "#pragma version 10

smart_contracts.test_contract.contract.TestContract.approval_program:
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txn NumAppArgs
    bz main_bare_routing@11
    method "add(uint64,uint64)uint64"
    method "get_pay_txn_amount(pay)uint64"
    method "echo_bytes(byte[])byte[]"
    method "echo_static_array(uint64[4])uint64[4]"
    method "echo_dynamic_array(uint64[])uint64[]"
    method "nest_array_and_tuple(uint64[][],(uint64[],string))(uint64[][],(uint64[],string))"
    method "echo_boolean(bool)bool"
    txna ApplicationArgs 0
    match main_add_route@2 main_get_pay_txn_amount_route@3 main_echo_bytes_route@4 main_echo_static_array_route@5 main_echo_dynamic_array_route@6 main_nest_array_and_tuple_route@7 main_echo_boolean_route@8
    err // reject transaction

main_add_route@2:
    // smart_contracts/test_contract/contract.py:18
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // smart_contracts/test_contract/contract.py:18
    // @arc4.abimethod
    callsub add
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_get_pay_txn_amount_route@3:
    // smart_contracts/test_contract/contract.py:22
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txn GroupIndex
    int 1
    -
    dup
    gtxns TypeEnum
    int pay
    ==
    assert // transaction type is pay
    // smart_contracts/test_contract/contract.py:22
    // @arc4.abimethod
    callsub get_pay_txn_amount
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_echo_bytes_route@4:
    // smart_contracts/test_contract/contract.py:26
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // smart_contracts/test_contract/contract.py:26
    // @arc4.abimethod
    callsub echo_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_echo_static_array_route@5:
    // smart_contracts/test_contract/contract.py:30
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    // smart_contracts/test_contract/contract.py:30
    // @arc4.abimethod
    callsub echo_static_array
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_echo_dynamic_array_route@6:
    // smart_contracts/test_contract/contract.py:34
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    // smart_contracts/test_contract/contract.py:34
    // @arc4.abimethod
    callsub echo_dynamic_array
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_nest_array_and_tuple_route@7:
    // smart_contracts/test_contract/contract.py:38
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // smart_contracts/test_contract/contract.py:38
    // @arc4.abimethod
    callsub nest_array_and_tuple
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_echo_boolean_route@8:
    // smart_contracts/test_contract/contract.py:51
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is NoOp
    txn ApplicationID
    assert // is not creating
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    // smart_contracts/test_contract/contract.py:51
    // @arc4.abimethod
    callsub echo_boolean
    byte 0x151f7c75
    swap
    concat
    log
    int 1
    return

main_bare_routing@11:
    // smart_contracts/test_contract/contract.py:17
    // class TestContract(ARC4Contract):
    txn OnCompletion
    !
    assert // reject transaction
    txn ApplicationID
    !
    assert // is creating
    int 1
    return


// smart_contracts.test_contract.contract.TestContract.add(a: bytes, b: bytes) -> bytes:
add:
    // smart_contracts/test_contract/contract.py:18-19
    // @arc4.abimethod
    // def add(self, a: arc4.UInt64, b: arc4.UInt64) -> arc4.UInt64:
    proto 2 1
    // smart_contracts/test_contract/contract.py:20
    // return arc4.UInt64(a.native + b.native)
    frame_dig -2
    btoi
    frame_dig -1
    btoi
    +
    itob
    retsub


// smart_contracts.test_contract.contract.TestContract.get_pay_txn_amount(pay_txn: uint64) -> bytes:
get_pay_txn_amount:
    // smart_contracts/test_contract/contract.py:22-23
    // @arc4.abimethod
    // def get_pay_txn_amount(self, pay_txn: gtxn.PaymentTransaction) -> arc4.UInt64:
    proto 1 1
    // smart_contracts/test_contract/contract.py:24
    // return arc4.UInt64(pay_txn.amount)
    frame_dig -1
    gtxns Amount
    itob
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_bytes(a: bytes) -> bytes:
echo_bytes:
    // smart_contracts/test_contract/contract.py:26-27
    // @arc4.abimethod
    // def echo_bytes(self, a: Bytes) -> Bytes:
    proto 1 1
    // smart_contracts/test_contract/contract.py:28
    // return a
    frame_dig -1
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_static_array(arr: bytes) -> bytes:
echo_static_array:
    // smart_contracts/test_contract/contract.py:30-31
    // @arc4.abimethod
    // def echo_static_array(self, arr: StaticInts) -> StaticInts:
    proto 1 1
    // smart_contracts/test_contract/contract.py:32
    // return arr
    frame_dig -1
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_dynamic_array(arr: bytes) -> bytes:
echo_dynamic_array:
    // smart_contracts/test_contract/contract.py:34-35
    // @arc4.abimethod
    // def echo_dynamic_array(self, arr: DynamicInts) -> DynamicInts:
    proto 1 1
    // smart_contracts/test_contract/contract.py:36
    // return arr
    frame_dig -1
    retsub


// smart_contracts.test_contract.contract.TestContract.nest_array_and_tuple(arr: bytes, tuple: bytes) -> bytes:
nest_array_and_tuple:
    // smart_contracts/test_contract/contract.py:38-41
    // @arc4.abimethod
    // def nest_array_and_tuple(
    //     self, arr: DynamicNestedInts, tuple: arc4.Tuple[DynamicInts, arc4.String]
    // ) -> ReturnType:
    proto 2 1
    // smart_contracts/test_contract/contract.py:42
    // (child_array, str) = tuple.native
    frame_dig -1
    int 0
    extract_uint16
    frame_dig -1
    int 2
    extract_uint16
    frame_dig -1
    uncover 2
    dig 2
    substring3
    swap
    frame_dig -1
    len
    frame_dig -1
    cover 2
    substring3
    swap
    // smart_contracts/test_contract/contract.py:47
    // arc4.Tuple[DynamicInts, arc4.String]((child_array.copy(), str)),
    dup
    len
    int 4
    +
    itob
    extract 6 2
    byte 0x0004
    swap
    concat
    swap
    concat
    swap
    concat
    // smart_contracts/test_contract/contract.py:44-49
    // return ReturnType(
    //     (
    //         arr.copy(),
    //         arc4.Tuple[DynamicInts, arc4.String]((child_array.copy(), str)),
    //     )
    // )
    frame_dig -2
    len
    int 4
    +
    itob
    extract 6 2
    byte 0x0004
    swap
    concat
    frame_dig -2
    concat
    swap
    concat
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_boolean(bool: bytes) -> bytes:
echo_boolean:
    // smart_contracts/test_contract/contract.py:51-52
    // @arc4.abimethod
    // def echo_boolean(self, bool: arc4.Bool) -> arc4.Bool:
    proto 1 1
    // smart_contracts/test_contract/contract.py:53
    // return bool
    frame_dig -1
    retsub
", - "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCgpzbWFydF9jb250cmFjdHMudGVzdF9jb250cmFjdC5jb250cmFjdC5UZXN0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbToKICAgIC8vIHNtYXJ0X2NvbnRyYWN0cy90ZXN0X2NvbnRyYWN0L2NvbnRyYWN0LnB5OjE3CiAgICAvLyBjbGFzcyBUZXN0Q29udHJhY3QoQVJDNENvbnRyYWN0KToKICAgIGludCAxCiAgICByZXR1cm4K" + "approval": "#pragma version 10

smart_contracts.test_contract.contract.TestContract.approval_program:
    intcblock 1 0 4
    bytecblock 0x151f7c75 0x0004
    txn ApplicationID
    bnz main_after_if_else@2
    callsub __init__

main_after_if_else@2:
    callsub __puya_arc4_router__
    return


// smart_contracts.test_contract.contract.TestContract.__init__() -> void:
__init__:
    // smart_contracts/test_contract/contract.py:12
    // def __init__(self) -> None:
    proto 0 0
    // smart_contracts/test_contract/contract.py:13
    // self.global_state_big_int = GlobalState(UInt64(33399922244455501))
    pushbytes "global_state_big_int"
    pushint 33399922244455501 // 33399922244455501
    app_global_put
    retsub


// smart_contracts.test_contract.contract.TestContract.__puya_arc4_router__() -> uint64:
__puya_arc4_router__:
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    proto 0 1
    txn NumAppArgs
    bz __puya_arc4_router___bare_routing@11
    pushbytess 0xfe6bdf69 0x9fd835f8 0xea4513d3 0xef3463bc 0x168afdba 0x8ea750d2 0x713d72e4 // method "add(uint64,uint64)uint64", method "get_pay_txn_amount(pay)uint64", method "echo_bytes(byte[])byte[]", method "echo_static_array(uint64[4])uint64[4]", method "echo_dynamic_array(uint64[])uint64[]", method "nest_array_and_tuple(uint64[][],(uint64[],string))(uint64[][],(uint64[],string))", method "echo_boolean(bool)bool"
    txna ApplicationArgs 0
    match __puya_arc4_router___add_route@2 __puya_arc4_router___get_pay_txn_amount_route@3 __puya_arc4_router___echo_bytes_route@4 __puya_arc4_router___echo_static_array_route@5 __puya_arc4_router___echo_dynamic_array_route@6 __puya_arc4_router___nest_array_and_tuple_route@7 __puya_arc4_router___echo_boolean_route@8
    intc_1 // 0
    retsub

__puya_arc4_router___add_route@2:
    // smart_contracts/test_contract/contract.py:15
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // smart_contracts/test_contract/contract.py:15
    // @arc4.abimethod
    callsub add
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___get_pay_txn_amount_route@3:
    // smart_contracts/test_contract/contract.py:19
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    // smart_contracts/test_contract/contract.py:19
    // @arc4.abimethod
    callsub get_pay_txn_amount
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___echo_bytes_route@4:
    // smart_contracts/test_contract/contract.py:23
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    extract 2 0
    // smart_contracts/test_contract/contract.py:23
    // @arc4.abimethod
    callsub echo_bytes
    dup
    len
    itob
    extract 6 2
    swap
    concat
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___echo_static_array_route@5:
    // smart_contracts/test_contract/contract.py:27
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    // smart_contracts/test_contract/contract.py:27
    // @arc4.abimethod
    callsub echo_static_array
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___echo_dynamic_array_route@6:
    // smart_contracts/test_contract/contract.py:31
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    // smart_contracts/test_contract/contract.py:31
    // @arc4.abimethod
    callsub echo_dynamic_array
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___nest_array_and_tuple_route@7:
    // smart_contracts/test_contract/contract.py:35
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    txna ApplicationArgs 2
    // smart_contracts/test_contract/contract.py:35
    // @arc4.abimethod
    callsub nest_array_and_tuple
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___echo_boolean_route@8:
    // smart_contracts/test_contract/contract.py:48
    // @arc4.abimethod
    txn OnCompletion
    !
    assert // OnCompletion is not NoOp
    txn ApplicationID
    assert // can only call when not creating
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txna ApplicationArgs 1
    // smart_contracts/test_contract/contract.py:48
    // @arc4.abimethod
    callsub echo_boolean
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    retsub

__puya_arc4_router___bare_routing@11:
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    txn OnCompletion
    bnz __puya_arc4_router___after_if_else@15
    txn ApplicationID
    !
    assert // can only call when creating
    intc_0 // 1
    retsub

__puya_arc4_router___after_if_else@15:
    // smart_contracts/test_contract/contract.py:11
    // class TestContract(ARC4Contract):
    intc_1 // 0
    retsub


// smart_contracts.test_contract.contract.TestContract.add(a: bytes, b: bytes) -> bytes:
add:
    // smart_contracts/test_contract/contract.py:15-16
    // @arc4.abimethod
    // def add(self, a: arc4.UInt64, b: arc4.UInt64) -> arc4.UInt64:
    proto 2 1
    // smart_contracts/test_contract/contract.py:17
    // return arc4.UInt64(a.native + b.native)
    frame_dig -2
    btoi
    frame_dig -1
    btoi
    +
    itob
    retsub


// smart_contracts.test_contract.contract.TestContract.get_pay_txn_amount(pay_txn: uint64) -> bytes:
get_pay_txn_amount:
    // smart_contracts/test_contract/contract.py:19-20
    // @arc4.abimethod
    // def get_pay_txn_amount(self, pay_txn: gtxn.PaymentTransaction) -> arc4.UInt64:
    proto 1 1
    // smart_contracts/test_contract/contract.py:21
    // return arc4.UInt64(pay_txn.amount)
    frame_dig -1
    gtxns Amount
    itob
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_bytes(a: bytes) -> bytes:
echo_bytes:
    // smart_contracts/test_contract/contract.py:23-24
    // @arc4.abimethod
    // def echo_bytes(self, a: Bytes) -> Bytes:
    proto 1 1
    // smart_contracts/test_contract/contract.py:25
    // return a
    frame_dig -1
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_static_array(arr: bytes) -> bytes:
echo_static_array:
    // smart_contracts/test_contract/contract.py:27-28
    // @arc4.abimethod
    // def echo_static_array(self, arr: StaticInts) -> StaticInts:
    proto 1 1
    // smart_contracts/test_contract/contract.py:29
    // return arr
    frame_dig -1
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_dynamic_array(arr: bytes) -> bytes:
echo_dynamic_array:
    // smart_contracts/test_contract/contract.py:31-32
    // @arc4.abimethod
    // def echo_dynamic_array(self, arr: DynamicInts) -> DynamicInts:
    proto 1 1
    // smart_contracts/test_contract/contract.py:33
    // return arr
    frame_dig -1
    retsub


// smart_contracts.test_contract.contract.TestContract.nest_array_and_tuple(arr: bytes, tuple: bytes) -> bytes:
nest_array_and_tuple:
    // smart_contracts/test_contract/contract.py:35-38
    // @arc4.abimethod
    // def nest_array_and_tuple(
    //     self, arr: DynamicNestedInts, tuple: arc4.Tuple[DynamicInts, arc4.String]
    // ) -> ReturnType:
    proto 2 1
    // smart_contracts/test_contract/contract.py:39
    // (child_array, str) = tuple.native
    frame_dig -1
    intc_1 // 0
    extract_uint16
    frame_dig -1
    pushint 2 // 2
    extract_uint16
    frame_dig -1
    uncover 2
    dig 2
    substring3
    frame_dig -1
    len
    frame_dig -1
    uncover 3
    uncover 2
    substring3
    // smart_contracts/test_contract/contract.py:44
    // arc4.Tuple[DynamicInts, arc4.String]((child_array.copy(), str)),
    dig 1
    len
    intc_2 // 4
    +
    itob
    extract 6 2
    bytec_1 // 0x0004
    swap
    concat
    uncover 2
    concat
    swap
    concat
    // smart_contracts/test_contract/contract.py:41-46
    // return ReturnType(
    //     (
    //         arr.copy(),
    //         arc4.Tuple[DynamicInts, arc4.String]((child_array.copy(), str)),
    //     )
    // )
    frame_dig -2
    len
    intc_2 // 4
    +
    itob
    extract 6 2
    bytec_1 // 0x0004
    swap
    concat
    frame_dig -2
    concat
    swap
    concat
    retsub


// smart_contracts.test_contract.contract.TestContract.echo_boolean(bool: bytes) -> bytes:
echo_boolean:
    // smart_contracts/test_contract/contract.py:48-49
    // @arc4.abimethod
    // def echo_boolean(self, bool: arc4.Bool) -> arc4.Bool:
    proto 1 1
    // smart_contracts/test_contract/contract.py:50
    // return bool
    frame_dig -1
    retsub
", + "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCgpzbWFydF9jb250cmFjdHMudGVzdF9jb250cmFjdC5jb250cmFjdC5UZXN0Q29udHJhY3QuY2xlYXJfc3RhdGVfcHJvZ3JhbToKICAgIHB1c2hpbnQgMSAvLyAxCiAgICByZXR1cm4K" }, "state": { "global": { "num_byte_slices": 0, - "num_uints": 0 + "num_uints": 1 }, "local": { "num_byte_slices": 0, @@ -52,7 +52,12 @@ }, "schema": { "global": { - "declared": {}, + "declared": { + "global_state_big_int": { + "type": "uint64", + "key": "global_state_big_int" + } + }, "reserved": {} }, "local": { @@ -75,6 +80,7 @@ "name": "b" } ], + "readonly": false, "returns": { "type": "uint64" } @@ -87,6 +93,7 @@ "name": "pay_txn" } ], + "readonly": false, "returns": { "type": "uint64" } @@ -99,6 +106,7 @@ "name": "a" } ], + "readonly": false, "returns": { "type": "byte[]" } @@ -111,6 +119,7 @@ "name": "arr" } ], + "readonly": false, "returns": { "type": "uint64[4]" } @@ -123,6 +132,7 @@ "name": "arr" } ], + "readonly": false, "returns": { "type": "uint64[]" } @@ -139,6 +149,7 @@ "name": "tuple" } ], + "readonly": false, "returns": { "type": "(uint64[][],(uint64[],string))" } @@ -151,6 +162,7 @@ "name": "bool" } ], + "readonly": false, "returns": { "type": "bool" }