-
Notifications
You must be signed in to change notification settings - Fork 224
/
spanStackTraceMinDuration.test.js
104 lines (96 loc) · 2.74 KB
/
spanStackTraceMinDuration.test.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
/*
* Copyright Elasticsearch B.V. and other contributors where applicable.
* Licensed under the BSD 2-Clause License; you may not use this file except in
* compliance with the BSD 2-Clause License.
*/
'use strict';
// Test the behavior of the `spanStackTraceMinDuration` config option.
const tape = require('tape');
const agent = require('..').start({
disableSend: true,
logLevel: 'off',
});
tape.test(
'spanStackTraceMinDuration default is no span.stacktrace, even if over 10ms duration',
function (t) {
const trans = agent.startTransaction('myTrans');
const span = agent.startSpan('mySpan');
setTimeout(function () {
span.end();
trans.end();
span._encode(function (err, data) {
t.error(err);
t.ok(!data.stacktrace, 'stacktrace not set');
t.end();
});
}, 20);
},
);
tape.test(
'span faster than configured spanStackTraceMinDuration should have no stacktrace',
function (t) {
agent._config({ spanFramesMinDuration: '100ms' });
const trans = agent.startTransaction('myTrans');
const span = agent.startSpan('mySpan');
setTimeout(function () {
span.end();
trans.end();
span._encode(function (err, data) {
t.error(err);
t.ok(!data.stacktrace, 'stacktrace not set');
t.end();
});
}, 50);
},
);
tape.test(
'span slower than configured spanStackTraceMinDuration should have stacktrace',
function (t) {
agent._config({ spanStackTraceMinDuration: '100ms' });
const trans = agent.startTransaction('myTrans');
const span = agent.startSpan('mySpan');
setTimeout(function () {
span.end();
trans.end();
span._encode(function (err, data) {
t.error(err);
t.ok(data.stacktrace, 'stacktrace set');
t.end();
});
}, 101);
},
);
tape.test(
'spanStackTraceMinDuration=<negative> means no span stack traces',
function (t) {
agent._config({ spanStackTraceMinDuration: -42 });
const trans = agent.startTransaction('myTrans');
const span = agent.startSpan('mySpan');
setImmediate(function () {
span.end();
trans.end();
span._encode(function (err, data) {
t.error(err);
t.ok(!data.stacktrace, 'stacktrace is not set');
t.end();
});
});
},
);
tape.test(
'spanFramesMinDuration=<zero> means always have span stack traces',
function (t) {
agent._config({ spanStackTraceMinDuration: '0s' });
const trans = agent.startTransaction('myTrans');
const span = agent.startSpan('mySpan');
setTimeout(function () {
span.end();
trans.end();
span._encode(function (err, data) {
t.error(err);
t.ok(data.stacktrace, 'stacktrace is set');
t.end();
});
}, 200);
},
);