mirror of https://github.com/cloudreve/Cloudreve
Test: remote handler.delete
parent
bf0998f3a5
commit
fffcf1aa1b
|
@ -7,6 +7,7 @@ import (
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/local"
|
"github.com/HFO4/cloudreve/pkg/filesystem/local"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/remote"
|
"github.com/HFO4/cloudreve/pkg/filesystem/remote"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/response"
|
"github.com/HFO4/cloudreve/pkg/filesystem/response"
|
||||||
|
"github.com/HFO4/cloudreve/pkg/request"
|
||||||
"github.com/HFO4/cloudreve/pkg/serializer"
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
"io"
|
"io"
|
||||||
|
@ -152,6 +153,7 @@ func (fs *FileSystem) dispatchHandler() error {
|
||||||
case "remote":
|
case "remote":
|
||||||
fs.Handler = remote.Handler{
|
fs.Handler = remote.Handler{
|
||||||
Policy: currentPolicy,
|
Policy: currentPolicy,
|
||||||
|
Client: request.HTTPClient{},
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -22,7 +22,7 @@ import (
|
||||||
|
|
||||||
// Handler 远程存储策略适配器
|
// Handler 远程存储策略适配器
|
||||||
type Handler struct {
|
type Handler struct {
|
||||||
client request.HTTPClient
|
Client request.Client
|
||||||
Policy *model.Policy
|
Policy *model.Policy
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,7 +69,7 @@ func (handler Handler) Delete(ctx context.Context, files []string) ([]string, er
|
||||||
// 发送删除请求
|
// 发送删除请求
|
||||||
bodyReader := strings.NewReader(string(reqBodyEncoded))
|
bodyReader := strings.NewReader(string(reqBodyEncoded))
|
||||||
authInstance := auth.HMACAuth{SecretKey: []byte(handler.Policy.SecretKey)}
|
authInstance := auth.HMACAuth{SecretKey: []byte(handler.Policy.SecretKey)}
|
||||||
resp, err := handler.client.Request(
|
resp, err := handler.Client.Request(
|
||||||
"POST",
|
"POST",
|
||||||
handler.getAPI("delete"),
|
handler.getAPI("delete"),
|
||||||
bodyReader,
|
bodyReader,
|
||||||
|
@ -87,9 +87,11 @@ func (handler Handler) Delete(ctx context.Context, files []string) ([]string, er
|
||||||
}
|
}
|
||||||
if reqResp.Code != 0 {
|
if reqResp.Code != 0 {
|
||||||
var failedResp serializer.RemoteDeleteRequest
|
var failedResp serializer.RemoteDeleteRequest
|
||||||
err = json.Unmarshal([]byte(reqResp.Data.(string)), &failedResp)
|
if failed, ok := reqResp.Data.(string); ok {
|
||||||
if err == nil {
|
err = json.Unmarshal([]byte(failed), &failedResp)
|
||||||
return failedResp.Files, errors.New(reqResp.Error)
|
if err == nil {
|
||||||
|
return failedResp.Files, errors.New(reqResp.Error)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return files, errors.New("未知的返回结果格式")
|
return files, errors.New("未知的返回结果格式")
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,9 +6,15 @@ import (
|
||||||
"github.com/HFO4/cloudreve/pkg/auth"
|
"github.com/HFO4/cloudreve/pkg/auth"
|
||||||
"github.com/HFO4/cloudreve/pkg/cache"
|
"github.com/HFO4/cloudreve/pkg/cache"
|
||||||
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
|
"github.com/HFO4/cloudreve/pkg/filesystem/fsctx"
|
||||||
|
"github.com/HFO4/cloudreve/pkg/request"
|
||||||
"github.com/HFO4/cloudreve/pkg/serializer"
|
"github.com/HFO4/cloudreve/pkg/serializer"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
testMock "github.com/stretchr/testify/mock"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -85,3 +91,93 @@ func TestHandler_Source(t *testing.T) {
|
||||||
asserts.Contains(res, "api/v3/slave/source/0")
|
asserts.Contains(res, "api/v3/slave/source/0")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ClientMock struct {
|
||||||
|
testMock.Mock
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m ClientMock) Request(method, target string, body io.Reader, opts ...request.Option) request.Response {
|
||||||
|
args := m.Called(method, target, body, opts)
|
||||||
|
return args.Get(0).(request.Response)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHandler_Delete(t *testing.T) {
|
||||||
|
asserts := assert.New(t)
|
||||||
|
handler := Handler{
|
||||||
|
Policy: &model.Policy{
|
||||||
|
SecretKey: "test",
|
||||||
|
Server: "http://test.com",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
// 成功
|
||||||
|
{
|
||||||
|
clientMock := ClientMock{}
|
||||||
|
clientMock.On(
|
||||||
|
"Request",
|
||||||
|
"POST",
|
||||||
|
"http://test.com/api/v3/slave/delete",
|
||||||
|
testMock.Anything,
|
||||||
|
testMock.Anything,
|
||||||
|
).Return(request.Response{
|
||||||
|
Err: nil,
|
||||||
|
Response: &http.Response{
|
||||||
|
StatusCode: 200,
|
||||||
|
Body: ioutil.NopCloser(strings.NewReader(`{"code":0}`)),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
handler.Client = clientMock
|
||||||
|
failed, err := handler.Delete(ctx, []string{"/test1.txt", "test2.txt"})
|
||||||
|
clientMock.AssertExpectations(t)
|
||||||
|
asserts.NoError(err)
|
||||||
|
asserts.Len(failed, 0)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// 结果解析失败
|
||||||
|
{
|
||||||
|
clientMock := ClientMock{}
|
||||||
|
clientMock.On(
|
||||||
|
"Request",
|
||||||
|
"POST",
|
||||||
|
"http://test.com/api/v3/slave/delete",
|
||||||
|
testMock.Anything,
|
||||||
|
testMock.Anything,
|
||||||
|
).Return(request.Response{
|
||||||
|
Err: nil,
|
||||||
|
Response: &http.Response{
|
||||||
|
StatusCode: 200,
|
||||||
|
Body: ioutil.NopCloser(strings.NewReader(`{"code":203}`)),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
handler.Client = clientMock
|
||||||
|
failed, err := handler.Delete(ctx, []string{"/test1.txt", "test2.txt"})
|
||||||
|
clientMock.AssertExpectations(t)
|
||||||
|
asserts.Error(err)
|
||||||
|
asserts.Len(failed, 2)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 一个失败
|
||||||
|
{
|
||||||
|
clientMock := ClientMock{}
|
||||||
|
clientMock.On(
|
||||||
|
"Request",
|
||||||
|
"POST",
|
||||||
|
"http://test.com/api/v3/slave/delete",
|
||||||
|
testMock.Anything,
|
||||||
|
testMock.Anything,
|
||||||
|
).Return(request.Response{
|
||||||
|
Err: nil,
|
||||||
|
Response: &http.Response{
|
||||||
|
StatusCode: 200,
|
||||||
|
Body: ioutil.NopCloser(strings.NewReader(`{"code":203,"data":"{\"files\":[\"1\"]}"}`)),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
handler.Client = clientMock
|
||||||
|
failed, err := handler.Delete(ctx, []string{"/test1.txt", "test2.txt"})
|
||||||
|
clientMock.AssertExpectations(t)
|
||||||
|
asserts.Error(err)
|
||||||
|
asserts.Len(failed, 1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue