| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- package v2
- import (
- "context"
- "errors"
- "fmt"
- "time"
- "github.com/fatih/color"
- api "github.com/porter-dev/porter/api/client"
- "github.com/porter-dev/porter/api/server/handlers/porter_app"
- )
- const (
- // DefaultWaitTimeoutMinutes is the default timeout for waiting for an update-image to complete
- DefaultWaitTimeoutMinutes = 10
- // DefaultRetryFrequencySeconds is the default frequency for checking the status of an update-image
- DefaultRetryFrequencySeconds = 10
- )
- // waitForAppRevisionStatusInput is the input for the WaitForAppRevisionStatus function
- type waitForAppRevisionStatusInput struct {
- ProjectID uint
- ClusterID uint
- AppName string
- RevisionID string
- Client api.Client
- }
- // waitForAppRevisionStatus waits for an app revision to complete
- func waitForAppRevisionStatus(ctx context.Context, input waitForAppRevisionStatusInput) error {
- timeoutMinutes := DefaultWaitTimeoutMinutes
- timeout := time.Duration(timeoutMinutes) * time.Minute
- deadline := time.Now().Add(timeout)
- color.New(color.FgBlue).Printf("Waiting up to %d minutes for all services to deploy\n", timeoutMinutes) // nolint:errcheck,gosec
- var status porter_app.HighLevelStatus
- for time.Now().Before(deadline) {
- statusResp, err := input.Client.GetRevisionStatus(ctx, input.ProjectID, input.ClusterID, input.AppName, input.RevisionID)
- if err != nil {
- return fmt.Errorf("error getting app revision status: %w", err)
- }
- if statusResp == nil {
- return errors.New("unable to determine status of app revision")
- }
- status = statusResp.HighLevelStatus
- if status != porter_app.HighLevelStatus_Progressing {
- break
- }
- time.Sleep(DefaultRetryFrequencySeconds * time.Second)
- }
- switch status {
- case porter_app.HighLevelStatus_Progressing:
- return fmt.Errorf("timeout exceeded")
- case porter_app.HighLevelStatus_Successful:
- _, _ = color.New(color.FgGreen).Printf("All services deployed successfully\n") // nolint:errcheck,gosec
- return nil
- case porter_app.HighLevelStatus_Failed:
- return fmt.Errorf("update failed: check dashboard for details")
- default:
- return fmt.Errorf("received unknown status: %s", status)
- }
- }
|