From 90b0f3ebb163e05aa47aec66bf16ddaa03739546 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 31 Mar 2026 19:53:51 -0300 Subject: test: move lib functions into one (short!) file --- test/lib/strict-match-error.js | 50 ------------------------------------------ 1 file changed, 50 deletions(-) delete mode 100644 test/lib/strict-match-error.js (limited to 'test/lib/strict-match-error.js') diff --git a/test/lib/strict-match-error.js b/test/lib/strict-match-error.js deleted file mode 100644 index e3b36e93..00000000 --- a/test/lib/strict-match-error.js +++ /dev/null @@ -1,50 +0,0 @@ -export function strictlyThrows(t, fn, pattern) { - const error = catchErrorOrNull(fn); - - t.currentAssert = strictlyThrows; - - if (error === null) { - t.fail(`expected to throw`); - return; - } - - const nameAndMessage = `${pattern.constructor.name} ${pattern.message}`; - t.match( - prepareErrorForMatch(error), - prepareErrorForMatch(pattern), - (pattern instanceof AggregateError - ? `expected to throw: ${nameAndMessage} (${pattern.errors.length} error(s))` - : `expected to throw: ${nameAndMessage}`)); -} - -function prepareErrorForMatch(error) { - if (error instanceof RegExp) { - return { - message: error, - }; - } - - if (!(error instanceof Error)) { - return error; - } - - const matchable = { - name: error.constructor.name, - message: error.message, - }; - - if (error instanceof AggregateError) { - matchable.errors = error.errors.map(prepareErrorForMatch); - } - - return matchable; -} - -function catchErrorOrNull(fn) { - try { - fn(); - return null; - } catch (error) { - return error; - } -} -- cgit 1.3.0-6-gf8a5