mirror of
https://github.com/nodejs/node.git
synced 2025-05-02 03:31:35 +00:00

This helps to prevent issues where a failed test can keep a bound socket open long enough to cause other tests to fail with EADDRINUSE because the same port number is used. PR-URL: https://github.com/nodejs/node/pull/7045 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Rod Vagg <rod@vagg.org>
47 lines
1.2 KiB
JavaScript
47 lines
1.2 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
var assert = require('assert');
|
|
var http = require('http');
|
|
|
|
var expectedHeaders = {
|
|
'DELETE': ['host', 'connection'],
|
|
'GET': ['host', 'connection'],
|
|
'HEAD': ['host', 'connection'],
|
|
'OPTIONS': ['host', 'connection'],
|
|
'POST': ['host', 'connection', 'content-length'],
|
|
'PUT': ['host', 'connection', 'content-length']
|
|
};
|
|
|
|
var expectedMethods = Object.keys(expectedHeaders);
|
|
|
|
var requestCount = 0;
|
|
|
|
var server = http.createServer(function(req, res) {
|
|
requestCount++;
|
|
res.end();
|
|
|
|
assert(expectedHeaders.hasOwnProperty(req.method),
|
|
req.method + ' was an unexpected method');
|
|
|
|
var requestHeaders = Object.keys(req.headers);
|
|
requestHeaders.forEach(function(header) {
|
|
assert(expectedHeaders[req.method].indexOf(header.toLowerCase()) !== -1,
|
|
header + ' shoud not exist for method ' + req.method);
|
|
});
|
|
|
|
assert(requestHeaders.length === expectedHeaders[req.method].length,
|
|
'some headers were missing for method: ' + req.method);
|
|
|
|
if (expectedMethods.length === requestCount)
|
|
server.close();
|
|
});
|
|
|
|
server.listen(0, function() {
|
|
expectedMethods.forEach(function(method) {
|
|
http.request({
|
|
method: method,
|
|
port: server.address().port
|
|
}).end();
|
|
});
|
|
});
|