mirror of
https://github.com/nodejs/node.git
synced 2025-05-06 04:59:52 +00:00

In preparation for a lint rule that will enforce assert.deepStrictEqual() over assert.deepEqual(), change tests and benchmarks accordingly. For tests and benchmarks that are testing or benchmarking assert.deepEqual() itself, apply a comment to ignore the upcoming rule. PR-URL: https://github.com/nodejs/node/pull/6213 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
80 lines
1.8 KiB
JavaScript
80 lines
1.8 KiB
JavaScript
'use strict';
|
|
// Verify that the 'upgrade' header causes an 'upgrade' event to be emitted to
|
|
// the HTTP client. This test uses a raw TCP server to better control server
|
|
// behavior.
|
|
|
|
var common = require('../common');
|
|
var assert = require('assert');
|
|
|
|
var http = require('http');
|
|
var net = require('net');
|
|
|
|
// Create a TCP server
|
|
var srv = net.createServer(function(c) {
|
|
var data = '';
|
|
c.on('data', function(d) {
|
|
data += d.toString('utf8');
|
|
|
|
c.write('HTTP/1.1 101\r\n');
|
|
c.write('hello: world\r\n');
|
|
c.write('connection: upgrade\r\n');
|
|
c.write('upgrade: websocket\r\n');
|
|
c.write('\r\n');
|
|
c.write('nurtzo');
|
|
});
|
|
|
|
c.on('end', function() {
|
|
c.end();
|
|
});
|
|
});
|
|
|
|
var gotUpgrade = false;
|
|
|
|
srv.listen(common.PORT, '127.0.0.1', function() {
|
|
|
|
var options = {
|
|
port: common.PORT,
|
|
host: '127.0.0.1',
|
|
headers: {
|
|
'connection': 'upgrade',
|
|
'upgrade': 'websocket'
|
|
}
|
|
};
|
|
var name = options.host + ':' + options.port;
|
|
|
|
var req = http.request(options);
|
|
req.end();
|
|
|
|
req.on('upgrade', function(res, socket, upgradeHead) {
|
|
var recvData = upgradeHead;
|
|
socket.on('data', function(d) {
|
|
recvData += d;
|
|
});
|
|
|
|
socket.on('close', common.mustCall(function() {
|
|
assert.equal(recvData, 'nurtzo');
|
|
}));
|
|
|
|
console.log(res.headers);
|
|
var expectedHeaders = { 'hello': 'world',
|
|
'connection': 'upgrade',
|
|
'upgrade': 'websocket' };
|
|
assert.deepStrictEqual(expectedHeaders, res.headers);
|
|
|
|
// Make sure this request got removed from the pool.
|
|
assert(!http.globalAgent.sockets.hasOwnProperty(name));
|
|
|
|
req.on('close', function() {
|
|
socket.end();
|
|
srv.close();
|
|
|
|
gotUpgrade = true;
|
|
});
|
|
});
|
|
|
|
});
|
|
|
|
process.on('exit', function() {
|
|
assert.ok(gotUpgrade);
|
|
});
|