From cb4dd7489c74295d9efa246849ac3d438f4eaa58 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Mon, 24 Jun 2024 13:15:52 +0930 Subject: [PATCH] lightningd: check command should return as much detail as possible. If they're explicitly calling "check", don't obfuscate the result! Signed-off-by: Rusty Russell --- common/json_command.c | 2 +- tests/test_misc.py | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/common/json_command.c b/common/json_command.c index 613b02e1d646..0e081cb6b11e 100644 --- a/common/json_command.c +++ b/common/json_command.c @@ -8,7 +8,7 @@ command_fail_badparam(struct command *cmd, const jsmntok_t *tok, const char *msg) { - if (command_dev_apis(cmd)) { + if (command_dev_apis(cmd) || command_check_only(cmd)) { return command_fail(cmd, JSONRPC2_INVALID_PARAMS, "%s: %s: invalid token '%.*s'", paramname, msg, diff --git a/tests/test_misc.py b/tests/test_misc.py index 5a35ab150d32..6cd2a9ed905c 100644 --- a/tests/test_misc.py +++ b/tests/test_misc.py @@ -4244,3 +4244,9 @@ def test_badparam_discretion(node_factory): l1.rpc.checkrune(rune='THIS IS NOT ACTUALLY A RUNE') l1.daemon.wait_for_log(r"checkrune: Invalid parameter rune \(should be base64 string\): token '\"THIS IS NOT ACTUALLY A RUNE\"'") + + # But: check command *SHOULD* give as much info as we can. + with pytest.raises(RpcError, match='rune: should be base64 string: invalid token') as err: + l1.rpc.check('checkrune', rune='THIS IS NOT ACTUALLY A RUNE') + + assert err.value.error['message'] == "rune: should be base64 string: invalid token '\"THIS IS NOT ACTUALLY A RUNE\"'"