56 lines
1.5 KiB
JavaScript
56 lines
1.5 KiB
JavaScript
var loopback = require('../');
|
|
var app;
|
|
var assert = require('assert');
|
|
var request = require('supertest');
|
|
|
|
describe('loopback.errorHandler(options)', function() {
|
|
|
|
it('should return default middleware when options object is not present', function(done) {
|
|
|
|
//arrange
|
|
var app = loopback();
|
|
app.use(loopback.urlNotFound());
|
|
app.use(loopback.errorHandler({ log: false }));
|
|
|
|
//act/assert
|
|
request(app)
|
|
.get('/url-does-not-exist')
|
|
.end(function(err, res) {
|
|
assert.ok(res.error.text.match(/<ul id="stacktrace"><li> at raiseUrlNotFoundError/));
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should delete stack when options.includeStack is false', function(done) {
|
|
|
|
//arrange
|
|
var app = loopback();
|
|
app.use(loopback.urlNotFound());
|
|
app.use(loopback.errorHandler({ includeStack: false, log: false }));
|
|
|
|
//act/assert
|
|
request(app)
|
|
.get('/url-does-not-exist')
|
|
.end(function(err, res) {
|
|
assert.ok(res.error.text.match(/<ul id="stacktrace"><\/ul>/));
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should pass options on to error handler module', function(done) {
|
|
//arrange
|
|
var app = loopback();
|
|
app.use(loopback.urlNotFound());
|
|
app.use(loopback.errorHandler({ includeStack: false, log: customLogger }));
|
|
|
|
//act
|
|
request(app).get('/url-does-not-exist').end();
|
|
|
|
//assert
|
|
function customLogger(err, str, req) {
|
|
assert.ok(err.message === 'Cannot GET /url-does-not-exist');
|
|
done();
|
|
}
|
|
});
|
|
});
|