Merge pull request #8440 from mishamo/master

Add optional name property to testgroup for better test failure output
This commit is contained in:
Julien Pivotto 2021-02-09 21:23:24 +01:00 committed by GitHub
commit e29b47b39e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 22 additions and 4 deletions

View file

@ -1,6 +1,7 @@
tests: tests:
# Simple failing test. # Simple failing test.
- interval: 1m - interval: 1m
name: "Failing test"
input_series: input_series:
- series: test - series: test
values: '0' values: '0'

View file

@ -146,6 +146,7 @@ type testGroup struct {
AlertRuleTests []alertTestCase `yaml:"alert_rule_test,omitempty"` AlertRuleTests []alertTestCase `yaml:"alert_rule_test,omitempty"`
PromqlExprTests []promqlTestCase `yaml:"promql_expr_test,omitempty"` PromqlExprTests []promqlTestCase `yaml:"promql_expr_test,omitempty"`
ExternalLabels labels.Labels `yaml:"external_labels,omitempty"` ExternalLabels labels.Labels `yaml:"external_labels,omitempty"`
TestGroupName string `yaml:"name,omitempty"`
} }
// test performs the unit tests. // test performs the unit tests.
@ -299,16 +300,29 @@ func (tg *testGroup) test(evalInterval time.Duration, groupOrderMap map[string]i
}) })
} }
var sb strings.Builder
if gotAlerts.Len() != expAlerts.Len() { if gotAlerts.Len() != expAlerts.Len() {
errs = append(errs, errors.Errorf(" alertname:%s, time:%s, \n exp:%#v, \n got:%#v", if tg.TestGroupName != "" {
testcase.Alertname, testcase.EvalTime.String(), expAlerts.String(), gotAlerts.String())) fmt.Fprintf(&sb, " name: %s,\n", tg.TestGroupName)
}
fmt.Fprintf(&sb, " alertname:%s, time:%s, \n", testcase.Alertname, testcase.EvalTime.String())
fmt.Fprintf(&sb, " exp:%#v, \n", expAlerts.String())
fmt.Fprintf(&sb, " got:%#v", gotAlerts.String())
errs = append(errs, errors.New(sb.String()))
} else { } else {
sort.Sort(gotAlerts) sort.Sort(gotAlerts)
sort.Sort(expAlerts) sort.Sort(expAlerts)
if !reflect.DeepEqual(expAlerts, gotAlerts) { if !reflect.DeepEqual(expAlerts, gotAlerts) {
errs = append(errs, errors.Errorf(" alertname:%s, time:%s, \n exp:%#v, \n got:%#v", if tg.TestGroupName != "" {
testcase.Alertname, testcase.EvalTime.String(), expAlerts.String(), gotAlerts.String())) fmt.Fprintf(&sb, " name: %s,\n", tg.TestGroupName)
}
fmt.Fprintf(&sb, " alertname:%s, time:%s, \n", testcase.Alertname, testcase.EvalTime.String())
fmt.Fprintf(&sb, " exp:%#v, \n", expAlerts.String())
fmt.Fprintf(&sb, " got:%#v", gotAlerts.String())
errs = append(errs, errors.New(sb.String()))
} }
} }
} }

View file

@ -44,6 +44,9 @@ interval: <duration>
input_series: input_series:
[ - <series> ] [ - <series> ]
# Name of the test group
[ name: <string> ]
# Unit tests for the above data. # Unit tests for the above data.
# Unit tests for alerting rules. We consider the alerting rules from the input file. # Unit tests for alerting rules. We consider the alerting rules from the input file.