node/test/parallel/test-tls-zero-clear-in.js
Santiago Gimeno 795eeb1ccf test: fix test-tls-zero-clear-in flakiness
It can happen that the server-side socket is destroyed before the
client-side socket has gracefully closed, thus causing a 'ECONNRESET'
error in this socket. To solve this, also close gracefully in the server
side too.

PR-URL: https://github.com/nodejs/node/pull/4888
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Fedor Indutny <fedor@indutny.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
2016-01-28 11:44:29 -08:00

53 lines
1.1 KiB
JavaScript

'use strict';
var common = require('../common');
var assert = require('assert');
if (!common.hasCrypto) {
console.log('1..0 # Skipped: missing crypto');
return;
}
var tls = require('tls');
var fs = require('fs');
var path = require('path');
var cert = fs.readFileSync(path.join(common.fixturesDir, 'test_cert.pem'));
var key = fs.readFileSync(path.join(common.fixturesDir, 'test_key.pem'));
var errorEmitted = false;
var server = tls.createServer({
cert: cert,
key: key
}, function(c) {
// Nop
setTimeout(function() {
c.end();
server.close();
}, 20);
}).listen(common.PORT, function() {
var conn = tls.connect({
cert: cert,
key: key,
rejectUnauthorized: false,
port: common.PORT
}, function() {
setTimeout(function() {
conn.destroy();
}, 20);
});
// SSL_write() call's return value, when called 0 bytes, should not be
// treated as error.
conn.end('');
conn.on('error', function(err) {
console.log(err);
errorEmitted = true;
});
});
process.on('exit', function() {
assert.ok(!errorEmitted);
});