mirror of
https://github.com/jstemmer/go-junit-report.git
synced 2025-04-05 21:18:08 -05:00
compiled test's output have no result line, fill "package name" with flag -package-name , and fill "time" with sum of individual tests' time.
This commit is contained in:
parent
18ee6df2f2
commit
27383b3a74
@ -7,16 +7,18 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var noXmlHeader bool
|
var noXmlHeader bool
|
||||||
|
var packageName string
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
flag.BoolVar(&noXmlHeader, "no-xml-header", false, "do not print xml header")
|
flag.BoolVar(&noXmlHeader, "no-xml-header", false, "do not print xml header")
|
||||||
|
flag.StringVar(&packageName, "package-name", "", "specify a package name (compiled test have no package name in output)")
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
// Read input
|
// Read input
|
||||||
report, err := Parse(os.Stdin)
|
report, err := Parse(os.Stdin, packageName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("Error reading input: %s\n", err)
|
fmt.Printf("Error reading input: %s\n", err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
|
22
parser.go
22
parser.go
@ -38,7 +38,7 @@ var (
|
|||||||
regexResult = regexp.MustCompile(`^(ok|FAIL)\s+(.+)\s(\d+\.\d+)s$`)
|
regexResult = regexp.MustCompile(`^(ok|FAIL)\s+(.+)\s(\d+\.\d+)s$`)
|
||||||
)
|
)
|
||||||
|
|
||||||
func Parse(r io.Reader) (*Report, error) {
|
func Parse(r io.Reader, specifiedPackageName string) (*Report, error) {
|
||||||
reader := bufio.NewReader(r)
|
reader := bufio.NewReader(r)
|
||||||
|
|
||||||
report := &Report{make([]Package, 0)}
|
report := &Report{make([]Package, 0)}
|
||||||
@ -46,6 +46,9 @@ func Parse(r io.Reader) (*Report, error) {
|
|||||||
// keep track of tests we find
|
// keep track of tests we find
|
||||||
tests := make([]Test, 0)
|
tests := make([]Test, 0)
|
||||||
|
|
||||||
|
// sum of tests' time, use this if current test has no result line (when it is compiled test)
|
||||||
|
testsTime := 0
|
||||||
|
|
||||||
// current test
|
// current test
|
||||||
var test *Test
|
var test *Test
|
||||||
|
|
||||||
@ -85,6 +88,7 @@ func Parse(r io.Reader) (*Report, error) {
|
|||||||
})
|
})
|
||||||
|
|
||||||
tests = make([]Test, 0)
|
tests = make([]Test, 0)
|
||||||
|
testsTime = 0
|
||||||
} else if test != nil {
|
} else if test != nil {
|
||||||
if matches := regexStatus.FindStringSubmatch(line); len(matches) == 4 {
|
if matches := regexStatus.FindStringSubmatch(line); len(matches) == 4 {
|
||||||
// test status
|
// test status
|
||||||
@ -97,7 +101,9 @@ func Parse(r io.Reader) (*Report, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
test.Name = matches[2]
|
test.Name = matches[2]
|
||||||
test.Time = parseTime(matches[3]) * 10
|
testTime := parseTime(matches[3]) * 10
|
||||||
|
test.Time = testTime
|
||||||
|
testsTime += testTime
|
||||||
} else if strings.HasPrefix(line, "\t") {
|
} else if strings.HasPrefix(line, "\t") {
|
||||||
// test output
|
// test output
|
||||||
test.Output = append(test.Output, line[1:])
|
test.Output = append(test.Output, line[1:])
|
||||||
@ -105,6 +111,18 @@ func Parse(r io.Reader) (*Report, error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if test != nil {
|
||||||
|
tests = append(tests, *test)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(tests) > 0 { //no result line found
|
||||||
|
report.Packages = append(report.Packages, Package{
|
||||||
|
Name: specifiedPackageName,
|
||||||
|
Time: testsTime,
|
||||||
|
Tests: tests,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
return report, nil
|
return report, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user