forked from request/request
/
test-timing.js
62 lines (53 loc) · 1.6 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
'use strict'
var http = require('http')
, 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(plain_server.port, 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)
})
request('http://localhost:' + plain_server.port + '/', {}, function(err, res, body) {
t.equal(err, null)
})
t.end()
})
})
tape('no-op', function(t) {
t.end()
})
tape('non-redirected request is timed', function(t) {
var options = {time: true}
request('http://localhost:' + plain_server.port + '/', options, function(err, res, body) {
t.equal(err, null)
t.equal(typeof res.elapsedTime, 'number')
t.equal((res.elapsedTime > 0), true)
t.end()
})
})
tape('redirected request is timed with rollup', function(t) {
var options = {time: true}
request('http://localhost:' + plain_server.port + '/redir', options, function(err, res, body) {
t.equal(err, null)
t.equal(typeof res.elapsedTime, 'number')
t.equal((res.elapsedTime > 0), true)
t.equal((res.elapsedTime > redirect_mock_time), true)
t.end()
})
})
tape('cleanup', function(t) {
plain_server.close(function() {
t.end()
})
})