-
Notifications
You must be signed in to change notification settings - Fork 323
/
Copy pathbody-parser.spec.js
97 lines (75 loc) · 2.87 KB
/
body-parser.spec.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
97
'use strict'
const dc = require('dc-polyfill')
const axios = require('axios')
const agent = require('../../dd-trace/test/plugins/agent')
const { storage } = require('../../datadog-core')
withVersions('body-parser', 'body-parser', version => {
describe('body parser instrumentation', () => {
const bodyParserReadCh = dc.channel('datadog:body-parser:read:finish')
let port, server, middlewareProcessBodyStub
before(() => {
return agent.load(['http', 'express', 'body-parser'], { client: false })
})
before((done) => {
const express = require('../../../versions/express').get()
const bodyParser = require(`../../../versions/body-parser@${version}`).get()
const app = express()
app.use(bodyParser.json())
app.post('/', (req, res) => {
middlewareProcessBodyStub()
res.end('DONE')
})
server = app.listen(0, () => {
port = server.address().port
done()
})
})
beforeEach(async () => {
middlewareProcessBodyStub = sinon.stub()
})
after(() => {
server.close()
return agent.close({ ritmReset: false })
})
it('should not abort the request by default', async () => {
const res = await axios.post(`http://localhost:${port}/`, { key: 'value' })
expect(middlewareProcessBodyStub).to.be.calledOnce
expect(res.data).to.be.equal('DONE')
})
it('should not abort the request with non blocker subscription', async () => {
function noop () {}
bodyParserReadCh.subscribe(noop)
const res = await axios.post(`http://localhost:${port}/`, { key: 'value' })
expect(middlewareProcessBodyStub).to.be.calledOnce
expect(res.data).to.be.equal('DONE')
bodyParserReadCh.unsubscribe(noop)
})
it('should abort the request when abortController.abort() is called', async () => {
function blockRequest ({ res, abortController }) {
res.end('BLOCKED')
abortController.abort()
}
bodyParserReadCh.subscribe(blockRequest)
const res = await axios.post(`http://localhost:${port}/`, { key: 'value' })
expect(middlewareProcessBodyStub).not.to.be.called
expect(res.data).to.be.equal('BLOCKED')
bodyParserReadCh.unsubscribe(blockRequest)
})
it('should not lose the http async context', async () => {
let store
let payload
function handler (data) {
store = storage('legacy').getStore()
payload = data
}
bodyParserReadCh.subscribe(handler)
const res = await axios.post(`http://localhost:${port}/`, { key: 'value' })
expect(store).to.have.property('req', payload.req)
expect(store).to.have.property('res', payload.res)
expect(store).to.have.property('span')
expect(middlewareProcessBodyStub).to.be.calledOnce
expect(res.data).to.be.equal('DONE')
bodyParserReadCh.unsubscribe(handler)
})
})
})