mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-08 17:24:08 +00:00
lib/fs: Pass infinite recursion error on instead of warning (#6846)
Prompted by https://forum.syncthing.net/t/infinite-filesystem-recursion-detected/15285. In my opinion the filesystem shouldn't throw warnings but pass on errors for the caller to decide what's to be happening with it. Right now in this PR an infinite recursion is a normal scan error, i.e. folder is in failed state and displays failed items, but no warning. I think that's appropriate but if deemed appropriate an additional warning can be thrown in the scanner.
This commit is contained in:
parent
d91d77a2b2
commit
ebead944b5
@ -11,9 +11,12 @@
|
||||
package fs
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"path/filepath"
|
||||
)
|
||||
|
||||
var ErrInfiniteRecursion = errors.New("infinite filesystem recursion detected")
|
||||
|
||||
type ancestorDirList struct {
|
||||
list []FileInfo
|
||||
fs Filesystem
|
||||
@ -90,8 +93,7 @@ func (f *walkFilesystem) walk(path string, info FileInfo, walkFn WalkFunc, ances
|
||||
ancestors.Push(info)
|
||||
defer ancestors.Pop()
|
||||
} else {
|
||||
l.Warnf("Infinite filesystem recursion detected on path '%s', not walking further down", path)
|
||||
return nil
|
||||
return walkFn(path, info, ErrInfiniteRecursion)
|
||||
}
|
||||
|
||||
names, err := f.DirNames(path)
|
||||
|
@ -7,6 +7,7 @@
|
||||
package fs
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
osexec "os/exec"
|
||||
"path/filepath"
|
||||
@ -105,8 +106,16 @@ func testWalkInfiniteRecursion(t *testing.T, fsType FilesystemType, uri string)
|
||||
}
|
||||
dirjunctCnt := 0
|
||||
fooCnt := 0
|
||||
found := false
|
||||
if err := fs.Walk("towalk", func(path string, info FileInfo, err error) error {
|
||||
if err != nil {
|
||||
if errors.Is(err, ErrInfiniteRecursion) {
|
||||
if found {
|
||||
t.Fatal("second infinite recursion detected at", path)
|
||||
}
|
||||
found = true
|
||||
return nil
|
||||
}
|
||||
t.Fatal(err)
|
||||
}
|
||||
if info.Name() == "dirjunct" {
|
||||
@ -118,7 +127,7 @@ func testWalkInfiniteRecursion(t *testing.T, fsType FilesystemType, uri string)
|
||||
}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if dirjunctCnt != 2 || fooCnt != 1 {
|
||||
if dirjunctCnt != 2 || fooCnt != 1 || !found {
|
||||
t.Fatal("Infinite recursion not detected correctly")
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user