Skip to content

Commit

Permalink
Merge bitcoin#22139: test: add type annotations to util.get_rpc_proxy
Browse files Browse the repository at this point in the history
fbeb8c4 test: add type annotations to util.get_rpc_proxy (fanquake)

Pull request description:

  Split out from bitcoin#22092 while we address the functional test failure.

ACKs for top commit:
  instagibbs:
    ACK bitcoin@fbeb8c4

Tree-SHA512: 031ef8703202ae5271787719fc3fea8693574b2eb937ccf852875de95798d7fa3c39a8db7c91993d0c946b45d9b4d6de570bd1102e0344348784723bd84803a8
  • Loading branch information
MarcoFalke authored and UdjinM6 committed Nov 16, 2023
1 parent a69ded9 commit ce07481
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 17 deletions.
21 changes: 12 additions & 9 deletions test/functional/test_framework/coverage.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@

import os

from .authproxy import AuthServiceProxy

REFERENCE_FILENAME = 'rpc_interface.txt'

Expand All @@ -19,24 +20,25 @@ class AuthServiceProxyWrapper():
An object that wraps AuthServiceProxy to record specific RPC calls.
"""
def __init__(self, auth_service_proxy_instance, coverage_logfile=None):
def __init__(self, auth_service_proxy_instance: AuthServiceProxy, rpc_url: str, coverage_logfile: str=None):
"""
Kwargs:
auth_service_proxy_instance (AuthServiceProxy): the instance
being wrapped.
coverage_logfile (str): if specified, write each service_name
auth_service_proxy_instance: the instance being wrapped.
rpc_url: url of the RPC instance being wrapped
coverage_logfile: if specified, write each service_name
out to a file when called.
"""
self.auth_service_proxy_instance = auth_service_proxy_instance
self.rpc_url = rpc_url
self.coverage_logfile = coverage_logfile

def __getattr__(self, name):
return_val = getattr(self.auth_service_proxy_instance, name)
if not isinstance(return_val, type(self.auth_service_proxy_instance)):
# If proxy getattr returned an unwrapped value, do the same here.
return return_val
return AuthServiceProxyWrapper(return_val, self.coverage_logfile)
return AuthServiceProxyWrapper(return_val, self.rpc_url, self.coverage_logfile)

def __call__(self, *args, **kwargs):
"""
Expand All @@ -57,6 +59,7 @@ def _log_call(self):

def __truediv__(self, relative_uri):
return AuthServiceProxyWrapper(self.auth_service_proxy_instance / relative_uri,
self.rpc_url,
self.coverage_logfile)

def get_request(self, *args, **kwargs):
Expand All @@ -74,18 +77,18 @@ def get_filename(dirname, n_node):
dirname, "coverage.pid%s.node%s.txt" % (pid, str(n_node)))


def write_all_rpc_commands(dirname, node):
def write_all_rpc_commands(dirname: str, node: AuthServiceProxy) -> bool:
"""
Write out a list of all RPC functions available in `dash-cli` for
coverage comparison. This will only happen once per coverage
directory.
Args:
dirname (str): temporary test dir
node (AuthServiceProxy): client
dirname: temporary test dir
node: client
Returns:
bool. if the RPC interface file was written.
if the RPC interface file was written.
"""
filename = os.path.join(dirname, REFERENCE_FILENAME)
Expand Down
2 changes: 1 addition & 1 deletion test/functional/test_framework/test_node.py
Original file line number Diff line number Diff line change
Expand Up @@ -271,7 +271,7 @@ def wait_for_rpc_connection(self):
return
self.rpc = rpc
self.rpc_connected = True
self.url = self.rpc.url
self.url = self.rpc.rpc_url
return
except JSONRPCException as e: # Initialization phase
# -28 RPC in warmup
Expand Down
14 changes: 7 additions & 7 deletions test/functional/test_framework/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -260,15 +260,16 @@ class PortSeed:
# Must be initialized with a unique integer for each process
n = None

def get_rpc_proxy(url, node_number, *, timeout=None, coveragedir=None):

def get_rpc_proxy(url: str, node_number: int, *, timeout: int=None, coveragedir: str=None) -> coverage.AuthServiceProxyWrapper:
"""
Args:
url (str): URL of the RPC server to call
node_number (int): the node number (or id) that this calls to
url: URL of the RPC server to call
node_number: the node number (or id) that this calls to
Kwargs:
timeout (int): HTTP timeout in seconds
coveragedir (str): Directory
timeout: HTTP timeout in seconds
coveragedir: Directory
Returns:
AuthServiceProxy. convenience object for making RPC calls.
Expand All @@ -279,12 +280,11 @@ def get_rpc_proxy(url, node_number, *, timeout=None, coveragedir=None):
proxy_kwargs['timeout'] = int(timeout)

proxy = AuthServiceProxy(url, **proxy_kwargs)
proxy.url = url # store URL on proxy for info

coverage_logfile = coverage.get_filename(
coveragedir, node_number) if coveragedir else None

return coverage.AuthServiceProxyWrapper(proxy, coverage_logfile)
return coverage.AuthServiceProxyWrapper(proxy, url, coverage_logfile)

def p2p_port(n):
assert n <= MAX_NODES
Expand Down

0 comments on commit ce07481

Please sign in to comment.