Merge pull request #44237 from cpuguy83/22.06_fix_restore_volumerefs
[22.06] Fix live-restore w/ restart policies + volume refs
This commit is contained in:
commit
dbcd0e7aee
3 changed files with 78 additions and 0 deletions
|
@ -519,6 +519,9 @@ func (daemon *Daemon) restore() error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := daemon.prepareMountPoints(c); err != nil {
|
||||||
|
log.WithError(err).Error("failed to prepare mount points for container")
|
||||||
|
}
|
||||||
if err := daemon.containerStart(c, "", "", true); err != nil {
|
if err := daemon.containerStart(c, "", "", true); err != nil {
|
||||||
log.WithError(err).Error("failed to start container")
|
log.WithError(err).Error("failed to start container")
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,10 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/docker/docker/api/types"
|
"github.com/docker/docker/api/types"
|
||||||
|
"github.com/docker/docker/api/types/mount"
|
||||||
|
"github.com/docker/docker/api/types/volume"
|
||||||
"github.com/docker/docker/daemon/config"
|
"github.com/docker/docker/daemon/config"
|
||||||
|
"github.com/docker/docker/integration/internal/container"
|
||||||
"github.com/docker/docker/testutil/daemon"
|
"github.com/docker/docker/testutil/daemon"
|
||||||
"gotest.tools/v3/assert"
|
"gotest.tools/v3/assert"
|
||||||
is "gotest.tools/v3/assert/cmp"
|
is "gotest.tools/v3/assert/cmp"
|
||||||
|
@ -378,3 +381,57 @@ func TestDaemonProxy(t *testing.T) {
|
||||||
assert.Assert(t, !strings.Contains(string(logs), userPass), "logs should not contain the non-sanitized proxy URL: %s", string(logs))
|
assert.Assert(t, !strings.Contains(string(logs), userPass), "logs should not contain the non-sanitized proxy URL: %s", string(logs))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestLiveRestore(t *testing.T) {
|
||||||
|
skip.If(t, runtime.GOOS == "windows", "cannot start multiple daemons on windows")
|
||||||
|
|
||||||
|
t.Run("volume references", testLiveRestoreVolumeReferences)
|
||||||
|
}
|
||||||
|
|
||||||
|
func testLiveRestoreVolumeReferences(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
d := daemon.New(t)
|
||||||
|
d.StartWithBusybox(t, "--live-restore", "--iptables=false")
|
||||||
|
defer func() {
|
||||||
|
d.Stop(t)
|
||||||
|
d.Cleanup(t)
|
||||||
|
}()
|
||||||
|
|
||||||
|
c := d.NewClientT(t)
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
runTest := func(t *testing.T, policy string) {
|
||||||
|
t.Run(policy, func(t *testing.T) {
|
||||||
|
volName := "test-live-restore-volume-references-" + policy
|
||||||
|
_, err := c.VolumeCreate(ctx, volume.CreateOptions{Name: volName})
|
||||||
|
assert.NilError(t, err)
|
||||||
|
|
||||||
|
// Create a container that uses the volume
|
||||||
|
m := mount.Mount{
|
||||||
|
Type: mount.TypeVolume,
|
||||||
|
Source: volName,
|
||||||
|
Target: "/foo",
|
||||||
|
}
|
||||||
|
cID := container.Run(ctx, t, c, container.WithMount(m), container.WithCmd("top"), container.WithRestartPolicy(policy))
|
||||||
|
defer c.ContainerRemove(ctx, cID, types.ContainerRemoveOptions{Force: true})
|
||||||
|
|
||||||
|
// Stop the daemon
|
||||||
|
d.Restart(t, "--live-restore", "--iptables=false")
|
||||||
|
|
||||||
|
// Try to remove the volume
|
||||||
|
err = c.VolumeRemove(ctx, volName, false)
|
||||||
|
assert.ErrorContains(t, err, "volume is in use")
|
||||||
|
|
||||||
|
_, err = c.VolumeInspect(ctx, volName)
|
||||||
|
assert.NilError(t, err)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
t.Run("restartPolicy", func(t *testing.T) {
|
||||||
|
runTest(t, "always")
|
||||||
|
runTest(t, "unless-stopped")
|
||||||
|
runTest(t, "on-failure")
|
||||||
|
runTest(t, "no")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
|
@ -1,10 +1,28 @@
|
||||||
package daemon // import "github.com/docker/docker/integration/daemon"
|
package daemon // import "github.com/docker/docker/integration/daemon"
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/docker/docker/testutil/environment"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var testEnv *environment.Execution
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
var err error
|
||||||
|
testEnv, err = environment.New()
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
err = environment.EnsureFrozenImagesLinux(testEnv)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
testEnv.Print()
|
||||||
os.Exit(m.Run())
|
os.Exit(m.Run())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue