node/test/sequential/test-tcp-wrap-listen.js

103 lines
2.3 KiB
JavaScript
Raw Normal View History

var common = require('../common');
var assert = require('assert');
var TCP = process.binding('tcp_wrap').TCP;
var WriteWrap = process.binding('stream_wrap').WriteWrap;
var server = new TCP();
var r = server.bind('0.0.0.0', common.PORT);
assert.equal(0, r);
server.listen(128);
var slice, sliceCount = 0, eofCount = 0;
2011-06-16 19:16:54 +08:00
var writeCount = 0;
var recvCount = 0;
server.onconnection = function(err, client) {
2011-06-16 21:49:44 +08:00
assert.equal(0, client.writeQueueSize);
console.log('got connection');
2011-06-16 19:16:54 +08:00
function maybeCloseClient() {
if (client.pendingWrites.length == 0 && client.gotEOF) {
console.log('close client');
2011-06-16 19:16:54 +08:00
client.close();
}
}
client.readStart();
2011-06-16 19:16:54 +08:00
client.pendingWrites = [];
client.onread = function(err, buffer) {
if (buffer) {
assert.ok(buffer.length > 0);
2011-06-16 21:49:44 +08:00
assert.equal(0, client.writeQueueSize);
var req = new WriteWrap();
req.async = false;
var err = client.writeBuffer(req, buffer);
assert.equal(err, 0);
2011-06-16 19:16:54 +08:00
client.pendingWrites.push(req);
console.log('client.writeQueueSize: ' + client.writeQueueSize);
2011-06-28 19:56:02 +08:00
// 11 bytes should flush
assert.equal(0, client.writeQueueSize);
2011-06-16 21:49:44 +08:00
if (req.async)
req.oncomplete = done;
else
process.nextTick(done.bind(null, 0, client, req));
function done(status, client_, req_) {
2011-06-16 19:16:54 +08:00
assert.equal(req, client.pendingWrites.shift());
// Check parameters.
2011-06-16 21:33:47 +08:00
assert.equal(0, status);
assert.equal(client, client_);
assert.equal(req, req_);
console.log('client.writeQueueSize: ' + client.writeQueueSize);
2011-06-16 21:49:44 +08:00
assert.equal(0, client.writeQueueSize);
2011-06-16 19:16:54 +08:00
writeCount++;
console.log('write ' + writeCount);
2011-06-16 19:16:54 +08:00
maybeCloseClient();
};
sliceCount++;
} else {
console.log('eof');
2011-06-16 19:16:54 +08:00
client.gotEOF = true;
server.close();
eofCount++;
2011-06-16 19:16:54 +08:00
maybeCloseClient();
}
};
};
var net = require('net');
var c = net.createConnection(common.PORT);
c.on('connect', function() {
c.end('hello world');
});
2011-06-16 19:16:54 +08:00
c.setEncoding('utf8');
c.on('data', function(d) {
assert.equal('hello world', d);
recvCount++;
});
c.on('close', function() {
console.error('client closed');
});
process.on('exit', function() {
assert.equal(1, sliceCount);
assert.equal(1, eofCount);
2011-06-16 19:16:54 +08:00
assert.equal(1, writeCount);
assert.equal(1, recvCount);
});