X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/481631f6b541a0f00c7c3ba789c13ac934bdefbc..a2ef262a164fc735b9b8471ac0c8001eea2b9bf6:/hotline/file_store.go?ds=inline diff --git a/hotline/file_store.go b/hotline/file_store.go index ba86c6a..1525e2e 100644 --- a/hotline/file_store.go +++ b/hotline/file_store.go @@ -4,21 +4,21 @@ import ( "github.com/stretchr/testify/mock" "io/fs" "os" + "time" ) -var FS FileStore - type FileStore interface { + Create(name string) (*os.File, error) Mkdir(name string, perm os.FileMode) error - Stat(name string) (os.FileInfo, error) Open(name string) (*os.File, error) - Symlink(oldname, newname string) error + OpenFile(name string, flag int, perm fs.FileMode) (*os.File, error) Remove(name string) error - Create(name string) (*os.File, error) + RemoveAll(path string) error + Rename(oldpath string, newpath string) error + Stat(name string) (fs.FileInfo, error) + Symlink(oldname, newname string) error WriteFile(name string, data []byte, perm fs.FileMode) error - // TODO: implement these - // Rename(oldpath string, newpath string) error - // RemoveAll(path string) error + ReadFile(name string) ([]byte, error) } type OSFileStore struct{} @@ -39,6 +39,10 @@ func (fs *OSFileStore) Symlink(oldname, newname string) error { return os.Symlink(oldname, newname) } +func (fs *OSFileStore) RemoveAll(name string) error { + return os.RemoveAll(name) +} + func (fs *OSFileStore) Remove(name string) error { return os.Remove(name) } @@ -51,6 +55,18 @@ func (fs *OSFileStore) WriteFile(name string, data []byte, perm fs.FileMode) err return os.WriteFile(name, data, perm) } +func (fs *OSFileStore) Rename(oldpath string, newpath string) error { + return os.Rename(oldpath, newpath) +} + +func (fs *OSFileStore) ReadFile(name string) ([]byte, error) { + return os.ReadFile(name) +} + +func (fs *OSFileStore) OpenFile(name string, flag int, perm fs.FileMode) (*os.File, error) { + return os.OpenFile(name, flag, perm) +} + type MockFileStore struct { mock.Mock } @@ -64,7 +80,6 @@ func (mfs *MockFileStore) Stat(name string) (os.FileInfo, error) { args := mfs.Called(name) if args.Get(0) == nil { return nil, args.Error(1) - } return args.Get(0).(os.FileInfo), args.Error(1) } @@ -74,11 +89,21 @@ func (mfs *MockFileStore) Open(name string) (*os.File, error) { return args.Get(0).(*os.File), args.Error(1) } +func (mfs *MockFileStore) OpenFile(name string, flag int, perm fs.FileMode) (*os.File, error) { + args := mfs.Called(name, flag, perm) + return args.Get(0).(*os.File), args.Error(1) +} + func (mfs *MockFileStore) Symlink(oldname, newname string) error { args := mfs.Called(oldname, newname) return args.Error(0) } +func (mfs *MockFileStore) RemoveAll(name string) error { + args := mfs.Called(name) + return args.Error(0) +} + func (mfs *MockFileStore) Remove(name string) error { args := mfs.Called(name) return args.Error(0) @@ -93,3 +118,47 @@ func (mfs *MockFileStore) WriteFile(name string, data []byte, perm fs.FileMode) args := mfs.Called(name, data, perm) return args.Error(0) } + +func (mfs *MockFileStore) Rename(oldpath, newpath string) error { + args := mfs.Called(oldpath, newpath) + return args.Error(0) +} + +func (mfs *MockFileStore) ReadFile(name string) ([]byte, error) { + args := mfs.Called(name) + return args.Get(0).([]byte), args.Error(1) +} + +type MockFileInfo struct { + mock.Mock +} + +func (mfi *MockFileInfo) Name() string { + args := mfi.Called() + return args.String(0) +} + +func (mfi *MockFileInfo) Size() int64 { + args := mfi.Called() + return args.Get(0).(int64) +} + +func (mfi *MockFileInfo) Mode() fs.FileMode { + args := mfi.Called() + return args.Get(0).(fs.FileMode) +} + +func (mfi *MockFileInfo) ModTime() time.Time { + _ = mfi.Called() + return time.Now() +} + +func (mfi *MockFileInfo) IsDir() bool { + args := mfi.Called() + return args.Bool(0) +} + +func (mfi *MockFileInfo) Sys() interface{} { + _ = mfi.Called() + return nil +}