-
-
Notifications
You must be signed in to change notification settings - Fork 54
fix: ignore status message for HTTP/2 #53
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 4 commits
9382f71
da59021
bd8c04a
7795a8c
e2f9f7f
8fcfd80
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -6,7 +6,8 @@ var SlowWriteStream = require('./sws') | |
|
|
||
| exports.assert = assert | ||
| exports.createError = createError | ||
| exports.createServer = createServer | ||
| exports.createHTTPServer = createHTTPServer | ||
| exports.createHTTP2Server = createHTTP2Server | ||
| exports.createSlowWriteStream = createSlowWriteStream | ||
| exports.rawrequest = rawrequest | ||
| exports.request = request | ||
|
|
@@ -26,7 +27,20 @@ function createError (message, props) { | |
| return err | ||
| } | ||
|
|
||
| function createServer (err, opts) { | ||
| function createHTTPServer (err, opts) { | ||
| return http.createServer(function (req, res) { | ||
| var done = finalhandler(req, res, opts) | ||
|
|
||
| if (typeof err === 'function') { | ||
| err(req, res, done) | ||
| return | ||
| } | ||
|
|
||
| done(err) | ||
| }) | ||
| } | ||
|
|
||
| function createHTTP2Server (err, opts) { | ||
| return http.createServer(function (req, res) { | ||
|
||
| var done = finalhandler(req, res, opts) | ||
|
|
||
|
|
||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -6,7 +6,8 @@ var utils = require('./support/utils') | |
|
|
||
| var assert = utils.assert | ||
| var createError = utils.createError | ||
| var createServer = utils.createServer | ||
| var createHTTPServer = utils.createHTTPServer | ||
| var createHTTP2Server = utils.createHTTP2Server | ||
| var createSlowWriteStream = utils.createSlowWriteStream | ||
| var rawrequest = utils.rawrequest | ||
| var request = utils.request | ||
|
|
@@ -18,7 +19,7 @@ var describeStatusMessage = !/statusMessage/.test(http.IncomingMessage.toString( | |
| ? describe.skip | ||
| : describe | ||
|
|
||
| describe('finalhandler(req, res)', function () { | ||
| var topDescribe = function (createServer) { | ||
| describe('headers', function () { | ||
| it('should ignore err.headers without status code', function (done) { | ||
| request(createServer(createError('oops!', { | ||
|
|
@@ -387,7 +388,7 @@ describe('finalhandler(req, res)', function () { | |
|
|
||
| describe('when res.statusCode set', function () { | ||
| it('should keep when >= 400', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.statusCode = 503 | ||
| done(new Error('oops')) | ||
|
|
@@ -399,7 +400,7 @@ describe('finalhandler(req, res)', function () { | |
| }) | ||
|
|
||
| it('should convert to 500 is not a number', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.statusCode = 'oh no' | ||
| done(new Error('oops')) | ||
|
|
@@ -411,7 +412,7 @@ describe('finalhandler(req, res)', function () { | |
| }) | ||
|
|
||
| it('should override with err.status', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
|
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Use |
||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| var err = createError('oops', { | ||
| status: 414, | ||
|
|
@@ -439,7 +440,7 @@ describe('finalhandler(req, res)', function () { | |
|
|
||
| describe('when res.statusCode undefined', function () { | ||
| it('should set to 500', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.statusCode = undefined | ||
| done(new Error('oops')) | ||
|
|
@@ -454,7 +455,7 @@ describe('finalhandler(req, res)', function () { | |
|
|
||
| describe('headers set', function () { | ||
| it('should persist set headers', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.setHeader('Server', 'foobar') | ||
| done() | ||
|
|
@@ -468,7 +469,7 @@ describe('finalhandler(req, res)', function () { | |
| }) | ||
|
|
||
| it('should override content-type and length', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.setHeader('Content-Type', 'image/png') | ||
| res.setHeader('Content-Length', '50') | ||
|
|
@@ -484,7 +485,7 @@ describe('finalhandler(req, res)', function () { | |
| }) | ||
|
|
||
| it('should remove other content headers', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.setHeader('Content-Encoding', 'gzip') | ||
| res.setHeader('Content-Language', 'jp') | ||
|
|
@@ -504,7 +505,7 @@ describe('finalhandler(req, res)', function () { | |
|
|
||
| describe('request started', function () { | ||
| it('should not respond', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.statusCode = 301 | ||
| res.write('0') | ||
|
|
@@ -520,7 +521,7 @@ describe('finalhandler(req, res)', function () { | |
| }) | ||
|
|
||
| it('should terminate on error', function (done) { | ||
| var server = http.createServer(function (req, res) { | ||
| var server = createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| res.statusCode = 301 | ||
| res.write('0') | ||
|
|
@@ -571,4 +572,103 @@ describe('finalhandler(req, res)', function () { | |
| }) | ||
| }) | ||
| }) | ||
| }) | ||
|
|
||
| describe('no deprecation warnings', function () { | ||
| it('should respond 404 on no error', function (done) { | ||
| var http2 | ||
| try { | ||
| http2 = require('http2') | ||
| } catch (e) { | ||
| return done() | ||
| } | ||
|
|
||
| var warned = false | ||
|
|
||
| process.once('warning', function (warning) { | ||
| if (/The http2 module is an experimental API/.test(warning)) return | ||
| assert.fail(warning) | ||
| }) | ||
|
|
||
| var server = http2.createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
| done() | ||
| }) | ||
|
|
||
| server.listen(function () { | ||
| var port = server.address().port | ||
| var client = http2.connect('http://localhost:' + port) | ||
| var req = client.request({ | ||
| ':method': 'GET', | ||
| ':path': '/foo' | ||
| }) | ||
|
|
||
| req.on('response', function (headers) { | ||
| assert.strictEqual(headers[':status'], 404) | ||
| req.close() | ||
| client.close() | ||
| server.close() | ||
| assert.strictEqual(warned, false) | ||
| done() | ||
| }) | ||
| }) | ||
| }) | ||
|
|
||
| it('should respond 500 on error', function (done) { | ||
| var http2 | ||
| try { | ||
| http2 = require('http2') | ||
| } catch (e) { | ||
| return done() | ||
| } | ||
|
|
||
| var warned = false | ||
|
|
||
| process.once('warning', function (warning) { | ||
| if (/The http2 module is an experimental API/.test(warning)) return | ||
| assert.fail(warning) | ||
| }) | ||
|
|
||
| var err = createError() | ||
|
|
||
| var server = http2.createServer(function (req, res) { | ||
| var done = finalhandler(req, res) | ||
|
|
||
| if (typeof err === 'function') { | ||
| err(req, res, done) | ||
| return | ||
| } | ||
|
|
||
| done(err) | ||
| }) | ||
|
|
||
| server.listen(function () { | ||
| var port = server.address().port | ||
| var client = http2.connect('http://localhost:' + port) | ||
| var req = client.request({ | ||
| ':method': 'GET', | ||
| ':path': '/foo' | ||
| }) | ||
|
|
||
| req.on('response', function (headers) { | ||
| assert.strictEqual(headers[':status'], 500) | ||
| req.close() | ||
| client.close() | ||
| server.close() | ||
| assert.strictEqual(warned, false) | ||
| done() | ||
| }) | ||
| }) | ||
| }) | ||
| }) | ||
| } | ||
|
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Let's make these test for |
||
|
|
||
| var servers = [ | ||
| ['http', createHTTPServer], | ||
| ['http2', createHTTP2Server] | ||
| ] | ||
|
|
||
| for (var i = 0; i < servers.length; i++) { | ||
| var tests = topDescribe.bind(undefined, servers[i][1]) | ||
|
|
||
| describe(servers[i][0], tests) | ||
| } | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just rename