Merge pull request #45 from strongloop/feature/improve-validation-error-properties

Improve properties of ValidationError
This commit is contained in:
Miroslav Bajtoš 2013-12-02 12:36:36 -08:00
commit 9a5241e8e8
4 changed files with 14 additions and 8 deletions

View File

@ -4,6 +4,7 @@ exports.ModelBuilder = exports.LDL = require('./lib/model-builder.js').ModelBuil
exports.DataSource = exports.Schema = require('./lib/datasource.js').DataSource;
exports.ModelBaseClass = require('./lib/model.js');
exports.Connector = require('./lib/connector.js');
exports.ValidationError = require('./lib/validations.js').ValidationError;
var baseSQL = './lib/sql';

View File

@ -599,12 +599,16 @@ function ValidationError(obj) {
if (!(this instanceof ValidationError)) return new ValidationError(obj);
this.name = 'ValidationError';
this.message = 'Validation error';
this.statusCode = 400;
this.codes = obj.errors && obj.errors.codes;
this.context = obj && obj.constructor && obj.constructor.modelName;
this.message = 'The Model instance is not valid. ' +
'See `details` property of the error object for more info.';
this.statusCode = 422;
this.details = {
context: obj && obj.constructor && obj.constructor.modelName,
codes: obj.errors && obj.errors.codes,
messages: obj.errors
};
Error.call(this);
Error.captureStackTrace(this, this.constructor);
}

View File

@ -2,6 +2,7 @@
var should = require('./init.js');
var db, Person;
var ValidationError = require('..').ValidationError;
describe('manipulation', function() {
@ -173,7 +174,7 @@ describe('manipulation', function() {
p.save({
'throws': true
});
}).should.throw('Validation error');
}).should.throw(ValidationError);
});
});

View File

@ -2,7 +2,7 @@
var should = require('./init.js');
var j = require('../'), db, User;
var ValidationError = require('../lib/validations.js').ValidationError;
var ValidationError = j.ValidationError;
function getValidAttributes() {
return {
@ -98,7 +98,7 @@ describe('validations', function() {
User.validatesPresenceOf('name');
User.create(function(e, u) {
should.exist(e);
e.codes.name.should.eql(['presence']);
e.details.codes.name.should.eql(['presence']);
done();
});
});