Skip to content

Commit

Permalink
feat: adds wait option for sf deploys #300
Browse files Browse the repository at this point in the history
  • Loading branch information
srinandan committed Sep 20, 2023
1 parent ba4ea88 commit c916aae
Showing 1 changed file with 41 additions and 1 deletion.
42 changes: 41 additions & 1 deletion cmd/sharedflows/depsf.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,10 @@
package sharedflows

import (
"encoding/json"
"internal/apiclient"
"internal/clilog"
"time"

"internal/client/sharedflows"

Expand All @@ -38,15 +41,49 @@ var DepCmd = &cobra.Command{
}
}
_, err = sharedflows.Deploy(name, revision, overrides, serviceAccountName)
apiclient.DisableCmdPrintHttpResponse()

if wait {
clilog.Info.Printf("Checking deployment status in %d seconds\n", interval)

stop := apiclient.Every(interval*time.Second, func(time.Time) bool {
var respBody []byte
respMap := make(map[string]interface{})
if respBody, err = sharedflows.ListRevisionDeployments(name, revision); err != nil {
clilog.Error.Printf("Error fetching sharedflow revision status: %v", err)
return false
}

if err = json.Unmarshal(respBody, &respMap); err != nil {
return true
}

if respMap["state"] == "PROGRESSING" {
clilog.Info.Printf("Sharedflow deployment status is: %s. Waiting %d seconds.\n", respMap["state"], interval)
return true
} else if respMap["state"] == "READY" {
clilog.Info.Println("Sharedflow deployment completed with status: ", respMap["state"])
return false
} else {
clilog.Info.Println("Sharedflow deployment failed with status: ", respMap["state"])
return false
}
})

<-stop
}

return err
},
}

var (
overrides bool
overrides, wait bool
serviceAccountName string
)

const interval = 10

func init() {
DepCmd.Flags().StringVarP(&name, "name", "n",
"", "Sharedflow name")
Expand All @@ -56,6 +93,9 @@ func init() {
-1, "Sharedflow revision. If not set, the highest revision is used")
DepCmd.Flags().BoolVarP(&overrides, "ovr", "r",
false, "Forces deployment of the new revision")
DepCmd.Flags().BoolVarP(&wait, "wait", "",
false, "Waits for the deployment to finish, with success or error")

DepCmd.Flags().StringVarP(&serviceAccountName, "sa", "s",
"", "The format must be {ACCOUNT_ID}@{PROJECT}.iam.gserviceaccount.com.")

Expand Down

0 comments on commit c916aae

Please sign in to comment.