NodeRedis/redis-errors

Name: redis-errors

Owner: NodeRedis

Description: Redis error classes

Created: 2017-05-19 00:54:17.0

Updated: 2017-05-19 00:58:14.0

Pushed: 2017-06-01 00:22:41.0

Homepage: null

Size: 13

Language: JavaScript

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

js-standard-style

redis-errors

All error classes used in node_redis from v.3.0.0 are in here. They can be required as needed.

Install

Install with NPM:

npm install redis-errors

Usage
t { ReplyError, InterruptError } = require('redis-errors');

sing async await
{
ait client.set('foo') // Missing value
tch (err) {
 (err instanceof InterruptError) {
console.error('Command might have been processed')

 (err instanceof ReplyError) {
// ...

row err


sing callbacks
nt.set('foo', (err, res) => {
 (err) {
if (err instanceof InterruptError) {
  // ...
}


Error classes

All errors returned by NodeRedis use own Error classes. You can distinguish different errors easily by checking for these classes.

To know what caused the error they might contain properties to know in more detail what happened.

Each error contains a message, a name and a stack property. Please be aware that the stack might not be useful due to the async nature and is in those cases therefore limited to two frames.

There might be more not yet documented properties as well. Please feel free to open a pull request to document those as well.

RedisError

Properties:

Properties depend on the individual error.

All errors returned by NodeRedis (client) are RedisErrors.
Subclass of Error

ReplyError

Properties:

All errors returned by Redis itself (server) will be a ReplyError.
Subclass of RedisError

ParserError

Properties:

Parsing errors are returned as ParserError.
Subclass of RedisError Note: If you encounter one of these please report that error including the attached offset and buffer properties!

AbortError

Properties:

If a command was not yet executed but rejected, it'll return a AbortError.
Subclass of RedisError

InterruptError

Properties:

All executed commands that could not fulfill (e.g. network drop while executing) return a InterruptError.
Subclass of AbortError
Note: Interrupt errors can happen for multiple reasons that are out of the scope of NodeRedis itself. There is nothing that can be done on library side to prevent those.

License

MIT


This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.