forked from TrueCloudLab/rclone
fstest: make ChangeNotify test clean up after itself and be more reliable
Previous to this fix old notifications could creep in and cause the test to fail. It also left files around which upset the TestObjectRemove test. Fixes #2177
This commit is contained in:
parent
98a924602f
commit
0bfbde8856
1 changed files with 21 additions and 2 deletions
|
@ -704,6 +704,11 @@ func TestFsChangeNotify(t *testing.T) {
|
||||||
dirChanges := []string{}
|
dirChanges := []string{}
|
||||||
objChanges := []string{}
|
objChanges := []string{}
|
||||||
quitChannel := doChangeNotify(func(x string, e fs.EntryType) {
|
quitChannel := doChangeNotify(func(x string, e fs.EntryType) {
|
||||||
|
fs.Debugf(nil, "doChangeNotify(%q, %+v)", x, e)
|
||||||
|
if strings.HasPrefix(x, file1.Path[:5]) || strings.HasPrefix(x, file2.Path[:5]) {
|
||||||
|
fs.Debugf(nil, "Ignoring notify for file1 or file2: %q, %v", x, e)
|
||||||
|
return
|
||||||
|
}
|
||||||
if e == fs.EntryDirectory {
|
if e == fs.EntryDirectory {
|
||||||
dirChanges = append(dirChanges, x)
|
dirChanges = append(dirChanges, x)
|
||||||
} else if e == fs.EntryObject {
|
} else if e == fs.EntryObject {
|
||||||
|
@ -712,24 +717,38 @@ func TestFsChangeNotify(t *testing.T) {
|
||||||
}, time.Second)
|
}, time.Second)
|
||||||
defer func() { close(quitChannel) }()
|
defer func() { close(quitChannel) }()
|
||||||
|
|
||||||
|
var dirs []string
|
||||||
for _, idx := range []int{1, 3, 2} {
|
for _, idx := range []int{1, 3, 2} {
|
||||||
err = operations.Mkdir(remote, fmt.Sprintf("dir/subdir%d", idx))
|
dir := fmt.Sprintf("dir/subdir%d", idx)
|
||||||
|
err = operations.Mkdir(remote, dir)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
dirs = append(dirs, dir)
|
||||||
}
|
}
|
||||||
|
|
||||||
contents := fstest.RandomString(100)
|
contents := fstest.RandomString(100)
|
||||||
buf := bytes.NewBufferString(contents)
|
buf := bytes.NewBufferString(contents)
|
||||||
|
|
||||||
|
var objs []fs.Object
|
||||||
for _, idx := range []int{2, 4, 3} {
|
for _, idx := range []int{2, 4, 3} {
|
||||||
obji := object.NewStaticObjectInfo(fmt.Sprintf("dir/file%d", idx), time.Now(), int64(buf.Len()), true, nil, nil)
|
obji := object.NewStaticObjectInfo(fmt.Sprintf("dir/file%d", idx), time.Now(), int64(buf.Len()), true, nil, nil)
|
||||||
_, err = remote.Put(buf, obji)
|
o, err := remote.Put(buf, obji)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
objs = append(objs, o)
|
||||||
}
|
}
|
||||||
|
|
||||||
time.Sleep(3 * time.Second)
|
time.Sleep(3 * time.Second)
|
||||||
|
|
||||||
assert.Equal(t, []string{"dir/subdir1", "dir/subdir3", "dir/subdir2"}, dirChanges)
|
assert.Equal(t, []string{"dir/subdir1", "dir/subdir3", "dir/subdir2"}, dirChanges)
|
||||||
assert.Equal(t, []string{"dir/file2", "dir/file4", "dir/file3"}, objChanges)
|
assert.Equal(t, []string{"dir/file2", "dir/file4", "dir/file3"}, objChanges)
|
||||||
|
|
||||||
|
// tidy up afterwards
|
||||||
|
for _, o := range objs {
|
||||||
|
assert.NoError(t, o.Remove())
|
||||||
|
}
|
||||||
|
dirs = append(dirs, "dir")
|
||||||
|
for _, dir := range dirs {
|
||||||
|
assert.NoError(t, remote.Rmdir(dir))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestObjectString tests the Object String method
|
// TestObjectString tests the Object String method
|
||||||
|
|
Loading…
Reference in a new issue