mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
2bc7841d0f
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>
49 lines
1.2 KiB
JavaScript
49 lines
1.2 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
var assert = require('assert');
|
|
var http = require('http');
|
|
|
|
// Verify that ServerResponse.writeHead() works as setHeader.
|
|
// Issue 5036 on github.
|
|
|
|
var s = http.createServer(function(req, res) {
|
|
res.setHeader('test', '1');
|
|
|
|
// toLowerCase() is used on the name argument, so it must be a string.
|
|
var threw = false;
|
|
try {
|
|
res.setHeader(0xf00, 'bar');
|
|
} catch (e) {
|
|
assert.ok(e instanceof TypeError);
|
|
threw = true;
|
|
}
|
|
assert.ok(threw, 'Non-string names should throw');
|
|
|
|
// undefined value should throw, via 979d0ca8
|
|
threw = false;
|
|
try {
|
|
res.setHeader('foo', undefined);
|
|
} catch (e) {
|
|
assert.ok(e instanceof Error);
|
|
assert.equal(e.message, '"value" required in setHeader("foo", value)');
|
|
threw = true;
|
|
}
|
|
assert.ok(threw, 'Undefined value should throw');
|
|
|
|
res.writeHead(200, { Test: '2' });
|
|
res.end();
|
|
});
|
|
|
|
s.listen(0, runTest);
|
|
|
|
function runTest() {
|
|
http.get({ port: this.address().port }, function(response) {
|
|
response.on('end', function() {
|
|
assert.equal(response.headers['test'], '2');
|
|
assert(response.rawHeaders.indexOf('Test') !== -1);
|
|
s.close();
|
|
});
|
|
response.resume();
|
|
});
|
|
}
|