mirror of
https://github.com/datarhei/core.git
synced 2025-10-05 07:57:13 +08:00
264 lines
6.7 KiB
Go
264 lines
6.7 KiB
Go
package api
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"io"
|
|
"net/http"
|
|
"testing"
|
|
|
|
"github.com/datarhei/core/v16/http/api"
|
|
httpfs "github.com/datarhei/core/v16/http/fs"
|
|
"github.com/datarhei/core/v16/http/handler"
|
|
"github.com/datarhei/core/v16/http/mock"
|
|
"github.com/datarhei/core/v16/io/fs"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/labstack/echo/v4"
|
|
)
|
|
|
|
func getDummyFilesystemsHandler(filesystems []httpfs.FS) (*FSHandler, error) {
|
|
config := map[string]FSConfig{}
|
|
|
|
for _, fs := range filesystems {
|
|
config[fs.Name] = FSConfig{
|
|
Type: fs.Filesystem.Type(),
|
|
Mountpoint: fs.Mountpoint,
|
|
Handler: handler.NewFS(fs),
|
|
}
|
|
}
|
|
handler := NewFS(config)
|
|
|
|
return handler, nil
|
|
}
|
|
|
|
func getDummyFilesystemsRouter(filesystems []httpfs.FS) (*echo.Echo, error) {
|
|
router := mock.DummyEcho()
|
|
|
|
handler, err := getDummyFilesystemsHandler(filesystems)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
router.GET("/:name/*", handler.GetFile)
|
|
router.PUT("/:name/*", handler.PutFile)
|
|
router.DELETE("/:name/*", handler.DeleteFile)
|
|
router.GET("/:name", handler.ListFiles)
|
|
router.GET("/", handler.List)
|
|
router.PUT("/", handler.FileOperation)
|
|
|
|
return router, nil
|
|
}
|
|
|
|
func TestFilesystems(t *testing.T) {
|
|
memfs, err := fs.NewMemFilesystem(fs.MemConfig{})
|
|
require.NoError(t, err)
|
|
|
|
filesystems := []httpfs.FS{
|
|
{
|
|
Name: "foo",
|
|
Mountpoint: "/",
|
|
AllowWrite: true,
|
|
Filesystem: memfs,
|
|
},
|
|
}
|
|
|
|
router, err := getDummyFilesystemsRouter(filesystems)
|
|
require.NoError(t, err)
|
|
|
|
response := mock.Request(t, http.StatusOK, router, "GET", "/", nil)
|
|
|
|
mock.Validate(t, &[]api.FilesystemInfo{}, response.Data)
|
|
|
|
f := []api.FilesystemInfo{}
|
|
err = json.Unmarshal(response.Raw, &f)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(f))
|
|
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/bar", nil)
|
|
|
|
response = mock.Request(t, http.StatusOK, router, "GET", "/foo", nil)
|
|
|
|
mock.Validate(t, &[]api.FileInfo{}, response.Data)
|
|
|
|
l := []api.FileInfo{}
|
|
err = json.Unmarshal(response.Raw, &l)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 0, len(l))
|
|
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/bar/file", nil)
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/foo/file", nil)
|
|
|
|
data := mock.Read(t, "./fixtures/addProcess.json")
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusCreated, router, "PUT", "/foo/file", data)
|
|
mock.Request(t, http.StatusNotFound, router, "PUT", "/bar/file", data)
|
|
|
|
data = mock.Read(t, "./fixtures/addProcess.json")
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusNoContent, router, "PUT", "/foo/file", data)
|
|
|
|
require.Equal(t, 1, len(memfs.List("/", "")))
|
|
|
|
response = mock.Request(t, http.StatusOK, router, "GET", "/foo", nil)
|
|
|
|
mock.Validate(t, &[]api.FileInfo{}, response.Data)
|
|
|
|
l = []api.FileInfo{}
|
|
err = json.Unmarshal(response.Raw, &l)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(l))
|
|
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/foo/elif", nil)
|
|
|
|
response = mock.Request(t, http.StatusOK, router, "GET", "/foo/file", nil)
|
|
|
|
databytes, err := io.ReadAll(mock.Read(t, "./fixtures/addProcess.json"))
|
|
require.NoError(t, err)
|
|
require.Equal(t, databytes, response.Raw)
|
|
|
|
mock.Request(t, http.StatusNotFound, router, "DELETE", "/foo/elif", nil)
|
|
mock.Request(t, http.StatusNotFound, router, "DELETE", "/bar/elif", nil)
|
|
mock.Request(t, http.StatusOK, router, "DELETE", "/foo/file", nil)
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/foo/file", nil)
|
|
|
|
require.Equal(t, 0, len(memfs.List("/", "")))
|
|
|
|
response = mock.Request(t, http.StatusOK, router, "GET", "/foo", nil)
|
|
|
|
mock.Validate(t, &[]api.FileInfo{}, response.Data)
|
|
|
|
l = []api.FileInfo{}
|
|
err = json.Unmarshal(response.Raw, &l)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 0, len(l))
|
|
}
|
|
|
|
func TestFileOperation(t *testing.T) {
|
|
memfs1, err := fs.NewMemFilesystem(fs.MemConfig{})
|
|
require.NoError(t, err)
|
|
|
|
memfs2, err := fs.NewMemFilesystem(fs.MemConfig{})
|
|
require.NoError(t, err)
|
|
|
|
filesystems := []httpfs.FS{
|
|
{
|
|
Name: "foo",
|
|
Mountpoint: "/foo",
|
|
AllowWrite: true,
|
|
Filesystem: memfs1,
|
|
},
|
|
{
|
|
Name: "bar",
|
|
Mountpoint: "/bar",
|
|
AllowWrite: true,
|
|
Filesystem: memfs2,
|
|
},
|
|
}
|
|
|
|
router, err := getDummyFilesystemsRouter(filesystems)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/foo/file", nil)
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/bar/file", nil)
|
|
|
|
data := mock.Read(t, "./fixtures/addProcess.json")
|
|
require.NotNil(t, data)
|
|
|
|
mock.Request(t, http.StatusCreated, router, "PUT", "/foo/file", data)
|
|
mock.Request(t, http.StatusOK, router, "GET", "/foo/file", nil)
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/bar/file", nil)
|
|
|
|
op := api.FilesystemOperation{}
|
|
|
|
jsondata, err := json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusBadRequest, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
op = api.FilesystemOperation{
|
|
Operation: "copy",
|
|
}
|
|
|
|
jsondata, err = json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusBadRequest, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
op = api.FilesystemOperation{
|
|
Operation: "copy",
|
|
From: "foo:/elif",
|
|
}
|
|
|
|
jsondata, err = json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusBadRequest, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
op = api.FilesystemOperation{
|
|
Operation: "copy",
|
|
From: "foo:/elif",
|
|
To: "/bar",
|
|
}
|
|
|
|
jsondata, err = json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusBadRequest, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
op = api.FilesystemOperation{
|
|
Operation: "copy",
|
|
From: "foo:/file",
|
|
To: "/bar",
|
|
}
|
|
|
|
jsondata, err = json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusBadRequest, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
op = api.FilesystemOperation{
|
|
Operation: "copy",
|
|
From: "foo:file",
|
|
To: "bar:/file",
|
|
}
|
|
|
|
jsondata, err = json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusOK, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
mock.Request(t, http.StatusOK, router, "GET", "/foo/file", nil)
|
|
response := mock.Request(t, http.StatusOK, router, "GET", "/bar/file", nil)
|
|
|
|
filedata, err := io.ReadAll(mock.Read(t, "./fixtures/addProcess.json"))
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, filedata, response.Raw)
|
|
|
|
op = api.FilesystemOperation{
|
|
Operation: "move",
|
|
From: "foo:file",
|
|
To: "bar:/file",
|
|
}
|
|
|
|
jsondata, err = json.Marshal(op)
|
|
require.NoError(t, err)
|
|
|
|
mock.Request(t, http.StatusOK, router, "PUT", "/", bytes.NewReader(jsondata))
|
|
|
|
mock.Request(t, http.StatusNotFound, router, "GET", "/foo/file", nil)
|
|
response = mock.Request(t, http.StatusOK, router, "GET", "/bar/file", nil)
|
|
|
|
filedata, err = io.ReadAll(mock.Read(t, "./fixtures/addProcess.json"))
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, filedata, response.Raw)
|
|
}
|