feat: Add tests for File.Name()
This commit is contained in:
@@ -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
131
pkg/fs/file_test.go
Normal 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
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
@@ -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)
|
||||
|
||||
@@ -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"},
|
||||
|
||||
Reference in New Issue
Block a user