blob: 4c409ae7a010e2cb9c202a2431674de39a235f3a [file] [log] [blame]
// Copyright 2020 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package fs_test
import (
"errors"
. "io/fs"
"os"
"testing"
"testing/fstest"
"time"
)
type readDirOnly struct{ ReadDirFS }
func (readDirOnly) Open(name string) (File, error) { return nil, ErrNotExist }
func TestReadDir(t *testing.T) {
check := func(desc string, dirs []DirEntry, err error) {
t.Helper()
if err != nil || len(dirs) != 2 || dirs[0].Name() != "hello.txt" || dirs[1].Name() != "sub" {
var names []string
for _, d := range dirs {
names = append(names, d.Name())
}
t.Errorf("ReadDir(%s) = %v, %v, want %v, nil", desc, names, err, []string{"hello.txt", "sub"})
}
}
// Test that ReadDir uses the method when present.
dirs, err := ReadDir(readDirOnly{testFsys}, ".")
check("readDirOnly", dirs, err)
// Test that ReadDir uses Open when the method is not present.
dirs, err = ReadDir(openOnly{testFsys}, ".")
check("openOnly", dirs, err)
// Test that ReadDir on Sub of . works (sub_test checks non-trivial subs).
sub, err := Sub(testFsys, ".")
if err != nil {
t.Fatal(err)
}
dirs, err = ReadDir(sub, ".")
check("sub(.)", dirs, err)
}
func TestFileInfoToDirEntry(t *testing.T) {
testFs := fstest.MapFS{
"notadir.txt": {
Data: []byte("hello, world"),
Mode: 0,
ModTime: time.Now(),
Sys: &sysValue,
},
"adir": {
Data: nil,
Mode: os.ModeDir,
ModTime: time.Now(),
Sys: &sysValue,
},
}
tests := []struct {
path string
wantMode FileMode
wantDir bool
}{
{path: "notadir.txt", wantMode: 0, wantDir: false},
{path: "adir", wantMode: os.ModeDir, wantDir: true},
}
for _, test := range tests {
test := test
t.Run(test.path, func(t *testing.T) {
fi, err := Stat(testFs, test.path)
if err != nil {
t.Fatal(err)
}
dirEntry := FileInfoToDirEntry(fi)
if g, w := dirEntry.Type(), test.wantMode; g != w {
t.Errorf("FileMode mismatch: got=%v, want=%v", g, w)
}
if g, w := dirEntry.Name(), test.path; g != w {
t.Errorf("Name mismatch: got=%v, want=%v", g, w)
}
if g, w := dirEntry.IsDir(), test.wantDir; g != w {
t.Errorf("IsDir mismatch: got=%v, want=%v", g, w)
}
})
}
}
func errorPath(err error) string {
var perr *PathError
if !errors.As(err, &perr) {
return ""
}
return perr.Path
}
func TestReadDirPath(t *testing.T) {
fsys := os.DirFS(t.TempDir())
_, err1 := ReadDir(fsys, "non-existent")
_, err2 := ReadDir(struct{ FS }{fsys}, "non-existent")
if s1, s2 := errorPath(err1), errorPath(err2); s1 != s2 {
t.Fatalf("s1: %s != s2: %s", s1, s2)
}
}