Merge #14658: qa: Add test to ensure node can generate all rpc help texts at runtime
bbbbb3f885
qa: Add test to ensure node can generate all help texts at runtime (MarcoFalke)
Pull request description:
This might increase coverage, but more importantly this checks that the node doesn't crash when generating the help. (Right now the help is a static string, but in the future it might be generated at runtime)
Tree-SHA512: 0226e7c65f8a1a6fdc96c07dcf491d90559bc2355c92e9da9b1f174b09733fc349269e71da6d792f954de563a1e57c848471813eabae1a40b849a0d989520a0d
This commit is contained in:
commit
cdddd17780
1 changed files with 15 additions and 0 deletions
|
@ -7,12 +7,18 @@
|
|||
from test_framework.test_framework import BitcoinTestFramework
|
||||
from test_framework.util import assert_equal, assert_raises_rpc_error
|
||||
|
||||
import os
|
||||
|
||||
|
||||
class HelpRpcTest(BitcoinTestFramework):
|
||||
def set_test_params(self):
|
||||
self.num_nodes = 1
|
||||
|
||||
def run_test(self):
|
||||
self.test_categories()
|
||||
self.dump_help()
|
||||
|
||||
def test_categories(self):
|
||||
node = self.nodes[0]
|
||||
|
||||
# wrong argument count
|
||||
|
@ -37,6 +43,15 @@ class HelpRpcTest(BitcoinTestFramework):
|
|||
|
||||
assert_equal(titles, components)
|
||||
|
||||
def dump_help(self):
|
||||
dump_dir = os.path.join(self.options.tmpdir, 'rpc_help_dump')
|
||||
os.mkdir(dump_dir)
|
||||
calls = [line.split(' ', 1)[0] for line in self.nodes[0].help().splitlines() if line and not line.startswith('==')]
|
||||
for call in calls:
|
||||
with open(os.path.join(dump_dir, call), 'w', encoding='utf-8') as f:
|
||||
# Make sure the node can generate the help at runtime without crashing
|
||||
f.write(self.nodes[0].help(call))
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
HelpRpcTest().main()
|
||||
|
|
Loading…
Reference in a new issue