node/test/parallel/test-http-destroyed-socket-write2.js
Rich Trott 1027b9447e lib,test: update in preparation for linter update
ESLint 2.9.0 fixes some bugs that resulted in minor issues not being
caught by ESLint 2.7.0. Update instances of our code that will be
flagged when we upgrade to ESLint 2.9.0.

PR-URL: https://github.com/nodejs/node/pull/6498
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Roman Reiss <me@silverwind.io>
2016-05-04 10:24:47 -07:00

66 lines
1.5 KiB
JavaScript

'use strict';
var common = require('../common');
var assert = require('assert');
// Verify that ECONNRESET is raised when writing to a http request
// where the server has ended the socket.
var http = require('http');
var server = http.createServer(function(req, res) {
setImmediate(function() {
res.destroy();
});
});
server.listen(common.PORT, function() {
var req = http.request({
port: common.PORT,
path: '/',
method: 'POST'
});
function write() {
req.write('hello', function() {
setImmediate(write);
});
}
req.on('error', common.mustCall(function(er) {
switch (er.code) {
// This is the expected case
case 'ECONNRESET':
break;
// On Windows, this sometimes manifests as ECONNABORTED
case 'ECONNABORTED':
break;
// This test is timing sensitive so an EPIPE is not out of the question.
// It should be infrequent, given the 50 ms timeout, but not impossible.
case 'EPIPE':
break;
default:
assert.strictEqual(er.code,
'ECONNRESET',
'Write to a torn down client should RESET or ABORT');
break;
}
assert.equal(req.output.length, 0);
assert.equal(req.outputEncodings.length, 0);
server.close();
}));
req.on('response', function(res) {
res.on('data', function(chunk) {
common.fail('Should not receive response data');
});
res.on('end', function() {
common.fail('Should not receive response end');
});
});
write();
});