From d795bd9b294035195fc5428d5139cf94d76ad873 Mon Sep 17 00:00:00 2001 From: Benjamin DeMann Date: Mon, 8 Jul 2024 10:02:02 -0600 Subject: [PATCH] add backwards compatibility with old tests --- test/index.ts | 42 +++++++++++++++++++++++++++++++++++------- 1 file changed, 35 insertions(+), 7 deletions(-) diff --git a/test/index.ts b/test/index.ts index a8115986df..3052d3b231 100644 --- a/test/index.ts +++ b/test/index.ts @@ -14,10 +14,13 @@ export type Test<> = { test?: () => Promise>; }; -type AzleResult = Partial<{ - Ok: { isSuccessful: boolean; message?: string }; - Err: E; -}>; +// TODO get rid of this union once the jest migration is complete +type AzleResult = + | Partial<{ + Ok: { isSuccessful: boolean; message?: string }; + Err: E; + }> + | Partial<{ Ok: boolean; Err: E }>; // TODO should this just return a boolean? // TODO then the function calling can decide to throw or not @@ -71,10 +74,20 @@ export async function runTests( } } - if (result.Ok.isSuccessful !== true) { + // TODO replace this with the below commented out code once jest migration is complete + const message = + typeof result.Ok === 'object' && result.Ok !== null + ? result.Ok.message + : undefined; + const successful = + typeof result.Ok === 'boolean' + ? result.Ok + : result.Ok.isSuccessful; + + if (successful !== true) { console.info('\x1b[31m', `test: ${test.name} failed`); - if (result.Ok.message !== undefined) { - console.info('\x1b[31m', `${result.Ok.message}`); + if (message !== undefined) { + console.info('\x1b[31m', `${message}`); } console.info('\x1b[0m'); @@ -85,6 +98,21 @@ export async function runTests( } } + // TODO bring this back once jest migration is complete + // if (result.Ok.isSuccessful !== true) { + // console.info('\x1b[31m', `test: ${test.name} failed`); + // if (result.Ok.message !== undefined) { + // console.info('\x1b[31m', `${result.Ok.message}`); + // } + // console.info('\x1b[0m'); + + // if (exitProcess) { + // process.exit(1); + // } else { + // return false; + // } + // } + console.info('\x1b[32m', `test: ${test.name} passed`); console.info('\x1b[0m'); } catch (error) {