Decom: Easily restart decommission when it is done (#14855)

When a decommission task is successfully completed, failed, or canceled,
this commit allows restarting the decommission again. Restarting is not
allowed when there is an ongoing decommission task.
This commit is contained in:
Anis Elleuch 2022-05-03 21:36:08 +01:00 committed by GitHub
parent a53dc1d9c8
commit 46de9ac03e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -242,41 +242,26 @@ func (p *poolMeta) Decommission(idx int, pi poolSpaceInfo) error {
} }
} }
now := UTCNow() // Return an error when there is decommission on going - the user needs
if p.Pools[idx].Decommission == nil { // to explicitly cancel it first in order to restart decommissioning again.
p.Pools[idx].LastUpdate = now if p.Pools[idx].Decommission != nil &&
p.Pools[idx].Decommission = &PoolDecommissionInfo{ !p.Pools[idx].Decommission.Complete &&
StartTime: now, !p.Pools[idx].Decommission.Failed &&
StartSize: pi.Free, !p.Pools[idx].Decommission.Canceled {
CurrentSize: pi.Free,
TotalSize: pi.Total,
}
return nil
}
// Completed pool doesn't need to be decommissioned again.
if p.Pools[idx].Decommission.Complete {
return errDecommissionComplete
}
// Canceled or Failed decommission can be triggered again.
if p.Pools[idx].Decommission.StartTime.IsZero() {
if p.Pools[idx].Decommission.Canceled || p.Pools[idx].Decommission.Failed {
p.Pools[idx].LastUpdate = now
p.Pools[idx].Decommission = &PoolDecommissionInfo{
StartTime: now,
StartSize: pi.Free,
CurrentSize: pi.Free,
TotalSize: pi.Total,
}
return nil
}
} // In-progress pool doesn't need to be decommissioned again.
// In all other scenarios an active decommissioning is in progress.
return errDecommissionAlreadyRunning return errDecommissionAlreadyRunning
} }
now := UTCNow()
p.Pools[idx].LastUpdate = now
p.Pools[idx].Decommission = &PoolDecommissionInfo{
StartTime: now,
StartSize: pi.Free,
CurrentSize: pi.Free,
TotalSize: pi.Total,
}
return nil
}
func (p poolMeta) IsSuspended(idx int) bool { func (p poolMeta) IsSuspended(idx int) bool {
return p.Pools[idx].Decommission != nil return p.Pools[idx].Decommission != nil
} }