dd-trace 4.6.0 → 4.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +3 -3
- package/packages/datadog-instrumentations/src/cucumber.js +5 -2
- package/packages/datadog-instrumentations/src/grpc/client.js +44 -42
- package/packages/datadog-instrumentations/src/grpc/server.js +69 -60
- package/packages/datadog-instrumentations/src/http2/client.js +25 -26
- package/packages/datadog-instrumentations/src/jest.js +3 -1
- package/packages/datadog-instrumentations/src/mocha.js +5 -3
- package/packages/datadog-plugin-cypress/src/plugin.js +4 -2
- package/packages/datadog-plugin-grpc/src/client.js +29 -11
- package/packages/datadog-plugin-grpc/src/server.js +22 -6
- package/packages/datadog-plugin-http2/src/client.js +46 -29
- package/packages/datadog-plugin-router/src/index.js +1 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/command-injection-analyzer.js +3 -0
- package/packages/dd-trace/src/appsec/iast/analyzers/cookie-analyzer.js +7 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/ldap-injection-analyzer.js +3 -0
- package/packages/dd-trace/src/appsec/iast/analyzers/path-traversal-analyzer.js +19 -15
- package/packages/dd-trace/src/appsec/iast/analyzers/sql-injection-analyzer.js +5 -2
- package/packages/dd-trace/src/appsec/iast/analyzers/ssrf-analyzer.js +2 -0
- package/packages/dd-trace/src/appsec/iast/analyzers/unvalidated-redirect-analyzer.js +3 -1
- package/packages/dd-trace/src/appsec/iast/analyzers/vulnerability-analyzer.js +18 -19
- package/packages/dd-trace/src/appsec/iast/analyzers/weak-cipher-analyzer.js +3 -0
- package/packages/dd-trace/src/appsec/iast/analyzers/weak-hash-analyzer.js +3 -0
- package/packages/dd-trace/src/appsec/iast/iast-log.js +1 -1
- package/packages/dd-trace/src/appsec/iast/iast-plugin.js +205 -0
- package/packages/dd-trace/src/appsec/iast/index.js +6 -5
- package/packages/dd-trace/src/appsec/iast/tags.js +2 -1
- package/packages/dd-trace/src/appsec/iast/taint-tracking/csi-methods.js +6 -6
- package/packages/dd-trace/src/appsec/iast/taint-tracking/index.js +3 -3
- package/packages/dd-trace/src/appsec/iast/taint-tracking/operations.js +23 -4
- package/packages/dd-trace/src/appsec/iast/taint-tracking/plugin.js +32 -16
- package/packages/dd-trace/src/appsec/iast/taint-tracking/rewriter-telemetry.js +33 -0
- package/packages/dd-trace/src/appsec/iast/taint-tracking/rewriter.js +23 -16
- package/packages/dd-trace/src/appsec/iast/taint-tracking/taint-tracking-impl.js +76 -37
- package/packages/dd-trace/src/appsec/iast/telemetry/iast-metric.js +101 -0
- package/packages/dd-trace/src/appsec/iast/telemetry/index.js +45 -0
- package/packages/dd-trace/src/appsec/iast/telemetry/{logs.js → log/index.js} +5 -5
- package/packages/dd-trace/src/appsec/iast/telemetry/{log_collector.js → log/log-collector.js} +1 -1
- package/packages/dd-trace/src/appsec/iast/telemetry/namespaces.js +76 -0
- package/packages/dd-trace/src/appsec/iast/telemetry/span-tags.js +53 -0
- package/packages/dd-trace/src/appsec/iast/telemetry/verbosity.js +42 -0
- package/packages/dd-trace/src/config.js +21 -2
- package/packages/dd-trace/src/constants.js +1 -0
- package/packages/dd-trace/src/opentracing/tracer.js +1 -0
- package/packages/dd-trace/src/plugins/ci_plugin.js +6 -1
- package/packages/dd-trace/src/plugins/outbound.js +29 -12
- package/packages/dd-trace/src/plugins/plugin.js +28 -0
- package/packages/dd-trace/src/plugins/tracing.js +33 -16
- package/packages/dd-trace/src/plugins/util/ci.js +1 -1
- package/packages/dd-trace/src/plugins/util/test.js +55 -11
- package/packages/dd-trace/src/plugins/util/user-provided-git.js +1 -22
- package/packages/dd-trace/src/profiling/config.js +0 -3
- package/packages/dd-trace/src/profiling/index.js +0 -2
- package/packages/dd-trace/src/profiling/profilers/wall.js +23 -11
- package/packages/diagnostics_channel/src/index.js +64 -0
- package/packages/dd-trace/src/profiling/profilers/cpu.js +0 -126
- /package/packages/dd-trace/src/appsec/iast/taint-tracking/{origin-types.js → source-types.js} +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "dd-trace",
|
|
3
|
-
"version": "4.
|
|
3
|
+
"version": "4.7.0",
|
|
4
4
|
"description": "Datadog APM tracing client for JavaScript",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"typings": "index.d.ts",
|
|
@@ -70,7 +70,7 @@
|
|
|
70
70
|
"@datadog/native-iast-rewriter": "2.0.1",
|
|
71
71
|
"@datadog/native-iast-taint-tracking": "^1.5.0",
|
|
72
72
|
"@datadog/native-metrics": "^2.0.0",
|
|
73
|
-
"@datadog/pprof": "
|
|
73
|
+
"@datadog/pprof": "3.0.0",
|
|
74
74
|
"@datadog/sketches-js": "^2.1.0",
|
|
75
75
|
"@opentelemetry/api": "^1.0.0",
|
|
76
76
|
"@opentelemetry/core": "^1.14.0",
|
|
@@ -94,7 +94,7 @@
|
|
|
94
94
|
"node-abort-controller": "^3.0.1",
|
|
95
95
|
"opentracing": ">=0.12.1",
|
|
96
96
|
"path-to-regexp": "^0.1.2",
|
|
97
|
-
"protobufjs": "^7.
|
|
97
|
+
"protobufjs": "^7.2.4",
|
|
98
98
|
"retry": "^0.10.1",
|
|
99
99
|
"semver": "^7.3.8"
|
|
100
100
|
},
|
|
@@ -37,6 +37,7 @@ const patched = new WeakSet()
|
|
|
37
37
|
|
|
38
38
|
let pickleByFile = {}
|
|
39
39
|
const pickleResultByFile = {}
|
|
40
|
+
let isSuitesSkipped = false
|
|
40
41
|
|
|
41
42
|
function getSuiteStatusFromTestStatuses (testStatuses) {
|
|
42
43
|
if (testStatuses.some(status => status === 'fail')) {
|
|
@@ -264,7 +265,9 @@ addHook({
|
|
|
264
265
|
const { err, skippableSuites } = await skippableSuitesPromise
|
|
265
266
|
|
|
266
267
|
if (!err) {
|
|
267
|
-
|
|
268
|
+
const newPickleIds = getPicklesToRun(this, skippableSuites)
|
|
269
|
+
isSuitesSkipped = newPickleIds.length !== this.pickleIds.length
|
|
270
|
+
this.pickleIds = newPickleIds
|
|
268
271
|
}
|
|
269
272
|
|
|
270
273
|
pickleByFile = getPickleByFile(this)
|
|
@@ -292,7 +295,7 @@ addHook({
|
|
|
292
295
|
asyncResource.runInAsyncScope(() => {
|
|
293
296
|
sessionFinishCh.publish({
|
|
294
297
|
status: success ? 'pass' : 'fail',
|
|
295
|
-
isSuitesSkipped
|
|
298
|
+
isSuitesSkipped,
|
|
296
299
|
testCodeCoverageLinesTotal
|
|
297
300
|
})
|
|
298
301
|
})
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict'
|
|
2
2
|
|
|
3
3
|
const types = require('./types')
|
|
4
|
-
const { addHook, channel
|
|
4
|
+
const { addHook, channel } = require('../helpers/instrument')
|
|
5
5
|
const shimmer = require('../../../datadog-shimmer')
|
|
6
6
|
|
|
7
7
|
const nodeMajor = parseInt(process.versions.node.split('.')[0])
|
|
@@ -10,8 +10,10 @@ const patched = new WeakSet()
|
|
|
10
10
|
const instances = new WeakMap()
|
|
11
11
|
|
|
12
12
|
const startChannel = channel('apm:grpc:client:request:start')
|
|
13
|
+
const asyncStartChannel = channel('apm:grpc:client:request:asyncStart')
|
|
13
14
|
const errorChannel = channel('apm:grpc:client:request:error')
|
|
14
15
|
const finishChannel = channel('apm:grpc:client:request:finish')
|
|
16
|
+
const emitChannel = channel('apm:grpc:client:request:emit')
|
|
15
17
|
|
|
16
18
|
function createWrapMakeRequest (type) {
|
|
17
19
|
return function wrapMakeRequest (makeRequest) {
|
|
@@ -101,45 +103,39 @@ function wrapMethod (method, path, type) {
|
|
|
101
103
|
return wrapped
|
|
102
104
|
}
|
|
103
105
|
|
|
104
|
-
function wrapCallback (
|
|
106
|
+
function wrapCallback (ctx, callback = () => { }) {
|
|
105
107
|
return function (err) {
|
|
106
108
|
if (err) {
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
})
|
|
109
|
+
ctx.error = err
|
|
110
|
+
errorChannel.publish(ctx)
|
|
110
111
|
}
|
|
111
112
|
|
|
112
|
-
|
|
113
|
-
return
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
}
|
|
113
|
+
return asyncStartChannel.runStores(ctx, () => {
|
|
114
|
+
return callback.apply(this, arguments)
|
|
115
|
+
// No async end channel needed
|
|
116
|
+
})
|
|
117
117
|
}
|
|
118
118
|
}
|
|
119
119
|
|
|
120
|
-
function
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
break
|
|
135
|
-
}
|
|
136
|
-
})
|
|
120
|
+
function createWrapEmit (ctx) {
|
|
121
|
+
return function wrapEmit (emit) {
|
|
122
|
+
return function (event, arg1) {
|
|
123
|
+
switch (event) {
|
|
124
|
+
case 'error':
|
|
125
|
+
ctx.error = arg1
|
|
126
|
+
errorChannel.publish(ctx)
|
|
127
|
+
break
|
|
128
|
+
case 'status':
|
|
129
|
+
ctx.result = arg1
|
|
130
|
+
finishChannel.publish(ctx)
|
|
131
|
+
break
|
|
132
|
+
}
|
|
137
133
|
|
|
138
|
-
return
|
|
134
|
+
return emitChannel.runStores(ctx, () => {
|
|
139
135
|
return emit.apply(this, arguments)
|
|
140
136
|
})
|
|
141
137
|
}
|
|
142
|
-
}
|
|
138
|
+
}
|
|
143
139
|
}
|
|
144
140
|
|
|
145
141
|
function callMethod (client, method, args, path, metadata, type) {
|
|
@@ -147,25 +143,31 @@ function callMethod (client, method, args, path, metadata, type) {
|
|
|
147
143
|
|
|
148
144
|
const length = args.length
|
|
149
145
|
const callback = args[length - 1]
|
|
150
|
-
const parentResource = new AsyncResource('bound-anonymous-fn')
|
|
151
|
-
const requestResource = new AsyncResource('bound-anonymous-fn')
|
|
152
146
|
|
|
153
|
-
|
|
154
|
-
startChannel.publish({ metadata, path, type })
|
|
147
|
+
const ctx = { metadata, path, type }
|
|
155
148
|
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
149
|
+
return startChannel.runStores(ctx, () => {
|
|
150
|
+
try {
|
|
151
|
+
if (type === types.unary || type === types.client_stream) {
|
|
152
|
+
if (typeof callback === 'function') {
|
|
153
|
+
args[length - 1] = wrapCallback(ctx, callback)
|
|
154
|
+
} else {
|
|
155
|
+
args[length] = wrapCallback(ctx)
|
|
156
|
+
}
|
|
161
157
|
}
|
|
162
|
-
}
|
|
163
158
|
|
|
164
|
-
|
|
159
|
+
const call = method.apply(client, args)
|
|
165
160
|
|
|
166
|
-
|
|
161
|
+
if (call && typeof call.emit === 'function') {
|
|
162
|
+
shimmer.wrap(call, 'emit', createWrapEmit(ctx))
|
|
163
|
+
}
|
|
167
164
|
|
|
168
|
-
|
|
165
|
+
return call
|
|
166
|
+
} catch (e) {
|
|
167
|
+
ctx.error = e
|
|
168
|
+
errorChannel.publish(ctx)
|
|
169
|
+
}
|
|
170
|
+
// No end channel needed
|
|
169
171
|
})
|
|
170
172
|
}
|
|
171
173
|
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
'use strict'
|
|
2
2
|
|
|
3
3
|
const types = require('./types')
|
|
4
|
-
const { channel, addHook
|
|
4
|
+
const { channel, addHook } = require('../helpers/instrument')
|
|
5
5
|
const shimmer = require('../../../datadog-shimmer')
|
|
6
6
|
|
|
7
7
|
const nodeMajor = parseInt(process.versions.node.split('.')[0])
|
|
8
8
|
|
|
9
9
|
const startChannel = channel('apm:grpc:server:request:start')
|
|
10
|
+
const asyncStartChannel = channel('apm:grpc:server:request:asyncStart')
|
|
10
11
|
const errorChannel = channel('apm:grpc:server:request:error')
|
|
11
12
|
const updateChannel = channel('apm:grpc:server:request:update')
|
|
12
13
|
const finishChannel = channel('apm:grpc:server:request:finish')
|
|
14
|
+
const emitChannel = channel('apm:grpc:server:request:emit')
|
|
13
15
|
|
|
14
16
|
// https://github.com/grpc/grpc/blob/master/doc/statuscodes.md
|
|
15
17
|
const OK = 0
|
|
@@ -33,28 +35,38 @@ function wrapHandler (func, name) {
|
|
|
33
35
|
const type = types[this.type]
|
|
34
36
|
const isStream = type !== 'unary'
|
|
35
37
|
|
|
36
|
-
const
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
38
|
+
const ctx = { name, metadata, type }
|
|
39
|
+
|
|
40
|
+
return startChannel.runStores(ctx, () => {
|
|
41
|
+
try {
|
|
42
|
+
const onCancel = () => {
|
|
43
|
+
ctx.code = CANCELLED
|
|
44
|
+
finishChannel.publish(ctx)
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// Finish the span if the call was cancelled.
|
|
48
|
+
call.once('cancelled', onCancel)
|
|
49
|
+
|
|
50
|
+
if (isStream) {
|
|
51
|
+
wrapStream(call, ctx, onCancel)
|
|
52
|
+
} else {
|
|
53
|
+
arguments[1] = wrapCallback(callback, call, ctx, onCancel)
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
shimmer.wrap(call, 'emit', emit => {
|
|
57
|
+
return function () {
|
|
58
|
+
return emitChannel.runStores(ctx, () => {
|
|
59
|
+
return emit.apply(this, arguments)
|
|
60
|
+
})
|
|
61
|
+
}
|
|
62
|
+
})
|
|
48
63
|
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
64
|
+
return func.apply(this, arguments)
|
|
65
|
+
} catch (e) {
|
|
66
|
+
ctx.error = e
|
|
67
|
+
errorChannel.publish(ctx)
|
|
53
68
|
}
|
|
54
|
-
|
|
55
|
-
shimmer.wrap(call, 'emit', emit => requestResource.bind(emit))
|
|
56
|
-
|
|
57
|
-
return func.apply(this, arguments)
|
|
69
|
+
// No end channel needed
|
|
58
70
|
})
|
|
59
71
|
}
|
|
60
72
|
}
|
|
@@ -69,69 +81,66 @@ function wrapRegister (register) {
|
|
|
69
81
|
}
|
|
70
82
|
}
|
|
71
83
|
|
|
72
|
-
function
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
shimmer.wrap(call, 'emit', emit => {
|
|
78
|
-
return function (eventName, ...args) {
|
|
79
|
-
switch (eventName) {
|
|
84
|
+
function createWrapEmit (call, ctx, onCancel) {
|
|
85
|
+
return function wrapEmit (emit) {
|
|
86
|
+
return function (event, arg1) {
|
|
87
|
+
switch (event) {
|
|
80
88
|
case 'error':
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
89
|
+
ctx.error = arg1
|
|
90
|
+
errorChannel.publish(ctx)
|
|
91
|
+
ctx.code = arg1.code
|
|
92
|
+
finishChannel.publish(ctx)
|
|
84
93
|
call.removeListener('cancelled', onCancel)
|
|
85
|
-
|
|
86
94
|
break
|
|
87
|
-
|
|
88
|
-
// Finish the span of the response only if it was successful.
|
|
89
|
-
// Otherwise it'll be finished in the `error` listener.
|
|
90
95
|
case 'finish':
|
|
91
96
|
if (call.status) {
|
|
92
97
|
updateChannel.publish(call.status)
|
|
93
98
|
}
|
|
94
|
-
|
|
95
99
|
if (!call.status || call.status.code === 0) {
|
|
96
|
-
finishChannel.publish()
|
|
100
|
+
finishChannel.publish(ctx)
|
|
97
101
|
}
|
|
98
|
-
|
|
99
102
|
call.removeListener('cancelled', onCancel)
|
|
100
|
-
|
|
101
103
|
break
|
|
102
104
|
}
|
|
103
105
|
|
|
104
106
|
return emit.apply(this, arguments)
|
|
105
107
|
}
|
|
106
|
-
}
|
|
108
|
+
}
|
|
107
109
|
}
|
|
108
110
|
|
|
109
|
-
function
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
errorChannel.publish(err)
|
|
114
|
-
finishChannel.publish(err)
|
|
115
|
-
} else {
|
|
116
|
-
finishChannel.publish({ code: OK, trailer })
|
|
117
|
-
}
|
|
111
|
+
function wrapStream (call, ctx, onCancel) {
|
|
112
|
+
if (call.call && call.call.sendStatus) {
|
|
113
|
+
call.call.sendStatus = wrapSendStatus(call.call.sendStatus, ctx)
|
|
114
|
+
}
|
|
118
115
|
|
|
119
|
-
|
|
120
|
-
|
|
116
|
+
shimmer.wrap(call, 'emit', createWrapEmit(call, ctx, onCancel))
|
|
117
|
+
}
|
|
121
118
|
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
119
|
+
function wrapCallback (callback = () => {}, call, ctx, onCancel) {
|
|
120
|
+
return function (err, value, trailer, flags) {
|
|
121
|
+
if (err) {
|
|
122
|
+
ctx.error = err
|
|
123
|
+
errorChannel.publish(ctx)
|
|
124
|
+
} else {
|
|
125
|
+
ctx.code = OK
|
|
126
|
+
ctx.trailer = trailer
|
|
126
127
|
}
|
|
128
|
+
|
|
129
|
+
finishChannel.publish(ctx)
|
|
130
|
+
|
|
131
|
+
call.removeListener('cancelled', onCancel)
|
|
132
|
+
|
|
133
|
+
return asyncStartChannel.runStores(ctx, () => {
|
|
134
|
+
return callback.apply(this, arguments)
|
|
135
|
+
// No async end channel needed
|
|
136
|
+
})
|
|
127
137
|
}
|
|
128
138
|
}
|
|
129
139
|
|
|
130
|
-
function wrapSendStatus (sendStatus,
|
|
140
|
+
function wrapSendStatus (sendStatus, ctx) {
|
|
131
141
|
return function (status) {
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
})
|
|
142
|
+
ctx.status = status
|
|
143
|
+
updateChannel.publish(ctx)
|
|
135
144
|
|
|
136
145
|
return sendStatus.apply(this, arguments)
|
|
137
146
|
}
|
|
@@ -1,32 +1,27 @@
|
|
|
1
1
|
'use strict'
|
|
2
2
|
|
|
3
3
|
const shimmer = require('../../../datadog-shimmer')
|
|
4
|
-
const { addHook, channel
|
|
4
|
+
const { addHook, channel } = require('../helpers/instrument')
|
|
5
5
|
|
|
6
6
|
const connectChannel = channel('apm:http2:client:connect:start')
|
|
7
7
|
const startChannel = channel('apm:http2:client:request:start')
|
|
8
|
-
const
|
|
8
|
+
const endChannel = channel('apm:http2:client:request:end')
|
|
9
|
+
const asyncStartChannel = channel('apm:http2:client:request:asyncStart')
|
|
10
|
+
const asyncEndChannel = channel('apm:http2:client:request:asyncEnd')
|
|
9
11
|
const errorChannel = channel('apm:http2:client:request:error')
|
|
10
|
-
const responseChannel = channel('apm:http2:client:response')
|
|
11
12
|
|
|
12
|
-
function createWrapEmit (
|
|
13
|
+
function createWrapEmit (ctx) {
|
|
13
14
|
return function wrapEmit (emit) {
|
|
14
15
|
return function (event, arg1) {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
case 'response':
|
|
18
|
-
responseChannel.publish(arg1)
|
|
19
|
-
break
|
|
20
|
-
case 'error':
|
|
21
|
-
errorChannel.publish(arg1)
|
|
22
|
-
case 'close': // eslint-disable-line no-fallthrough
|
|
23
|
-
finishChannel.publish()
|
|
24
|
-
break
|
|
25
|
-
}
|
|
26
|
-
})
|
|
16
|
+
ctx.eventName = event
|
|
17
|
+
ctx.eventData = arg1
|
|
27
18
|
|
|
28
|
-
return
|
|
29
|
-
|
|
19
|
+
return asyncStartChannel.runStores(ctx, () => {
|
|
20
|
+
try {
|
|
21
|
+
return emit.apply(this, arguments)
|
|
22
|
+
} finally {
|
|
23
|
+
asyncEndChannel.publish(ctx)
|
|
24
|
+
}
|
|
30
25
|
})
|
|
31
26
|
}
|
|
32
27
|
}
|
|
@@ -35,17 +30,21 @@ function createWrapEmit (requestResource, parentResource) {
|
|
|
35
30
|
function createWrapRequest (authority, options) {
|
|
36
31
|
return function wrapRequest (request) {
|
|
37
32
|
return function (headers) {
|
|
38
|
-
const
|
|
39
|
-
const requestResource = new AsyncResource('bound-anonymous-fn')
|
|
33
|
+
const ctx = { headers, authority, options }
|
|
40
34
|
|
|
41
|
-
return
|
|
42
|
-
|
|
35
|
+
return startChannel.runStores(ctx, () => {
|
|
36
|
+
try {
|
|
37
|
+
const req = request.apply(this, arguments)
|
|
43
38
|
|
|
44
|
-
|
|
39
|
+
shimmer.wrap(req, 'emit', createWrapEmit(ctx))
|
|
45
40
|
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
41
|
+
return req
|
|
42
|
+
} catch (e) {
|
|
43
|
+
ctx.error = e
|
|
44
|
+
errorChannel.publish(ctx)
|
|
45
|
+
} finally {
|
|
46
|
+
endChannel.publish(ctx)
|
|
47
|
+
}
|
|
49
48
|
})
|
|
50
49
|
}
|
|
51
50
|
}
|
|
@@ -42,6 +42,7 @@ const jestItrConfigurationCh = channel('ci:jest:itr-configuration')
|
|
|
42
42
|
let skippableSuites = []
|
|
43
43
|
let isCodeCoverageEnabled = false
|
|
44
44
|
let isSuitesSkippingEnabled = false
|
|
45
|
+
let isSuitesSkipped = false
|
|
45
46
|
|
|
46
47
|
const sessionAsyncResource = new AsyncResource('bound-anonymous-fn')
|
|
47
48
|
|
|
@@ -227,7 +228,6 @@ function cliWrapper (cli, jestVersion) {
|
|
|
227
228
|
log.error(err)
|
|
228
229
|
}
|
|
229
230
|
}
|
|
230
|
-
const isSuitesSkipped = !!skippableSuites.length
|
|
231
231
|
|
|
232
232
|
const processArgv = process.argv.slice(2).join(' ')
|
|
233
233
|
sessionAsyncResource.runInAsyncScope(() => {
|
|
@@ -430,6 +430,8 @@ addHook({
|
|
|
430
430
|
|
|
431
431
|
const filteredTests = getJestSuitesToRun(skippableSuites, tests, rootDir)
|
|
432
432
|
|
|
433
|
+
isSuitesSkipped = filteredTests.length !== tests.length
|
|
434
|
+
|
|
433
435
|
skippableSuites = []
|
|
434
436
|
|
|
435
437
|
return { ...testPaths, tests: filteredTests }
|
|
@@ -46,6 +46,7 @@ const originalCoverageMap = createCoverageMap()
|
|
|
46
46
|
|
|
47
47
|
let suitesToSkip = []
|
|
48
48
|
let frameworkVersion
|
|
49
|
+
let isSuitesSkipped = false
|
|
49
50
|
|
|
50
51
|
function getSuitesByTestFile (root) {
|
|
51
52
|
const suitesByTestFile = {}
|
|
@@ -125,8 +126,6 @@ function mochaHook (Runner) {
|
|
|
125
126
|
}
|
|
126
127
|
testFileToSuiteAr.clear()
|
|
127
128
|
|
|
128
|
-
const isSuitesSkipped = !!suitesToSkip.length
|
|
129
|
-
|
|
130
129
|
let testCodeCoverageLinesTotal
|
|
131
130
|
if (global.__coverage__) {
|
|
132
131
|
try {
|
|
@@ -360,7 +359,10 @@ addHook({
|
|
|
360
359
|
suitesToSkip = skippableSuites
|
|
361
360
|
}
|
|
362
361
|
// We remove the suites that we skip through ITR
|
|
363
|
-
|
|
362
|
+
const newSuites = getSuitesToRun(runner.suite.suites)
|
|
363
|
+
isSuitesSkipped = newSuites.length !== runner.suite.suites.length
|
|
364
|
+
runner.suite.suites = newSuites
|
|
365
|
+
|
|
364
366
|
global.run()
|
|
365
367
|
}
|
|
366
368
|
|
|
@@ -37,7 +37,7 @@ const CYPRESS_STATUS_TO_TEST_STATUS = {
|
|
|
37
37
|
function getTestSpanMetadata (tracer, testName, testSuite, cypressConfig) {
|
|
38
38
|
const childOf = getTestParentSpan(tracer)
|
|
39
39
|
|
|
40
|
-
const commonTags = getTestCommonTags(testName, testSuite, cypressConfig.version)
|
|
40
|
+
const commonTags = getTestCommonTags(testName, testSuite, cypressConfig.version, TEST_FRAMEWORK_NAME)
|
|
41
41
|
|
|
42
42
|
return {
|
|
43
43
|
childOf,
|
|
@@ -119,6 +119,7 @@ function getSkippableTests (isSuitesSkippingEnabled, tracer, testConfiguration)
|
|
|
119
119
|
}
|
|
120
120
|
|
|
121
121
|
module.exports = (on, config) => {
|
|
122
|
+
let isTestsSkipped = false
|
|
122
123
|
const tracer = require('../../dd-trace')
|
|
123
124
|
const testEnvironmentMetadata = getTestEnvironmentMetadata(TEST_FRAMEWORK_NAME)
|
|
124
125
|
|
|
@@ -306,7 +307,7 @@ module.exports = (on, config) => {
|
|
|
306
307
|
testSessionSpan,
|
|
307
308
|
testModuleSpan,
|
|
308
309
|
{
|
|
309
|
-
isSuitesSkipped:
|
|
310
|
+
isSuitesSkipped: isTestsSkipped,
|
|
310
311
|
isSuitesSkippingEnabled,
|
|
311
312
|
isCodeCoverageEnabled
|
|
312
313
|
}
|
|
@@ -352,6 +353,7 @@ module.exports = (on, config) => {
|
|
|
352
353
|
if (testsToSkip.find(test => {
|
|
353
354
|
return testName === test.name && testSuite === test.suite
|
|
354
355
|
})) {
|
|
356
|
+
isTestsSkipped = true
|
|
355
357
|
return { shouldSkip: true }
|
|
356
358
|
}
|
|
357
359
|
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
'use strict'
|
|
2
2
|
|
|
3
|
+
const { storage } = require('../../datadog-core')
|
|
3
4
|
const ClientPlugin = require('../../dd-trace/src/plugins/client')
|
|
4
5
|
const { TEXT_MAP } = require('../../../ext/formats')
|
|
5
6
|
const { addMetadataTags, getFilter, getMethodMetadata } = require('./util')
|
|
@@ -7,9 +8,20 @@ const { addMetadataTags, getFilter, getMethodMetadata } = require('./util')
|
|
|
7
8
|
class GrpcClientPlugin extends ClientPlugin {
|
|
8
9
|
static get id () { return 'grpc' }
|
|
9
10
|
static get operation () { return 'client:request' }
|
|
11
|
+
static get prefix () { return `apm:grpc:client:request` }
|
|
10
12
|
static get peerServicePrecursors () { return ['rpc.service'] }
|
|
11
13
|
|
|
12
|
-
|
|
14
|
+
constructor (...args) {
|
|
15
|
+
super(...args)
|
|
16
|
+
|
|
17
|
+
this.addTraceBind('emit', ({ parentStore }) => {
|
|
18
|
+
return parentStore
|
|
19
|
+
})
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
bindStart (message) {
|
|
23
|
+
const store = storage.getStore()
|
|
24
|
+
const { metadata, path, type } = message
|
|
13
25
|
const metadataFilter = this.config.metadataFilter
|
|
14
26
|
const method = getMethodMetadata(path, type)
|
|
15
27
|
const span = this.startSpan(this.operationName(), {
|
|
@@ -28,7 +40,7 @@ class GrpcClientPlugin extends ClientPlugin {
|
|
|
28
40
|
metrics: {
|
|
29
41
|
'grpc.status.code': 0
|
|
30
42
|
}
|
|
31
|
-
})
|
|
43
|
+
}, false)
|
|
32
44
|
|
|
33
45
|
// needed as precursor for peer.service
|
|
34
46
|
if (method.service && method.package) {
|
|
@@ -39,22 +51,27 @@ class GrpcClientPlugin extends ClientPlugin {
|
|
|
39
51
|
addMetadataTags(span, metadata, metadataFilter, 'request')
|
|
40
52
|
inject(this.tracer, span, metadata)
|
|
41
53
|
}
|
|
42
|
-
}
|
|
43
54
|
|
|
44
|
-
|
|
45
|
-
|
|
55
|
+
message.span = span
|
|
56
|
+
message.parentStore = store
|
|
57
|
+
message.currentStore = { ...store, span }
|
|
46
58
|
|
|
47
|
-
|
|
59
|
+
return message.currentStore
|
|
60
|
+
}
|
|
48
61
|
|
|
49
|
-
|
|
50
|
-
|
|
62
|
+
bindAsyncStart ({ parentStore }) {
|
|
63
|
+
return parentStore
|
|
51
64
|
}
|
|
52
65
|
|
|
53
|
-
|
|
54
|
-
|
|
66
|
+
error ({ span, error }) {
|
|
67
|
+
this.addCode(span, error.code)
|
|
68
|
+
this.addError(error, span)
|
|
69
|
+
}
|
|
55
70
|
|
|
71
|
+
finish ({ span, result }) {
|
|
56
72
|
if (!span) return
|
|
57
73
|
|
|
74
|
+
const { code, metadata } = result || {}
|
|
58
75
|
const metadataFilter = this.config.metadataFilter
|
|
59
76
|
|
|
60
77
|
this.addCode(span, code)
|
|
@@ -63,7 +80,8 @@ class GrpcClientPlugin extends ClientPlugin {
|
|
|
63
80
|
addMetadataTags(span, metadata, metadataFilter, 'response')
|
|
64
81
|
}
|
|
65
82
|
|
|
66
|
-
|
|
83
|
+
this.tagPeerService(span)
|
|
84
|
+
span.finish()
|
|
67
85
|
}
|
|
68
86
|
|
|
69
87
|
configure (config) {
|