feat: Add tests for File.Name()

This commit is contained in:
Felicitas Pojtinger
2022-01-18 21:21:06 +01:00
parent 84f91bfd4a
commit b5aca14188
4 changed files with 150 additions and 4 deletions

View File

@@ -10,6 +10,7 @@ import (
"time"
"github.com/pojntfx/stfs/internal/ioext"
"github.com/pojntfx/stfs/internal/pathext"
"github.com/pojntfx/stfs/pkg/cache"
"github.com/pojntfx/stfs/pkg/config"
"github.com/pojntfx/stfs/pkg/inventory"
@@ -370,6 +371,10 @@ func (f *File) Name() string {
f.ioLock.Lock()
defer f.ioLock.Unlock()
if pathext.IsRoot(f.path, false) {
return ""
}
return f.path
}

131
pkg/fs/file_test.go Normal file
View File

@@ -0,0 +1,131 @@
package fs
import (
"fmt"
"os"
"testing"
)
var filenameTests = []struct {
name string
open string
prepare func(symFs) error
check func(string) error
withCache bool
withOsFs bool
}{
{
"Can get correct file name for /test.txt",
"/test.txt",
func(f symFs) error {
if _, err := f.Create("/test.txt"); err != nil {
return err
}
return nil
},
func(got string) error {
want := "/test.txt"
if got != want {
return fmt.Errorf("invalid name, got %v, want %v", got, want)
}
return nil
},
true,
true,
},
{
"Can get correct file name for /mydir/test.txt",
"/mydir/test.txt",
func(f symFs) error {
if err := f.Mkdir("/mydir", os.ModePerm); err != nil {
return err
}
if _, err := f.Create("/mydir/test.txt"); err != nil {
return err
}
return nil
},
func(got string) error {
want := "/mydir/test.txt"
if got != want {
return fmt.Errorf("invalid name, got %v, want %v", got, want)
}
return nil
},
true,
true,
},
{
"Can get correct file name for /",
"/",
func(f symFs) error { return nil },
func(got string) error {
want := ""
if got != want {
return fmt.Errorf("invalid name, got %v, want %v", got, want)
}
return nil
},
true,
true,
},
{
"Can get correct file name for ''",
"",
func(f symFs) error { return nil },
func(got string) error {
want := ""
if got != want {
return fmt.Errorf("invalid name, got %v, want %v", got, want)
}
return nil
},
true,
true,
},
}
func TestFile_Name(t *testing.T) {
for _, tt := range filenameTests {
tt := tt
runTestForAllFss(t, tt.name, true, tt.withCache, tt.withOsFs, func(t *testing.T, fs fsConfig) {
symFs, ok := fs.fs.(symFs)
if !ok {
return
}
if err := tt.prepare(symFs); err != nil {
t.Errorf("%v prepare() error = %v", symFs.Name(), err)
return
}
file, err := symFs.Open(tt.open)
if err != nil {
t.Errorf("%v open() error = %v", symFs.Name(), err)
return
}
got := file.Name()
if err := tt.check(got); err != nil {
t.Errorf("%v check() error = %v", symFs.Name(), err)
return
}
})
}
}

View File

@@ -367,10 +367,6 @@ func (f *STFS) Open(name string) (afero.File, error) {
"name": name,
})
if checkName(name) {
return nil, os.ErrInvalid
}
name = cleanName(name)
return f.OpenFile(name, os.O_RDONLY, 0)

View File

@@ -990,6 +990,20 @@ var openTests = []struct {
func(f afero.Fs) error { return nil },
func(f afero.File) error { return nil },
},
{
"Can not open ' '",
openArgs{" "},
true,
func(f afero.Fs) error { return nil },
func(f afero.File) error { return nil },
},
{
"Can open ''",
openArgs{""},
false,
func(f afero.Fs) error { return nil },
func(f afero.File) error { return nil },
},
{
"Can not open /test.txt without creating it",
openArgs{"/test.txt"},