|
@@ -2,6 +2,7 @@ package image // import "github.com/docker/docker/integration/image"
|
|
|
|
|
|
import (
|
|
|
"context"
|
|
|
+ "strings"
|
|
|
"testing"
|
|
|
|
|
|
"github.com/docker/docker/api/types"
|
|
@@ -17,36 +18,36 @@ func TestRemoveImageOrphaning(t *testing.T) {
|
|
|
ctx := context.Background()
|
|
|
client := testEnv.APIClient()
|
|
|
|
|
|
- img := "test-container-orphaning"
|
|
|
+ imgName := strings.ToLower(t.Name())
|
|
|
|
|
|
// Create a container from busybox, and commit a small change so we have a new image
|
|
|
cID1 := container.Create(ctx, t, client, container.WithCmd(""))
|
|
|
commitResp1, err := client.ContainerCommit(ctx, cID1, types.ContainerCommitOptions{
|
|
|
Changes: []string{`ENTRYPOINT ["true"]`},
|
|
|
- Reference: img,
|
|
|
+ Reference: imgName,
|
|
|
})
|
|
|
assert.NilError(t, err)
|
|
|
|
|
|
// verifies that reference now points to first image
|
|
|
- resp, _, err := client.ImageInspectWithRaw(ctx, img)
|
|
|
+ resp, _, err := client.ImageInspectWithRaw(ctx, imgName)
|
|
|
assert.NilError(t, err)
|
|
|
assert.Check(t, is.Equal(resp.ID, commitResp1.ID))
|
|
|
|
|
|
// Create a container from created image, and commit a small change with same reference name
|
|
|
- cID2 := container.Create(ctx, t, client, container.WithImage(img), container.WithCmd(""))
|
|
|
+ cID2 := container.Create(ctx, t, client, container.WithImage(imgName), container.WithCmd(""))
|
|
|
commitResp2, err := client.ContainerCommit(ctx, cID2, types.ContainerCommitOptions{
|
|
|
Changes: []string{`LABEL Maintainer="Integration Tests"`},
|
|
|
- Reference: img,
|
|
|
+ Reference: imgName,
|
|
|
})
|
|
|
assert.NilError(t, err)
|
|
|
|
|
|
// verifies that reference now points to second image
|
|
|
- resp, _, err = client.ImageInspectWithRaw(ctx, img)
|
|
|
+ resp, _, err = client.ImageInspectWithRaw(ctx, imgName)
|
|
|
assert.NilError(t, err)
|
|
|
assert.Check(t, is.Equal(resp.ID, commitResp2.ID))
|
|
|
|
|
|
// try to remove the image, should not error out.
|
|
|
- _, err = client.ImageRemove(ctx, img, types.ImageRemoveOptions{})
|
|
|
+ _, err = client.ImageRemove(ctx, imgName, types.ImageRemoveOptions{})
|
|
|
assert.NilError(t, err)
|
|
|
|
|
|
// check if the first image is still there
|