]> git.r.bdr.sh - rbdr/mobius/blobdiff - hotline/file_store.go
Merge pull request #39 from benabernathy/mobius_38
[rbdr/mobius] / hotline / file_store.go
index e9d083f6b0a8af29354d224c6f8557fc427c22f2..2ba9d7af6b9e3ea8444f1ff4a74c4d60b1e62292 100644 (file)
@@ -2,17 +2,18 @@ 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
@@ -40,6 +41,14 @@ 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
 }
@@ -72,3 +81,13 @@ 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)
+}