Skip to content

Commit 3a67b4c

Browse files
api-clients-generation-pipeline[bot]ci.datadog-api-spec
andauthored
Update SearchFlakyTests endpoint documentation (#3929)
Co-authored-by: ci.datadog-api-spec <packages@datadoghq.com>
1 parent 69b5527 commit 3a67b4c

11 files changed

Lines changed: 1150 additions & 70 deletions

.generator/schemas/v2/openapi.yaml

Lines changed: 147 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -26664,9 +26664,18 @@ components:
2666426664
Includes state transitions like new -> quarantined -> fixed, along with the associated commit SHA when available.
2666526665
example:
2666626666
- commit_sha: abc123def456
26667+
policy_id: ftm_policy.quarantine.failure_rate
26668+
policy_meta:
26669+
config:
26670+
failure_rate: 0.1
26671+
required_runs: 100
26672+
failure_rate: 0.25
26673+
total_runs: 200
2666726674
status: quarantined
2666826675
timestamp: 1704067200000
2666926676
- commit_sha: ""
26677+
policy_id: unknown
26678+
policy_meta:
2667026679
status: new
2667126680
timestamp: 1703980800000
2667226681
items:
@@ -26736,6 +26745,11 @@ components:
2673626745
description: The commit SHA associated with this status change. Will be an empty string if the commit SHA is not available.
2673726746
example: abc123def456
2673826747
type: string
26748+
policy_id:
26749+
$ref: "#/components/schemas/FlakyTestHistoryPolicyId"
26750+
policy_meta:
26751+
$ref: "#/components/schemas/FlakyTestHistoryPolicyMeta"
26752+
nullable: true
2673926753
status:
2674026754
description: The test status at this point in history.
2674126755
example: quarantined
@@ -26750,6 +26764,131 @@ components:
2675026764
- commit_sha
2675126765
- timestamp
2675226766
type: object
26767+
FlakyTestHistoryPolicyId:
26768+
description: The policy that triggered this status change.
26769+
enum:
26770+
- ftm_policy.manual
26771+
- ftm_policy.fixed
26772+
- ftm_policy.disable.failure_rate
26773+
- ftm_policy.disable.branch_flake
26774+
- ftm_policy.disable.days_active
26775+
- ftm_policy.quarantine.failure_rate
26776+
- ftm_policy.quarantine.branch_flake
26777+
- ftm_policy.quarantine.days_active
26778+
- unknown
26779+
example: ftm_policy.quarantine.failure_rate
26780+
nullable: false
26781+
type: string
26782+
x-enum-varnames:
26783+
- MANUAL
26784+
- FIXED
26785+
- DISABLE_FAILURE_RATE
26786+
- DISABLE_BRANCH_FLAKE
26787+
- DISABLE_DAYS_ACTIVE
26788+
- QUARANTINE_FAILURE_RATE
26789+
- QUARANTINE_BRANCH_FLAKE
26790+
- QUARANTINE_DAYS_ACTIVE
26791+
- UNKNOWN
26792+
FlakyTestHistoryPolicyMeta:
26793+
description: Metadata about the policy that triggered this status change.
26794+
properties:
26795+
branches:
26796+
description: Branches where the test was flaky at the time of the status change.
26797+
example: ["main", "develop"]
26798+
items:
26799+
type: string
26800+
nullable: true
26801+
type: array
26802+
config:
26803+
$ref: "#/components/schemas/FlakyTestHistoryPolicyMetaConfig"
26804+
nullable: true
26805+
days_active:
26806+
description: The number of days the test has been active at the time of the status change.
26807+
example: 15
26808+
format: int32
26809+
maximum: 2147483647
26810+
nullable: true
26811+
type: integer
26812+
days_without_flake:
26813+
description: The number of days since the test last exhibited flakiness.
26814+
example: 30
26815+
format: int32
26816+
maximum: 2147483647
26817+
nullable: true
26818+
type: integer
26819+
failure_rate:
26820+
description: The failure rate of the test at the time of the status change.
26821+
example: 0.25
26822+
format: double
26823+
maximum: 1
26824+
minimum: 0
26825+
nullable: true
26826+
type: number
26827+
state:
26828+
description: The previous state of the test.
26829+
example: quarantined
26830+
nullable: true
26831+
type: string
26832+
total_runs:
26833+
description: The total number of test runs at the time of the status change.
26834+
example: 200
26835+
format: int32
26836+
maximum: 2147483647
26837+
nullable: true
26838+
type: integer
26839+
type: object
26840+
FlakyTestHistoryPolicyMetaConfig:
26841+
description: Configuration parameters of the policy that triggered this status change.
26842+
properties:
26843+
branches:
26844+
description: The branches considered by the policy.
26845+
example: ["main"]
26846+
items:
26847+
type: string
26848+
nullable: true
26849+
type: array
26850+
days_active:
26851+
description: The number of days a test must have been active for the policy to trigger.
26852+
example: 30
26853+
format: int32
26854+
maximum: 2147483647
26855+
nullable: true
26856+
type: integer
26857+
failure_rate:
26858+
description: The failure rate threshold for the policy to trigger.
26859+
example: 0.7
26860+
format: double
26861+
maximum: 1
26862+
minimum: 0
26863+
nullable: true
26864+
type: number
26865+
forget_branches:
26866+
description: Branches excluded from the policy evaluation.
26867+
example: ["release"]
26868+
items:
26869+
type: string
26870+
nullable: true
26871+
type: array
26872+
required_runs:
26873+
description: The minimum number of test runs required for the policy to trigger.
26874+
example: 100
26875+
format: int32
26876+
maximum: 2147483647
26877+
nullable: true
26878+
type: integer
26879+
state:
26880+
description: The target state the policy transitions the test from.
26881+
example: quarantined
26882+
nullable: true
26883+
type: string
26884+
test_services:
26885+
description: Test services excluded from the policy evaluation.
26886+
example: ["my-service"]
26887+
items:
26888+
type: string
26889+
nullable: true
26890+
type: array
26891+
type: object
2675326892
FlakyTestPipelineStats:
2675426893
description: CI pipeline related statistics for the flaky test. This information is only available if test runs are associated with CI pipeline events from CI Visibility.
2675526894
properties:
@@ -26829,6 +26968,14 @@ components:
2682926968
FlakyTestsSearchFilter:
2683026969
description: Search filter settings.
2683126970
properties:
26971+
include_history:
26972+
default: false
26973+
description: |-
26974+
Whether to include the status change history for each flaky test in the response.
26975+
When set to true, each test will include a `history` array with chronological status changes.
26976+
Defaults to false.
26977+
example: true
26978+
type: boolean
2683226979
query:
2683326980
default: "*"
2683426981
description: |-
@@ -26874,14 +27021,6 @@ components:
2687427021
properties:
2687527022
filter:
2687627023
$ref: "#/components/schemas/FlakyTestsSearchFilter"
26877-
include_history:
26878-
default: false
26879-
description: |-
26880-
Whether to include the status change history for each flaky test in the response.
26881-
When set to true, each test will include a `history` array with chronological status changes.
26882-
Defaults to false.
26883-
example: true
26884-
type: boolean
2688527024
page:
2688627025
$ref: "#/components/schemas/FlakyTestsSearchPageOptions"
2688727026
sort:

api/datadogV2/model_flaky_test_history.go

Lines changed: 87 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,10 @@ import (
1414
type FlakyTestHistory struct {
1515
// The commit SHA associated with this status change. Will be an empty string if the commit SHA is not available.
1616
CommitSha string `json:"commit_sha"`
17+
// The policy that triggered this status change.
18+
PolicyId *FlakyTestHistoryPolicyId `json:"policy_id,omitempty"`
19+
// Metadata about the policy that triggered this status change.
20+
PolicyMeta *FlakyTestHistoryPolicyMeta `json:"policy_meta,omitempty"`
1721
// The test status at this point in history.
1822
Status string `json:"status"`
1923
// Unix timestamp in milliseconds when this status change occurred.
@@ -66,6 +70,62 @@ func (o *FlakyTestHistory) SetCommitSha(v string) {
6670
o.CommitSha = v
6771
}
6872

73+
// GetPolicyId returns the PolicyId field value if set, zero value otherwise.
74+
func (o *FlakyTestHistory) GetPolicyId() FlakyTestHistoryPolicyId {
75+
if o == nil || o.PolicyId == nil {
76+
var ret FlakyTestHistoryPolicyId
77+
return ret
78+
}
79+
return *o.PolicyId
80+
}
81+
82+
// GetPolicyIdOk returns a tuple with the PolicyId field value if set, nil otherwise
83+
// and a boolean to check if the value has been set.
84+
func (o *FlakyTestHistory) GetPolicyIdOk() (*FlakyTestHistoryPolicyId, bool) {
85+
if o == nil || o.PolicyId == nil {
86+
return nil, false
87+
}
88+
return o.PolicyId, true
89+
}
90+
91+
// HasPolicyId returns a boolean if a field has been set.
92+
func (o *FlakyTestHistory) HasPolicyId() bool {
93+
return o != nil && o.PolicyId != nil
94+
}
95+
96+
// SetPolicyId gets a reference to the given FlakyTestHistoryPolicyId and assigns it to the PolicyId field.
97+
func (o *FlakyTestHistory) SetPolicyId(v FlakyTestHistoryPolicyId) {
98+
o.PolicyId = &v
99+
}
100+
101+
// GetPolicyMeta returns the PolicyMeta field value if set, zero value otherwise.
102+
func (o *FlakyTestHistory) GetPolicyMeta() FlakyTestHistoryPolicyMeta {
103+
if o == nil || o.PolicyMeta == nil {
104+
var ret FlakyTestHistoryPolicyMeta
105+
return ret
106+
}
107+
return *o.PolicyMeta
108+
}
109+
110+
// GetPolicyMetaOk returns a tuple with the PolicyMeta field value if set, nil otherwise
111+
// and a boolean to check if the value has been set.
112+
func (o *FlakyTestHistory) GetPolicyMetaOk() (*FlakyTestHistoryPolicyMeta, bool) {
113+
if o == nil || o.PolicyMeta == nil {
114+
return nil, false
115+
}
116+
return o.PolicyMeta, true
117+
}
118+
119+
// HasPolicyMeta returns a boolean if a field has been set.
120+
func (o *FlakyTestHistory) HasPolicyMeta() bool {
121+
return o != nil && o.PolicyMeta != nil
122+
}
123+
124+
// SetPolicyMeta gets a reference to the given FlakyTestHistoryPolicyMeta and assigns it to the PolicyMeta field.
125+
func (o *FlakyTestHistory) SetPolicyMeta(v FlakyTestHistoryPolicyMeta) {
126+
o.PolicyMeta = &v
127+
}
128+
69129
// GetStatus returns the Status field value.
70130
func (o *FlakyTestHistory) GetStatus() string {
71131
if o == nil {
@@ -119,6 +179,12 @@ func (o FlakyTestHistory) MarshalJSON() ([]byte, error) {
119179
return datadog.Marshal(o.UnparsedObject)
120180
}
121181
toSerialize["commit_sha"] = o.CommitSha
182+
if o.PolicyId != nil {
183+
toSerialize["policy_id"] = o.PolicyId
184+
}
185+
if o.PolicyMeta != nil {
186+
toSerialize["policy_meta"] = o.PolicyMeta
187+
}
122188
toSerialize["status"] = o.Status
123189
toSerialize["timestamp"] = o.Timestamp
124190

@@ -131,9 +197,11 @@ func (o FlakyTestHistory) MarshalJSON() ([]byte, error) {
131197
// UnmarshalJSON deserializes the given payload.
132198
func (o *FlakyTestHistory) UnmarshalJSON(bytes []byte) (err error) {
133199
all := struct {
134-
CommitSha *string `json:"commit_sha"`
135-
Status *string `json:"status"`
136-
Timestamp *int64 `json:"timestamp"`
200+
CommitSha *string `json:"commit_sha"`
201+
PolicyId *FlakyTestHistoryPolicyId `json:"policy_id,omitempty"`
202+
PolicyMeta *FlakyTestHistoryPolicyMeta `json:"policy_meta,omitempty"`
203+
Status *string `json:"status"`
204+
Timestamp *int64 `json:"timestamp"`
137205
}{}
138206
if err = datadog.Unmarshal(bytes, &all); err != nil {
139207
return datadog.Unmarshal(bytes, &o.UnparsedObject)
@@ -149,17 +217,32 @@ func (o *FlakyTestHistory) UnmarshalJSON(bytes []byte) (err error) {
149217
}
150218
additionalProperties := make(map[string]interface{})
151219
if err = datadog.Unmarshal(bytes, &additionalProperties); err == nil {
152-
datadog.DeleteKeys(additionalProperties, &[]string{"commit_sha", "status", "timestamp"})
220+
datadog.DeleteKeys(additionalProperties, &[]string{"commit_sha", "policy_id", "policy_meta", "status", "timestamp"})
153221
} else {
154222
return err
155223
}
224+
225+
hasInvalidField := false
156226
o.CommitSha = *all.CommitSha
227+
if all.PolicyId != nil && !all.PolicyId.IsValid() {
228+
hasInvalidField = true
229+
} else {
230+
o.PolicyId = all.PolicyId
231+
}
232+
if all.PolicyMeta != nil && all.PolicyMeta.UnparsedObject != nil && o.UnparsedObject == nil {
233+
hasInvalidField = true
234+
}
235+
o.PolicyMeta = all.PolicyMeta
157236
o.Status = *all.Status
158237
o.Timestamp = *all.Timestamp
159238

160239
if len(additionalProperties) > 0 {
161240
o.AdditionalProperties = additionalProperties
162241
}
163242

243+
if hasInvalidField {
244+
return datadog.Unmarshal(bytes, &o.UnparsedObject)
245+
}
246+
164247
return nil
165248
}

0 commit comments

Comments
 (0)