mirror of https://github.com/docker/cli.git
Fix panic (npe) when updating service limits/reservations
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
e5760891ab
commit
579bb91853
|
@ -302,6 +302,12 @@ func updateService(ctx context.Context, apiClient client.NetworkAPIClient, flags
|
||||||
if task.Resources == nil {
|
if task.Resources == nil {
|
||||||
task.Resources = &swarm.ResourceRequirements{}
|
task.Resources = &swarm.ResourceRequirements{}
|
||||||
}
|
}
|
||||||
|
if task.Resources.Limits == nil {
|
||||||
|
task.Resources.Limits = &swarm.Resources{}
|
||||||
|
}
|
||||||
|
if task.Resources.Reservations == nil {
|
||||||
|
task.Resources.Reservations = &swarm.Resources{}
|
||||||
|
}
|
||||||
return task.Resources
|
return task.Resources
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -617,6 +617,38 @@ func TestUpdateIsolationValid(t *testing.T) {
|
||||||
// and that values are not updated are not reset to their default value
|
// and that values are not updated are not reset to their default value
|
||||||
func TestUpdateLimitsReservations(t *testing.T) {
|
func TestUpdateLimitsReservations(t *testing.T) {
|
||||||
spec := swarm.ServiceSpec{
|
spec := swarm.ServiceSpec{
|
||||||
|
TaskTemplate: swarm.TaskSpec{
|
||||||
|
ContainerSpec: &swarm.ContainerSpec{},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// test that updating works if the service did not previously
|
||||||
|
// have limits set (https://github.com/moby/moby/issues/38363)
|
||||||
|
flags := newUpdateCommand(nil).Flags()
|
||||||
|
err := flags.Set(flagLimitCPU, "2")
|
||||||
|
assert.NilError(t, err)
|
||||||
|
err = flags.Set(flagLimitMemory, "200M")
|
||||||
|
assert.NilError(t, err)
|
||||||
|
err = updateService(context.Background(), nil, flags, &spec)
|
||||||
|
assert.NilError(t, err)
|
||||||
|
|
||||||
|
spec = swarm.ServiceSpec{
|
||||||
|
TaskTemplate: swarm.TaskSpec{
|
||||||
|
ContainerSpec: &swarm.ContainerSpec{},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// test that updating works if the service did not previously
|
||||||
|
// have reservations set (https://github.com/moby/moby/issues/38363)
|
||||||
|
flags = newUpdateCommand(nil).Flags()
|
||||||
|
err = flags.Set(flagReserveCPU, "2")
|
||||||
|
assert.NilError(t, err)
|
||||||
|
err = flags.Set(flagReserveMemory, "200M")
|
||||||
|
assert.NilError(t, err)
|
||||||
|
err = updateService(context.Background(), nil, flags, &spec)
|
||||||
|
assert.NilError(t, err)
|
||||||
|
|
||||||
|
spec = swarm.ServiceSpec{
|
||||||
TaskTemplate: swarm.TaskSpec{
|
TaskTemplate: swarm.TaskSpec{
|
||||||
ContainerSpec: &swarm.ContainerSpec{},
|
ContainerSpec: &swarm.ContainerSpec{},
|
||||||
Resources: &swarm.ResourceRequirements{
|
Resources: &swarm.ResourceRequirements{
|
||||||
|
@ -632,8 +664,8 @@ func TestUpdateLimitsReservations(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
flags := newUpdateCommand(nil).Flags()
|
flags = newUpdateCommand(nil).Flags()
|
||||||
err := flags.Set(flagLimitCPU, "2")
|
err = flags.Set(flagLimitCPU, "2")
|
||||||
assert.NilError(t, err)
|
assert.NilError(t, err)
|
||||||
err = flags.Set(flagReserveCPU, "2")
|
err = flags.Set(flagReserveCPU, "2")
|
||||||
assert.NilError(t, err)
|
assert.NilError(t, err)
|
||||||
|
|
Loading…
Reference in New Issue