mirror of
https://github.com/jstemmer/go-junit-report.git
synced 2025-04-05 05:00:15 -05:00

Having multiple benchmarks for a single name is something specific to the gotest output, so grouping benchmarks by name is not something that belongs in the junit package.
119 lines
2.4 KiB
Go
119 lines
2.4 KiB
Go
package junit
|
|
|
|
import (
|
|
"encoding/xml"
|
|
"testing"
|
|
|
|
"github.com/jstemmer/go-junit-report/v2/gtr"
|
|
|
|
"github.com/google/go-cmp/cmp"
|
|
)
|
|
|
|
func TestCreateFromReport(t *testing.T) {
|
|
// TODO: complete this report
|
|
report := gtr.Report{
|
|
Packages: []gtr.Package{
|
|
{
|
|
Benchmarks: []gtr.Benchmark{
|
|
{
|
|
Name: "BenchmarkFail",
|
|
Result: gtr.Fail,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
want := Testsuites{
|
|
Tests: 1,
|
|
Failures: 1,
|
|
Suites: []Testsuite{
|
|
{
|
|
Tests: 1,
|
|
Failures: 1,
|
|
Time: "0.000",
|
|
ID: 0,
|
|
Testcases: []Testcase{
|
|
{
|
|
Name: "BenchmarkFail",
|
|
Time: "0.000000000",
|
|
Failure: &Result{Message: "Failed"},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
got := CreateFromReport(report, "")
|
|
if diff := cmp.Diff(want, got); diff != "" {
|
|
t.Errorf("CreateFromReport incorrect, diff (-want, +got):\n%s\n", diff)
|
|
}
|
|
}
|
|
|
|
func TestMarshalUnmarshal(t *testing.T) {
|
|
want := Testsuites{
|
|
Name: "name",
|
|
Time: "12.345",
|
|
Tests: 1,
|
|
Errors: 1,
|
|
Failures: 1,
|
|
Disabled: 1,
|
|
Suites: []Testsuite{
|
|
{
|
|
Name: "suite1",
|
|
Tests: 1,
|
|
Errors: 1,
|
|
Failures: 1,
|
|
Hostname: "localhost",
|
|
ID: 0,
|
|
Package: "package",
|
|
Skipped: 1,
|
|
Time: "12.345",
|
|
Timestamp: "2012-03-09T14:38:06+01:00",
|
|
Properties: properties("key", "value"),
|
|
Testcases: []Testcase{
|
|
{
|
|
Name: "test1",
|
|
Classname: "class",
|
|
Time: "12.345",
|
|
Status: "status",
|
|
Skipped: &Result{Message: "skipped", Type: "type", Data: "data"},
|
|
Error: &Result{Message: "error", Type: "type", Data: "data"},
|
|
Failure: &Result{Message: "failure", Type: "type", Data: "data"},
|
|
SystemOut: &Output{"system-out"},
|
|
SystemErr: &Output{"system-err"},
|
|
},
|
|
},
|
|
SystemOut: &Output{"system-out"},
|
|
SystemErr: &Output{"system-err"},
|
|
},
|
|
},
|
|
}
|
|
|
|
data, err := xml.MarshalIndent(want, "", "\t")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
var got Testsuites
|
|
if err := xml.Unmarshal(data, &got); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
want.XMLName.Local = "testsuites"
|
|
if diff := cmp.Diff(want, got); diff != "" {
|
|
t.Errorf("Unmarshal result incorrect, diff (-want +got):\n%s\n", diff)
|
|
}
|
|
}
|
|
|
|
func properties(keyvals ...string) *[]Property {
|
|
if len(keyvals)%2 != 0 {
|
|
panic("invalid keyvals specified")
|
|
}
|
|
var props []Property
|
|
for i := 0; i < len(keyvals); i += 2 {
|
|
props = append(props, Property{keyvals[i], keyvals[i+1]})
|
|
}
|
|
return &props
|
|
}
|