/
test-timing.js
69 lines (62 loc) 路 2.22 KB
/
test-timing.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
'use strict'
var server = require('./server')
, request = require('../index')
, tape = require('tape')
var plain_server = server.createServer()
, redirect_mock_time = 10
tape('setup', function(t) {
plain_server.listen(0, function() {
plain_server.on('/', function (req, res) {
res.writeHead(200)
res.end('plain')
})
plain_server.on('/redir', function (req, res) {
// fake redirect delay to ensure strong signal for rollup check
setTimeout(function() {
res.writeHead(301, { 'location': 'http://localhost:' + plain_server.port + '/' })
res.end()
}, redirect_mock_time)
})
t.end()
})
})
tape('non-redirected request is timed', function(t) {
var options = {time: true}
var r = request('http://localhost:' + plain_server.port + '/', options, function(err, res, body) {
t.equal(err, null)
t.equal(typeof res.elapsedTime, 'number')
t.equal(typeof res.responseStartTime, 'number')
t.equal(typeof res.timings, 'object')
t.equal((res.elapsedTime > 0), true)
t.equal((res.responseStartTime > r.startTime), true)
t.equal((res.timings.start > 0), true)
t.equal((res.timings.socket >= res.timings.start), true)
t.equal((res.timings.connect >= res.timings.socket), true)
t.equal((res.timings.response >= res.timings.connect), true)
t.equal((res.timings.end >= res.timings.response), true)
t.equal((res.timings.dns >= 0), true)
t.equal((res.timings.tcp >= 0), true)
t.equal((res.timings.firstByte > 0), true)
t.equal((res.timings.download > 0), true)
t.equal((res.timings.total > 0), true)
t.end()
})
})
tape('redirected request is timed with rollup', function(t) {
var options = {time: true}
var r = request('http://localhost:' + plain_server.port + '/redir', options, function(err, res, body) {
t.equal(err, null)
t.equal(typeof res.elapsedTime, 'number')
t.equal(typeof res.responseStartTime, 'number')
t.equal((res.elapsedTime > 0), true)
t.equal((res.responseStartTime > 0), true)
t.equal((res.elapsedTime > redirect_mock_time), true)
t.equal((res.responseStartTime > r.startTime), true)
t.end()
})
})
tape('cleanup', function(t) {
plain_server.close(function() {
t.end()
})
})