mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-11 23:58:18 +00:00
[test] Add support for custom arguments to TestNodeCLI
Github-Pull: #11125
Rebased-From: 5c18a84b9a
This commit is contained in:
parent
812c870043
commit
e0bfd28de2
@ -155,8 +155,16 @@ class TestNodeCLI():
|
|||||||
"""Interface to bitcoin-cli for an individual node"""
|
"""Interface to bitcoin-cli for an individual node"""
|
||||||
|
|
||||||
def __init__(self, binary, datadir):
|
def __init__(self, binary, datadir):
|
||||||
|
self.args = []
|
||||||
self.binary = binary
|
self.binary = binary
|
||||||
self.datadir = datadir
|
self.datadir = datadir
|
||||||
|
self.input = None
|
||||||
|
|
||||||
|
def __call__(self, *args, input=None):
|
||||||
|
# TestNodeCLI is callable with bitcoin-cli command-line args
|
||||||
|
self.args = [str(arg) for arg in args]
|
||||||
|
self.input = input
|
||||||
|
return self
|
||||||
|
|
||||||
def __getattr__(self, command):
|
def __getattr__(self, command):
|
||||||
def dispatcher(*args, **kwargs):
|
def dispatcher(*args, **kwargs):
|
||||||
@ -169,9 +177,9 @@ class TestNodeCLI():
|
|||||||
pos_args = [str(arg) for arg in args]
|
pos_args = [str(arg) for arg in args]
|
||||||
named_args = [str(key) + "=" + str(value) for (key, value) in kwargs.items()]
|
named_args = [str(key) + "=" + str(value) for (key, value) in kwargs.items()]
|
||||||
assert not (pos_args and named_args), "Cannot use positional arguments and named arguments in the same bitcoin-cli call"
|
assert not (pos_args and named_args), "Cannot use positional arguments and named arguments in the same bitcoin-cli call"
|
||||||
p_args = [self.binary, "-datadir=" + self.datadir]
|
p_args = [self.binary, "-datadir=" + self.datadir] + self.args
|
||||||
if named_args:
|
if named_args:
|
||||||
p_args += ["-named"]
|
p_args += ["-named"]
|
||||||
p_args += [command] + pos_args + named_args
|
p_args += [command] + pos_args + named_args
|
||||||
cli_output = subprocess.check_output(p_args, universal_newlines=True)
|
cli_output = subprocess.check_output(p_args, input=self.input, universal_newlines=True)
|
||||||
return json.loads(cli_output, parse_float=decimal.Decimal)
|
return json.loads(cli_output, parse_float=decimal.Decimal)
|
||||||
|
Loading…
Reference in New Issue
Block a user