From 5e310f7e7df7c0d0a5df05e0918c12cc60c7edaf Mon Sep 17 00:00:00 2001 From: Alex Myers Date: Wed, 9 Aug 2023 12:10:44 -0500 Subject: [PATCH 1/2] cli: don't crash when there's no argument This should provide the default help message and exit, but was resulting in a segmentation fault from freeing pointers passed to the default config. Changelog-Fixed: lightning-cli properly returns help without argument --- cli/lightning-cli.c | 5 +++-- common/configdir.c | 10 ++++++---- common/configdir.h | 2 ++ devtools/checkchannels.c | 4 +++- 4 files changed, 14 insertions(+), 7 deletions(-) diff --git a/cli/lightning-cli.c b/cli/lightning-cli.c index 392ad88fc7a8..117f6b19b99c 100644 --- a/cli/lightning-cli.c +++ b/cli/lightning-cli.c @@ -650,7 +650,7 @@ int main(int argc, char *argv[]) jsmntok_t *toks; const jsmntok_t *result, *error, *id; const tal_t *ctx = tal(NULL, char); - char *net_dir, *rpc_filename; + char *config_filename, *base_dir, *net_dir, *rpc_filename; jsmn_parser parser; int parserr; enum format format = DEFAULT_FORMAT; @@ -668,7 +668,8 @@ int main(int argc, char *argv[]) setup_option_allocators(); opt_exitcode = ERROR_USAGE; - minimal_config_opts(ctx, argc, argv, &net_dir, &rpc_filename); + minimal_config_opts(ctx, argc, argv, &config_filename, &base_dir, + &net_dir, &rpc_filename); opt_register_noarg("--help|-h", opt_usage_and_exit, " [...]", "Show this message. Use the command help (without hyphens -- \"lightning-cli help\") to get a list of all RPC commands"); diff --git a/common/configdir.c b/common/configdir.c index 8446ba16a959..8f8a30eec33e 100644 --- a/common/configdir.c +++ b/common/configdir.c @@ -281,16 +281,18 @@ static struct configvar **gather_cmdline_args(const tal_t *ctx, void minimal_config_opts(const tal_t *ctx, int argc, char *argv[], + char **config_filename, + char **basedir, char **config_netdir, char **rpc_filename) { - char *unused_filename, *unused_basedir; - initial_config_opts(tmpctx, &argc, argv, false, - &unused_filename, - &unused_basedir, + config_filename, + basedir, config_netdir, rpc_filename); + tal_steal(ctx, *config_filename); + tal_steal(ctx, *basedir); tal_steal(ctx, *config_netdir); tal_steal(ctx, *rpc_filename); } diff --git a/common/configdir.h b/common/configdir.h index 283b4ec9cbef..e25207be5edf 100644 --- a/common/configdir.h +++ b/common/configdir.h @@ -15,6 +15,8 @@ void setup_option_allocators(void); /* Minimal config parsing for tools: use opt_early_parse/opt_parse after */ void minimal_config_opts(const tal_t *ctx, int argc, char *argv[], + char **config_filename, + char **basedir, char **config_netdir, char **rpc_filename); diff --git a/devtools/checkchannels.c b/devtools/checkchannels.c index 538912938fee..d70407b14868 100644 --- a/devtools/checkchannels.c +++ b/devtools/checkchannels.c @@ -109,6 +109,7 @@ static void copy_column(void *dst, size_t size, int main(int argc, char *argv[]) { + char *config_filename, *base_dir; char *net_dir, *rpc_filename, *hsmfile, *dbfile; sqlite3 *sql; sqlite3_stmt *stmt; @@ -124,7 +125,8 @@ int main(int argc, char *argv[]) setup_option_allocators(); - minimal_config_opts(top_ctx, argc, argv, &net_dir, &rpc_filename); + minimal_config_opts(top_ctx, argc, argv, &config_filename, &base_dir, + &net_dir, &rpc_filename); opt_register_noarg("-v|--verbose", opt_set_bool, &verbose, "Print everything"); From be74b0e1dea867e750102a3f5db9574a4462932f Mon Sep 17 00:00:00 2001 From: Alex Myers Date: Tue, 15 Aug 2023 10:42:23 -0500 Subject: [PATCH 2/2] pytest: add no argument cli test --- tests/test_misc.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/tests/test_misc.py b/tests/test_misc.py index ef410852a8d6..ee59d5b7fa04 100644 --- a/tests/test_misc.py +++ b/tests/test_misc.py @@ -1195,6 +1195,13 @@ def test_daemon_option(node_factory): assert 'No child process' not in f.read() +def test_cli_no_argument(): + """If no arguments are provided, should display help and exit.""" + out = subprocess.run(['cli/lightning-cli'], stdout=subprocess.PIPE) + assert out.returncode in [0, 2] # returns 2 if lightning-rpc not available + assert "Usage: cli/lightning-cli [...]" in out.stdout.decode() + + @pytest.mark.developer("needs DEVELOPER=1") def test_blockchaintrack(node_factory, bitcoind): """Check that we track the blockchain correctly across reorgs