-
Notifications
You must be signed in to change notification settings - Fork 323
/
Copy pathmulter.spec.js
108 lines (86 loc) · 3.21 KB
/
multer.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
98
99
100
101
102
103
104
105
106
107
108
'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('multer', 'multer', version => {
describe('multer parser instrumentation', () => {
const multerReadCh = dc.channel('datadog:multer:read:finish')
let port, server, middlewareProcessBodyStub, formData
before(() => {
return agent.load(['http', 'express', 'multer'], { client: false })
})
before((done) => {
const express = require('../../../versions/express').get()
const multer = require(`../../../versions/multer@${version}`).get()
const uploadToMemory = multer({ storage: multer.memoryStorage(), limits: { fileSize: 200000 } })
const app = express()
app.post('/', uploadToMemory.single('file'), (req, res) => {
middlewareProcessBodyStub(req.body.key)
res.end('DONE')
})
server = app.listen(0, () => {
port = server.address().port
done()
})
})
beforeEach(async () => {
middlewareProcessBodyStub = sinon.stub()
formData = new FormData()
formData.append('key', 'value')
})
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}/`, formData)
expect(middlewareProcessBodyStub).to.be.calledOnceWithExactly(formData.get('key'))
expect(res.data).to.be.equal('DONE')
})
it('should not abort the request with non blocker subscription', async () => {
function noop () {}
multerReadCh.subscribe(noop)
try {
const res = await axios.post(`http://localhost:${port}/`, formData)
expect(middlewareProcessBodyStub).to.be.calledOnceWithExactly(formData.get('key'))
expect(res.data).to.be.equal('DONE')
} finally {
multerReadCh.unsubscribe(noop)
}
})
it('should abort the request when abortController.abort() is called', async () => {
function blockRequest ({ res, abortController }) {
res.end('BLOCKED')
abortController.abort()
}
multerReadCh.subscribe(blockRequest)
try {
const res = await axios.post(`http://localhost:${port}/`, formData)
expect(middlewareProcessBodyStub).not.to.be.called
expect(res.data).to.be.equal('BLOCKED')
} finally {
multerReadCh.unsubscribe(blockRequest)
}
})
it('should not lose the http async context', async () => {
let store
let payload
function handler (data) {
store = storage('legacy').getStore()
payload = data
}
multerReadCh.subscribe(handler)
try {
const res = await axios.post(`http://localhost:${port}/`, formData)
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.calledOnceWithExactly(formData.get('key'))
expect(res.data).to.be.equal('DONE')
} finally {
multerReadCh.unsubscribe(handler)
}
})
})
})