| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- /*
- Copyright 2020 Docker Compose CLI authors
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- */
- package e2e
- import (
- "strings"
- "testing"
- "gotest.tools/v3/assert"
- "gotest.tools/v3/icmd"
- )
- func TestComposePull(t *testing.T) {
- c := NewParallelCLI(t)
- t.Run("Verify image pulled", func(t *testing.T) {
- // cleanup existing images
- c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/simple", "down", "--rmi", "all")
- res := c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/simple", "pull")
- output := res.Combined()
- assert.Assert(t, strings.Contains(output, "Image alpine:3.14 Pulled"))
- assert.Assert(t, strings.Contains(output, "Image alpine:3.15 Pulled"))
- // verify default policy is 'always' for pull command
- res = c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/simple", "pull")
- output = res.Combined()
- assert.Assert(t, strings.Contains(output, "Image alpine:3.14 Pulled"))
- assert.Assert(t, strings.Contains(output, "Image alpine:3.15 Pulled"))
- })
- t.Run("Verify skipped pull if image is already present locally", func(t *testing.T) {
- // make sure the required image is present
- c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/image-present-locally", "pull")
- res := c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/image-present-locally", "pull")
- output := res.Combined()
- assert.Assert(t, strings.Contains(output, "alpine:3.13.12 Skipped Image is already present locally"))
- // image with :latest tag gets pulled regardless if pull_policy: missing or if_not_present
- assert.Assert(t, strings.Contains(output, "alpine:latest Pulled"))
- })
- t.Run("Verify skipped no image to be pulled", func(t *testing.T) {
- res := c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/no-image-name-given", "pull")
- output := res.Combined()
- assert.Assert(t, strings.Contains(output, "Skipped No image to be pulled"))
- })
- t.Run("Verify pull failure", func(t *testing.T) {
- res := c.RunDockerComposeCmdNoCheck(t, "--project-directory", "fixtures/compose-pull/unknown-image", "pull")
- res.Assert(t, icmd.Expected{ExitCode: 1, Err: "pull access denied for does_not_exists"})
- })
- t.Run("Verify ignore pull failure", func(t *testing.T) {
- res := c.RunDockerComposeCmd(t, "--project-directory", "fixtures/compose-pull/unknown-image", "pull", "--ignore-pull-failures")
- res.Assert(t, icmd.Expected{Err: "Some service image(s) must be built from source by running:"})
- })
- }
|