Skip to content

Commit

Permalink
Add tests for Put/GetReplicationTasksDLQ (cadence-workflow#6057)
Browse files Browse the repository at this point in the history
  • Loading branch information
3vilhamster authored May 24, 2024
1 parent 346d753 commit 8fe9988
Show file tree
Hide file tree
Showing 2 changed files with 95 additions and 1 deletion.
2 changes: 1 addition & 1 deletion common/persistence/execution_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -1044,7 +1044,7 @@ func (m *executionManagerImpl) toInternalReplicationTaskInfo(info *ReplicationTa
ScheduledID: info.ScheduledID,
BranchToken: info.BranchToken,
NewRunBranchToken: info.NewRunBranchToken,
CreationTime: time.Unix(0, info.CreationTime),
CreationTime: time.Unix(0, info.CreationTime).UTC(),
}
}

Expand Down
94 changes: 94 additions & 0 deletions common/persistence/execution_manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -675,6 +675,100 @@ func TestDeserializeBufferedEvents(t *testing.T) {
}
}

func TestPutReplicationTaskToDLQ(t *testing.T) {
ctrl := gomock.NewController(t)
mockedStore := NewMockExecutionStore(ctrl)
manager := NewExecutionManagerImpl(mockedStore, testlogger.New(t), nil)

now := time.Now().UTC().Round(time.Second)

task := &PutReplicationTaskToDLQRequest{
SourceClusterName: "test-cluster",
TaskInfo: &ReplicationTaskInfo{
DomainID: testDomainID,
WorkflowID: testWorkflowID,
CreationTime: now.UnixNano(),
},
DomainName: testDomain,
}

mockedStore.EXPECT().PutReplicationTaskToDLQ(gomock.Any(), gomock.Any()).DoAndReturn(func(ctx context.Context, req *InternalPutReplicationTaskToDLQRequest) error {
assert.Equal(t, &InternalPutReplicationTaskToDLQRequest{
SourceClusterName: "test-cluster",
TaskInfo: &InternalReplicationTaskInfo{
DomainID: testDomainID,
WorkflowID: testWorkflowID,
CreationTime: now,
},
}, req)
return nil
})

err := manager.PutReplicationTaskToDLQ(context.Background(), task)
assert.NoError(t, err)
}

func TestGetReplicationTasksFromDLQ(t *testing.T) {
ctrl := gomock.NewController(t)
mockedStore := NewMockExecutionStore(ctrl)
manager := NewExecutionManagerImpl(mockedStore, testlogger.New(t), nil)

request := &GetReplicationTasksFromDLQRequest{
SourceClusterName: "test-cluster",
GetReplicationTasksRequest: GetReplicationTasksRequest{
ReadLevel: 1,
MaxReadLevel: 2,
BatchSize: 10,
NextPageToken: nil,
},
}

now := time.Now().UTC().Round(time.Second)

mockedStore.EXPECT().GetReplicationTasksFromDLQ(gomock.Any(), request).Return(
&InternalGetReplicationTasksFromDLQResponse{
Tasks: []*InternalReplicationTaskInfo{
{
DomainID: testDomainID,
WorkflowID: testWorkflowID,
TaskID: 1,
TaskType: 1,
CreationTime: now,
},
{
DomainID: testDomainID,
WorkflowID: testWorkflowID,
TaskID: 2,
TaskType: 2,
CreationTime: now.Add(time.Second),
},
},
NextPageToken: []byte("test-token"),
}, nil)

res, err := manager.GetReplicationTasksFromDLQ(context.Background(), request)
assert.NoError(t, err)
assert.Equal(t, &GetReplicationTasksFromDLQResponse{
Tasks: []*ReplicationTaskInfo{
{
DomainID: testDomainID,
WorkflowID: testWorkflowID,
TaskID: 1,
TaskType: 1,
CreationTime: now.UnixNano(),
},
{
DomainID: testDomainID,
WorkflowID: testWorkflowID,
TaskID: 2,
TaskType: 2,
CreationTime: now.Add(time.Second).UnixNano(),
},
},
NextPageToken: []byte("test-token"),
}, res)
}

func sampleInternalActivityInfo(name string) *InternalActivityInfo {
return &InternalActivityInfo{
Version: 1,
Expand Down

0 comments on commit 8fe9988

Please sign in to comment.