X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/003a743e6767b3041c3a8321566c3586d73b399a..c6a3fa2cdbf7eb78964a5df7622482cdd8782d74:/hotline/file_store.go?ds=sidebyside diff --git a/hotline/file_store.go b/hotline/file_store.go index e9d083f..3c46fae 100644 --- a/hotline/file_store.go +++ b/hotline/file_store.go @@ -2,20 +2,23 @@ package hotline 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 - // TODO: implement these - // Rename(oldpath string, newpath string) error - // RemoveAll(path string) 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 + ReadFile(name string) ([]byte, error) } type OSFileStore struct{} @@ -36,10 +39,34 @@ 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) } +func (fs *OSFileStore) Create(name string) (*os.File, error) { + return os.Create(name) +} + +func (fs *OSFileStore) WriteFile(name string, data []byte, perm fs.FileMode) error { + 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 } @@ -63,12 +90,76 @@ 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) } + +func (mfs *MockFileStore) Create(name string) (*os.File, error) { + args := mfs.Called(name) + return args.Get(0).(*os.File), args.Error(1) +} + +func (mfs *MockFileStore) WriteFile(name string, data []byte, perm fs.FileMode) error { + 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 +}