mirror of
https://github.com/helm/helm.git
synced 2026-04-21 14:17:01 -04:00
Merge pull request #31648 from hiddeco/backport-12564-to-dev-v3
[v3 backport] fix(uninstall): supersede deployed releases
This commit is contained in:
commit
0bfd2cbe75
4 changed files with 26 additions and 1 deletions
1
cmd/helm/testdata/output/uninstall-keep-history-earlier-deployed.txt
vendored
Normal file
1
cmd/helm/testdata/output/uninstall-keep-history-earlier-deployed.txt
vendored
Normal file
|
|
@ -0,0 +1 @@
|
|||
release "aeneas" uninstalled
|
||||
|
|
@ -57,6 +57,15 @@ func TestUninstall(t *testing.T) {
|
|||
golden: "output/uninstall-keep-history.txt",
|
||||
rels: []*release.Release{release.Mock(&release.MockReleaseOptions{Name: "aeneas"})},
|
||||
},
|
||||
{
|
||||
name: "keep history with earlier deployed release",
|
||||
cmd: "uninstall aeneas --keep-history",
|
||||
golden: "output/uninstall-keep-history-earlier-deployed.txt",
|
||||
rels: []*release.Release{
|
||||
release.Mock(&release.MockReleaseOptions{Name: "aeneas", Version: 1, Status: release.StatusDeployed}),
|
||||
release.Mock(&release.MockReleaseOptions{Name: "aeneas", Version: 2, Status: release.StatusFailed}),
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "wait",
|
||||
cmd: "uninstall aeneas --wait",
|
||||
|
|
|
|||
|
|
@ -26,6 +26,7 @@ import (
|
|||
|
||||
"helm.sh/helm/v3/pkg/chartutil"
|
||||
"helm.sh/helm/v3/pkg/release"
|
||||
"helm.sh/helm/v3/pkg/storage/driver"
|
||||
helmtime "helm.sh/helm/v3/pkg/time"
|
||||
)
|
||||
|
||||
|
|
@ -249,7 +250,7 @@ func (r *Rollback) performRollback(currentRelease, targetRelease *release.Releas
|
|||
}
|
||||
|
||||
deployed, err := r.cfg.Releases.DeployedAll(currentRelease.Name)
|
||||
if err != nil && !strings.Contains(err.Error(), "has no deployed releases") {
|
||||
if err != nil && !errors.Is(err, driver.ErrNoDeployedReleases) {
|
||||
return nil, err
|
||||
}
|
||||
// Supersede all previous deployments, see issue #2941.
|
||||
|
|
|
|||
|
|
@ -28,6 +28,7 @@ import (
|
|||
"helm.sh/helm/v3/pkg/kube"
|
||||
"helm.sh/helm/v3/pkg/release"
|
||||
"helm.sh/helm/v3/pkg/releaseutil"
|
||||
"helm.sh/helm/v3/pkg/storage/driver"
|
||||
helmtime "helm.sh/helm/v3/pkg/time"
|
||||
)
|
||||
|
||||
|
|
@ -170,6 +171,19 @@ func (u *Uninstall) Run(name string) (*release.UninstallReleaseResponse, error)
|
|||
u.cfg.Log("uninstall: Failed to store updated release: %s", err)
|
||||
}
|
||||
|
||||
// Supersede all previous deployments, see issue #12556 (which is a
|
||||
// variation on #2941).
|
||||
deployed, err := u.cfg.Releases.DeployedAll(name)
|
||||
if err != nil && !errors.Is(err, driver.ErrNoDeployedReleases) {
|
||||
return nil, err
|
||||
}
|
||||
for _, reli := range deployed {
|
||||
reli.Info.Status = release.StatusSuperseded
|
||||
if err = u.cfg.Releases.Update(reli); err != nil {
|
||||
u.cfg.Log("uninstall: Failed to store updated release: %s", err)
|
||||
}
|
||||
}
|
||||
|
||||
if len(errs) > 0 {
|
||||
return res, errors.Errorf("uninstallation completed with %d error(s): %s", len(errs), joinErrors(errs))
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in a new issue