Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions client/api/contracts.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
from client.resource import Resource


class Contracts(Resource):

def all(self):
return self.with_endpoint('api').request_get('contracts')

def abi(self, name: str, implementation: str):
return self.with_endpoint('api').request_get(f'contracts/{name}/{implementation}/abi')
9 changes: 9 additions & 0 deletions client/client.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
from typing import Union
from client.api.contracts import Contracts
from client.connection import ClientHosts, Connection
from client.api.api_nodes import ApiNodes
from client.api.blockchain import Blockchain
Expand Down Expand Up @@ -54,6 +55,14 @@ def commits(self):
"""
return Commits(self.connection)

@property
def contracts(self):
"""
:return: contracts API
:rtype: client.api.contracts.Contracts
"""
return Contracts(self.connection)

@property
def evm(self):
"""
Expand Down
30 changes: 30 additions & 0 deletions tests/api/test_contracts.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import responses
from client import ArkClient


def test_all_calls_correct_url():
responses.add(
responses.GET,
'http://127.0.0.1:4002/api/contracts',
json={'success': True},
status=200
)

client = ArkClient('http://127.0.0.1:4002/api')
client.contracts.all()
assert len(responses.calls) == 1
assert responses.calls[0].request.url == 'http://127.0.0.1:4002/api/contracts'


def test_abi_calls_correct_url():
responses.add(
responses.GET,
'http://127.0.0.1:4002/api/contracts/consensus/some-address/abi',
json={'success': True},
status=200
)

client = ArkClient('http://127.0.0.1:4002/api')
client.contracts.abi('consensus', 'some-address')
assert len(responses.calls) == 1
assert responses.calls[0].request.url == 'http://127.0.0.1:4002/api/contracts/consensus/some-address/abi'