-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathresultAnalyse.js
96 lines (77 loc) · 3.06 KB
/
resultAnalyse.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#!/usr/bin/node
var fs = require("fs");
var lazy = require("lazy");
var async = require('async');
var webServices = process.argv[2].split(",");
var userCounts = process.argv[3].split(",");
var jmeter_result = process.argv[4];
var tps_all = [];
var bw_all = [];
var rtAvg_all = [];
var error_all = [];
async.forEach(webServices, function(service, callback1) {
async.forEach(userCounts, function(user_count, callback2) {
var response = [];
var service_user = service + '_' + user_count + 'users';
var fileName = jmeter_result + '/' + service_user +
'_' + process.argv[5] + 'min.jtl';
var bw = [service_user];//bandwidth
var tps = [service_user]; // throughput
var rtAvg = [service_user]; //average response time
var errPercent = [service_user];//error percentage
new lazy(fs.createReadStream(fileName))
.lines
.forEach(function(line) {
response.push(line.toString());
})
.on('pipe',function() {
var len = response.length - 1;
console.log("Requests: " + len);
var start = response[1].split(",");
console.log("Start: " + start);
var stop = response[len - 1].split(",");
console.log("Stop: " + stop);
var time = ((parseInt(stop[0]) - parseInt(start[0])) / 1000) + 1;
console.log("Duration: " + time + " sec");
tps.push((len / time).toFixed(1));
bw.push(((sum(response, 9) / 1024) / time).toFixed(1));
rtAvg.push(Math.round(sum(response, 1) / len));
errPercent.push(errorNum(response).toFixed(2));
console.log("Requests / sec: " + tps[1]);
console.log("Avg Bandwidth: " + bw[1] + " KB");
console.log("Avg Response: " + rtAvg[1] + " ms");
console.log("Error percentage: " + errPercent[1]*100 + " %");
tps.push("\n");
rtAvg.push("\n");
bw.push("\n");
errPercent.push("\n");
fs.appendFileSync(jmeter_result + '/result_throughput.txt', tps);
fs.appendFileSync(jmeter_result + '/result_bandwidth.txt', bw);
fs.appendFileSync(jmeter_result + '/result_responseTime.txt', rtAvg);
fs.appendFileSync(jmeter_result + '/result_error.txt', errPercent);
return callback2();
});
}, function(err){
return callback1();
});
}, function(err){
return;
});
function sum(response, position) {
var dataSum = 0;
for (var i = 1; i < response.length; i++) {
var str = response[i].split(",");
dataSum += parseInt(str[position]);
}
return dataSum;
}
function errorNum(response) {
var err = 0;
for (var i = 1; i < response.length; i++) {
var str = response[i].split(",");
if (str[3] != 200)
err++;
}
var err_percent = err / (response.length);
return err_percent;
}