Add tests for sync handler
This commit is contained in:
parent
3f90011c10
commit
500725ffee
@ -90,7 +90,7 @@ func (s *syncTreeHandler) handleHeadUpdate(
|
|||||||
|
|
||||||
if fullRequest != nil {
|
if fullRequest != nil {
|
||||||
log.With("senderId", senderId).
|
log.With("senderId", senderId).
|
||||||
With("heads", fullRequest.GetContent().GetFullSyncRequest().Heads).
|
With("heads", objTree.Heads()).
|
||||||
With("treeId", objTree.ID()).
|
With("treeId", objTree.ID()).
|
||||||
Debug("sending full sync request")
|
Debug("sending full sync request")
|
||||||
return s.syncClient.SendAsync(senderId, fullRequest, replyId)
|
return s.syncClient.SendAsync(senderId, fullRequest, replyId)
|
||||||
@ -127,10 +127,6 @@ func (s *syncTreeHandler) handleFullSyncRequest(
|
|||||||
objTree.Lock()
|
objTree.Lock()
|
||||||
defer objTree.Unlock()
|
defer objTree.Unlock()
|
||||||
|
|
||||||
if header == nil {
|
|
||||||
header = objTree.Header()
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(request.Changes) != 0 && !s.alreadyHasHeads(objTree, request.Heads) {
|
if len(request.Changes) != 0 && !s.alreadyHasHeads(objTree, request.Heads) {
|
||||||
_, err = objTree.AddRawChanges(ctx, request.Changes...)
|
_, err = objTree.AddRawChanges(ctx, request.Changes...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@ -3,14 +3,13 @@ package synctree
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/spacesyncproto"
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/synctree/mock_synctree"
|
||||||
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/syncservice/mock_syncservice"
|
|
||||||
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/commonspace/treegetter/mock_treegetter"
|
|
||||||
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/pkg/acl/tree"
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/pkg/acl/tree"
|
||||||
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/pkg/acl/tree/mock_objecttree"
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/pkg/acl/tree/mock_objecttree"
|
||||||
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/pkg/acl/treechangeproto"
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/common/pkg/acl/treechangeproto"
|
||||||
"github.com/golang/mock/gomock"
|
"github.com/golang/mock/gomock"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
"go.uber.org/zap"
|
||||||
"sync"
|
"sync"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
@ -39,25 +38,26 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
defer ctrl.Finish()
|
defer ctrl.Finish()
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
spaceId := "spaceId"
|
syncClientMock := mock_synctree.NewMockSyncClient(ctrl)
|
||||||
cacheMock := mock_treegetter.NewMockTreeGetter(ctrl)
|
|
||||||
syncClientMock := mock_syncservice.NewMockSyncClient(ctrl)
|
|
||||||
objectTreeMock := newTestObjMock(mock_tree.NewMockObjectTree(ctrl))
|
objectTreeMock := newTestObjMock(mock_tree.NewMockObjectTree(ctrl))
|
||||||
|
|
||||||
syncHandler := newSyncTreeHandler(spaceId, cacheMock, syncClientMock)
|
syncHandler := newSyncTreeHandler(objectTreeMock, syncClientMock)
|
||||||
|
log = zap.NewNop().Sugar()
|
||||||
|
|
||||||
t.Run("head update non empty all heads added", func(t *testing.T) {
|
t.Run("head update non empty all heads added", func(t *testing.T) {
|
||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
headUpdate := &spacesyncproto.ObjectHeadUpdate{
|
headUpdate := &treechangeproto.TreeHeadUpdate{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}
|
}
|
||||||
msg := spacesyncproto.WrapHeadUpdate(headUpdate, chWithId, treeId, "")
|
treeMsg := treechangeproto.WrapHeadUpdate(headUpdate, chWithId)
|
||||||
cacheMock.EXPECT().
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(objectTreeMock, nil)
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h2"})
|
Return([]string{"h2"})
|
||||||
@ -74,7 +74,7 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
HasChanges(gomock.Eq([]string{"h1"})).
|
HasChanges(gomock.Eq([]string{"h1"})).
|
||||||
Return(true)
|
Return(true)
|
||||||
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -82,16 +82,17 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
headUpdate := &spacesyncproto.ObjectHeadUpdate{
|
headUpdate := &treechangeproto.TreeHeadUpdate{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}
|
}
|
||||||
fullRequest := &spacesyncproto.ObjectSyncMessage{}
|
treeMsg := treechangeproto.WrapHeadUpdate(headUpdate, chWithId)
|
||||||
msg := spacesyncproto.WrapHeadUpdate(headUpdate, chWithId, treeId, "")
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
cacheMock.EXPECT().
|
fullRequest := &treechangeproto.TreeSyncMessage{}
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(objectTreeMock, nil)
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h2"})
|
Return([]string{"h2"})
|
||||||
@ -108,11 +109,15 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
HasChanges(gomock.Eq([]string{"h1"})).
|
HasChanges(gomock.Eq([]string{"h1"})).
|
||||||
Return(false)
|
Return(false)
|
||||||
syncClientMock.EXPECT().
|
syncClientMock.EXPECT().
|
||||||
CreateFullSyncRequest(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"}), gomock.Eq("")).
|
CreateFullSyncRequest(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"})).
|
||||||
Return(fullRequest, nil)
|
Return(fullRequest, nil)
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
Heads().
|
||||||
|
Return([]string{"h2"})
|
||||||
|
|
||||||
syncClientMock.EXPECT().SendAsync(gomock.Eq([]string{senderId}), gomock.Eq(fullRequest))
|
syncClientMock.EXPECT().SendAsync(gomock.Eq(senderId), gomock.Eq(fullRequest), gomock.Eq(""))
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
|
||||||
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -120,20 +125,21 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
headUpdate := &spacesyncproto.ObjectHeadUpdate{
|
headUpdate := &treechangeproto.TreeHeadUpdate{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}
|
}
|
||||||
msg := spacesyncproto.WrapHeadUpdate(headUpdate, chWithId, treeId, "")
|
treeMsg := treechangeproto.WrapHeadUpdate(headUpdate, chWithId)
|
||||||
cacheMock.EXPECT().
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(objectTreeMock, nil)
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h1"})
|
Return([]string{"h1"})
|
||||||
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -141,25 +147,30 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
headUpdate := &spacesyncproto.ObjectHeadUpdate{
|
headUpdate := &treechangeproto.TreeHeadUpdate{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: nil,
|
Changes: nil,
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}
|
}
|
||||||
fullRequest := &spacesyncproto.ObjectSyncMessage{}
|
treeMsg := treechangeproto.WrapHeadUpdate(headUpdate, chWithId)
|
||||||
msg := spacesyncproto.WrapHeadUpdate(headUpdate, chWithId, treeId, "")
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
cacheMock.EXPECT().
|
fullRequest := &treechangeproto.TreeSyncMessage{}
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(objectTreeMock, nil)
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h2"})
|
Return([]string{"h2"})
|
||||||
syncClientMock.EXPECT().
|
syncClientMock.EXPECT().
|
||||||
CreateFullSyncRequest(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"}), gomock.Eq("")).
|
CreateFullSyncRequest(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"})).
|
||||||
Return(fullRequest, nil)
|
Return(fullRequest, nil)
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
Heads().
|
||||||
|
Return([]string{"h2"})
|
||||||
|
|
||||||
syncClientMock.EXPECT().SendAsync(gomock.Eq([]string{senderId}), gomock.Eq(fullRequest))
|
syncClientMock.EXPECT().SendAsync(gomock.Eq(senderId), gomock.Eq(fullRequest), gomock.Eq(""))
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
|
||||||
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -167,21 +178,21 @@ func TestSyncHandler_HandleHeadUpdate(t *testing.T) {
|
|||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
headUpdate := &spacesyncproto.ObjectHeadUpdate{
|
headUpdate := &treechangeproto.TreeHeadUpdate{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: nil,
|
Changes: nil,
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}
|
}
|
||||||
msg := spacesyncproto.WrapHeadUpdate(headUpdate, chWithId, treeId, "")
|
treeMsg := treechangeproto.WrapHeadUpdate(headUpdate, chWithId)
|
||||||
cacheMock.EXPECT().
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(objectTreeMock, nil)
|
|
||||||
|
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h1"})
|
Return([]string{"h1"})
|
||||||
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -191,26 +202,26 @@ func TestSyncHandler_HandleFullSyncRequest(t *testing.T) {
|
|||||||
defer ctrl.Finish()
|
defer ctrl.Finish()
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
spaceId := "spaceId"
|
syncClientMock := mock_synctree.NewMockSyncClient(ctrl)
|
||||||
cacheMock := mock_treegetter.NewMockTreeGetter(ctrl)
|
|
||||||
syncClientMock := mock_syncservice.NewMockSyncClient(ctrl)
|
|
||||||
objectTreeMock := newTestObjMock(mock_tree.NewMockObjectTree(ctrl))
|
objectTreeMock := newTestObjMock(mock_tree.NewMockObjectTree(ctrl))
|
||||||
|
|
||||||
syncHandler := newSyncTreeHandler(spaceId, cacheMock, syncClientMock)
|
syncHandler := newSyncTreeHandler(objectTreeMock, syncClientMock)
|
||||||
|
log = zap.NewNop().Sugar()
|
||||||
t.Run("full sync request with change", func(t *testing.T) {
|
t.Run("full sync request with change", func(t *testing.T) {
|
||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
msg := spacesyncproto.WrapFullRequest(&spacesyncproto.ObjectFullSyncRequest{
|
fullSyncRequest := &treechangeproto.TreeFullSyncRequest{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}, chWithId, treeId, "")
|
}
|
||||||
fullRequest := &spacesyncproto.ObjectSyncMessage{}
|
treeMsg := treechangeproto.WrapFullRequest(fullSyncRequest, chWithId)
|
||||||
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
cacheMock.EXPECT().
|
fullResponse := &treechangeproto.TreeSyncMessage{}
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
objectTreeMock.EXPECT().
|
||||||
Return(objectTreeMock, nil)
|
ID().AnyTimes().Return(treeId)
|
||||||
|
objectTreeMock.EXPECT().Header().Return(nil)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h2"})
|
Return([]string{"h2"})
|
||||||
@ -221,11 +232,10 @@ func TestSyncHandler_HandleFullSyncRequest(t *testing.T) {
|
|||||||
AddRawChanges(gomock.Any(), gomock.Eq([]*treechangeproto.RawTreeChangeWithId{chWithId})).
|
AddRawChanges(gomock.Any(), gomock.Eq([]*treechangeproto.RawTreeChangeWithId{chWithId})).
|
||||||
Return(tree.AddResult{}, nil)
|
Return(tree.AddResult{}, nil)
|
||||||
syncClientMock.EXPECT().
|
syncClientMock.EXPECT().
|
||||||
CreateFullSyncResponse(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"}), gomock.Eq("")).
|
CreateFullSyncResponse(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"})).
|
||||||
Return(fullRequest, nil)
|
Return(fullResponse, nil)
|
||||||
|
syncClientMock.EXPECT().SendAsync(gomock.Eq(senderId), gomock.Eq(fullResponse), gomock.Eq(""))
|
||||||
syncClientMock.EXPECT().SendAsync(gomock.Eq([]string{senderId}), gomock.Eq(fullRequest))
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -233,66 +243,76 @@ func TestSyncHandler_HandleFullSyncRequest(t *testing.T) {
|
|||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
msg := spacesyncproto.WrapFullRequest(&spacesyncproto.ObjectFullSyncRequest{
|
fullSyncRequest := &treechangeproto.TreeFullSyncRequest{
|
||||||
Heads: []string{"h2"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h2"},
|
SnapshotPath: []string{"h1"},
|
||||||
}, chWithId, treeId, "")
|
}
|
||||||
fullRequest := &spacesyncproto.ObjectSyncMessage{}
|
treeMsg := treechangeproto.WrapFullRequest(fullSyncRequest, chWithId)
|
||||||
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
|
fullResponse := &treechangeproto.TreeSyncMessage{}
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
|
objectTreeMock.EXPECT().Header().Return(nil)
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
Heads().
|
||||||
|
Return([]string{"h1"})
|
||||||
|
syncClientMock.EXPECT().
|
||||||
|
CreateFullSyncResponse(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"})).
|
||||||
|
Return(fullResponse, nil)
|
||||||
|
syncClientMock.EXPECT().SendAsync(gomock.Eq(senderId), gomock.Eq(fullResponse), gomock.Eq(""))
|
||||||
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
|
require.NoError(t, err)
|
||||||
|
})
|
||||||
|
|
||||||
cacheMock.EXPECT().
|
t.Run("full sync request without change but with reply id", func(t *testing.T) {
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
treeId := "treeId"
|
||||||
Return(objectTreeMock, nil)
|
senderId := "senderId"
|
||||||
|
replyId := "replyId"
|
||||||
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
|
fullSyncRequest := &treechangeproto.TreeFullSyncRequest{
|
||||||
|
Heads: []string{"h1"},
|
||||||
|
SnapshotPath: []string{"h1"},
|
||||||
|
}
|
||||||
|
treeMsg := treechangeproto.WrapFullRequest(fullSyncRequest, chWithId)
|
||||||
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, replyId)
|
||||||
|
fullResponse := &treechangeproto.TreeSyncMessage{}
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
|
objectTreeMock.EXPECT().Header().Return(nil)
|
||||||
|
syncClientMock.EXPECT().
|
||||||
|
CreateFullSyncResponse(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"})).
|
||||||
|
Return(fullResponse, nil)
|
||||||
|
syncClientMock.EXPECT().SendAsync(gomock.Eq(senderId), gomock.Eq(fullResponse), gomock.Eq(replyId))
|
||||||
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
|
require.NoError(t, err)
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("full sync request with add raw changes error", func(t *testing.T) {
|
||||||
|
treeId := "treeId"
|
||||||
|
senderId := "senderId"
|
||||||
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
|
fullSyncRequest := &treechangeproto.TreeFullSyncRequest{
|
||||||
|
Heads: []string{"h1"},
|
||||||
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
|
SnapshotPath: []string{"h1"},
|
||||||
|
}
|
||||||
|
treeMsg := treechangeproto.WrapFullRequest(fullSyncRequest, chWithId)
|
||||||
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, "")
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
|
ID().AnyTimes().Return(treeId)
|
||||||
|
objectTreeMock.EXPECT().Header().Return(nil)
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h2"})
|
Return([]string{"h2"})
|
||||||
syncClientMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
CreateFullSyncResponse(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h2"}), gomock.Eq([]string{"h2"}), gomock.Eq("")).
|
HasChanges(gomock.Eq([]string{"h1"})).
|
||||||
Return(fullRequest, nil)
|
Return(false)
|
||||||
|
objectTreeMock.EXPECT().
|
||||||
syncClientMock.EXPECT().SendAsync(gomock.Eq([]string{senderId}), gomock.Eq(fullRequest))
|
AddRawChanges(gomock.Any(), gomock.Eq([]*treechangeproto.RawTreeChangeWithId{chWithId})).
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
Return(tree.AddResult{}, fmt.Errorf(""))
|
||||||
require.NoError(t, err)
|
syncClientMock.EXPECT().SendAsync(gomock.Eq(senderId), gomock.Any(), gomock.Eq(""))
|
||||||
})
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
|
|
||||||
t.Run("full sync request without change", func(t *testing.T) {
|
|
||||||
treeId := "treeId"
|
|
||||||
senderId := "senderId"
|
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
|
||||||
msg := spacesyncproto.WrapFullRequest(&spacesyncproto.ObjectFullSyncRequest{
|
|
||||||
Heads: []string{"h1"},
|
|
||||||
SnapshotPath: []string{"h1"},
|
|
||||||
}, chWithId, treeId, "")
|
|
||||||
fullRequest := &spacesyncproto.ObjectSyncMessage{}
|
|
||||||
|
|
||||||
cacheMock.EXPECT().
|
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(objectTreeMock, nil)
|
|
||||||
syncClientMock.EXPECT().
|
|
||||||
CreateFullSyncResponse(gomock.Eq(objectTreeMock), gomock.Eq([]string{"h1"}), gomock.Eq([]string{"h1"}), gomock.Eq("")).
|
|
||||||
Return(fullRequest, nil)
|
|
||||||
|
|
||||||
syncClientMock.EXPECT().SendAsync(gomock.Eq([]string{senderId}), gomock.Eq(fullRequest))
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
|
||||||
require.NoError(t, err)
|
|
||||||
})
|
|
||||||
|
|
||||||
t.Run("full sync request with get tree error", func(t *testing.T) {
|
|
||||||
treeId := "treeId"
|
|
||||||
senderId := "senderId"
|
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
|
||||||
msg := spacesyncproto.WrapFullRequest(&spacesyncproto.ObjectFullSyncRequest{
|
|
||||||
Heads: []string{"h1"},
|
|
||||||
SnapshotPath: []string{"h1"},
|
|
||||||
}, chWithId, treeId, "")
|
|
||||||
|
|
||||||
cacheMock.EXPECT().
|
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
|
||||||
Return(nil, fmt.Errorf("some"))
|
|
||||||
|
|
||||||
syncClientMock.EXPECT().
|
|
||||||
SendAsync(gomock.Eq([]string{senderId}), gomock.Any())
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -302,25 +322,25 @@ func TestSyncHandler_HandleFullSyncResponse(t *testing.T) {
|
|||||||
defer ctrl.Finish()
|
defer ctrl.Finish()
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
spaceId := "spaceId"
|
syncClientMock := mock_synctree.NewMockSyncClient(ctrl)
|
||||||
cacheMock := mock_treegetter.NewMockTreeGetter(ctrl)
|
|
||||||
syncClientMock := mock_syncservice.NewMockSyncClient(ctrl)
|
|
||||||
objectTreeMock := newTestObjMock(mock_tree.NewMockObjectTree(ctrl))
|
objectTreeMock := newTestObjMock(mock_tree.NewMockObjectTree(ctrl))
|
||||||
|
|
||||||
syncHandler := newSyncTreeHandler(spaceId, cacheMock, syncClientMock)
|
syncHandler := newSyncTreeHandler(objectTreeMock, syncClientMock)
|
||||||
|
log = zap.NewNop().Sugar()
|
||||||
|
|
||||||
t.Run("full sync response with change", func(t *testing.T) {
|
t.Run("full sync response with change", func(t *testing.T) {
|
||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
|
replyId := "replyId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
msg := spacesyncproto.WrapFullResponse(&spacesyncproto.ObjectFullSyncResponse{
|
fullSyncResponse := &treechangeproto.TreeFullSyncResponse{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}, chWithId, treeId, "")
|
}
|
||||||
|
treeMsg := treechangeproto.WrapFullResponse(fullSyncResponse, chWithId)
|
||||||
cacheMock.EXPECT().
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, replyId)
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
objectTreeMock.EXPECT().ID().AnyTimes().Return(treeId)
|
||||||
Return(objectTreeMock, nil)
|
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h2"})
|
Return([]string{"h2"})
|
||||||
@ -331,28 +351,28 @@ func TestSyncHandler_HandleFullSyncResponse(t *testing.T) {
|
|||||||
AddRawChanges(gomock.Any(), gomock.Eq([]*treechangeproto.RawTreeChangeWithId{chWithId})).
|
AddRawChanges(gomock.Any(), gomock.Eq([]*treechangeproto.RawTreeChangeWithId{chWithId})).
|
||||||
Return(tree.AddResult{}, nil)
|
Return(tree.AddResult{}, nil)
|
||||||
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("full sync response same heads", func(t *testing.T) {
|
t.Run("full sync response with same heads", func(t *testing.T) {
|
||||||
treeId := "treeId"
|
treeId := "treeId"
|
||||||
senderId := "senderId"
|
senderId := "senderId"
|
||||||
|
replyId := "replyId"
|
||||||
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
chWithId := &treechangeproto.RawTreeChangeWithId{}
|
||||||
msg := spacesyncproto.WrapFullResponse(&spacesyncproto.ObjectFullSyncResponse{
|
fullSyncResponse := &treechangeproto.TreeFullSyncResponse{
|
||||||
Heads: []string{"h1"},
|
Heads: []string{"h1"},
|
||||||
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
Changes: []*treechangeproto.RawTreeChangeWithId{chWithId},
|
||||||
SnapshotPath: []string{"h1"},
|
SnapshotPath: []string{"h1"},
|
||||||
}, chWithId, treeId, "")
|
}
|
||||||
|
treeMsg := treechangeproto.WrapFullResponse(fullSyncResponse, chWithId)
|
||||||
cacheMock.EXPECT().
|
objectMsg, _ := marshallTreeMessage(treeMsg, treeId, replyId)
|
||||||
GetTree(gomock.Any(), spaceId, treeId).
|
objectTreeMock.EXPECT().ID().AnyTimes().Return(treeId)
|
||||||
Return(objectTreeMock, nil)
|
|
||||||
objectTreeMock.EXPECT().
|
objectTreeMock.EXPECT().
|
||||||
Heads().
|
Heads().
|
||||||
Return([]string{"h1"})
|
Return([]string{"h1"})
|
||||||
|
|
||||||
err := syncHandler.HandleMessage(ctx, senderId, msg)
|
err := syncHandler.HandleMessage(ctx, senderId, objectMsg)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user