X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/d492c46d7e2087114d25f64823de9027592d5fc4..4fad3266d27d3d193c6e25298c6085dbf8a6b610:/hotline/file_store.go diff --git a/hotline/file_store.go b/hotline/file_store.go index b56d9a1..2ba9d7a 100644 --- a/hotline/file_store.go +++ b/hotline/file_store.go @@ -2,44 +2,63 @@ package hotline import ( "github.com/stretchr/testify/mock" + "io/fs" "os" ) -var FS FileStore - 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 +67,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) +}