From 76cb9c2a39d477a64824a985ade40507e3bbade1 Mon Sep 17 00:00:00 2001 From: Adam Mathes Date: Fri, 13 Feb 2026 21:34:48 -0800 Subject: feat(vanilla): add testing infrastructure and tests (NK-wjnczv) --- vanilla/node_modules/@exodus/bytes/assert.js | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 vanilla/node_modules/@exodus/bytes/assert.js (limited to 'vanilla/node_modules/@exodus/bytes/assert.js') diff --git a/vanilla/node_modules/@exodus/bytes/assert.js b/vanilla/node_modules/@exodus/bytes/assert.js new file mode 100644 index 0000000..fee83fc --- /dev/null +++ b/vanilla/node_modules/@exodus/bytes/assert.js @@ -0,0 +1,26 @@ +export function assertEmptyRest(rest) { + if (Object.keys(rest).length > 0) throw new TypeError('Unexpected extra options') +} + +// eslint-disable-next-line sonarjs/no-nested-template-literals +const makeMessage = (name, extra) => `Expected${name ? ` ${name} to be` : ''} an Uint8Array${extra}` + +const TypedArray = Object.getPrototypeOf(Uint8Array) + +export function assertTypedArray(arr) { + if (arr instanceof TypedArray) return + throw new TypeError('Expected a TypedArray instance') +} + +export function assertUint8(arr, options) { + if (!options) { + // fast path + if (arr instanceof Uint8Array) return + throw new TypeError('Expected an Uint8Array') + } + + const { name, length, ...rest } = options + assertEmptyRest(rest) + if (arr instanceof Uint8Array && (length === undefined || arr.length === length)) return + throw new TypeError(makeMessage(name, length === undefined ? '' : ` of size ${Number(length)}`)) +} -- cgit v1.2.3