mirror of
https://github.com/jstemmer/go-junit-report.git
synced 2025-04-05 21:18:08 -05:00
Merge pull request #2 from placeybordeaux/bugfix/skip-isnt-failure
check for SKIP on the regex and the if condition
This commit is contained in:
commit
c4d99d755b
@ -20,11 +20,16 @@ type JUnitTestSuite struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type JUnitTestCase struct {
|
type JUnitTestCase struct {
|
||||||
XMLName xml.Name `xml:"testcase"`
|
XMLName xml.Name `xml:"testcase"`
|
||||||
Classname string `xml:"classname,attr"`
|
Classname string `xml:"classname,attr"`
|
||||||
Name string `xml:"name,attr"`
|
Name string `xml:"name,attr"`
|
||||||
Time string `xml:"time,attr"`
|
Time string `xml:"time,attr"`
|
||||||
Failure *JUnitFailure `xml:"failure,omitempty"`
|
SkipMessage *JUnitSkipMessage `xml:"skipped,omitempty"`
|
||||||
|
Failure *JUnitFailure `xml:"failure,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type JUnitSkipMessage struct {
|
||||||
|
Message string `xml:"message,attr"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type JUnitProperty struct {
|
type JUnitProperty struct {
|
||||||
@ -88,6 +93,10 @@ func JUnitReportXML(report *Report, w io.Writer) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if test.Result == SKIP {
|
||||||
|
testCase.SkipMessage = &JUnitSkipMessage{strings.Join(test.Output, "\n")}
|
||||||
|
}
|
||||||
|
|
||||||
ts.TestCases = append(ts.TestCases, testCase)
|
ts.TestCases = append(ts.TestCases, testCase)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,6 +13,7 @@ type Result int
|
|||||||
const (
|
const (
|
||||||
PASS Result = iota
|
PASS Result = iota
|
||||||
FAIL
|
FAIL
|
||||||
|
SKIP
|
||||||
)
|
)
|
||||||
|
|
||||||
type Report struct {
|
type Report struct {
|
||||||
@ -33,7 +34,7 @@ type Test struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
regexStatus = regexp.MustCompile(`^--- (PASS|FAIL): (.+) \((\d+\.\d+) seconds\)$`)
|
regexStatus = regexp.MustCompile(`^--- (PASS|FAIL|SKIP): (.+) \((\d+\.\d+) seconds\)$`)
|
||||||
regexResult = regexp.MustCompile(`^(ok|FAIL)\s+(.+)\s(\d+\.\d+)s$`)
|
regexResult = regexp.MustCompile(`^(ok|FAIL)\s+(.+)\s(\d+\.\d+)s$`)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -89,6 +90,8 @@ func Parse(r io.Reader) (*Report, error) {
|
|||||||
// test status
|
// test status
|
||||||
if matches[1] == "PASS" {
|
if matches[1] == "PASS" {
|
||||||
test.Result = PASS
|
test.Result = PASS
|
||||||
|
} else if matches[1] == "SKIP" {
|
||||||
|
test.Result = SKIP
|
||||||
} else {
|
} else {
|
||||||
test.Result = FAIL
|
test.Result = FAIL
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user