From d848cc0ee8b15af9fc98d9a10b87ada8ca1d5927 Mon Sep 17 00:00:00 2001 From: Connor Peet Date: Thu, 30 May 2024 11:34:19 -0700 Subject: [PATCH] fix: throw a well-typed error on run failure (#275) --- CHANGELOG.md | 4 ++++ lib/index.ts | 2 +- lib/runTest.ts | 15 +++++++++------ 3 files changed, 14 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9555ccf7..77968b4f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +### TBA + +- Throw a typed `TestRunFailedError` on failure instead of a string. + ### 2.4.0 | 2024-05-24 - Allow installing unreleased builds using an `-unreleased` suffix, such as `insiders-unreleased`. diff --git a/lib/index.ts b/lib/index.ts index dc2f85a3..05249d70 100644 --- a/lib/index.ts +++ b/lib/index.ts @@ -4,7 +4,7 @@ *--------------------------------------------------------------------------------------------*/ export { download, downloadAndUnzipVSCode, DownloadOptions } from './download'; -export { runTests, TestOptions } from './runTest'; +export { runTests, TestOptions, TestRunFailedError } from './runTest'; export { resolveCliPathFromVSCodeExecutablePath, resolveCliArgsFromVSCodeExecutablePath, diff --git a/lib/runTest.ts b/lib/runTest.ts index 3e622852..6b2fd5be 100644 --- a/lib/runTest.ts +++ b/lib/runTest.ts @@ -161,13 +161,10 @@ async function innerRunTests( cmd.stdout.destroy(); cmd.stderr.destroy(); - if (code === null) { - reject(signal); - } else if (code !== 0) { - reject('Failed'); + if (code !== 0) { + reject(new TestRunFailedError(code ?? undefined, signal ?? undefined)); } else { - console.log('Done\n'); - resolve(code ?? -1); + resolve(0); } } @@ -190,3 +187,9 @@ async function innerRunTests( return code; } + +export class TestRunFailedError extends Error { + constructor(public readonly code: number | undefined, public readonly signal: string | undefined) { + super(signal ? `Test run terminated with signal ${signal}` : `Test run failed with code ${code}`); + } +}