0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test/parallel/test-http-after-connect.js
Rich Trott 44efd66132 test: replace deprecated util.debug() calls
common.debug() is just util.debug() and emits a deprecation notice. Per
docs, use console.error() instead.

PR-URL: https://github.com/nodejs/node/pull/3082
Reviewed-By: Michaël Zasso <mic.besace@gmail.com>
2015-09-28 11:15:06 -07:00

73 lines
1.6 KiB
JavaScript

'use strict';
var common = require('../common');
var assert = require('assert');
var http = require('http');
var serverConnected = false;
var serverRequests = 0;
var clientResponses = 0;
var server = http.createServer(function(req, res) {
console.error('Server got GET request');
req.resume();
++serverRequests;
res.writeHead(200);
res.write('');
setTimeout(function() {
res.end(req.url);
}, 50);
});
server.on('connect', function(req, socket, firstBodyChunk) {
console.error('Server got CONNECT request');
serverConnected = true;
socket.write('HTTP/1.1 200 Connection established\r\n\r\n');
socket.resume();
socket.on('end', function() {
socket.end();
});
});
server.listen(common.PORT, function() {
var req = http.request({
port: common.PORT,
method: 'CONNECT',
path: 'google.com:80'
});
req.on('connect', function(res, socket, firstBodyChunk) {
console.error('Client got CONNECT response');
socket.end();
socket.on('end', function() {
doRequest(0);
doRequest(1);
});
socket.resume();
});
req.end();
});
function doRequest(i) {
var req = http.get({
port: common.PORT,
path: '/request' + i
}, function(res) {
console.error('Client got GET response');
var data = '';
res.setEncoding('utf8');
res.on('data', function(chunk) {
data += chunk;
});
res.on('end', function() {
assert.equal(data, '/request' + i);
++clientResponses;
if (clientResponses === 2) {
server.close();
}
});
});
}
process.on('exit', function() {
assert(serverConnected);
assert.equal(serverRequests, 2);
assert.equal(clientResponses, 2);
});