Skip to content

Commit

Permalink
Add unit test for add tag (flyteorg#4185)
Browse files Browse the repository at this point in the history
Signed-off-by: Da-Yi Wu <[email protected]>
  • Loading branch information
ericwudayi committed Oct 15, 2023
1 parent 2611d77 commit af77f31
Show file tree
Hide file tree
Showing 19 changed files with 454 additions and 380 deletions.
2 changes: 1 addition & 1 deletion flyteadmin/pkg/manager/impl/execution_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -1346,7 +1346,7 @@ func (m *ExecutionManager) UpdateExecution(ctx context.Context, request admin.Ex
return nil, err
}

if err = transformers.UpdateExecutionModelTag(executionModel, request.Tags); err != nil {
if err = transformers.UpdateExecutionModelAddTag(executionModel, request.AddTags); err != nil {
return nil, err
}

Expand Down
2 changes: 1 addition & 1 deletion flyteadmin/pkg/manager/impl/execution_manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2937,7 +2937,7 @@ func TestUpdateExecution(t *testing.T) {
execManager := NewExecutionManager(repository, r, getMockExecutionsConfigProvider(), getMockStorageForExecTest(context.Background()), mockScope.NewTestScope(), mockScope.NewTestScope(), &mockPublisher, mockExecutionRemoteURL, nil, nil, nil, nil, &eventWriterMocks.WorkflowExecutionEventWriter{})
updateResponse, err := execManager.UpdateExecution(context.Background(), admin.ExecutionUpdateRequest{
Id: &executionIdentifier,
Tags: []string{"tag1", "tag2"},
AddTags: []string{"tag1", "tag2"},
}, time.Now())
assert.NoError(t, err)
assert.NotNil(t, updateResponse)
Expand Down
8 changes: 6 additions & 2 deletions flyteadmin/pkg/repositories/transformers/execution.go
Original file line number Diff line number Diff line change
Expand Up @@ -293,7 +293,7 @@ func UpdateExecutionModelStateChangeDetails(executionModel *models.Execution, st
}

// Update tag information of existing execution model.
func UpdateExecutionModelTag(executionModel *models.Execution, tagsUpdatedTo []string) error {
func UpdateExecutionModelAddTag(executionModel *models.Execution, addTags []string) error {

var spec admin.ExecutionSpec
var err error
Expand All @@ -310,7 +310,11 @@ func UpdateExecutionModelTag(executionModel *models.Execution, tagsUpdatedTo []s
for _, tag := range spec.Tags {
tagSet.Insert(tag)
}
for _, tag := range tagsUpdatedTo {
for _, tag := range addTags {
// if len(tag) == 0, skip
if len(tag) == 0 {
continue
}
// if tag not in tagSet, append into executionModel.Tags
if !tagSet.Has(tag) {
executionModel.Tags = append(executionModel.Tags, models.AdminTag{Name: tag})
Expand Down
67 changes: 67 additions & 0 deletions flyteadmin/pkg/repositories/transformers/execution_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -901,6 +901,73 @@ func TestUpdateExecutionModelStateChangeDetails(t *testing.T) {
})
}

func TestUpdateExecutionModelAddTags(t *testing.T) {
t.Run("empty closure", func(t *testing.T) {
execModel := &models.Execution{}
tags := []string{"tags1", "tags2"}

err := UpdateExecutionModelAddTag(execModel, tags)
assert.Nil(t, err)
execTags := execModel.Tags
// Extract string of execTags
var execTagsString []string
for _, tag := range execTags {
execTagsString = append(execTagsString, tag.Name)
}
assert.Equal(t, tags, execTagsString)

var spec admin.ExecutionSpec
err = proto.Unmarshal(execModel.Spec, &spec)
assert.Nil(t, err)
assert.NotNil(t, spec)
assert.Equal(t, tags, spec.Tags)
})

t.Run("empty add tags", func(t *testing.T) {
execModel := &models.Execution{}
execModel.Tags = []models.AdminTag{
{Name: "tags1",},
{Name: "tags2",},
}
ref_tags := []string{"tags1", "tags2"}
tags := []string{""}

err := UpdateExecutionModelAddTag(execModel, tags)
assert.Nil(t, err)
var execTagsString []string
for _, tag := range execModel.Tags {
execTagsString = append(execTagsString, tag.Name)
}
assert.Nil(t, err)
assert.Equal(t, ref_tags, execTagsString)
})
t.Run("duplicate tags", func(t *testing.T) {
spec := testutils.GetExecutionRequest().Spec
spec.Tags = []string{"tags1", "tags2"}
specBytes, _ := proto.Marshal(spec)

execModel := &models.Execution{
Spec: specBytes,
}

execModel.Tags = []models.AdminTag{
{Name: "tags1",},
{Name: "tags2",},
}

tags := []string{"tags2", "tags3"}
err := UpdateExecutionModelAddTag(execModel, tags)
assert.Nil(t, err)

var execTagsString []string
for _, tag := range execModel.Tags {
execTagsString = append(execTagsString, tag.Name)
}
assert.Nil(t, err)
assert.Equal(t, []string{"tags1", "tags2", "tags3"}, execTagsString)
})
}

func TestTrimErrorMessage(t *testing.T) {
errMsg := "[1/1] currentAttempt done. Last Error: USER:: │\n│ ❱ 760 │ │ │ │ return __callback(*args, **kwargs) │\n││"
trimmedErrMessage := TrimErrorMessage(errMsg)
Expand Down
87 changes: 44 additions & 43 deletions flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.cc

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit af77f31

Please sign in to comment.