datadog-ci 0.3.0 → 0.5.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +89 -1
- data/README.md +57 -34
- data/lib/datadog/ci/concurrent_span.rb +59 -0
- data/lib/datadog/ci/configuration/components.rb +40 -1
- data/lib/datadog/ci/configuration/extensions.rb +21 -0
- data/lib/datadog/ci/configuration/settings.rb +7 -1
- data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +12 -1
- data/lib/datadog/ci/contrib/cucumber/formatter.rb +22 -29
- data/lib/datadog/ci/contrib/minitest/configuration/settings.rb +10 -1
- data/lib/datadog/ci/contrib/minitest/hooks.rb +15 -25
- data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +10 -1
- data/lib/datadog/ci/contrib/rspec/example.rb +13 -18
- data/lib/datadog/ci/contrib/settings.rb +2 -0
- data/lib/datadog/ci/ext/app_types.rb +5 -0
- data/lib/datadog/ci/ext/environment/extractor.rb +5 -10
- data/lib/datadog/ci/ext/environment/providers/github_actions.rb +13 -4
- data/lib/datadog/ci/ext/settings.rb +11 -0
- data/lib/datadog/ci/ext/test.rb +12 -1
- data/lib/datadog/ci/null_span.rb +63 -0
- data/lib/datadog/ci/span.rb +117 -0
- data/lib/datadog/ci/test.rb +25 -0
- data/lib/datadog/ci/test_module.rb +23 -0
- data/lib/datadog/ci/test_session.rb +36 -0
- data/lib/datadog/ci/test_suite.rb +25 -0
- data/lib/datadog/ci/test_visibility/context/global.rb +82 -0
- data/lib/datadog/ci/test_visibility/context/local.rb +52 -0
- data/lib/datadog/ci/test_visibility/recorder.rb +293 -0
- data/lib/datadog/ci/test_visibility/serializers/base.rb +100 -12
- data/lib/datadog/ci/test_visibility/serializers/factories/test_suite_level.rb +37 -0
- data/lib/datadog/ci/test_visibility/serializers/span.rb +2 -16
- data/lib/datadog/ci/test_visibility/serializers/test_module.rb +46 -0
- data/lib/datadog/ci/test_visibility/serializers/test_session.rb +46 -0
- data/lib/datadog/ci/test_visibility/serializers/test_suite.rb +46 -0
- data/lib/datadog/ci/test_visibility/serializers/test_v1.rb +3 -17
- data/lib/datadog/ci/test_visibility/serializers/test_v2.rb +38 -0
- data/lib/datadog/ci/test_visibility/transport.rb +4 -4
- data/lib/datadog/ci/utils/test_run.rb +15 -0
- data/lib/datadog/ci/utils/url.rb +15 -0
- data/lib/datadog/ci/version.rb +2 -2
- data/lib/datadog/ci.rb +378 -7
- data/sig/datadog/ci/concurrent_span.rbs +23 -0
- data/sig/datadog/ci/configuration/components.rbs +6 -0
- data/sig/datadog/ci/configuration/extensions.rbs +9 -0
- data/sig/datadog/ci/ext/app_types.rbs +6 -1
- data/sig/datadog/ci/ext/environment/extractor.rbs +0 -2
- data/sig/datadog/ci/ext/environment/providers/github_actions.rbs +5 -0
- data/sig/datadog/ci/ext/settings.rbs +3 -0
- data/sig/datadog/ci/ext/test.rbs +15 -0
- data/sig/datadog/ci/null_span.rbs +37 -0
- data/sig/datadog/ci/span.rbs +39 -0
- data/sig/datadog/ci/test.rbs +7 -0
- data/sig/datadog/ci/test_module.rbs +6 -0
- data/sig/datadog/ci/test_session.rbs +9 -0
- data/sig/datadog/ci/test_suite.rbs +6 -0
- data/sig/datadog/ci/test_visibility/context/global.rbs +39 -0
- data/sig/datadog/ci/test_visibility/context/local.rbs +23 -0
- data/sig/datadog/ci/test_visibility/recorder.rbs +85 -0
- data/sig/datadog/ci/test_visibility/serializers/base.rbs +26 -5
- data/sig/datadog/ci/test_visibility/serializers/factories/test_suite_level.rbs +13 -0
- data/sig/datadog/ci/test_visibility/serializers/test_module.rbs +26 -0
- data/sig/datadog/ci/test_visibility/serializers/test_session.rbs +26 -0
- data/sig/datadog/ci/test_visibility/serializers/test_suite.rbs +26 -0
- data/sig/datadog/ci/test_visibility/serializers/test_v1.rbs +1 -1
- data/sig/datadog/ci/test_visibility/serializers/test_v2.rbs +25 -0
- data/sig/datadog/ci/test_visibility/transport.rbs +3 -3
- data/sig/datadog/ci/utils/test_run.rbs +11 -0
- data/sig/datadog/ci/utils/url.rbs +9 -0
- data/sig/datadog/ci.rbs +31 -3
- metadata +38 -6
- data/lib/datadog/ci/extensions.rb +0 -19
- data/lib/datadog/ci/recorder.rb +0 -83
- data/sig/datadog/ci/extensions.rbs +0 -7
- data/sig/datadog/ci/recorder.rbs +0 -18
@@ -0,0 +1,46 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require_relative "base"
|
4
|
+
require_relative "../../ext/test"
|
5
|
+
|
6
|
+
module Datadog
|
7
|
+
module CI
|
8
|
+
module TestVisibility
|
9
|
+
module Serializers
|
10
|
+
class TestSession < Base
|
11
|
+
CONTENT_FIELDS = (["test_session_id"] + Base::CONTENT_FIELDS).freeze
|
12
|
+
|
13
|
+
CONTENT_MAP_SIZE = calculate_content_map_size(CONTENT_FIELDS)
|
14
|
+
|
15
|
+
REQUIRED_FIELDS = (["test_session_id"] + Base::REQUIRED_FIELDS).freeze
|
16
|
+
|
17
|
+
def content_fields
|
18
|
+
CONTENT_FIELDS
|
19
|
+
end
|
20
|
+
|
21
|
+
def content_map_size
|
22
|
+
CONTENT_MAP_SIZE
|
23
|
+
end
|
24
|
+
|
25
|
+
def type
|
26
|
+
Ext::AppTypes::TYPE_TEST_SESSION
|
27
|
+
end
|
28
|
+
|
29
|
+
def name
|
30
|
+
"#{@span.get_tag(Ext::Test::TAG_FRAMEWORK)}.test_session"
|
31
|
+
end
|
32
|
+
|
33
|
+
def resource
|
34
|
+
"#{@span.get_tag(Ext::Test::TAG_FRAMEWORK)}.test_session.#{@span.get_tag(Ext::Test::TAG_COMMAND)}"
|
35
|
+
end
|
36
|
+
|
37
|
+
private
|
38
|
+
|
39
|
+
def required_fields
|
40
|
+
REQUIRED_FIELDS
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
@@ -0,0 +1,46 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require_relative "base"
|
4
|
+
require_relative "../../ext/test"
|
5
|
+
|
6
|
+
module Datadog
|
7
|
+
module CI
|
8
|
+
module TestVisibility
|
9
|
+
module Serializers
|
10
|
+
class TestSuite < Base
|
11
|
+
CONTENT_FIELDS = (["test_session_id", "test_module_id", "test_suite_id"] + Base::CONTENT_FIELDS).freeze
|
12
|
+
|
13
|
+
CONTENT_MAP_SIZE = calculate_content_map_size(CONTENT_FIELDS)
|
14
|
+
|
15
|
+
REQUIRED_FIELDS = (["test_session_id", "test_module_id", "test_suite_id"] + Base::REQUIRED_FIELDS).freeze
|
16
|
+
|
17
|
+
def content_fields
|
18
|
+
CONTENT_FIELDS
|
19
|
+
end
|
20
|
+
|
21
|
+
def content_map_size
|
22
|
+
CONTENT_MAP_SIZE
|
23
|
+
end
|
24
|
+
|
25
|
+
def type
|
26
|
+
Ext::AppTypes::TYPE_TEST_SUITE
|
27
|
+
end
|
28
|
+
|
29
|
+
def name
|
30
|
+
"#{@span.get_tag(Ext::Test::TAG_FRAMEWORK)}.test_suite"
|
31
|
+
end
|
32
|
+
|
33
|
+
def resource
|
34
|
+
"#{@span.get_tag(Ext::Test::TAG_FRAMEWORK)}.test_suite.#{@span.get_tag(Ext::Test::TAG_SUITE)}"
|
35
|
+
end
|
36
|
+
|
37
|
+
private
|
38
|
+
|
39
|
+
def required_fields
|
40
|
+
REQUIRED_FIELDS
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
@@ -8,25 +8,11 @@ module Datadog
|
|
8
8
|
module TestVisibility
|
9
9
|
module Serializers
|
10
10
|
class TestV1 < Base
|
11
|
-
CONTENT_FIELDS = [
|
12
|
-
"trace_id", "span_id",
|
13
|
-
"name", "resource", "service",
|
14
|
-
"error", "start", "duration",
|
15
|
-
"meta", "metrics",
|
16
|
-
"type" => "span_type"
|
17
|
-
].freeze
|
11
|
+
CONTENT_FIELDS = (["trace_id", "span_id"] + Base::CONTENT_FIELDS).freeze
|
18
12
|
|
19
13
|
CONTENT_MAP_SIZE = calculate_content_map_size(CONTENT_FIELDS)
|
20
14
|
|
21
|
-
REQUIRED_FIELDS = [
|
22
|
-
"trace_id",
|
23
|
-
"span_id",
|
24
|
-
"error",
|
25
|
-
"name",
|
26
|
-
"resource",
|
27
|
-
"start",
|
28
|
-
"duration"
|
29
|
-
].freeze
|
15
|
+
REQUIRED_FIELDS = (["trace_id", "span_id"] + Base::REQUIRED_FIELDS).freeze
|
30
16
|
|
31
17
|
def content_fields
|
32
18
|
CONTENT_FIELDS
|
@@ -37,7 +23,7 @@ module Datadog
|
|
37
23
|
end
|
38
24
|
|
39
25
|
def type
|
40
|
-
|
26
|
+
Ext::AppTypes::TYPE_TEST
|
41
27
|
end
|
42
28
|
|
43
29
|
def name
|
@@ -0,0 +1,38 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require_relative "test_v1"
|
4
|
+
require_relative "../../ext/test"
|
5
|
+
|
6
|
+
module Datadog
|
7
|
+
module CI
|
8
|
+
module TestVisibility
|
9
|
+
module Serializers
|
10
|
+
class TestV2 < TestV1
|
11
|
+
CONTENT_FIELDS = (["test_session_id", "test_module_id", "test_suite_id"] + TestV1::CONTENT_FIELDS).freeze
|
12
|
+
|
13
|
+
CONTENT_MAP_SIZE = calculate_content_map_size(CONTENT_FIELDS)
|
14
|
+
|
15
|
+
REQUIRED_FIELDS = (["test_session_id", "test_module_id", "test_suite_id"] + TestV1::REQUIRED_FIELDS).freeze
|
16
|
+
|
17
|
+
def content_fields
|
18
|
+
CONTENT_FIELDS
|
19
|
+
end
|
20
|
+
|
21
|
+
def content_map_size
|
22
|
+
CONTENT_MAP_SIZE
|
23
|
+
end
|
24
|
+
|
25
|
+
def version
|
26
|
+
2
|
27
|
+
end
|
28
|
+
|
29
|
+
private
|
30
|
+
|
31
|
+
def required_fields
|
32
|
+
REQUIRED_FIELDS
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -81,7 +81,7 @@ module Datadog
|
|
81
81
|
if spans.respond_to?(:filter_map)
|
82
82
|
spans.filter_map { |span| encode_span(trace, span) }
|
83
83
|
else
|
84
|
-
|
84
|
+
spans.map { |span| encode_span(trace, span) }.reject(&:nil?)
|
85
85
|
end
|
86
86
|
end
|
87
87
|
end
|
@@ -94,15 +94,15 @@ module Datadog
|
|
94
94
|
|
95
95
|
if encoded.size > max_payload_size
|
96
96
|
# This single event is too large, we can't flush it
|
97
|
-
Datadog.logger.
|
98
|
-
Datadog.logger.
|
97
|
+
Datadog.logger.warn("Dropping test event. Payload too large: '#{span.inspect}'")
|
98
|
+
Datadog.logger.warn(encoded)
|
99
99
|
|
100
100
|
return nil
|
101
101
|
end
|
102
102
|
|
103
103
|
encoded
|
104
104
|
else
|
105
|
-
Datadog.logger.
|
105
|
+
Datadog.logger.warn("Invalid event skipped: #{serializer} Errors: #{serializer.validation_errors}")
|
106
106
|
nil
|
107
107
|
end
|
108
108
|
end
|
data/lib/datadog/ci/version.rb
CHANGED
data/lib/datadog/ci.rb
CHANGED
@@ -5,11 +5,382 @@ require_relative "ci/version"
|
|
5
5
|
require "datadog/core"
|
6
6
|
|
7
7
|
module Datadog
|
8
|
-
#
|
9
|
-
#
|
8
|
+
# Datadog CI visibility public API.
|
9
|
+
#
|
10
|
+
# @public_api
|
10
11
|
module CI
|
11
|
-
class
|
12
|
-
|
12
|
+
class << self
|
13
|
+
# Starts a {Datadog::CI::TestSession ci_test_session} that represents the whole test session run.
|
14
|
+
#
|
15
|
+
# Read Datadog documentation on test sessions
|
16
|
+
# [here](https://docs.datadoghq.com/continuous_integration/explorer/?tab=testruns#sessions).
|
17
|
+
#
|
18
|
+
# Returns the existing test session if one is already active. There is at most a single test session per process.
|
19
|
+
#
|
20
|
+
# The {.start_test_session} method is used to mark the start of the test session:
|
21
|
+
# ```
|
22
|
+
# Datadog::CI.start_test_session(
|
23
|
+
# service: "my-web-site-tests",
|
24
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
25
|
+
# )
|
26
|
+
#
|
27
|
+
# # Somewhere else after test run has ended
|
28
|
+
# Datadog::CI.active_test_session.finish
|
29
|
+
# ```
|
30
|
+
#
|
31
|
+
# Remember that calling {Datadog::CI::TestSession#finish} is mandatory.
|
32
|
+
#
|
33
|
+
# @param [String] service the service name for this session (optional, defaults to DD_SERVICE)
|
34
|
+
# @param [Hash<String,String>] tags extra tags which should be added to the test session.
|
35
|
+
# @return [Datadog::CI::TestSession] returns the active, running {Datadog::CI::TestSession}.
|
36
|
+
# @return [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled or if old Datadog agent is
|
37
|
+
# detected and test suite level visibility cannot be supported.
|
38
|
+
def start_test_session(service: nil, tags: {})
|
39
|
+
service ||= Datadog.configuration.service
|
40
|
+
recorder.start_test_session(service: service, tags: tags)
|
41
|
+
end
|
42
|
+
|
43
|
+
# The active, unfinished test session.
|
44
|
+
#
|
45
|
+
# Usage:
|
46
|
+
#
|
47
|
+
# ```
|
48
|
+
# # start a test session
|
49
|
+
# Datadog::CI.start_test_session(
|
50
|
+
# service: "my-web-site-tests",
|
51
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
52
|
+
# )
|
53
|
+
#
|
54
|
+
# # somewhere else, access the session
|
55
|
+
# test_session = Datadog::CI.active_test_session
|
56
|
+
# test_session.finish
|
57
|
+
# ```
|
58
|
+
#
|
59
|
+
# @return [Datadog::CI::TestSession] the active test session
|
60
|
+
# @return [nil] if no test session is active
|
61
|
+
def active_test_session
|
62
|
+
recorder.active_test_session
|
63
|
+
end
|
64
|
+
|
65
|
+
# Starts a {Datadog::CI::TestModule ci_test_module} that represents a single test module (for most Ruby test frameworks
|
66
|
+
# module will correspond 1-1 to the test session).
|
67
|
+
#
|
68
|
+
# Read Datadog documentation on test modules
|
69
|
+
# [here](https://docs.datadoghq.com/continuous_integration/explorer/?tab=testruns#module).
|
70
|
+
#
|
71
|
+
# Returns the existing test session if one is already active. There is at most a single test module per process
|
72
|
+
# active at any given time.
|
73
|
+
#
|
74
|
+
# The {.start_test_module} method is used to mark the start of the test session:
|
75
|
+
# ```
|
76
|
+
# Datadog::CI.start_test_module(
|
77
|
+
# "my-module",
|
78
|
+
# service: "my-web-site-tests",
|
79
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
80
|
+
# )
|
81
|
+
#
|
82
|
+
# # Somewhere else after the module has ended
|
83
|
+
# Datadog::CI.active_test_module.finish
|
84
|
+
# ```
|
85
|
+
#
|
86
|
+
# Remember that calling {Datadog::CI::TestModule#finish} is mandatory.
|
87
|
+
#
|
88
|
+
# @param [String] test_module_name the name for this module
|
89
|
+
# @param [String] service the service name for this session (optional, inherited from test session if not provided)
|
90
|
+
# @param [Hash<String,String>] tags extra tags which should be added to the test module (optional, some tags are inherited from test session).
|
91
|
+
# @return [Datadog::CI::TestModule] returns the active, running {Datadog::CI::TestModule}.
|
92
|
+
# @return [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled or if old Datadog agent is
|
93
|
+
# detected and test suite level visibility cannot be supported.
|
94
|
+
def start_test_module(test_module_name, service: nil, tags: {})
|
95
|
+
recorder.start_test_module(test_module_name, service: service, tags: tags)
|
96
|
+
end
|
97
|
+
|
98
|
+
# The active, unfinished test module.
|
99
|
+
#
|
100
|
+
# Usage:
|
101
|
+
#
|
102
|
+
# ```
|
103
|
+
# # start a test module
|
104
|
+
# Datadog::CI.start_test_module(
|
105
|
+
# "my-module",
|
106
|
+
# service: "my-web-site-tests",
|
107
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
108
|
+
# )
|
109
|
+
#
|
110
|
+
# # somewhere else, access the current module
|
111
|
+
# test_module = Datadog::CI.active_test_module
|
112
|
+
# test_module.finish
|
113
|
+
# ```
|
114
|
+
#
|
115
|
+
# @return [Datadog::CI::TestModule] the active test module
|
116
|
+
# @return [nil] if no test module is active
|
117
|
+
def active_test_module
|
118
|
+
recorder.active_test_module
|
119
|
+
end
|
120
|
+
|
121
|
+
# Starts a {Datadog::CI::TestSuite ci_test_suite} that represents a single test suite.
|
122
|
+
# If a test suite with given name is running, returns the existing test suite.
|
123
|
+
#
|
124
|
+
# Read Datadog documentation on test suites
|
125
|
+
# [here](https://docs.datadoghq.com/continuous_integration/explorer/?tab=testruns#module).
|
126
|
+
#
|
127
|
+
# The {.start_test_suite} method is used to mark the start of a test suite:
|
128
|
+
# ```
|
129
|
+
# Datadog::CI.start_test_suite(
|
130
|
+
# "calculator_tests",
|
131
|
+
# service: "my-web-site-tests",
|
132
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
133
|
+
# )
|
134
|
+
#
|
135
|
+
# # Somewhere else after the suite has ended
|
136
|
+
# Datadog::CI.active_test_suite("calculator_tests").finish
|
137
|
+
# ```
|
138
|
+
#
|
139
|
+
# Remember that calling {Datadog::CI::TestSuite#finish} is mandatory.
|
140
|
+
#
|
141
|
+
# @param [String] test_suite_name the name of the test suite
|
142
|
+
# @param [String] service the service name for this test suite (optional, inherited from test session if not provided)
|
143
|
+
# @param [Hash<String,String>] tags extra tags which should be added to the test module (optional, some tags are inherited from test session)
|
144
|
+
# @return [Datadog::CI::TestSuite] returns the active, running {Datadog::CI::TestSuite}.
|
145
|
+
# @return [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled or if old Datadog agent is
|
146
|
+
# detected and test suite level visibility cannot be supported.
|
147
|
+
def start_test_suite(test_suite_name, service: nil, tags: {})
|
148
|
+
recorder.start_test_suite(test_suite_name, service: service, tags: tags)
|
149
|
+
end
|
150
|
+
|
151
|
+
# The active, unfinished test suite.
|
152
|
+
#
|
153
|
+
# Usage:
|
154
|
+
#
|
155
|
+
# ```
|
156
|
+
# # start a test suite
|
157
|
+
# Datadog::CI.start_test_suite(
|
158
|
+
# "calculator_tests",
|
159
|
+
# service: "my-web-site-tests",
|
160
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
161
|
+
# )
|
162
|
+
#
|
163
|
+
# # Somewhere else after the suite has ended
|
164
|
+
# test_suite = Datadog::CI.active_test_suite("calculator_tests")
|
165
|
+
# test_suite.finish
|
166
|
+
# ```
|
167
|
+
#
|
168
|
+
# @return [Datadog::CI::TestSuite] the active test suite
|
169
|
+
# @return [nil] if no test suite with given name is active
|
170
|
+
def active_test_suite(test_suite_name)
|
171
|
+
recorder.active_test_suite(test_suite_name)
|
172
|
+
end
|
173
|
+
|
174
|
+
# Return a {Datadog::CI::Test ci_test} that will trace a test called `test_name`.
|
175
|
+
# Raises an error if a test is already active.
|
176
|
+
# If there is an active test session, the new test will be connected to the session.
|
177
|
+
# The test will inherit service name and tags from the running test session if not provided
|
178
|
+
# in parameters.
|
179
|
+
#
|
180
|
+
# You could trace your test using a <tt>do-block</tt> like:
|
181
|
+
#
|
182
|
+
# ```
|
183
|
+
# Datadog::CI.trace_test(
|
184
|
+
# "test_add_two_numbers",
|
185
|
+
# "calculator_tests",
|
186
|
+
# service: "my-web-site-tests",
|
187
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
188
|
+
# ) do |ci_test|
|
189
|
+
# result = run_test
|
190
|
+
#
|
191
|
+
# if result.ok?
|
192
|
+
# ci_test.passed!
|
193
|
+
# else
|
194
|
+
# ci_test.failed!(exception: result.exception)
|
195
|
+
# end
|
196
|
+
# end
|
197
|
+
# ```
|
198
|
+
#
|
199
|
+
# The {.trace_test} method can also be used without a block in this way:
|
200
|
+
# ```
|
201
|
+
# ci_test = Datadog::CI.trace_test(
|
202
|
+
# "test_add_two_numbers",
|
203
|
+
# "calculator_tests",
|
204
|
+
# service: "my-web-site-tests",
|
205
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
206
|
+
# )
|
207
|
+
# # ... run test here ...
|
208
|
+
# ci_test.finish
|
209
|
+
# ```
|
210
|
+
#
|
211
|
+
# Remember that in this case, calling {Datadog::CI::Test#finish} is mandatory.
|
212
|
+
#
|
213
|
+
# @param [String] test_name {Datadog::CI::Test} name (example: "test_add_two_numbers").
|
214
|
+
# @param [String] test_suite_name name of test suite this test belongs to (example: "CalculatorTest").
|
215
|
+
# @param [String] service the service name for this test (optional, inherited from test session if not provided)
|
216
|
+
# @param [Hash<String,String>] tags extra tags which should be added to the test.
|
217
|
+
# @return [Object] If a block is provided, returns the result of the block execution.
|
218
|
+
# @return [Datadog::CI::Test] If no block is provided, returns the active,
|
219
|
+
# unfinished {Datadog::CI::Test}.
|
220
|
+
# @return [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled
|
221
|
+
# @yield Optional block where newly created {Datadog::CI::Test} captures the execution.
|
222
|
+
# @yieldparam [Datadog::CI::Test] ci_test the newly created and active [Datadog::CI::Test]
|
223
|
+
# @yieldparam [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled
|
224
|
+
def trace_test(test_name, test_suite_name, service: nil, tags: {}, &block)
|
225
|
+
recorder.trace_test(test_name, test_suite_name, service: service, tags: tags, &block)
|
226
|
+
end
|
227
|
+
|
228
|
+
# Same as {.trace_test} but it does not accept a block.
|
229
|
+
# Raises an error if a test is already active.
|
230
|
+
#
|
231
|
+
# Usage:
|
232
|
+
#
|
233
|
+
# ```
|
234
|
+
# ci_test = Datadog::CI.start_test(
|
235
|
+
# "test_add_two_numbers",
|
236
|
+
# "calculator_tests",
|
237
|
+
# service: "my-web-site-tests",
|
238
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
239
|
+
# )
|
240
|
+
# # ... run test here ...
|
241
|
+
# ci_test.finish
|
242
|
+
# ```
|
243
|
+
#
|
244
|
+
# @param [String] test_name {Datadog::CI::Test} name (example: "test_add_two_numbers").
|
245
|
+
# @param [String] test_suite_name name of test suite this test belongs to (example: "CalculatorTest").
|
246
|
+
# @param [String] service the service name for this span (optional, inherited from test session if not provided)
|
247
|
+
# @param [Hash<String,String>] tags extra tags which should be added to the test.
|
248
|
+
# @return [Datadog::CI::Test] Returns the active, unfinished {Datadog::CI::Test}.
|
249
|
+
# @return [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled
|
250
|
+
def start_test(test_name, test_suite_name, service: nil, tags: {})
|
251
|
+
recorder.trace_test(test_name, test_suite_name, service: service, tags: tags)
|
252
|
+
end
|
253
|
+
|
254
|
+
# Trace any custom span inside a test. For example, you could trace:
|
255
|
+
# - cucumber step
|
256
|
+
# - database query
|
257
|
+
# - any custom operation you want to see in your trace view
|
258
|
+
#
|
259
|
+
# You can use this method with a <tt>do-block</tt> like:
|
260
|
+
#
|
261
|
+
# ```
|
262
|
+
# Datadog::CI.trace(
|
263
|
+
# "step",
|
264
|
+
# "Given I have 42 cucumbers",
|
265
|
+
# tags: {}
|
266
|
+
# ) do
|
267
|
+
# run_operation
|
268
|
+
# end
|
269
|
+
# ```
|
270
|
+
#
|
271
|
+
# The {.trace} method can also be used without a block in this way:
|
272
|
+
# ```
|
273
|
+
# ci_span = Datadog::CI.trace(
|
274
|
+
# "step",
|
275
|
+
# "Given I have 42 cucumbers",
|
276
|
+
# tags: {}
|
277
|
+
# )
|
278
|
+
# # ... run test here ...
|
279
|
+
# ci_span.finish
|
280
|
+
# ```
|
281
|
+
# Remember that in this case, calling {Datadog::CI::Span#finish} is mandatory.
|
282
|
+
#
|
283
|
+
# @param [String] span_type custom, user-defined span type (for example "step" or "query").
|
284
|
+
# @param [String] span_name the resource this span refers, or `test` if it's missing
|
285
|
+
# @param [Hash<String,String>] tags extra tags which should be added to the span.
|
286
|
+
# @return [Object] If a block is provided, returns the result of the block execution.
|
287
|
+
# @return [Datadog::CI::Span] If no block is provided, returns the active,
|
288
|
+
# unfinished {Datadog::CI::Span}.
|
289
|
+
# @return [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled
|
290
|
+
# @yield Optional block where newly created {Datadog::CI::Span} captures the execution.
|
291
|
+
# @yieldparam [Datadog::CI::Span] ci_span the newly created and active [Datadog::CI::Span]
|
292
|
+
# @yieldparam [Datadog::CI::NullSpan] ci_span null object if CI visibility is disabled
|
293
|
+
def trace(span_type, span_name, tags: {}, &block)
|
294
|
+
recorder.trace(span_type, span_name, tags: tags, &block)
|
295
|
+
end
|
296
|
+
|
297
|
+
# The active, unfinished custom span if it matches given type.
|
298
|
+
# If no span is active, or if the active span is not a custom span with given type, returns nil.
|
299
|
+
#
|
300
|
+
# The active span belongs to an {.active_test}.
|
301
|
+
#
|
302
|
+
# Usage:
|
303
|
+
#
|
304
|
+
# ```
|
305
|
+
# # start span
|
306
|
+
# Datadog::CI.trace(
|
307
|
+
# "step",
|
308
|
+
# "Given I have 42 cucumbers",
|
309
|
+
# tags: {}
|
310
|
+
# )
|
311
|
+
#
|
312
|
+
# # somewhere else, access the active "step" span
|
313
|
+
# step_span = Datadog::CI.active_span("step")
|
314
|
+
# step_span.finish()
|
315
|
+
# ```
|
316
|
+
#
|
317
|
+
# @param [String] span_type type of the span to retrieve (for example "step" or "query") that was provided to {.trace}
|
318
|
+
# @return [Datadog::CI::Span] the active span
|
319
|
+
# @return [nil] if no span is active, or if the active span is not a custom span with given type
|
320
|
+
def active_span(span_type)
|
321
|
+
span = recorder.active_span
|
322
|
+
span if span && span.span_type == span_type
|
323
|
+
end
|
324
|
+
|
325
|
+
# The active, unfinished test span.
|
326
|
+
#
|
327
|
+
# Usage:
|
328
|
+
#
|
329
|
+
# ```
|
330
|
+
# # start a test
|
331
|
+
# Datadog::CI.start_test(
|
332
|
+
# "test_add_two_numbers",
|
333
|
+
# "calculator_tests",
|
334
|
+
# service: "my-web-site-tests",
|
335
|
+
# tags: { Datadog::CI::Ext::Test::TAG_FRAMEWORK => "my-test-framework" }
|
336
|
+
# )
|
337
|
+
#
|
338
|
+
# # somewhere else, access the active test
|
339
|
+
# test_span = Datadog::CI.active_test
|
340
|
+
# test_span.passed!
|
341
|
+
# test_span.finish
|
342
|
+
# ```
|
343
|
+
#
|
344
|
+
# @return [Datadog::CI::Test] the active test
|
345
|
+
# @return [nil] if no test is active
|
346
|
+
def active_test
|
347
|
+
recorder.active_test
|
348
|
+
end
|
349
|
+
|
350
|
+
# Internal only, to finish a test use {Datadog::CI::Test#finish}
|
351
|
+
# @private
|
352
|
+
def deactivate_test(test)
|
353
|
+
recorder.deactivate_test(test)
|
354
|
+
end
|
355
|
+
|
356
|
+
# Internal only, to finish a test session use {Datadog::CI::TestSession#finish}
|
357
|
+
# @private
|
358
|
+
def deactivate_test_session
|
359
|
+
recorder.deactivate_test_session
|
360
|
+
end
|
361
|
+
|
362
|
+
# Internal only, to finish a test module use {Datadog::CI::TestModule#finish}
|
363
|
+
# @private
|
364
|
+
def deactivate_test_module
|
365
|
+
recorder.deactivate_test_module
|
366
|
+
end
|
367
|
+
|
368
|
+
# Internal only, to finish a test suite use {Datadog::CI::TestSuite#finish}
|
369
|
+
# @private
|
370
|
+
def deactivate_test_suite(test_suite_name)
|
371
|
+
recorder.deactivate_test_suite(test_suite_name)
|
372
|
+
end
|
373
|
+
|
374
|
+
private
|
375
|
+
|
376
|
+
def components
|
377
|
+
Datadog.send(:components)
|
378
|
+
end
|
379
|
+
|
380
|
+
def recorder
|
381
|
+
components.ci_recorder
|
382
|
+
end
|
383
|
+
end
|
13
384
|
end
|
14
385
|
end
|
15
386
|
|
@@ -18,6 +389,6 @@ require_relative "ci/contrib/cucumber/integration"
|
|
18
389
|
require_relative "ci/contrib/rspec/integration"
|
19
390
|
require_relative "ci/contrib/minitest/integration"
|
20
391
|
|
21
|
-
#
|
22
|
-
require_relative "ci/extensions"
|
23
|
-
Datadog::CI::Extensions.activate!
|
392
|
+
# Configuration extensions
|
393
|
+
require_relative "ci/configuration/extensions"
|
394
|
+
Datadog::CI::Configuration::Extensions.activate!
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module Datadog
|
2
|
+
module CI
|
3
|
+
class ConcurrentSpan < Span
|
4
|
+
@mutex: Thread::Mutex
|
5
|
+
|
6
|
+
def initialize: (Datadog::Tracing::SpanOperation tracer_span) -> void
|
7
|
+
def passed!: () -> void
|
8
|
+
def failed!: (?exception: untyped?) -> void
|
9
|
+
def skipped!: (?exception: untyped?, ?reason: String?) -> void
|
10
|
+
def get_tag: (String key) -> untyped?
|
11
|
+
def set_tag: (String key, untyped? value) -> void
|
12
|
+
def set_metric: (String key, untyped value) -> void
|
13
|
+
def finish: () -> void
|
14
|
+
def set_tags: (Hash[untyped, untyped] tags) -> void
|
15
|
+
|
16
|
+
def set_environment_runtime_tags: () -> void
|
17
|
+
|
18
|
+
def set_default_tags: () -> void
|
19
|
+
|
20
|
+
def synchronize: () { () -> untyped } -> untyped
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -2,6 +2,10 @@ module Datadog
|
|
2
2
|
module CI
|
3
3
|
module Configuration
|
4
4
|
module Components : Datadog::Core::Configuration::Components
|
5
|
+
@ci_recorder: Datadog::CI::TestVisibility::Recorder
|
6
|
+
|
7
|
+
attr_reader ci_recorder: Datadog::CI::TestVisibility::Recorder
|
8
|
+
|
5
9
|
def initialize: (untyped settings) -> void
|
6
10
|
|
7
11
|
def activate_ci!: (untyped settings) -> untyped
|
@@ -9,6 +13,8 @@ module Datadog
|
|
9
13
|
def build_agentless_transport: (untyped settings) -> Datadog::CI::TestVisibility::Transport?
|
10
14
|
def build_evp_proxy_transport: (untyped settings, untyped agent_settings) -> Datadog::CI::TestVisibility::Transport
|
11
15
|
def can_use_evp_proxy?: (untyped settings, untyped agent_settings) -> bool
|
16
|
+
def serializers_factory: (untyped settings) -> (singleton(Datadog::CI::TestVisibility::Serializers::Factories::TestSuiteLevel) | singleton(Datadog::CI::TestVisibility::Serializers::Factories::TestLevel))
|
17
|
+
def check_dd_site: (untyped settings) -> void
|
12
18
|
end
|
13
19
|
end
|
14
20
|
end
|