test_: WalletService class (#6171)

This commit is contained in:
Igor Sirotin 2024-12-09 12:18:34 +00:00 committed by GitHub
parent 943ae13358
commit 4ccb08f11d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 36 additions and 9 deletions

View File

@ -6,6 +6,7 @@ from tenacity import retry, stop_after_delay, wait_fixed
from conftest import option from conftest import option
from json import JSONDecodeError from json import JSONDecodeError
class RpcClient: class RpcClient:
def __init__(self, rpc_url, client=requests.Session()): def __init__(self, rpc_url, client=requests.Session()):
@ -43,7 +44,9 @@ class RpcClient:
self._check_decode_and_key_errors_in_response(response, "error") self._check_decode_and_key_errors_in_response(response, "error")
@retry(stop=stop_after_delay(10), wait=wait_fixed(0.5), reraise=True) @retry(stop=stop_after_delay(10), wait=wait_fixed(0.5), reraise=True)
def rpc_request(self, method, params=[], request_id=13, url=None): def rpc_request(self, method, params=None, request_id=13, url=None):
if params is None:
params = []
url = url if url else self.rpc_url url = url if url else self.rpc_url
data = {"jsonrpc": "2.0", "method": method, "id": request_id} data = {"jsonrpc": "2.0", "method": method, "id": request_id}
if params: if params:
@ -59,7 +62,7 @@ class RpcClient:
logging.info(f"Got response: {response.content}") logging.info(f"Got response: {response.content}")
return response return response
def rpc_valid_request(self, method, params=[], _id=None, url=None): def rpc_valid_request(self, method, params=None, _id=None, url=None):
response = self.rpc_request(method, params, _id, url) response = self.rpc_request(method, params, _id, url)
self.verify_is_valid_json_rpc_response(response, _id) self.verify_is_valid_json_rpc_response(response, _id)
return response return response

View File

@ -0,0 +1,12 @@
from clients.rpc import RpcClient
class Service:
def __init__(self, client: RpcClient, name: str):
assert name is not ""
self.rpc_client = client
self.name = name
def rpc_request(self, method: str, params=None):
full_method_name = f"{self.name}_{method}"
return self.rpc_client.rpc_request(full_method_name, params)

View File

@ -0,0 +1,11 @@
from clients.rpc import RpcClient
from clients.services.service import Service
class WalletService(Service):
def __init__(self, client: RpcClient):
super().__init__(client, "wallet")
def get_balances_at_by_chain(self, chains: list, addresses: list, tokens: list):
params = [chains, addresses, tokens]
return self.rpc_request("getBalancesByChain", params)

View File

@ -13,7 +13,6 @@ from conftest import option
from constants import user_1, DEFAULT_DISPLAY_NAME from constants import user_1, DEFAULT_DISPLAY_NAME
class StatusBackend(RpcClient, SignalClient): class StatusBackend(RpcClient, SignalClient):
def __init__(self, await_signals=[], url=None): def __init__(self, await_signals=[], url=None):
@ -27,7 +26,6 @@ class StatusBackend(RpcClient, SignalClient):
self.ws_url = f"{url}".replace("http", "ws") self.ws_url = f"{url}".replace("http", "ws")
self.rpc_url = f"{url}/statusgo/CallRPC" self.rpc_url = f"{url}/statusgo/CallRPC"
RpcClient.__init__(self, self.rpc_url) RpcClient.__init__(self, self.rpc_url)
SignalClient.__init__(self, self.ws_url, await_signals) SignalClient.__init__(self, self.ws_url, await_signals)
@ -83,7 +81,8 @@ class StatusBackend(RpcClient, SignalClient):
} }
return self.api_valid_request(method, data) return self.api_valid_request(method, data)
def restore_account_and_login(self, data_dir="/",display_name=DEFAULT_DISPLAY_NAME, user=user_1): def restore_account_and_login(self, data_dir="/",display_name=DEFAULT_DISPLAY_NAME, user=user_1,
network_id=31337):
method = "RestoreAccountAndLogin" method = "RestoreAccountAndLogin"
data = { data = {
"rootDataDir": data_dir, "rootDataDir": data_dir,
@ -95,10 +94,10 @@ class StatusBackend(RpcClient, SignalClient):
"logEnabled": True, "logEnabled": True,
"logLevel": "DEBUG", "logLevel": "DEBUG",
"testNetworksEnabled": False, "testNetworksEnabled": False,
"networkId": 31337, "networkId": network_id,
"networksOverride": [ "networksOverride": [
{ {
"ChainID": 31337, "ChainID": network_id,
"ChainName": "Anvil", "ChainName": "Anvil",
"DefaultRPCURL": "http://anvil:8545", "DefaultRPCURL": "http://anvil:8545",
"RPCURL": "http://anvil:8545", "RPCURL": "http://anvil:8545",

View File

@ -7,6 +7,7 @@ from collections import namedtuple
import pytest import pytest
from clients.services.wallet import WalletService
from clients.signals import SignalClient, SignalType from clients.signals import SignalClient, SignalType
from clients.status_backend import RpcClient, StatusBackend from clients.status_backend import RpcClient, StatusBackend
from conftest import option from conftest import option
@ -28,15 +29,16 @@ class StatusBackendTestCase:
SignalType.NODE_LOGIN.value SignalType.NODE_LOGIN.value
] ]
network_id = 31337
def setup_class(self): def setup_class(self):
self.rpc_client = StatusBackend(await_signals=self.await_signals) self.rpc_client = StatusBackend(await_signals=self.await_signals)
self.wallet_service = WalletService(self.rpc_client)
self.rpc_client.init_status_backend() self.rpc_client.init_status_backend()
self.rpc_client.restore_account_and_login() self.rpc_client.restore_account_and_login()
self.rpc_client.wait_for_login() self.rpc_client.wait_for_login()
self.network_id = 31337
class WalletTestCase(StatusBackendTestCase): class WalletTestCase(StatusBackendTestCase):