Skip to content

Commit

Permalink
Merge pull request #3903 from jchip/v17
Browse files Browse the repository at this point in the history
Handle signals in onRequest. Closes #3884
  • Loading branch information
hueniverse authored Mar 19, 2019
2 parents 054482c + 5fe33ac commit 8c0efce
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 2 deletions.
4 changes: 3 additions & 1 deletion lib/response.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,9 @@ exports = module.exports = internals.Response = class {

static wrap(result, request) {

if (result instanceof internals.Response) {
if (result instanceof internals.Response ||
typeof result === 'symbol') {

return result;
}

Expand Down
51 changes: 50 additions & 1 deletion test/toolkit.js
Original file line number Diff line number Diff line change
Expand Up @@ -295,10 +295,11 @@ describe('Toolkit', () => {

describe('abandon', () => {

it('abandon request with manual response', async () => {
it('abandon request with manual response (handler)', async () => {

const handler = (request, h) => {

request.raw.res.setHeader('content-type', 'text/plain');
request.raw.res.end('manual');
return h.abandon;
};
Expand All @@ -309,6 +310,54 @@ describe('Toolkit', () => {
const res = await server.inject('/');
expect(res.result).to.equal('manual');
});

it('abandon request with manual response (onRequest)', async () => {

const server = Hapi.server();
server.route({ method: 'GET', path: '/', handler: () => null });

server.ext('onRequest', (request, h) => {

request.raw.res.setHeader('content-type', 'text/plain');
request.raw.res.end('manual');
return h.abandon;
});

const res = await server.inject('/');
expect(res.result).to.equal('manual');
});

it('abandon request with manual response (lifecycle)', async () => {

const server = Hapi.server();
server.route({ method: 'GET', path: '/', handler: () => null });

server.ext('onPreHandler', (request, h) => {

request.raw.res.setHeader('content-type', 'text/plain');
request.raw.res.end('manual');
return h.abandon;
});

const res = await server.inject('/');
expect(res.result).to.equal('manual');
});

it('abandon request with manual response (post cycle)', async () => {

const server = Hapi.server();
server.route({ method: 'GET', path: '/', handler: () => null });

server.ext('onPreResponse', (request, h) => {

request.raw.res.setHeader('content-type', 'text/plain');
request.raw.res.end('manual');
return h.abandon;
});

const res = await server.inject('/');
expect(res.result).to.equal('manual');
});
});

describe('close', () => {
Expand Down

0 comments on commit 8c0efce

Please sign in to comment.