mirror of
https://github.com/jstemmer/go-junit-report.git
synced 2025-04-05 13:08:07 -05:00
Parse package name output when test binary name is included
Sometimes, the text after "# " shows the name of the test binary ("<package>.test") in addition to the package e.g.: "# package/name [package/name.test]". This change ensures that the packages' build outputs are associated correctly in this case.
This commit is contained in:
parent
af01ea7f80
commit
6315b3013b
@ -1425,6 +1425,87 @@ var testCases = []TestCase{
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "31-syntax-error-test-binary.txt",
|
||||
reportName: "31-report.xml",
|
||||
report: &parser.Report{
|
||||
Packages: []parser.Package{
|
||||
{
|
||||
Name: "package/name/passing1",
|
||||
Duration: 100 * time.Millisecond,
|
||||
Time: 100,
|
||||
Tests: []*parser.Test{
|
||||
{
|
||||
Name: "TestA",
|
||||
Duration: 100 * time.Millisecond,
|
||||
Time: 100,
|
||||
Result: parser.PASS,
|
||||
Output: []string{},
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Name: "package/name/passing2",
|
||||
Duration: 100 * time.Millisecond,
|
||||
Time: 100,
|
||||
Tests: []*parser.Test{
|
||||
{
|
||||
Name: "TestB",
|
||||
Duration: 100 * time.Millisecond,
|
||||
Time: 100,
|
||||
Result: parser.PASS,
|
||||
Output: []string{},
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Name: "package/name/failing1",
|
||||
Tests: []*parser.Test{
|
||||
{
|
||||
Name: "[build failed]",
|
||||
Duration: 0,
|
||||
Time: 0,
|
||||
Result: parser.FAIL,
|
||||
Output: []string{
|
||||
"failing1/failing_test.go:15: undefined: x",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Name: "package/name/failing2",
|
||||
Tests: []*parser.Test{
|
||||
{
|
||||
Name: "[build failed]",
|
||||
Duration: 0,
|
||||
Time: 0,
|
||||
Result: parser.FAIL,
|
||||
Output: []string{
|
||||
"failing2/another_failing_test.go:20: undefined: y",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Name: "package/name/setupfailing1",
|
||||
Tests: []*parser.Test{
|
||||
{
|
||||
Name: "[setup failed]",
|
||||
Duration: 0,
|
||||
Time: 0,
|
||||
Result: parser.FAIL,
|
||||
Output: []string{
|
||||
"setupfailing1/failing_test.go:4: cannot find package \"other/package\" in any of:",
|
||||
"\t/path/vendor (vendor tree)",
|
||||
"\t/path/go/root (from $GOROOT)",
|
||||
"\t/path/go/path (from $GOPATH)",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
func TestParser(t *testing.T) {
|
||||
|
@ -65,9 +65,10 @@ var (
|
||||
regexCoverage = regexp.MustCompile(`^coverage:\s+(\d+\.\d+)%\s+of\s+statements(?:\sin\s.+)?$`)
|
||||
regexResult = regexp.MustCompile(`^(ok|FAIL)\s+([^ ]+)\s+(?:(\d+\.\d+)s|\(cached\)|(\[\w+ failed]))(?:\s+coverage:\s+(\d+\.\d+)%\sof\sstatements(?:\sin\s.+)?)?$`)
|
||||
// regexBenchmark captures 3-5 groups: benchmark name, number of times ran, ns/op (with or without decimal), B/op (optional), and allocs/op (optional).
|
||||
regexBenchmark = regexp.MustCompile(`^(Benchmark[^ -]+)(?:-\d+\s+|\s+)(\d+)\s+(\d+|\d+\.\d+)\sns/op(?:\s+(\d+)\sB/op)?(?:\s+(\d+)\sallocs/op)?`)
|
||||
regexOutput = regexp.MustCompile(`( )*\t(.*)`)
|
||||
regexSummary = regexp.MustCompile(`^(PASS|FAIL|SKIP)$`)
|
||||
regexBenchmark = regexp.MustCompile(`^(Benchmark[^ -]+)(?:-\d+\s+|\s+)(\d+)\s+(\d+|\d+\.\d+)\sns/op(?:\s+(\d+)\sB/op)?(?:\s+(\d+)\sallocs/op)?`)
|
||||
regexOutput = regexp.MustCompile(`( )*\t(.*)`)
|
||||
regexSummary = regexp.MustCompile(`^(PASS|FAIL|SKIP)$`)
|
||||
regexPackageWithTest = regexp.MustCompile(`^# ([^\[\]]+) \[[^\]]+\]$`)
|
||||
)
|
||||
|
||||
// Parse parses go test output from reader r and returns a report with the
|
||||
@ -223,7 +224,15 @@ func Parse(r io.Reader, pkgName string) (*Report, error) {
|
||||
test.Output = append(test.Output, matches[2])
|
||||
} else if strings.HasPrefix(line, "# ") {
|
||||
// indicates a capture of build output of a package. set the current build package.
|
||||
capturedPackage = line[2:]
|
||||
packageWithTestBinary := regexPackageWithTest.FindStringSubmatch(line)
|
||||
if packageWithTestBinary != nil {
|
||||
// Sometimes, the text after "# " shows the name of the test binary
|
||||
// ("<package>.test") in addition to the package
|
||||
// e.g.: "# package/name [package/name.test]"
|
||||
capturedPackage = packageWithTestBinary[1]
|
||||
} else {
|
||||
capturedPackage = line[2:]
|
||||
}
|
||||
} else if capturedPackage != "" {
|
||||
// current line is build failure capture for the current built package
|
||||
packageCaptures[capturedPackage] = append(packageCaptures[capturedPackage], line)
|
||||
|
39
testdata/31-report.xml
vendored
Normal file
39
testdata/31-report.xml
vendored
Normal file
@ -0,0 +1,39 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<testsuites>
|
||||
<testsuite tests="1" failures="0" time="0.100" name="package/name/passing1">
|
||||
<properties>
|
||||
<property name="go.version" value="1.0"></property>
|
||||
</properties>
|
||||
<testcase classname="passing1" name="TestA" time="0.100"></testcase>
|
||||
</testsuite>
|
||||
<testsuite tests="1" failures="0" time="0.100" name="package/name/passing2">
|
||||
<properties>
|
||||
<property name="go.version" value="1.0"></property>
|
||||
</properties>
|
||||
<testcase classname="passing2" name="TestB" time="0.100"></testcase>
|
||||
</testsuite>
|
||||
<testsuite tests="1" failures="1" time="0.000" name="package/name/failing1">
|
||||
<properties>
|
||||
<property name="go.version" value="1.0"></property>
|
||||
</properties>
|
||||
<testcase classname="failing1" name="[build failed]" time="0.000">
|
||||
<failure message="Failed" type="">failing1/failing_test.go:15: undefined: x</failure>
|
||||
</testcase>
|
||||
</testsuite>
|
||||
<testsuite tests="1" failures="1" time="0.000" name="package/name/failing2">
|
||||
<properties>
|
||||
<property name="go.version" value="1.0"></property>
|
||||
</properties>
|
||||
<testcase classname="failing2" name="[build failed]" time="0.000">
|
||||
<failure message="Failed" type="">failing2/another_failing_test.go:20: undefined: y</failure>
|
||||
</testcase>
|
||||
</testsuite>
|
||||
<testsuite tests="1" failures="1" time="0.000" name="package/name/setupfailing1">
|
||||
<properties>
|
||||
<property name="go.version" value="1.0"></property>
|
||||
</properties>
|
||||
<testcase classname="setupfailing1" name="[setup failed]" time="0.000">
|
||||
<failure message="Failed" type="">setupfailing1/failing_test.go:4: cannot find package "other/package" in any of:
	/path/vendor (vendor tree)
	/path/go/root (from $GOROOT)
	/path/go/path (from $GOPATH)</failure>
|
||||
</testcase>
|
||||
</testsuite>
|
||||
</testsuites>
|
20
testdata/31-syntax-error-test-binary.txt
vendored
Normal file
20
testdata/31-syntax-error-test-binary.txt
vendored
Normal file
@ -0,0 +1,20 @@
|
||||
# package/name/failing1 [package/name/failing1.test]
|
||||
failing1/failing_test.go:15: undefined: x
|
||||
# package/name/failing2 [package/name/failing2.test]
|
||||
failing2/another_failing_test.go:20: undefined: y
|
||||
# package/name/setupfailing1 [package/name/setupfailing1.test]
|
||||
setupfailing1/failing_test.go:4: cannot find package "other/package" in any of:
|
||||
/path/vendor (vendor tree)
|
||||
/path/go/root (from $GOROOT)
|
||||
/path/go/path (from $GOPATH)
|
||||
=== RUN TestA
|
||||
--- PASS: TestA (0.10 seconds)
|
||||
PASS
|
||||
ok package/name/passing1 0.100s
|
||||
=== RUN TestB
|
||||
--- PASS: TestB (0.10 seconds)
|
||||
PASS
|
||||
ok package/name/passing2 0.100s
|
||||
FAIL package/name/failing1 [build failed]
|
||||
FAIL package/name/failing2 [build failed]
|
||||
FAIL package/name/setupfailing1 [setup failed]
|
Loading…
x
Reference in New Issue
Block a user