|
package op_test |
|
|
|
import ( |
|
"context" |
|
"testing" |
|
|
|
"github.com/alist-org/alist/v3/internal/conf" |
|
"github.com/alist-org/alist/v3/internal/db" |
|
"github.com/alist-org/alist/v3/internal/model" |
|
"github.com/alist-org/alist/v3/internal/op" |
|
"github.com/alist-org/alist/v3/pkg/utils" |
|
mapset "github.com/deckarep/golang-set/v2" |
|
"gorm.io/driver/sqlite" |
|
"gorm.io/gorm" |
|
) |
|
|
|
func init() { |
|
dB, err := gorm.Open(sqlite.Open("file::memory:?cache=shared"), &gorm.Config{}) |
|
if err != nil { |
|
panic("failed to connect database") |
|
} |
|
conf.Conf = conf.DefaultConfig() |
|
db.Init(dB) |
|
} |
|
|
|
func TestCreateStorage(t *testing.T) { |
|
var storages = []struct { |
|
storage model.Storage |
|
isErr bool |
|
}{ |
|
{storage: model.Storage{Driver: "Local", MountPath: "/local", Addition: `{"root_folder_path":"."}`}, isErr: false}, |
|
{storage: model.Storage{Driver: "Local", MountPath: "/local", Addition: `{"root_folder_path":"."}`}, isErr: true}, |
|
{storage: model.Storage{Driver: "None", MountPath: "/none", Addition: `{"root_folder_path":"."}`}, isErr: true}, |
|
} |
|
for _, storage := range storages { |
|
_, err := op.CreateStorage(context.Background(), storage.storage) |
|
if err != nil { |
|
if !storage.isErr { |
|
t.Errorf("failed to create storage: %+v", err) |
|
} else { |
|
t.Logf("expect failed to create storage: %+v", err) |
|
} |
|
} |
|
} |
|
} |
|
|
|
func TestGetStorageVirtualFilesByPath(t *testing.T) { |
|
setupStorages(t) |
|
virtualFiles := op.GetStorageVirtualFilesByPath("/a") |
|
var names []string |
|
for _, virtualFile := range virtualFiles { |
|
names = append(names, virtualFile.GetName()) |
|
} |
|
var expectedNames = []string{"b", "c", "d"} |
|
if utils.SliceEqual(names, expectedNames) { |
|
t.Logf("passed") |
|
} else { |
|
t.Errorf("expected: %+v, got: %+v", expectedNames, names) |
|
} |
|
} |
|
|
|
func TestGetBalancedStorage(t *testing.T) { |
|
setupStorages(t) |
|
set := mapset.NewSet[string]() |
|
for i := 0; i < 5; i++ { |
|
storage := op.GetBalancedStorage("/a/d/e1") |
|
set.Add(storage.GetStorage().MountPath) |
|
} |
|
expected := mapset.NewSet([]string{"/a/d/e1", "/a/d/e1.balance"}...) |
|
if !expected.Equal(set) { |
|
t.Errorf("expected: %+v, got: %+v", expected, set) |
|
} |
|
} |
|
|
|
func setupStorages(t *testing.T) { |
|
var storages = []model.Storage{ |
|
{Driver: "Local", MountPath: "/a/b", Order: 0, Addition: `{"root_folder_path":"."}`}, |
|
{Driver: "Local", MountPath: "/adc", Order: 0, Addition: `{"root_folder_path":"."}`}, |
|
{Driver: "Local", MountPath: "/a/c", Order: 1, Addition: `{"root_folder_path":"."}`}, |
|
{Driver: "Local", MountPath: "/a/d", Order: 2, Addition: `{"root_folder_path":"."}`}, |
|
{Driver: "Local", MountPath: "/a/d/e1", Order: 3, Addition: `{"root_folder_path":"."}`}, |
|
{Driver: "Local", MountPath: "/a/d/e", Order: 4, Addition: `{"root_folder_path":"."}`}, |
|
{Driver: "Local", MountPath: "/a/d/e1.balance", Order: 4, Addition: `{"root_folder_path":"."}`}, |
|
} |
|
for _, storage := range storages { |
|
_, err := op.CreateStorage(context.Background(), storage) |
|
if err != nil { |
|
t.Fatalf("failed to create storage: %+v", err) |
|
} |
|
} |
|
} |
|
|