| 'use strict'; |
| var common = require('../common'); |
| var assert = require('assert'); |
| var net = require('net'); |
| |
| var tcpPort = common.PORT; |
| var bytesRead = 0; |
| var bytesWritten = 0; |
| var count = 0; |
| |
| var tcp = net.Server(function(s) { |
| console.log('tcp server connection'); |
| |
| // trigger old mode. |
| s.resume(); |
| |
| s.on('end', function() { |
| bytesRead += s.bytesRead; |
| console.log('tcp socket disconnect #' + count); |
| }); |
| }); |
| |
| tcp.listen(common.PORT, function doTest() { |
| console.error('listening'); |
| var socket = net.createConnection(tcpPort); |
| |
| socket.on('connect', function() { |
| count++; |
| console.error('CLIENT connect #%d', count); |
| |
| socket.write('foo', function() { |
| console.error('CLIENT: write cb'); |
| socket.end('bar'); |
| }); |
| }); |
| |
| socket.on('finish', function() { |
| bytesWritten += socket.bytesWritten; |
| console.error('CLIENT end event #%d', count); |
| }); |
| |
| socket.on('close', function() { |
| console.error('CLIENT close event #%d', count); |
| console.log('Bytes read: ' + bytesRead); |
| console.log('Bytes written: ' + bytesWritten); |
| if (count < 2) { |
| console.error('RECONNECTING'); |
| socket.connect(tcpPort); |
| } else { |
| tcp.close(); |
| } |
| }); |
| }); |
| |
| process.on('exit', function() { |
| assert.equal(bytesRead, 12); |
| assert.equal(bytesWritten, 12); |
| }); |