mirror of
https://github.com/jstemmer/go-junit-report.git
synced 2025-04-05 21:18:08 -05:00
Add -match test flag to make testing specific tests easier
This commit is contained in:
parent
6e1ccef4d8
commit
c1eb342963
@ -2,9 +2,11 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
|
"regexp"
|
||||||
"runtime"
|
"runtime"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
@ -13,6 +15,8 @@ import (
|
|||||||
"github.com/jstemmer/go-junit-report/parser"
|
"github.com/jstemmer/go-junit-report/parser"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var matchTest = flag.String("match", "", "only test testdata matching this pattern")
|
||||||
|
|
||||||
type TestCase struct {
|
type TestCase struct {
|
||||||
name string
|
name string
|
||||||
reportName string
|
reportName string
|
||||||
@ -830,7 +834,11 @@ var testCases = []TestCase{
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParser(t *testing.T) {
|
func TestParser(t *testing.T) {
|
||||||
|
matchRegex := compileMatch(t)
|
||||||
for _, testCase := range testCases {
|
for _, testCase := range testCases {
|
||||||
|
if !matchRegex.MatchString(testCase.name) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
t.Logf("Test %s", testCase.name)
|
t.Logf("Test %s", testCase.name)
|
||||||
|
|
||||||
file, err := os.Open("testdata/" + testCase.name)
|
file, err := os.Open("testdata/" + testCase.name)
|
||||||
@ -904,7 +912,12 @@ func TestVersionFlag(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func testJUnitFormatter(t *testing.T, goVersion string) {
|
func testJUnitFormatter(t *testing.T, goVersion string) {
|
||||||
|
match := compileMatch(t)
|
||||||
for _, testCase := range testCases {
|
for _, testCase := range testCases {
|
||||||
|
if !match.MatchString(testCase.name) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
report, err := loadTestReport(testCase.reportName, goVersion)
|
report, err := loadTestReport(testCase.reportName, goVersion)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
@ -938,3 +951,11 @@ func loadTestReport(name, goVersion string) (string, error) {
|
|||||||
|
|
||||||
return report, nil
|
return report, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func compileMatch(t *testing.T) *regexp.Regexp {
|
||||||
|
rx, err := regexp.Compile(*matchTest)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error compiling -match flag %q: %v", *matchTest, err)
|
||||||
|
}
|
||||||
|
return rx
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user