add error handling example
This commit is contained in:
parent
5cc50ef2c8
commit
f6a2f54aef
1 changed files with 42 additions and 0 deletions
42
examples/errors.js
Normal file
42
examples/errors.js
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
|
||||||
|
var http = require('http');
|
||||||
|
var koa = require('..');
|
||||||
|
var app = koa();
|
||||||
|
|
||||||
|
// look ma, error propagation!
|
||||||
|
|
||||||
|
app.use(function(next){
|
||||||
|
return function *(){
|
||||||
|
try {
|
||||||
|
yield next;
|
||||||
|
} catch (err) {
|
||||||
|
// some errors will have .status
|
||||||
|
// however this is not a guarantee
|
||||||
|
this.status = err.status || 500;
|
||||||
|
this.type = 'html';
|
||||||
|
this.body = '<p>Something <em>exploded</em>, please contact Maru.</p>';
|
||||||
|
|
||||||
|
// since we handled this manually we'll
|
||||||
|
// want to delegate to the regular app
|
||||||
|
// level error handling as well so that
|
||||||
|
// centralized still functions correctly.
|
||||||
|
this.app.emit('error', err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// response
|
||||||
|
|
||||||
|
app.use(function(next){
|
||||||
|
return function *(){
|
||||||
|
throw new Error('boom boom');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// error handler
|
||||||
|
|
||||||
|
app.on('error', function(err){
|
||||||
|
console.log('sent error %s to the cloud', err.message);
|
||||||
|
});
|
||||||
|
|
||||||
|
app.listen(3000);
|
Loading…
Reference in a new issue