From d1343d769136005075f1b5031ec72b18c6240dd0 Mon Sep 17 00:00:00 2001 From: Shigeki Ohtsu Date: Wed, 6 May 2015 13:45:46 +0900 Subject: [PATCH] js_stream: fix buffer index in DoWrite The index of buffer to write in JSStream was always 0 by mistake. This fix was to use increment index of buffer arrays. The test was originally made by Brian White in #1594. Fixes: https://github.com/iojs/io.js/issues/1595 Fixes: https://github.com/iojs/io.js/pull/1594 --- src/js_stream.cc | 2 +- .../test-tls-connect-stream-writes.js | 65 +++++++++++++++++++ 2 files changed, 66 insertions(+), 1 deletion(-) create mode 100644 test/parallel/test-tls-connect-stream-writes.js diff --git a/src/js_stream.cc b/src/js_stream.cc index 09c4f58b96230e..6b7c4063e05a2a 100644 --- a/src/js_stream.cc +++ b/src/js_stream.cc @@ -89,7 +89,7 @@ int JSStream::DoWrite(WriteWrap* w, Local bufs_arr = Array::New(env()->isolate(), count); for (size_t i = 0; i < count; i++) - bufs_arr->Set(i, Buffer::New(env(), bufs[0].base, bufs[0].len)); + bufs_arr->Set(i, Buffer::New(env(), bufs[i].base, bufs[i].len)); Local argv[] = { w->object(), diff --git a/test/parallel/test-tls-connect-stream-writes.js b/test/parallel/test-tls-connect-stream-writes.js new file mode 100644 index 00000000000000..0bf1db12b71eb8 --- /dev/null +++ b/test/parallel/test-tls-connect-stream-writes.js @@ -0,0 +1,65 @@ +var assert = require('assert'), + fs = require('fs'), + path = require('path'), + tls = require('tls'), + stream = require('stream'), + net = require('net'); + +var common = require('../common'); + +var server; +var cert_dir = path.resolve(__dirname, '../fixtures'), + options = { key: fs.readFileSync(cert_dir + '/test_key.pem'), + cert: fs.readFileSync(cert_dir + '/test_cert.pem'), + ca: [ fs.readFileSync(cert_dir + '/test_ca.pem') ], + ciphers: 'AES256-GCM-SHA384' }; +var content = 'hello world'; +var recv_bufs = []; +var send_data = ''; +server = tls.createServer(options, function(s) { + s.on('data', function(c) { + recv_bufs.push(c); + }); +}); +server.listen(common.PORT, function() { + var raw = net.connect(common.PORT); + + var pending = false; + raw.on('readable', function() { + if (pending) + p._read(); + }); + + var p = new stream.Duplex({ + read: function read() { + pending = false; + + var chunk = raw.read(); + if (chunk) { + this.push(chunk); + } else { + pending = true; + } + }, + write: function write(data, enc, cb) { + raw.write(data, enc, cb); + } + }); + + var socket = tls.connect({ + socket: p, + rejectUnauthorized: false + }, function() { + for (var i = 0; i < 50; ++i) { + socket.write(content); + send_data += content; + } + socket.end(); + server.close(); + }); +}); + +process.on('exit', function() { + var recv_data = (Buffer.concat(recv_bufs)).toString(); + assert.strictEqual(send_data, recv_data); +});