fix(kube): Fixes nil panic with stateful set waiting

Sometimes the stateful set `rollingUpdate` field can be nil even when the
strategy is a rolling update

Fixes #6174

Signed-off-by: Taylor Thomas <taylor.thomas@microsoft.com>
pull/6175/head
Taylor Thomas 6 years ago
parent 539bafa58b
commit b46d7fd527

@ -267,7 +267,10 @@ func (w *waiter) statefulSetReady(sts *appsv1.StatefulSet) bool {
var partition int var partition int
// 1 is the default for replicas if not set // 1 is the default for replicas if not set
var replicas = 1 var replicas = 1
if sts.Spec.UpdateStrategy.RollingUpdate.Partition != nil { // For some reason, even if the update strategy is a rolling update, the
// actual rollingUpdate field can be nil. If it is, we can safely assume
// there is no partition value
if sts.Spec.UpdateStrategy.RollingUpdate != nil && sts.Spec.UpdateStrategy.RollingUpdate.Partition != nil {
partition = int(*sts.Spec.UpdateStrategy.RollingUpdate.Partition) partition = int(*sts.Spec.UpdateStrategy.RollingUpdate.Partition)
} }
if sts.Spec.Replicas != nil { if sts.Spec.Replicas != nil {

Loading…
Cancel
Save