| // 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) |
| } |
| } |