Introduce a new interface for WaitForDelete() to avoid breaking backwards compatibility

Signed-off-by: Mike Ng <ming@redhat.com>
pull/9702/head
Mike Ng 3 years ago
parent 655bdcd2fd
commit d51a61f9ab

@ -120,10 +120,12 @@ func (u *Uninstall) Run(name string) (*release.UninstallReleaseResponse, error)
res.Info = kept res.Info = kept
if u.Wait { if u.Wait {
if err := u.cfg.KubeClient.WaitForDelete(deletedResources, u.Timeout); err != nil { if kubeClient, ok := u.cfg.KubeClient.(kube.ClientInterface); ok {
if err := kubeClient.WaitForDelete(deletedResources, u.Timeout); err != nil {
errs = append(errs, err) errs = append(errs, err)
} }
} }
}
if !u.DisableHooks { if !u.DisableHooks {
if err := u.cfg.execHook(rel, release.HookPostDelete, u.Timeout); err != nil { if err := u.cfg.execHook(rel, release.HookPostDelete, u.Timeout); err != nil {

@ -162,7 +162,7 @@ func (c *Client) WaitWithJobs(resources ResourceList, timeout time.Duration) err
return w.waitForResources(resources) return w.waitForResources(resources)
} }
// Wait up to the given timeout for the specified resources to be deleted // WaitForDelete wait up to the given timeout for the specified resources to be deleted.
func (c *Client) WaitForDelete(resources ResourceList, timeout time.Duration) error { func (c *Client) WaitForDelete(resources ResourceList, timeout time.Duration) error {
w := waiter{ w := waiter{
log: c.Log, log: c.Log,

@ -36,8 +36,6 @@ type Interface interface {
// WaitWithJobs wait up to the given timeout for the specified resources to be ready, including jobs. // WaitWithJobs wait up to the given timeout for the specified resources to be ready, including jobs.
WaitWithJobs(resources ResourceList, timeout time.Duration) error WaitWithJobs(resources ResourceList, timeout time.Duration) error
WaitForDelete(resources ResourceList, timeout time.Duration) error
// Delete destroys one or more resources. // Delete destroys one or more resources.
Delete(resources ResourceList) (*Result, []error) Delete(resources ResourceList) (*Result, []error)
@ -72,4 +70,13 @@ type Interface interface {
IsReachable() error IsReachable() error
} }
// ClientInterface is introduced to avoid breaking backwards compatibility for Interface implementers.
//
// TODO Helm 4: Remove ClientInterface and integrate its method(s) into the Interface.
type ClientInterface interface {
// WaitForDelete wait up to the given timeout for the specified resources to be deleted.
WaitForDelete(resources ResourceList, timeout time.Duration) error
}
var _ Interface = (*Client)(nil) var _ Interface = (*Client)(nil)
var _ ClientInterface = (*Client)(nil)

Loading…
Cancel
Save