This repository has been archived by the owner on Apr 19, 2023. It is now read-only.
/
ping.mocha
345 lines (274 loc) · 9.95 KB
/
ping.mocha
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
var watchmen = require ('../lib/watchmen');
var assert = require ('assert');
var storage_mocked = require ('./lib/mock/storage_mocked');
describe('ping service', function(){
var temp_status = null;
var temp_last_outage = null;
var failed_request_timestamp = null;
var correct_request_timestamp = null;
var warning_request_timestamp = null;
var service = {
host : {host: 'www.correcthost.com', port:'80', name : 'test'},
url : '/',
ping_interval: 4,
failed_ping_interval: 5,
warning_if_takes_more_than: 1500, //miliseconds
method : 'get',
expected : {statuscode: 200, contains: ''}
};
var mocked_ping_service = require ('./lib/mock/request_mocked');
service.ping_service = mocked_ping_service;
describe('bad request', function(){
var _watchmen = null;
before(function(done){
failed_request_timestamp = +new Date();
mocked_ping_service.mocked_response = {error: 'mocked error', body : null, response : null, timeDiff : 0};
_watchmen = new watchmen(null, new storage_mocked(null));
done();
});
it('should emit error', function(done){
_watchmen.on('service_ok', function (service, status){
done('error. bad response - dns request');
});
_watchmen.on('service_error', function (service, status){
temp_status = status;
done(null);
});
_watchmen.ping({service:service, timestamp: failed_request_timestamp}, function(err, request_status){
assert.ifError(err);
});
});
it('should have last_check property', function(done){
assert.equal (temp_status.last_check, failed_request_timestamp);
done();
});
it('should have running_since property', function(done){
assert.equal (temp_status.running_since, failed_request_timestamp);
done();
});
it('should have right status error', function(done){
assert.equal (temp_status.status, "error");
done();
});
it('should have last_outage', function(done){
assert.ok (temp_status.last_outage);
temp_last_outage = temp_status.last_outage; //save for next test
done();
});
it('should have right delay for next attempt', function(done){
assert.equal (temp_status.next_attempt_secs, service.failed_ping_interval);
done();
});
it('should have an error event', function(done){
assert.equal (temp_status.events[0].status, 'error');
done();
});
it('should have a down_timestamp value', function(done){
assert.equal (temp_status.down_timestamp, failed_request_timestamp);
done();
});
it('should NOT have a downtime value yet', function(done){
assert.ok (!temp_status.down_time_last_request);
done();
});
it('should NOT have a prev_state yet', function(done){
assert.equal (JSON.stringify(temp_status.prev_state),'{}');
done();
});
it('should have a running_since value', function(done){
assert.equal (temp_status.running_since, failed_request_timestamp);
done();
});
it('should have 1 outage', function(done){
assert.equal (temp_status.outages, 1);
done();
});
it('should NOT have a up_since value yet', function(done){
assert.ok (!temp_status.up_since);
done();
});
it('should have zero uptime', function(done){
assert.equal (temp_status.uptime, 0);
done();
});
it('should NOT have ok_responses', function(done){
assert.equal (temp_status.ok_responses_count, 0);
done();
});
it('should NOT have avg_response_time value', function(done){
assert.ok (!temp_status.avg_response_time);
done();
});
});
describe('correct (service back) request', function(){
var _watchmen = null;
before(function(done){
correct_request_timestamp = failed_request_timestamp + 60*1000; //one minute later
mocked_ping_service.mocked_response = {error: null, body : 'ok', response : {body: 'ok', statusCode: 200}, timeDiff : 300};
_watchmen = new watchmen(null, new storage_mocked(temp_status));
done();
});
it('should emit service_back', function(done){
_watchmen.on('service_back', function (service, status){
temp_status = status;
done(null);
});
_watchmen.on('service_error', function (service, status){
done('error. bad response');
});
_watchmen.ping({service:service, timestamp: correct_request_timestamp}, function(err, request_status){
assert.ifError(err);
});
});
it('should have last_check', function(done){
assert.equal (temp_status.last_check, correct_request_timestamp);
done();
});
it('should have running_since property', function(done){
assert.equal (temp_status.running_since, failed_request_timestamp);
done();
});
it('should have prev_state', function(done){
assert.ok (temp_status.prev_state);
done();
});
it('should not have a nested prev_state property', function(done){
assert.ok (!temp_status.prev_state.prev_state);
done();
});
it('should have right status', function(done){
assert.equal (temp_status.status, "success");
done();
});
it('should have last_outage', function(done){
assert.equal (temp_status.last_outage, temp_last_outage);
done();
});
it('should have right delay for next attempt', function(done){
assert.equal (temp_status.next_attempt_secs, service.ping_interval);
done();
});
it('should have service_back event', function(done){
assert.equal (temp_status.events.length, 1);
done();
});
it('should NOT have a down_timestamp value', function(done){
assert.ok (!temp_status.down_timestamp);
done();
});
it('should have a up_since value', function(done){
assert.equal (temp_status.up_since, correct_request_timestamp);
done();
});
it('should have a downtime value', function(done){
//corresponding to the last failed request
assert.equal (temp_status.down_time_last_request, (correct_request_timestamp-failed_request_timestamp)/1000); //in seconds
done();
});
it('should have an accumulated downtime value', function(done){
assert.equal (temp_status.down_time_acc, (correct_request_timestamp-failed_request_timestamp)/1000); //in seconds
done();
});
it('should have 1 outage from last invalid request', function(done){
assert.equal (temp_status.outages, 1);
done();
});
it('should have zero uptime', function(done){
assert.equal (temp_status.uptime, 0);
done();
});
it('should have 1 successful response', function(done){
assert.equal (temp_status.ok_responses_count, 1);
done();
});
it('should have avg_response_time value', function(done){
assert.equal (temp_status.avg_response_time, 300);
done();
});
});
describe('warning request', function(){
var _watchmen = null;
before(function(done){
warning_request_timestamp = failed_request_timestamp + 2 * 60 * 1000; //one minute later
mocked_ping_service.mocked_response = {error: null, body : 'ok', response : {body: 'ok', statusCode: 200}, timeDiff : 22300};
_watchmen = new watchmen(null, new storage_mocked(temp_status));
done();
});
it('should emit service_back', function(done){
_watchmen.on('service_warning', function (service, status){
temp_status = status;
done(null);
});
_watchmen.on('service_error', function (service, status){
done('error. bad response');
});
_watchmen.ping({service:service, timestamp: warning_request_timestamp}, function(err, request_status){
assert.ifError(err);
});
});
it('should have last_check', function(done){
assert.equal (temp_status.last_check, warning_request_timestamp);
done();
});
it('should have running_since property', function(done){
assert.equal (temp_status.running_since, failed_request_timestamp);
done();
});
it('should have prev_state', function(done){
assert.ok (temp_status.prev_state);
done();
});
it('should not have a nested prev_state property', function(done){
assert.ok (!temp_status.prev_state.prev_state);
done();
});
it('should have right status', function(done){
assert.equal (temp_status.status, "success");
done();
});
it('should have last_outage', function(done){
assert.equal (temp_status.last_outage, temp_last_outage);
done();
});
it('should have right delay for next attempt', function(done){
assert.equal (temp_status.next_attempt_secs, service.ping_interval);
done();
});
it('should have service_back event', function(done){
assert.equal (temp_status.events.length, 1);
done();
});
it('should have NOT a down_timestamp value', function(done){
assert.ok (!temp_status.down_timestamp);
done();
});
it('should have NOT a downtime value', function(done){
assert.ok (!temp_status.down_time_last_request);
done();
});
it('should have an accumulated downtime value', function(done){
assert.equal (temp_status.down_time_acc, (correct_request_timestamp-failed_request_timestamp)/1000); //in seconds
done();
});
it('should have a up_since value', function(done){
assert.equal (temp_status.up_since, correct_request_timestamp);
done();
});
it('should have 1 outage from last invalid request', function(done){
assert.equal (temp_status.outages, 1);
done();
});
it('should have more than zero uptime', function(done){
assert.equal (temp_status.uptime, 50);
done();
});
it('should have 2 successful responses', function(done){
assert.equal (temp_status.ok_responses_count, 2);
done();
});
it('should have avg_response_time value', function(done){
assert.equal (temp_status.avg_response_time, 11300);
done();
});
});
});