From cc8a9665bcfd4511c2861d9c805bd6af7e1d5d2b Mon Sep 17 00:00:00 2001 From: Da-Yi Wu Date: Sat, 23 Sep 2023 15:47:40 +0800 Subject: [PATCH] Update the Tags into Execution.Tag Signed-off-by: Da-Yi Wu --- pkg/repositories/transformers/execution.go | 42 ++++------------------ 1 file changed, 6 insertions(+), 36 deletions(-) diff --git a/pkg/repositories/transformers/execution.go b/pkg/repositories/transformers/execution.go index 1dca8004..202c4e00 100644 --- a/pkg/repositories/transformers/execution.go +++ b/pkg/repositories/transformers/execution.go @@ -103,7 +103,7 @@ func CreateExecutionModel(input CreateExecutionModelInput) (*models.Execution, e for i, tag := range input.RequestSpec.Tags { tags[i] = models.AdminTag{Name: tag} } - + executionModel := &models.Execution{ ExecutionKey: models.ExecutionKey{ Project: input.WorkflowExecutionID.Project, @@ -294,7 +294,6 @@ func UpdateExecutionModelStateChangeDetails(executionModel *models.Execution, st // Update tag information of existing execution model. func UpdateExecutionModelTag(executionModel *models.Execution, tagsUpdatedTo []string) error { - //tagUpdatedAt time.Time, tagUpdatedBy string) error { var spec admin.ExecutionSpec var err error @@ -302,54 +301,25 @@ func UpdateExecutionModelTag(executionModel *models.Execution, tagsUpdatedTo []s return errors.NewFlyteAdminErrorf(codes.Internal, "failed to unmarshal spec") } - // Update the closure with the same - //var tagUpdatedAtProto *timestamppb.Timestamp - // Default use the createdAt timestamp as the state change occurredAt time - //if stateUpdatedAtProto, err = ptypes.TimestampProto(stateUpdatedAt); err != nil { - // return err - //} - - // combine tags and tagsUpdatedTo to one []models.AdminTag and then write back to executionModel.Tags - // logger out the tags name of executionModel.Tags - //logger.Infof(context.Background(), "Before UpdateTag is executed") - //for _, tag := range spec.Tags { - // logger.Infof(context.Background(), "tag name: %v", tag) - //} - //Append tagsUpdatedTo to spec.Tags, but use set to avoid duplicate tags tagSet := sets.NewString() for _, tag := range spec.Tags { tagSet.Insert(tag) } for _, tag := range tagsUpdatedTo { + // if tag not in tagSet, append into executionModel.Tags + if !tagSet.Has(tag) { + executionModel.Tags = append(executionModel.Tags, models.AdminTag{Name: tag}) + } tagSet.Insert(tag) } spec.Tags = tagSet.List() - //logger.Infof(context.Background(), "After tag name: %v", spec.Tags) - //spec.Tags = append(spec.Tags, tagsUpdatedTo...) - //Write into DB + marshaledSpec, err := proto.Marshal(&spec) if err != nil { return errors.NewFlyteAdminErrorf(codes.Internal, "Failed to marshal execution spec: %v", err) } executionModel.Spec = marshaledSpec - // logger out the tags name of executionModel.Tags - - //logger.Infof(context.Background(), "After UpdateTag is executed") - //for _, tag := range executionModel.Tags { - // logger.Infof(context.Background(), "tag name: %v", tag.Name) - //} - //I need to figure out where is tag is wrote? - //closure.StateChangeDetails = &admin.ExecutionStateChangeDetails{ - // Tags: tagsUpdatedTo, - // Principal: stateUpdatedBy, - // OccurredAt: stateUpdatedAtProto, - //} - //marshaledClosure, err := proto.Marshal(&closure) - //if err != nil { - // return errors.NewFlyteAdminErrorf(codes.Internal, "Failed to marshal execution closure: %v", err) - //} - //executionModel.Closure = marshaledClosure return nil }