diff --git a/fs/sync_test.go b/fs/sync_test.go index 9e9a10d44..9143a0d3f 100644 --- a/fs/sync_test.go +++ b/fs/sync_test.go @@ -3,6 +3,7 @@ package fs_test import ( + "runtime" "testing" "time" @@ -965,6 +966,10 @@ func TestSyncBackupDirWithSuffix(t *testing.T) { testSyncBackupDir(t, ".bak") } // Check we can sync two files with differing UTF-8 representations func TestSyncUTFNorm(t *testing.T) { + if runtime.GOOS == "darwin" { + t.Skip("Can't test UTF normalization on OS X") + } + r := NewRun(t) defer r.Finalise() diff --git a/fstest/fstest.go b/fstest/fstest.go index 9796d557f..e30bd9613 100644 --- a/fstest/fstest.go +++ b/fstest/fstest.go @@ -15,6 +15,7 @@ import ( "path" "path/filepath" "regexp" + "runtime" "sort" "strings" "testing" @@ -23,6 +24,7 @@ import ( "github.com/ncw/rclone/fs" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" + "golang.org/x/text/unicode/norm" ) // Globals @@ -124,6 +126,16 @@ func (i *Item) Check(t *testing.T, obj fs.Object, precision time.Duration) { i.CheckModTime(t, obj, obj.ModTime(), precision) } +// Normalize runs a utf8 normalization on the string if running on OS +// X. This is because OS X denormalizes file names it writes to the +// local file system. +func Normalize(name string) string { + if runtime.GOOS == "darwin" { + name = norm.NFC.String(name) + } + return name +} + // Items represents all items for checking type Items struct { byName map[string]*Item @@ -140,18 +152,19 @@ func NewItems(items []Item) *Items { } // Fill up byName for i := range items { - is.byName[items[i].Path] = &items[i] - is.byNameAlt[items[i].WinPath] = &items[i] + is.byName[Normalize(items[i].Path)] = &items[i] + is.byNameAlt[Normalize(items[i].WinPath)] = &items[i] } return is } // Find checks off an item func (is *Items) Find(t *testing.T, obj fs.Object, precision time.Duration) { - i, ok := is.byName[obj.Remote()] + remote := Normalize(obj.Remote()) + i, ok := is.byName[remote] if !ok { - i, ok = is.byNameAlt[obj.Remote()] - assert.True(t, ok, fmt.Sprintf("Unexpected file %q", obj.Remote())) + i, ok = is.byNameAlt[remote] + assert.True(t, ok, fmt.Sprintf("Unexpected file %q", remote)) } if i != nil { delete(is.byName, i.Path) @@ -177,8 +190,8 @@ func makeListingFromItems(items []Item) (string, string) { nameLengths1 := make([]string, len(items)) nameLengths2 := make([]string, len(items)) for i, item := range items { - remote1 := item.Path - remote2 := item.Path + remote1 := Normalize(item.Path) + remote2 := remote1 if item.WinPath != "" { remote2 = item.WinPath } @@ -194,7 +207,7 @@ func makeListingFromItems(items []Item) (string, string) { func makeListingFromObjects(objs []fs.Object) string { nameLengths := make([]string, len(objs)) for i, obj := range objs { - nameLengths[i] = fmt.Sprintf("%s (%d)", obj.Remote(), obj.Size()) + nameLengths[i] = fmt.Sprintf("%s (%d)", Normalize(obj.Remote()), obj.Size()) } sort.Strings(nameLengths) return strings.Join(nameLengths, ", ") @@ -281,13 +294,17 @@ func CheckListingWithPrecision(t *testing.T, f fs.Fs, items []Item, expectedDirs } // Check the directories if expectedDirs != nil { + expectedDirsCopy := make([]string, len(expectedDirs)) + for i, dir := range expectedDirs { + expectedDirsCopy[i] = Normalize(dir) + } actualDirs := []string{} for _, dir := range dirs { - actualDirs = append(actualDirs, dir.Remote()) + actualDirs = append(actualDirs, Normalize(dir.Remote())) } sort.Strings(actualDirs) - sort.Strings(expectedDirs) - assert.Equal(t, expectedDirs, actualDirs, "directories") + sort.Strings(expectedDirsCopy) + assert.Equal(t, expectedDirsCopy, actualDirs, "directories") } } diff --git a/fstest/fstests/fstests.go b/fstest/fstests/fstests.go index d99feb125..ffce3ae31 100644 --- a/fstest/fstests/fstests.go +++ b/fstest/fstests/fstests.go @@ -217,7 +217,7 @@ func winPath(s string) string { func dirsToNames(dirs []fs.Directory) []string { names := []string{} for _, dir := range dirs { - names = append(names, winPath(dir.Remote())) + names = append(names, winPath(fstest.Normalize(dir.Remote()))) } sort.Strings(names) return names @@ -227,7 +227,7 @@ func dirsToNames(dirs []fs.Directory) []string { func objsToNames(objs []fs.Object) []string { names := []string{} for _, obj := range objs { - names = append(names, winPath(obj.Remote())) + names = append(names, winPath(fstest.Normalize(obj.Remote()))) } sort.Strings(names) return names