Skip to content

Commit

Permalink
Enable a unit test on windows.
Browse files Browse the repository at this point in the history
Signed-off-by: Daniel Nephin <[email protected]>
  • Loading branch information
dnephin committed Apr 21, 2017
1 parent 0e9148b commit 9484c3b
Showing 1 changed file with 22 additions and 19 deletions.
41 changes: 22 additions & 19 deletions pkg/fileutils/fileutils_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ import (
"runtime"
"strings"
"testing"

"fmt"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)

// CopyFile with invalid src
Expand Down Expand Up @@ -299,17 +303,14 @@ func TestMatchesWithMalformedPatterns(t *testing.T) {
}
}

// Test lots of variants of patterns & strings
type matchesTestCase struct {
pattern string
text string
pass bool
}

func TestMatches(t *testing.T) {
// TODO Windows: Port this test
if runtime.GOOS == "windows" {
t.Skip("Needs porting to Windows")
}
tests := []struct {
pattern string
text string
pass bool
}{
tests := []matchesTestCase{
{"**", "file", true},
{"**", "file/", true},
{"**/", "file", true}, // weird one
Expand Down Expand Up @@ -361,9 +362,6 @@ func TestMatches(t *testing.T) {
{"abc.def", "abcZdef", false},
{"abc?def", "abcZdef", true},
{"abc?def", "abcdef", false},
{"a\\*b", "a*b", true},
{"a\\", "a", false},
{"a\\", "a\\", false},
{"a\\\\", "a\\", true},
{"**/foo/bar", "foo/bar", true},
{"**/foo/bar", "dir/foo/bar", true},
Expand All @@ -375,15 +373,20 @@ func TestMatches(t *testing.T) {
{"**/.foo", "bar.foo", false},
}

if runtime.GOOS != "windows" {
tests = append(tests, []matchesTestCase{
{"a\\*b", "a*b", true},
{"a\\", "a", false},
{"a\\", "a\\", false},
}...)
}

for _, test := range tests {
desc := fmt.Sprintf("pattern=%q text=%q", test.pattern, test.text)
pm, err := NewPatternMatcher([]string{test.pattern})
if err != nil {
t.Fatalf("invalid pattern %s", test.pattern)
}
require.NoError(t, err, desc)
res, _ := pm.Matches(test.text)
if res != test.pass {
t.Fatalf("Failed: %v - res:%v", test, res)
}
assert.Equal(t, test.pass, res, desc)
}
}

Expand Down

0 comments on commit 9484c3b

Please sign in to comment.