touch: fix recursive touch due to recently introduced error ErrorIsDir
This commit is contained in:
parent
a70c20fe6b
commit
9c8c0a58b5
2 changed files with 41 additions and 1 deletions
|
@ -132,7 +132,7 @@ func Touch(ctx context.Context, f fs.Fs, fileName string) error {
|
|||
return errors.Wrap(err, "failed to touch (create)")
|
||||
}
|
||||
}
|
||||
if errors.Cause(err) == fs.ErrorNotAFile {
|
||||
if errors.Cause(err) == fs.ErrorIsDir {
|
||||
if recursive {
|
||||
// Touch existing directory, recursive
|
||||
fs.Debugf(nil, "Touching files in directory recursively")
|
||||
|
|
|
@ -112,3 +112,43 @@ func TestTouchCreateMultipleDirAndFile(t *testing.T) {
|
|||
file1 := fstest.NewItem("a/b/c.txt", "", t1)
|
||||
fstest.CheckListingWithPrecision(t, r.Fremote, []fstest.Item{file1}, []string{"a", "a/b"}, fs.ModTimeNotSupported)
|
||||
}
|
||||
|
||||
func TestTouchEmptyDir(t *testing.T) {
|
||||
r := fstest.NewRun(t)
|
||||
defer r.Finalise()
|
||||
|
||||
err := r.Fremote.Mkdir(context.Background(), "a")
|
||||
require.NoError(t, err)
|
||||
err = Touch(context.Background(), r.Fremote, "a")
|
||||
require.NoError(t, err)
|
||||
fstest.CheckListingWithPrecision(t, r.Fremote, []fstest.Item{}, []string{"a"}, fs.ModTimeNotSupported)
|
||||
}
|
||||
|
||||
func TestTouchDirWithFiles(t *testing.T) {
|
||||
r := fstest.NewRun(t)
|
||||
defer r.Finalise()
|
||||
|
||||
err := r.Fremote.Mkdir(context.Background(), "a")
|
||||
require.NoError(t, err)
|
||||
file1 := r.WriteObject(context.Background(), "a/f1", "111", t1)
|
||||
file2 := r.WriteObject(context.Background(), "a/f2", "222", t1)
|
||||
err = Touch(context.Background(), r.Fremote, "a")
|
||||
require.NoError(t, err)
|
||||
fstest.CheckListingWithPrecision(t, r.Fremote, []fstest.Item{file1, file2}, []string{"a"}, fs.ModTimeNotSupported)
|
||||
}
|
||||
|
||||
func TestRecursiveTouchDirWithFiles(t *testing.T) {
|
||||
r := fstest.NewRun(t)
|
||||
defer r.Finalise()
|
||||
|
||||
err := r.Fremote.Mkdir(context.Background(), "a/b/c")
|
||||
require.NoError(t, err)
|
||||
file1 := r.WriteObject(context.Background(), "a/f1", "111", t1)
|
||||
file2 := r.WriteObject(context.Background(), "a/b/f2", "222", t1)
|
||||
file3 := r.WriteObject(context.Background(), "a/b/c/f3", "333", t1)
|
||||
recursive = true
|
||||
err = Touch(context.Background(), r.Fremote, "a")
|
||||
recursive = false
|
||||
require.NoError(t, err)
|
||||
fstest.CheckListingWithPrecision(t, r.Fremote, []fstest.Item{file1, file2, file3}, []string{"a", "a/b", "a/b/c"}, fs.ModTimeNotSupported)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue