Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

ensure-error

sindresorhus102.9kMIT5.0.0TypeScript support: included

Ensures a value is a valid error by making it one if not

error, ensure, valid, stack, message, name, string, to, make, fix, clean, convert, cause

readme

ensure-error

Ensures a value is a valid error by making it one if not

Pass it any value and you are guaranteed to get back an Error with name, message, and stack properties.

If the error has a .cause property, it will be recursively ensured to be a valid error too. If the error is an AggregateError, all items in the errors array will also be recursively ensured to be valid errors.

Can be useful when you don't control all the places an error can be thrown or rejected. A user could for example throw a string or an error without a stack property.

Install

npm install ensure-error

Usage

import ensureError from 'ensure-error';

const error = new TypeError('🦄');
error.name = '';

console.log(error.name);
//=> ''

console.log(ensureError(error).name);
//=> 'TypeError'
import ensureError from 'ensure-error';

console.log(ensureError(10));
//=> [NonError: 10]
import ensureError from 'ensure-error';

const error = new Error('Something went wrong');
error.cause = 'A string cause'; // Not a proper error

const result = ensureError(error);
console.log(result.cause);
//=> [NonError: 'A string cause']
import ensureError from 'ensure-error';

const aggregateError = new AggregateError(['error1', 42], 'Multiple errors');

const result = ensureError(aggregateError);
console.log(result.errors[0]);
//=> [NonError: 'error1']
console.log(result.errors[1]);
//=> [NonError: 42]

API

ensureError(input)

Ensures the input is a valid error.

If input is an Error, any missing Error properties will be added. If the error has a .cause property, it will be recursively ensured to be a valid error too. If the error is an AggregateError, all items in the errors array will also be recursively ensured to be valid errors. If it's not an Error, input is converted to an Error.

input

Type: unknown