From e734cf21bdd7b84fe7a401488e9b77e5a54156f5 Mon Sep 17 00:00:00 2001 From: pengli Date: Tue, 21 Apr 2020 20:08:30 +0800 Subject: [PATCH] Find first error step based on "FinishAt" and "StartAt" Fix issue: #2415 Introduce `StartAt` for the sorting when `FinishedAt` are exactly the same. Since the goal is to find the first failed step, the StartAt and FinishedAt are most simple and directly solution. Moreover, adopt a higher resolution format for `StartAt` to make it more accurately. --- pkg/entrypoint/entrypointer.go | 9 +++++++-- pkg/pod/status.go | 13 +++++++++++-- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/pkg/entrypoint/entrypointer.go b/pkg/entrypoint/entrypointer.go index ab4e416b7d6..1e029f73dc7 100644 --- a/pkg/entrypoint/entrypointer.go +++ b/pkg/entrypoint/entrypointer.go @@ -29,6 +29,11 @@ import ( "go.uber.org/zap" ) +//RFC3339 with millisecond +const ( + timeFormat = "2006-01-02T15:04:05.000Z07:00" +) + // Entrypointer holds fields for running commands with redirected // entrypoints. type Entrypointer struct { @@ -98,7 +103,7 @@ func (e Entrypointer) Go() error { e.WritePostFile(e.PostFile, err) output = append(output, v1alpha1.PipelineResourceResult{ Key: "StartedAt", - Value: time.Now().Format(time.RFC3339), + Value: time.Now().Format(timeFormat), }) return err @@ -110,7 +115,7 @@ func (e Entrypointer) Go() error { } output = append(output, v1alpha1.PipelineResourceResult{ Key: "StartedAt", - Value: time.Now().Format(time.RFC3339), + Value: time.Now().Format(timeFormat), }) err := e.Runner.Run(e.Args...) diff --git a/pkg/pod/status.go b/pkg/pod/status.go index e7ed666030d..61b3c5fd8dd 100644 --- a/pkg/pod/status.go +++ b/pkg/pod/status.go @@ -70,6 +70,9 @@ const ( // ReasonFailed indicates that the reason for the failure status is unknown or that one of the steps failed ReasonFailed = "Failed" + + //timeFormat is RFC3339 with millisecond + timeFormat = "2006-01-02T15:04:05.000Z07:00" ) const oomKilled = "OOMKilled" @@ -164,7 +167,7 @@ func updateStatusStartTime(s *corev1.ContainerStatus) error { } for index, result := range r { if result.Key == "StartedAt" { - t, err := time.Parse(time.RFC3339, result.Value) + t, err := time.Parse(timeFormat, result.Value) if err != nil { return fmt.Errorf("could not parse time value %q in StartedAt field: %w", result.Value, err) } @@ -264,12 +267,18 @@ func areStepsComplete(pod *corev1.Pod) bool { func sortContainerStatuses(podInstance *corev1.Pod) { sort.Slice(podInstance.Status.ContainerStatuses, func(i, j int) bool { - var ifinish, jfinish time.Time + var ifinish, istart, jfinish, jstart time.Time if term := podInstance.Status.ContainerStatuses[i].State.Terminated; term != nil { ifinish = term.FinishedAt.Time + istart = term.StartedAt.Time } if term := podInstance.Status.ContainerStatuses[j].State.Terminated; term != nil { jfinish = term.FinishedAt.Time + jstart = term.StartedAt.Time + } + + if ifinish.Equal(jfinish) { + return istart.Before(jstart) } return ifinish.Before(jfinish) })