-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathperformanceTest.js
94 lines (78 loc) · 4.3 KB
/
performanceTest.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
var loadtest = require('loadtest');
var should = require('should');
describe("Performance Test", function() {
var noRequestPerHour = 100000;
var avgRequestTime = 1000;
var host = 'https://loadtest.andreasponziell.repl.co'
it("performance testing /ping", function(done) {
this.timeout(1000 * 60);
var options = {
"url": host + '/ping',
"maxSeconds": 30,
"concurrency": 25,
"statusCallback": statusCallback
};
var gLatency;
function statusCallback(latency, result, error) {
console.log("Got latency:", latency);
gLatency = latency;
}
var operation = loadtest.loadTest(options, function(error) {
if (error) {
console.error('Got an error: %s', error);
} else if (operation.running == false) {
console.info("\n=========================================================================================================\n")
console.info("\tThreshold : No of request per hour = " + noRequestPerHour + ", Avg request time in millis = " + avgRequestTime)
console.info("\n=========================================================================================================\n")
console.info("Total Requests :", gLatency.totalRequests);
console.info("Total Failures :", gLatency.totalErrors);
console.info("Requests Per Second :", gLatency.rps);
console.info("Requests Per Hour :", (gLatency.rps * 3600));
console.info("Average Request Time(Mills) :", gLatency.meanLatencyMs);
console.info("Minimum Request Time(Mills) :", gLatency.minLatencyMs);
console.info("Maximum Request Time(Mills) :", gLatency.maxLatencyMs);
console.info("Percentiles :", gLatency.percentiles)
console.info("\n=========================================================================================================\n")
gLatency.totalErrors.should.equal(0);
(gLatency.rps * 3600).should.be.greaterThan(noRequestPerHour);
(gLatency.meanLatencyMs).should.be.below(avgRequestTime);
done();
}
});
});
it("performance testing /heaving-ping", function(done) {
this.timeout(1000 * 60);
var options = {
"url": host + '/heavy-ping',
"maxSeconds": 30,
"concurrency": 25,
"statusCallback": statusCallback
};
var gLatency;
function statusCallback(latency, result, error) {
gLatency = latency;
}
var operation = loadtest.loadTest(options, function(error) {
if (error) {
console.error('Got an error: %s', error);
} else if (operation.running == false) {
console.info("\n=========================================================================================================\n")
console.info("\tThreshold : No of request per hour = " + noRequestPerHour + ", Avg request time in millis = " + avgRequestTime)
console.info("\n=========================================================================================================\n")
console.info("Total Requests :", gLatency.totalRequests);
console.info("Total Failures :", gLatency.totalErrors);
console.info("Requests Per Second :", gLatency.rps);
console.info("Requests Per Hour :", (gLatency.rps * 3600));
console.info("Average Request Time(Mills) :", gLatency.meanLatencyMs);
console.info("Minimum Request Time(Mills) :", gLatency.minLatencyMs);
console.info("Maximum Request Time(Mills) :", gLatency.maxLatencyMs);
console.info("Percentiles :", gLatency.percentiles)
console.info("\n=========================================================================================================\n")
gLatency.totalErrors.should.equal(0);
(gLatency.rps * 3600).should.be.greaterThan(noRequestPerHour);
(gLatency.meanLatencyMs).should.be.below(avgRequestTime);
done();
}
});
});
});