From 53dcd047393a004260f6245d2e9d0bb8cc32e5b3 Mon Sep 17 00:00:00 2001 From: Dan Rammer Date: Fri, 8 Apr 2022 16:52:42 -0500 Subject: [PATCH] Reporting more complete metadata for map task subtasks (#417) * fixed potential nil pointer Signed-off-by: Daniel Rammer * updated flyteidl Signed-off-by: Daniel Rammer * added CacheStatus and Logs fields to ExternalResourceInfo proto Signed-off-by: Daniel Rammer * updated flyteplugins Signed-off-by: Daniel Rammer * updated flyteidl Signed-off-by: Daniel Rammer * updated flyteplugins Signed-off-by: Daniel Rammer * updated flyteplugins version Signed-off-by: Daniel Rammer * bumping flyteplugins version Signed-off-by: Daniel Rammer * setting TaskExecutionEvent version to 1 Signed-off-by: Daniel Rammer * bumped flyteidl and flyteplugins version Signed-off-by: Daniel Rammer --- go.mod | 4 ++-- go.sum | 10 +++++----- pkg/controller/nodes/task/transformer.go | 11 +++++++++-- 3 files changed, 16 insertions(+), 9 deletions(-) diff --git a/go.mod b/go.mod index 3a75e1faec..b1b120a76a 100644 --- a/go.mod +++ b/go.mod @@ -6,8 +6,8 @@ require ( github.com/DiSiqueira/GoTree v1.0.1-0.20180907134536-53a8e837f295 github.com/benlaurie/objecthash v0.0.0-20180202135721-d1e3d6079fc1 github.com/fatih/color v1.10.0 - github.com/flyteorg/flyteidl v0.24.9 - github.com/flyteorg/flyteplugins v0.10.16 + github.com/flyteorg/flyteidl v0.24.17 + github.com/flyteorg/flyteplugins v0.10.19 github.com/flyteorg/flytestdlib v0.4.13 github.com/ghodss/yaml v1.0.0 github.com/go-redis/redis v6.15.7+incompatible diff --git a/go.sum b/go.sum index 1e856b5761..36a82886b5 100644 --- a/go.sum +++ b/go.sum @@ -236,11 +236,11 @@ github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5Kwzbycv github.com/fatih/color v1.10.0 h1:s36xzo75JdqLaaWoiEHk767eHiwo0598uUxyfiPkDsg= github.com/fatih/color v1.10.0/go.mod h1:ELkj/draVOlAH/xkhN6mQ50Qd0MPOk5AAr3maGEBuJM= github.com/fatih/structtag v1.2.0/go.mod h1:mBJUNpUnHmRKrKlQQlmCrh5PuhftFbNv8Ys4/aAZl94= -github.com/flyteorg/flyteidl v0.23.0/go.mod h1:576W2ViEyjTpT+kEVHAGbrTP3HARNUZ/eCwrNPmdx9U= -github.com/flyteorg/flyteidl v0.24.9 h1:wmZ/JEiCQ8cR2mkpFsvwwoUdz+g9GotoifBjLqXh7QY= -github.com/flyteorg/flyteidl v0.24.9/go.mod h1:vHSugApgS3hRITIafzQDU8DZD/W8wFRfFcgaFU35Dww= -github.com/flyteorg/flyteplugins v0.10.16 h1:rwNI2MACPbcST2O6CEUsNW6bccz7ZLni0GiY3orevfw= -github.com/flyteorg/flyteplugins v0.10.16/go.mod h1:YBWV8QnFakDJfLyua8pYddiWqszAqseBKIJPNMERlos= +github.com/flyteorg/flyteidl v0.24.7/go.mod h1:576W2ViEyjTpT+kEVHAGbrTP3HARNUZ/eCwrNPmdx9U= +github.com/flyteorg/flyteidl v0.24.17 h1:Xx70bJbuQGyvS8uAyU4AN74rot6KnzJ9r/L9gcCdEsU= +github.com/flyteorg/flyteidl v0.24.17/go.mod h1:vHSugApgS3hRITIafzQDU8DZD/W8wFRfFcgaFU35Dww= +github.com/flyteorg/flyteplugins v0.10.19 h1:9fY3aYXfjVR8jyb4omdWu9RW2FwcmAnld9PHnR0BLW8= +github.com/flyteorg/flyteplugins v0.10.19/go.mod h1:C2va2hfD7mBi24dXRhBi0GIKG4dzFhSR27GsCCFDzss= github.com/flyteorg/flytestdlib v0.3.13/go.mod h1:Tz8JCECAbX6VWGwFT6cmEQ+RJpZ/6L9pswu3fzWs220= github.com/flyteorg/flytestdlib v0.4.13 h1:TzgqhECRGfOHYH1A7rUwcKEEH2rTtPxGy+oYcif7iBw= github.com/flyteorg/flytestdlib v0.4.13/go.mod h1:fv1ar34LJLMTaf0tbfetisLykUlARi7rP+NQTUn6QQs= diff --git a/pkg/controller/nodes/task/transformer.go b/pkg/controller/nodes/task/transformer.go index d988efd1b6..d8bbc2617d 100644 --- a/pkg/controller/nodes/task/transformer.go +++ b/pkg/controller/nodes/task/transformer.go @@ -13,6 +13,9 @@ import ( "github.com/flyteorg/flytepropeller/pkg/controller/nodes/handler" ) +// This is used by flyteadmin to indicate that map tasks now report subtask metadata individually. +var taskExecutionEventVersion = int32(1) + func ToTransitionType(ttype pluginCore.TransitionType) handler.TransitionType { if ttype == pluginCore.TransitionTypeBarrier { return handler.TransitionTypeBarrier @@ -106,13 +109,16 @@ func ToTaskExecutionEvent(input ToTaskExecutionEventInputs) (*event.TaskExecutio ResourcePoolInfo: input.ResourcePoolInfo, } - externalResources := input.Info.Info().ExternalResources - if externalResources != nil { + if input.Info.Info() != nil && input.Info.Info().ExternalResources != nil { + externalResources := input.Info.Info().ExternalResources + metadata.ExternalResources = make([]*event.ExternalResourceInfo, len(externalResources)) for idx, e := range input.Info.Info().ExternalResources { metadata.ExternalResources[idx] = &event.ExternalResourceInfo{ ExternalId: e.ExternalID, + CacheStatus: e.CacheStatus, Index: e.Index, + Logs: e.Logs, RetryAttempt: e.RetryAttempt, Phase: ToTaskEventPhase(e.Phase), } @@ -131,6 +137,7 @@ func ToTaskExecutionEvent(input ToTaskExecutionEventInputs) (*event.TaskExecutio TaskType: input.TaskType, Reason: input.Info.Reason(), Metadata: metadata, + EventVersion: taskExecutionEventVersion, } if input.Info.Phase().IsSuccess() && input.OutputWriter != nil {