2024-08-09 09:40:25 +00:00
|
|
|
package filer
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2025-01-07 10:49:23 +00:00
|
|
|
"errors"
|
2024-08-09 09:40:25 +00:00
|
|
|
"io"
|
|
|
|
"io/fs"
|
|
|
|
"path"
|
|
|
|
"sort"
|
|
|
|
"strings"
|
|
|
|
|
2024-11-15 15:37:21 +00:00
|
|
|
"github.com/databricks/cli/libs/fakefs"
|
|
|
|
)
|
2024-08-09 09:40:25 +00:00
|
|
|
|
|
|
|
type FakeFiler struct {
|
2024-11-15 15:37:21 +00:00
|
|
|
entries map[string]fakefs.FileInfo
|
2024-08-09 09:40:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FakeFiler) Write(ctx context.Context, p string, reader io.Reader, mode ...WriteMode) error {
|
2025-01-07 10:49:23 +00:00
|
|
|
return errors.New("not implemented")
|
2024-08-09 09:40:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FakeFiler) Read(ctx context.Context, p string) (io.ReadCloser, error) {
|
|
|
|
_, ok := f.entries[p]
|
|
|
|
if !ok {
|
|
|
|
return nil, fs.ErrNotExist
|
|
|
|
}
|
|
|
|
|
|
|
|
return io.NopCloser(strings.NewReader("foo")), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FakeFiler) Delete(ctx context.Context, p string, mode ...DeleteMode) error {
|
2025-01-07 10:49:23 +00:00
|
|
|
return errors.New("not implemented")
|
2024-08-09 09:40:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FakeFiler) ReadDir(ctx context.Context, p string) ([]fs.DirEntry, error) {
|
|
|
|
p = strings.TrimSuffix(p, "/")
|
|
|
|
entry, ok := f.entries[p]
|
|
|
|
if !ok {
|
|
|
|
return nil, NoSuchDirectoryError{p}
|
|
|
|
}
|
|
|
|
|
|
|
|
if !entry.FakeDir {
|
|
|
|
return nil, fs.ErrInvalid
|
|
|
|
}
|
|
|
|
|
|
|
|
// Find all entries contained in the specified directory `p`.
|
|
|
|
var out []fs.DirEntry
|
|
|
|
for k, v := range f.entries {
|
|
|
|
if k == p || path.Dir(k) != p {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2024-11-15 15:37:21 +00:00
|
|
|
out = append(out, fakefs.DirEntry{FileInfo: v})
|
2024-08-09 09:40:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sort.Slice(out, func(i, j int) bool { return out[i].Name() < out[j].Name() })
|
|
|
|
return out, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FakeFiler) Mkdir(ctx context.Context, path string) error {
|
2025-01-07 10:49:23 +00:00
|
|
|
return errors.New("not implemented")
|
2024-08-09 09:40:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (f *FakeFiler) Stat(ctx context.Context, path string) (fs.FileInfo, error) {
|
|
|
|
entry, ok := f.entries[path]
|
|
|
|
if !ok {
|
|
|
|
return nil, fs.ErrNotExist
|
|
|
|
}
|
|
|
|
|
|
|
|
return entry, nil
|
|
|
|
}
|
|
|
|
|
2024-11-15 15:37:21 +00:00
|
|
|
// NewFakeFiler creates a new fake [Filer] instance with the given entries.
|
|
|
|
// It sets the [Name] field of each entry to the base name of the path.
|
|
|
|
//
|
|
|
|
// This is meant to be used in tests.
|
|
|
|
func NewFakeFiler(entries map[string]fakefs.FileInfo) *FakeFiler {
|
2024-08-09 09:40:25 +00:00
|
|
|
fakeFiler := &FakeFiler{
|
|
|
|
entries: entries,
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, v := range fakeFiler.entries {
|
|
|
|
if v.FakeName != "" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
v.FakeName = path.Base(k)
|
|
|
|
fakeFiler.entries[k] = v
|
|
|
|
}
|
|
|
|
|
|
|
|
return fakeFiler
|
|
|
|
}
|