Skip to content

Commit

Permalink
Add new flag '--force' to run/deploy commands
Browse files Browse the repository at this point in the history
This flag controls, if resources may be re-created, if patching is not possible.
Summary of changes:
- Add force-deploy option to kubectl and kustomize deployer
- Add force-deploy option to helm deployer
- Reduce code duplication in helm_test.go

Signed-off-by: Cornelius Weig <[email protected]>
  • Loading branch information
corneliusweig committed Apr 4, 2019
1 parent e9907a4 commit 63693a3
Show file tree
Hide file tree
Showing 10 changed files with 140 additions and 237 deletions.
1 change: 1 addition & 0 deletions cmd/skaffold/app/cmd/cmd.go
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,7 @@ func FlagToEnvVarName(f *pflag.Flag) string {

func AddRunDeployFlags(cmd *cobra.Command) {
cmd.Flags().BoolVar(&opts.Tail, "tail", false, "Stream logs from deployed objects")
cmd.Flags().BoolVar(&opts.Force, "force", false, "Recreate kubernetes resources if necessary for deployment (default: false, warning: might cause downtime!)")
cmd.Flags().StringArrayVarP(&opts.CustomLabels, "label", "l", nil, "Add custom labels to deployed objects. Set multiple times for multiple labels.")
}

Expand Down
4 changes: 4 additions & 0 deletions docs/content/en/docs/references/cli/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -325,6 +325,7 @@ Flags:
-d, --default-repo string Default repository value (overrides global config)
--enable-rpc skaffold dev Enable gRPC for exposing Skaffold events (true by default for skaffold dev)
-f, --filename string Filename or URL to the pipeline file (default "skaffold.yaml")
--force Recreate kubernetes resources if necessary for deployment (default: false, warning: might cause downtime!)
--images strings A list of pre-built images to deploy
-l, --label stringArray Add custom labels to deployed objects. Set multiple times for multiple labels.
-n, --namespace string Run deployments in the specified namespace
Expand All @@ -349,6 +350,7 @@ Env vars:
* `SKAFFOLD_DEFAULT_REPO` (same as `--default-repo`)
* `SKAFFOLD_ENABLE_RPC` (same as `--enable-rpc`)
* `SKAFFOLD_FILENAME` (same as `--filename`)
* `SKAFFOLD_FORCE` (same as `--force`)
* `SKAFFOLD_IMAGES` (same as `--images`)
* `SKAFFOLD_LABEL` (same as `--label`)
* `SKAFFOLD_NAMESPACE` (same as `--namespace`)
Expand Down Expand Up @@ -511,6 +513,7 @@ Flags:
-d, --default-repo string Default repository value (overrides global config)
--enable-rpc skaffold dev Enable gRPC for exposing Skaffold events (true by default for skaffold dev)
-f, --filename string Filename or URL to the pipeline file (default "skaffold.yaml")
--force Recreate kubernetes resources if necessary for deployment (default: false, warning: might cause downtime!)
-l, --label stringArray Add custom labels to deployed objects. Set multiple times for multiple labels.
-n, --namespace string Run deployments in the specified namespace
--no-prune Skip removing images and containers built by Skaffold
Expand All @@ -535,6 +538,7 @@ Env vars:
* `SKAFFOLD_DEFAULT_REPO` (same as `--default-repo`)
* `SKAFFOLD_ENABLE_RPC` (same as `--enable-rpc`)
* `SKAFFOLD_FILENAME` (same as `--filename`)
* `SKAFFOLD_FORCE` (same as `--force`)
* `SKAFFOLD_LABEL` (same as `--label`)
* `SKAFFOLD_NAMESPACE` (same as `--namespace`)
* `SKAFFOLD_NO_PRUNE` (same as `--no-prune`)
Expand Down
5 changes: 5 additions & 0 deletions pkg/skaffold/config/options.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ type SkaffoldOptions struct {
CacheArtifacts bool
ExperimentalGUI bool
EnableRPC bool
Force bool
NoPrune bool
Profiles []string
CustomTag string
Expand Down Expand Up @@ -89,3 +90,7 @@ func (opts *SkaffoldOptions) Labels() map[string]string {
func (opts *SkaffoldOptions) Prune() bool {
return !opts.NoPrune && !opts.CacheArtifacts
}

func (opts *SkaffoldOptions) ForceDeploy() bool {
return opts.Command == "dev" || opts.Force
}
5 changes: 5 additions & 0 deletions pkg/skaffold/deploy/helm.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ type HelmDeployer struct {
kubeContext string
namespace string
defaultRepo string
forceDeploy bool
}

// NewHelmDeployer returns a new HelmDeployer for a DeployConfig filled
Expand All @@ -58,6 +59,7 @@ func NewHelmDeployer(ctx *runcontext.RunContext) *HelmDeployer {
kubeContext: ctx.KubeContext,
namespace: ctx.Opts.Namespace,
defaultRepo: ctx.DefaultRepo,
forceDeploy: ctx.Opts.ForceDeploy(),
}
}

Expand Down Expand Up @@ -190,6 +192,9 @@ func (h *HelmDeployer) deployRelease(ctx context.Context, out io.Writer, r lates
} else {
args = append(args, "upgrade", releaseName)
args = append(args, h.Flags.Upgrade...)
if h.forceDeploy {
args = append(args, "--force")
}
if r.RecreatePods {
args = append(args, "--recreate-pods")
}
Expand Down
Loading

0 comments on commit 63693a3

Please sign in to comment.