Browse Source

test: improve test-http-chunked-304

* change the nested functions call to run tests in parallel
* use const and let instead of var
* use common.mustCall to control functions execution
* use assert.strictEqual instead of assert.equal
* use arrow functions

PR-URL: https://github.com/nodejs/node/pull/10462
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Italo A. Casas <me@italoacasas.com>
Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
Reviewed-By: Prince John Wesley <princejohnwesley@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
v6.x
Adrian Estrada 8 years ago
committed by Myles Borins
parent
commit
2f1d231c0d
No known key found for this signature in database GPG Key ID: 933B01F40B5CA946
  1. 45
      test/parallel/test-http-chunked-304.js

45
test/parallel/test-http-chunked-304.js

@ -12,32 +12,35 @@ var net = require('net');
// Likewise for 304 responses. Verify that no empty chunk is sent when // Likewise for 304 responses. Verify that no empty chunk is sent when
// the user explicitly sets a Transfer-Encoding header. // the user explicitly sets a Transfer-Encoding header.
test(204, function() { test(204);
test(304); test(304);
});
function test(statusCode, next) { function test(statusCode) {
var server = http.createServer(function(req, res) { const server = http.createServer(common.mustCall((req, res) => {
res.writeHead(statusCode, { 'Transfer-Encoding': 'chunked' }); res.writeHead(statusCode, { 'Transfer-Encoding': 'chunked' });
res.end(); res.end();
server.close(); server.close();
}); }));
server.listen(0, function() { server.listen(0, common.mustCall(() => {
var conn = net.createConnection(this.address().port, function() { const conn = net.createConnection(
conn.write('GET / HTTP/1.1\r\n\r\n'); server.address().port,
common.mustCall(() => {
conn.write('GET / HTTP/1.1\r\n\r\n');
var resp = ''; let resp = '';
conn.setEncoding('utf8'); conn.setEncoding('utf8');
conn.on('data', function(data) { conn.on('data', common.mustCall((data) => {
resp += data; resp += data;
}); }));
conn.on('end', common.mustCall(function() { conn.on('end', common.mustCall(() => {
assert.equal(/^Connection: close\r\n$/m.test(resp), true); // Connection: close should be in the response
assert.equal(/^0\r\n$/m.test(resp), false); assert.strictEqual(/^Connection: close\r\n$/m.test(resp), true);
if (next) process.nextTick(next); // Make sure this doesn't end with 0\r\n\r\n
})); assert.strictEqual(/^0\r\n$/m.test(resp), false);
}); }));
}); })
);
}));
} }

Loading…
Cancel
Save