From be581d35e8ff028c308d3c9f5c0731cbdd88b914 Mon Sep 17 00:00:00 2001 From: Lev Chelyadinov Date: Sun, 20 Oct 2024 00:53:46 +0200 Subject: [PATCH] Throw errors on non-existent paths --- .changeset/mean-buses-tan.md | 5 +++++ packages/steiger/src/cli.ts | 17 +++++++++++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) create mode 100644 .changeset/mean-buses-tan.md diff --git a/.changeset/mean-buses-tan.md b/.changeset/mean-buses-tan.md new file mode 100644 index 00000000..59d52a6c --- /dev/null +++ b/.changeset/mean-buses-tan.md @@ -0,0 +1,5 @@ +--- +'steiger': patch +--- + +Fix the non-existent paths showing up as a success diff --git a/packages/steiger/src/cli.ts b/packages/steiger/src/cli.ts index 61cdc525..32065b02 100755 --- a/packages/steiger/src/cli.ts +++ b/packages/steiger/src/cli.ts @@ -1,6 +1,7 @@ #!/usr/bin/env node import { resolve, relative, dirname } from 'node:path' +import { stat } from 'node:fs/promises' import * as process from 'node:process' import yargs from 'yargs' import prexit from 'prexit' @@ -68,8 +69,20 @@ try { } } +const targetPath = resolve(consoleArgs._[0]) + +try { + if (!(await stat(targetPath)).isDirectory()) { + console.error(`${consoleArgs._[0]} is a file, must be a folder`) + process.exit(102) + } +} catch { + console.error(`Folder ${consoleArgs._[0]} does not exist`) + process.exit(101) +} + if (consoleArgs.watch) { - const [diagnosticsChanged, stopWatching] = await linter.watch(resolve(consoleArgs._[0])) + const [diagnosticsChanged, stopWatching] = await linter.watch(targetPath) const unsubscribe = diagnosticsChanged.watch((state) => { console.clear() reportPretty(state, process.cwd()) @@ -82,7 +95,7 @@ if (consoleArgs.watch) { unsubscribe() }) } else { - const diagnostics = await linter.run(resolve(consoleArgs._[0])) + const diagnostics = await linter.run(targetPath) let stillRelevantDiagnostics = diagnostics reportPretty(diagnostics, process.cwd())