X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/d492c46d7e2087114d25f64823de9027592d5fc4..93df4153a2028e7c6ffee0d005f58db8cec9917a:/hotline/file_store.go diff --git a/hotline/file_store.go b/hotline/file_store.go index b56d9a1..ba86c6a 100644 --- a/hotline/file_store.go +++ b/hotline/file_store.go @@ -2,6 +2,7 @@ package hotline import ( "github.com/stretchr/testify/mock" + "io/fs" "os" ) @@ -11,35 +12,55 @@ type FileStore interface { Mkdir(name string, perm os.FileMode) error Stat(name string) (os.FileInfo, error) Open(name string) (*os.File, error) + Symlink(oldname, newname string) error + Remove(name string) error + Create(name string) (*os.File, error) + WriteFile(name string, data []byte, perm fs.FileMode) error // TODO: implement these - //Rename(oldpath string, newpath string) error - //RemoveAll(path string) error + // Rename(oldpath string, newpath string) error + // RemoveAll(path string) error } type OSFileStore struct{} -func (fs OSFileStore) Mkdir(name string, perm os.FileMode) error { +func (fs *OSFileStore) Mkdir(name string, perm os.FileMode) error { return os.Mkdir(name, perm) } -func (fs OSFileStore) Stat(name string) (os.FileInfo, error) { +func (fs *OSFileStore) Stat(name string) (os.FileInfo, error) { return os.Stat(name) } -func (fs OSFileStore) Open(name string) (*os.File, error) { +func (fs *OSFileStore) Open(name string) (*os.File, error) { return os.Open(name) } +func (fs *OSFileStore) Symlink(oldname, newname string) error { + return os.Symlink(oldname, newname) +} + +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) +} + type MockFileStore struct { mock.Mock } -func (mfs MockFileStore) Mkdir(name string, perm os.FileMode) error { +func (mfs *MockFileStore) Mkdir(name string, perm os.FileMode) error { args := mfs.Called(name, perm) return args.Error(0) } -func (mfs MockFileStore) Stat(name string) (os.FileInfo, error) { +func (mfs *MockFileStore) Stat(name string) (os.FileInfo, error) { args := mfs.Called(name) if args.Get(0) == nil { return nil, args.Error(1) @@ -48,7 +69,27 @@ func (mfs MockFileStore) Stat(name string) (os.FileInfo, error) { return args.Get(0).(os.FileInfo), args.Error(1) } -func (mfs MockFileStore) Open(name string) (*os.File, error) { +func (mfs *MockFileStore) Open(name string) (*os.File, error) { + args := mfs.Called(name) + 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) 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) +}