test: refactor the code of test-keep-alive.js
* use const and let instead of var * use assert.strictEqual instead of assert.equal * use arrow functions * removed console.log statements PR-URL: https://github.com/nodejs/node/pull/10684 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
This commit is contained in:
parent
2d2a059827
commit
aacd323ff3
@ -12,8 +12,8 @@ if (common.isWindows) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var body = 'hello world\n';
|
const body = 'hello world\n';
|
||||||
var server = http.createServer(function(req, res) {
|
const server = http.createServer(function(req, res) {
|
||||||
res.writeHead(200, {
|
res.writeHead(200, {
|
||||||
'Content-Length': body.length,
|
'Content-Length': body.length,
|
||||||
'Content-Type': 'text/plain'
|
'Content-Type': 'text/plain'
|
||||||
@ -22,12 +22,12 @@ var server = http.createServer(function(req, res) {
|
|||||||
res.end();
|
res.end();
|
||||||
});
|
});
|
||||||
|
|
||||||
var keepAliveReqSec = 0;
|
let keepAliveReqSec = 0;
|
||||||
var normalReqSec = 0;
|
let normalReqSec = 0;
|
||||||
|
|
||||||
|
|
||||||
function runAb(opts, callback) {
|
function runAb(opts, callback) {
|
||||||
var args = [
|
const args = [
|
||||||
'-c', opts.concurrent || 100,
|
'-c', opts.concurrent || 100,
|
||||||
'-t', opts.threads || 2,
|
'-t', opts.threads || 2,
|
||||||
'-d', opts.duration || '10s',
|
'-d', opts.duration || '10s',
|
||||||
@ -41,13 +41,11 @@ function runAb(opts, callback) {
|
|||||||
args.push(url.format({ hostname: '127.0.0.1',
|
args.push(url.format({ hostname: '127.0.0.1',
|
||||||
port: common.PORT, protocol: 'http'}));
|
port: common.PORT, protocol: 'http'}));
|
||||||
|
|
||||||
//console.log(comm, args.join(' '));
|
const child = spawn('wrk', args);
|
||||||
|
|
||||||
var child = spawn('wrk', args);
|
|
||||||
child.stderr.pipe(process.stderr);
|
child.stderr.pipe(process.stderr);
|
||||||
child.stdout.setEncoding('utf8');
|
child.stdout.setEncoding('utf8');
|
||||||
|
|
||||||
var stdout;
|
let stdout;
|
||||||
|
|
||||||
child.stdout.on('data', function(data) {
|
child.stdout.on('data', function(data) {
|
||||||
stdout += data;
|
stdout += data;
|
||||||
@ -60,11 +58,11 @@ function runAb(opts, callback) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var matches = /Requests\/sec:\s*(\d+)\./mi.exec(stdout);
|
let matches = /Requests\/sec:\s*(\d+)\./mi.exec(stdout);
|
||||||
var reqSec = parseInt(matches[1]);
|
const reqSec = parseInt(matches[1]);
|
||||||
|
|
||||||
matches = /Keep-Alive requests:\s*(\d+)/mi.exec(stdout);
|
matches = /Keep-Alive requests:\s*(\d+)/mi.exec(stdout);
|
||||||
var keepAliveRequests;
|
let keepAliveRequests;
|
||||||
if (matches) {
|
if (matches) {
|
||||||
keepAliveRequests = parseInt(matches[1]);
|
keepAliveRequests = parseInt(matches[1]);
|
||||||
} else {
|
} else {
|
||||||
@ -75,21 +73,19 @@ function runAb(opts, callback) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
server.listen(common.PORT, function() {
|
server.listen(common.PORT, () => {
|
||||||
runAb({ keepalive: true }, function(reqSec) {
|
runAb({ keepalive: true }, (reqSec) => {
|
||||||
keepAliveReqSec = reqSec;
|
keepAliveReqSec = reqSec;
|
||||||
console.log('keep-alive:', keepAliveReqSec, 'req/sec');
|
|
||||||
|
|
||||||
runAb({ keepalive: false }, function(reqSec) {
|
runAb({ keepalive: false }, function(reqSec) {
|
||||||
normalReqSec = reqSec;
|
normalReqSec = reqSec;
|
||||||
console.log('normal:' + normalReqSec + ' req/sec');
|
|
||||||
server.close();
|
server.close();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
process.on('exit', function() {
|
process.on('exit', function() {
|
||||||
assert.equal(true, normalReqSec > 50);
|
assert.strictEqual(true, normalReqSec > 50);
|
||||||
assert.equal(true, keepAliveReqSec > 50);
|
assert.strictEqual(true, keepAliveReqSec > 50);
|
||||||
assert.equal(true, normalReqSec < keepAliveReqSec);
|
assert.strictEqual(true, normalReqSec < keepAliveReqSec);
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user