diff --git a/pkg/skaffold/kubernetes/status/resource/deployment.go b/pkg/skaffold/kubernetes/status/resource/deployment.go index 2013e300c4e..f6040975dc6 100644 --- a/pkg/skaffold/kubernetes/status/resource/deployment.go +++ b/pkg/skaffold/kubernetes/status/resource/deployment.go @@ -166,6 +166,8 @@ func (r *Resource) checkStandalonePodsStatus(ctx context.Context, cfg kubectl.Co if podReady, _ := strconv.ParseBool(string(b)); !podReady { pendingPods = append(pendingPods, pod.Name()) } + case "Succeeded": + log.Entry(ctx).Debugf("pod '%s' succeeded - ignoring", pod.Name()) default: pendingPods = append(pendingPods, pod.Name()) } @@ -237,6 +239,10 @@ func (r *Resource) CheckStatus(ctx context.Context, cfg kubectl.Config) { // See https://github.com/GoogleCloudPlatform/cloud-code-vscode-internal/issues/5277 if ae.ErrCode == proto.StatusCode_STATUSCHECK_SUCCESS { for _, pod := range r.resources { + if pod.Status() == "Succeeded" { + continue // Skip terminated pods + } + eventV2.ResourceStatusCheckEventCompletedMessage( pod.String(), fmt.Sprintf("%s %s: running.\n", tabHeader, pod.String()), diff --git a/pkg/skaffold/kubernetes/status/resource/deployment_test.go b/pkg/skaffold/kubernetes/status/resource/deployment_test.go index 03d1dc018e2..bd1f7f21a27 100644 --- a/pkg/skaffold/kubernetes/status/resource/deployment_test.go +++ b/pkg/skaffold/kubernetes/status/resource/deployment_test.go @@ -126,6 +126,58 @@ func TestDeploymentCheckStatus(t *testing.T) { } } +func TestStandalonePodsCheckStatus(t *testing.T) { + ns := "test-ns" + tests := []struct { + description string + podStatus string + expectedMessage string + expectedErrCode proto.StatusCode + }{ + { + description: "running pod not ready", + podStatus: "Running", + expectedErrCode: proto.StatusCode_STATUSCHECK_STANDALONE_PODS_PENDING, + expectedMessage: "pods not ready: [test-pod]", + }, + { + description: "failed pod", + podStatus: "Failed", + expectedErrCode: proto.StatusCode_STATUSCHECK_UNKNOWN, + expectedMessage: "pod test-pod failed", + }, + { + description: "pending pod", + podStatus: "Pending", + expectedErrCode: proto.StatusCode_STATUSCHECK_STANDALONE_PODS_PENDING, + expectedMessage: "pods not ready: [test-pod]", + }, + { + description: "succeeded pod", + podStatus: "Succeeded", + expectedErrCode: proto.StatusCode_STATUSCHECK_SUCCESS, + expectedMessage: "", + }, + { + description: "unknown status pod", + podStatus: "Unknown", + expectedErrCode: proto.StatusCode_STATUSCHECK_STANDALONE_PODS_PENDING, + expectedMessage: "pods not ready: [test-pod]", + }, + } + + for _, test := range tests { + testutil.Run(t, test.description, func(t *testutil.T) { + r := NewResource("test-standalone-pods", ResourceTypes.StandalonePods, ns, 42, false) + r.resources = map[string]validator.Resource{} + r.resources["test-pod"] = validator.NewResource(ns, "pod", "test-pod", validator.Status(test.podStatus), nil, nil) + r.CheckStatus(context.Background(), &statusConfig{}) + t.CheckDeepEqual(r.status.ae.GetMessage(), test.expectedMessage) + t.CheckDeepEqual(r.status.ae.GetErrCode(), test.expectedErrCode) + }) + } +} + func TestParseKubectlError(t *testing.T) { tests := []struct { description string