]> git.r.bdr.sh - rbdr/mobius/blobdiff - hotline/file_store.go
Update README.md
[rbdr/mobius] / hotline / file_store.go
index e9d083f6b0a8af29354d224c6f8557fc427c22f2..1525e2e473fd6c84d0eddd8e95bc5945c62043ed 100644 (file)
@@ -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
 }
@@ -53,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)
 }
@@ -63,12 +89,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
+}