|
|
@ -323,11 +323,11 @@ func (u *Upgrade) performUpgrade(ctx context.Context, originalRelease, upgradedR
|
|
|
|
rChan := make(chan resultMessage)
|
|
|
|
rChan := make(chan resultMessage)
|
|
|
|
ctxChan := make(chan resultMessage)
|
|
|
|
ctxChan := make(chan resultMessage)
|
|
|
|
doneChan := make(chan interface{})
|
|
|
|
doneChan := make(chan interface{})
|
|
|
|
|
|
|
|
defer close(doneChan)
|
|
|
|
go u.releasingUpgrade(rChan, upgradedRelease, current, target, originalRelease)
|
|
|
|
go u.releasingUpgrade(rChan, upgradedRelease, current, target, originalRelease)
|
|
|
|
go u.handleContext(ctx, doneChan, ctxChan, upgradedRelease)
|
|
|
|
go u.handleContext(ctx, doneChan, ctxChan, upgradedRelease)
|
|
|
|
select {
|
|
|
|
select {
|
|
|
|
case result := <-rChan:
|
|
|
|
case result := <-rChan:
|
|
|
|
doneChan <- true
|
|
|
|
|
|
|
|
return result.r, result.e
|
|
|
|
return result.r, result.e
|
|
|
|
case result := <-ctxChan:
|
|
|
|
case result := <-ctxChan:
|
|
|
|
return result.r, result.e
|
|
|
|
return result.r, result.e
|
|
|
@ -348,7 +348,6 @@ func (u *Upgrade) reportToPerformUpgrade(c chan<- resultMessage, rel *release.Re
|
|
|
|
|
|
|
|
|
|
|
|
// Setup listener for SIGINT and SIGTERM
|
|
|
|
// Setup listener for SIGINT and SIGTERM
|
|
|
|
func (u *Upgrade) handleContext(ctx context.Context, done chan interface{}, c chan<- resultMessage, upgradedRelease *release.Release) {
|
|
|
|
func (u *Upgrade) handleContext(ctx context.Context, done chan interface{}, c chan<- resultMessage, upgradedRelease *release.Release) {
|
|
|
|
go func() {
|
|
|
|
|
|
|
|
select {
|
|
|
|
select {
|
|
|
|
case <-ctx.Done():
|
|
|
|
case <-ctx.Done():
|
|
|
|
err := ctx.Err()
|
|
|
|
err := ctx.Err()
|
|
|
@ -358,7 +357,6 @@ func (u *Upgrade) handleContext(ctx context.Context, done chan interface{}, c ch
|
|
|
|
case <-done:
|
|
|
|
case <-done:
|
|
|
|
return
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
func (u *Upgrade) releasingUpgrade(c chan<- resultMessage, upgradedRelease *release.Release, current kube.ResourceList, target kube.ResourceList, originalRelease *release.Release) {
|
|
|
|
func (u *Upgrade) releasingUpgrade(c chan<- resultMessage, upgradedRelease *release.Release, current kube.ResourceList, target kube.ResourceList, originalRelease *release.Release) {
|
|
|
|
// pre-upgrade hooks
|
|
|
|
// pre-upgrade hooks
|
|
|
|