From d0dc0d71b6a211ed6858183b37801d75dc1f17cb Mon Sep 17 00:00:00 2001
From: Bartek Szopka <83575+bartaz@users.noreply.github.com>
Date: Mon, 3 Oct 2022 16:23:21 +0200
Subject: [PATCH] Fix for custom config for help (#217)
---
index.js | 4 ++--
test/allow-unknown-flags.js | 12 ++++++++++
.../fixture-allow-unknown-flags-with-help.js | 24 +++++++++++++++++++
3 files changed, 38 insertions(+), 2 deletions(-)
create mode 100755 test/fixtures/fixture-allow-unknown-flags-with-help.js
diff --git a/index.js b/index.js
index c4878ec..2ab52d0 100644
--- a/index.js
+++ b/index.js
@@ -149,11 +149,11 @@ const meow = (helpText, options = {}) => {
// Add --help and --version to known flags if autoHelp or autoVersion are set
if (!options.allowUnknownFlags) {
- if (options.autoHelp) {
+ if (options.autoHelp && !parserOptions.help) {
parserOptions.help = {type: 'boolean'};
}
- if (options.autoVersion) {
+ if (options.autoVersion && !parserOptions.version) {
parserOptions.version = {type: 'boolean'};
}
}
diff --git a/test/allow-unknown-flags.js b/test/allow-unknown-flags.js
index 8f37229..5fdd387 100644
--- a/test/allow-unknown-flags.js
+++ b/test/allow-unknown-flags.js
@@ -7,6 +7,7 @@ import {readPackage} from 'read-pkg';
const __dirname = path.dirname(fileURLToPath(import.meta.url));
const fixtureAllowUnknownFlags = path.join(__dirname, 'fixtures', 'fixture-allow-unknown-flags.js');
+const fixtureAllowUnknownFlagsWithHelp = path.join(__dirname, 'fixtures', 'fixture-allow-unknown-flags-with-help.js');
test('spawn CLI and test specifying unknown flags', async t => {
const error = await t.throwsAsync(
@@ -61,3 +62,14 @@ test('spawn CLI and test version as an unknown flag', async t => {
t.regex(stderr, /Unknown flag/);
t.regex(stderr, /--version/);
});
+
+test('spawn CLI and test help with custom config', async t => {
+ const {stdout} = await execa(fixtureAllowUnknownFlagsWithHelp, ['-h']);
+ t.is(stdout, indentString('\nCustom description\n\nUsage\n foo \n\n', 2));
+});
+
+test('spawn CLI and test version with custom config', async t => {
+ const pkg = await readPackage();
+ const {stdout} = await execa(fixtureAllowUnknownFlagsWithHelp, ['-v']);
+ t.is(stdout, pkg.version);
+});
diff --git a/test/fixtures/fixture-allow-unknown-flags-with-help.js b/test/fixtures/fixture-allow-unknown-flags-with-help.js
new file mode 100755
index 0000000..74725a9
--- /dev/null
+++ b/test/fixtures/fixture-allow-unknown-flags-with-help.js
@@ -0,0 +1,24 @@
+#!/usr/bin/env node
+import meow from '../../index.js';
+
+const cli = meow({
+ importMeta: import.meta,
+ description: 'Custom description',
+ help: `
+ Usage
+ foo
+ `,
+ allowUnknownFlags: false,
+ flags: {
+ help: {
+ alias: 'h',
+ type: 'boolean',
+ },
+ version: {
+ alias: 'v',
+ type: 'boolean',
+ },
+ },
+});
+
+console.log(cli.flags.help);