mirror of
https://github.com/nodejs/node.git
synced 2025-05-09 18:02:21 +00:00

This patch uses `return` statement to skip the test instead of using `process.exit` call. PR-URL: https://github.com/nodejs/io.js/pull/2109 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Johan Bergström <bugs@bergstroem.nu>
66 lines
1.5 KiB
JavaScript
66 lines
1.5 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 PORT = common.PORT;
|
|
var dir = common.fixturesDir;
|
|
var options = { key: fs.readFileSync(dir + '/test_key.pem'),
|
|
cert: fs.readFileSync(dir + '/test_cert.pem'),
|
|
ca: [ fs.readFileSync(dir + '/test_ca.pem') ] };
|
|
|
|
var server = tls.createServer(options, onconnection);
|
|
var gotChunk = false;
|
|
var gotDrain = false;
|
|
|
|
var timer = setTimeout(function() {
|
|
console.log('not ok - timed out');
|
|
process.exit(1);
|
|
}, common.platformTimeout(500));
|
|
|
|
function onconnection(conn) {
|
|
conn.on('data', function(c) {
|
|
if (!gotChunk) {
|
|
gotChunk = true;
|
|
console.log('ok - got chunk');
|
|
}
|
|
|
|
// just some basic sanity checks.
|
|
assert(c.length);
|
|
assert(Buffer.isBuffer(c));
|
|
|
|
if (gotDrain)
|
|
process.exit(0);
|
|
});
|
|
}
|
|
|
|
server.listen(PORT, function() {
|
|
var chunk = new Buffer(1024);
|
|
chunk.fill('x');
|
|
var opt = { port: PORT, rejectUnauthorized: false };
|
|
var conn = tls.connect(opt, function() {
|
|
conn.on('drain', ondrain);
|
|
write();
|
|
});
|
|
function ondrain() {
|
|
if (!gotDrain) {
|
|
gotDrain = true;
|
|
console.log('ok - got drain');
|
|
}
|
|
if (gotChunk)
|
|
process.exit(0);
|
|
write();
|
|
}
|
|
function write() {
|
|
// this needs to return false eventually
|
|
while (false !== conn.write(chunk));
|
|
}
|
|
});
|