Clean up getters/setters in errors

This commit is contained in:
Patrick Mooney 2015-11-02 22:31:02 -06:00
parent df43cab12d
commit dcce6ebe1e
2 changed files with 100 additions and 46 deletions

View File

@ -1,6 +1,7 @@
// Copyright 2011 Mark Cavage, Inc. All rights reserved.
var util = require('util');
var assert = require('assert-plus');
var LDAPResult = require('../messages').LDAPResult;
@ -11,36 +12,46 @@ var CODES = require('./codes');
var ERRORS = [];
///--- Error Base class
function LDAPError(errorName, errorCode, msg, dn, caller) {
function LDAPError(message, dn, caller) {
if (Error.captureStackTrace)
Error.captureStackTrace(this, caller || LDAPError);
this.__defineGetter__('dn', function () {
return (dn ? (dn.toString() || '') : '');
});
this.__defineGetter__('code', function () {
return errorCode;
});
this.__defineGetter__('name', function () {
return errorName;
});
this.__defineGetter__('message', function () {
return msg || errorName;
});
this.lde_message = message;
this.lde_dn = dn;
}
util.inherits(LDAPError, Error);
Object.defineProperties(LDAPError.prototype, {
name: {
get: function getName() { return 'LDAPError'; },
configurable: false
},
code: {
get: function getCode() { return CODES.LDAP_OTHER; },
configurable: false
},
message: {
get: function getMessage() {
return this.lde_message || this.name;
},
configurable: false
},
dn: {
get: function getDN() {
return (this.lde_dn ? this.lde_dn.toString() : '');
},
configurable: false
}
});
///--- Exported API
// Some whacky games here to make sure all the codes are exported
module.exports = {};
module.exports.LDAPError = LDAPError;
// Some whacky games here to make sure all the codes are exported
Object.keys(CODES).forEach(function (code) {
module.exports[code] = CODES[code];
if (code === 'LDAP_SUCCESS')
@ -62,15 +73,20 @@ Object.keys(CODES).forEach(function (code) {
// At this point LDAP_OPERATIONS_ERROR is now OperationsError in $err
// and 'Operations Error' in $msg
module.exports[err] = function (message, dn, caller) {
LDAPError.call(this,
err,
CODES[code],
message || msg,
dn || null,
caller || module.exports[err]);
LDAPError.call(this, message, dn, caller || module.exports[err]);
};
module.exports[err].constructor = module.exports[err];
util.inherits(module.exports[err], LDAPError);
Object.defineProperties(module.exports[err].prototype, {
name: {
get: function getName() { return err; },
configurable: false
},
code: {
get: function getCode() { return CODES[code]; },
configurable: false
}
});
ERRORS[CODES[code]] = {
err: err,
@ -78,10 +94,8 @@ Object.keys(CODES).forEach(function (code) {
};
});
module.exports.getError = function (res) {
if (!(res instanceof LDAPResult))
throw new TypeError('res (LDAPResult) required');
assert.ok(res instanceof LDAPResult, 'res (LDAPResult) required');
var errObj = ERRORS[res.status];
var E = module.exports[errObj.err];
@ -90,10 +104,8 @@ module.exports.getError = function (res) {
module.exports.getError);
};
module.exports.getMessage = function (code) {
if (typeof (code) !== 'number')
throw new TypeError('code (number) required');
assert.number(code, 'code (number) required');
var errObj = ERRORS[code];
return (errObj && errObj.message ? errObj.message : '');
@ -103,34 +115,37 @@ module.exports.getMessage = function (code) {
///--- Custom application errors
function ConnectionError(message) {
LDAPError.call(this,
'ConnectionError',
CODES.LDAP_OTHER,
message,
null,
ConnectionError);
LDAPError.call(this, message, null, ConnectionError);
}
util.inherits(ConnectionError, LDAPError);
module.exports.ConnectionError = ConnectionError;
Object.defineProperties(ConnectionError.prototype, {
name: {
get: function () { return 'ConnectionError'; },
configurable: false
}
});
function AbandonedError(message) {
LDAPError.call(this,
'AbandonedError',
CODES.LDAP_OTHER,
message,
null,
AbandonedError);
LDAPError.call(this, message, null, AbandonedError);
}
util.inherits(AbandonedError, LDAPError);
module.exports.AbandonedError = AbandonedError;
Object.defineProperties(AbandonedError.prototype, {
name: {
get: function () { return 'AbandonedError'; },
configurable: false
}
});
function TimeoutError(message) {
LDAPError.call(this,
'TimeoutError',
CODES.LDAP_OTHER,
message,
null,
TimeoutError);
LDAPError.call(this, message, null, TimeoutError);
}
util.inherits(TimeoutError, LDAPError);
module.exports.TimeoutError = TimeoutError;
Object.defineProperties(TimeoutError.prototype, {
name: {
get: function () { return 'TimeoutError'; },
configurable: false
}
});

39
test/errors.test.js Normal file
View File

@ -0,0 +1,39 @@
// Copyright 2015 Joyent, Inc.
var test = require('tape').test;
var ldap = require('../lib/index');
///--- Tests
test('basic error', function (t) {
var msg = 'mymsg';
var err = new ldap.LDAPError(msg, null, null);
t.ok(err);
t.equal(err.name, 'LDAPError');
t.equal(err.code, ldap.LDAP_OTHER);
t.equal(err.dn, '');
t.equal(err.message, msg);
t.end();
});
test('"custom" errors', function (t) {
var errors = [
{ name: 'ConnectionError', func: ldap.ConnectionError },
{ name: 'AbandonedError', func: ldap.AbandonedError },
{ name: 'TimeoutError', func: ldap.TimeoutError }
];
errors.forEach(function (entry) {
var msg = entry.name + 'msg';
var err = new entry.func(msg);
t.ok(err);
t.equal(err.name, entry.name);
t.equal(err.code, ldap.LDAP_OTHER);
t.equal(err.dn, '');
t.equal(err.message, msg);
});
t.end();
});