X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/b196a50a44a5c72fc43df39fce4407d05ec8863b..94742e2f44ca08a64c1851aa1a00c3e9f266d0e9:/hotline/file_store.go diff --git a/hotline/file_store.go b/hotline/file_store.go index 2ba9d7a..3c46fae 100644 --- a/hotline/file_store.go +++ b/hotline/file_store.go @@ -4,19 +4,21 @@ import ( "github.com/stretchr/testify/mock" "io/fs" "os" + "time" ) 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{} @@ -37,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) } @@ -49,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 } @@ -72,11 +90,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) @@ -91,3 +119,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 +}