]> git.r.bdr.sh - rbdr/mobius/blobdiff - hotline/file_store.go
Misc cleanup
[rbdr/mobius] / hotline / file_store.go
index 81c1f059d15a2473638ea431cc606233b4a41852..f528c3677ee08f65a4c1f8ca52ac3b88dff49b48 100644 (file)
@@ -9,38 +9,57 @@ var FS FileStore
 
 type FileStore interface {
        Mkdir(name string, perm os.FileMode) error
-
        Stat(name string) (os.FileInfo, error)
-       // TODO: implement
+       Open(name string) (*os.File, error)
+       Symlink(oldname, newname string) error
 
-       //Rename(oldpath string, newpath string) error
-       //RemoveAll(path string) error
+       // TODO: implement these
+       // 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) {
+       return os.Open(name)
+}
+
+func (fs *OSFileStore) Symlink(oldname, newname string) error {
+       return os.Symlink(oldname, newname)
+}
+
 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 {
+       if args.Get(0) == nil {
                return nil, args.Error(1)
 
        }
        return args.Get(0).(os.FileInfo), args.Error(1)
 }
+
+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)
+}