1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
'use strict';
var common = require('../common');
var assert = require('assert');
if (!common.hasCrypto) {
common.skip('missing crypto');
return;
}
var tls = require('tls');
var net = require('net');
var fs = require('fs');
var options = {
key: fs.readFileSync(common.fixturesDir + '/test_key.pem'),
cert: fs.readFileSync(common.fixturesDir + '/test_cert.pem')
};
var bonkers = new Buffer(1024 * 1024);
bonkers.fill(42);
var server = tls.createServer(options, function(c) {
}).listen(0, function() {
var client = net.connect(this.address().port, function() {
client.write(bonkers);
});
var once = false;
var writeAgain = setTimeout(function() {
client.write(bonkers);
});
client.on('error', function(err) {
if (!once) {
clearTimeout(writeAgain);
once = true;
client.destroy();
server.close();
}
});
client.on('close', function(hadError) {
assert.strictEqual(hadError, true, 'Client never errored');
});
});
|