From a2770b66ff26f5f4d7d41f10927257a726125207 Mon Sep 17 00:00:00 2001 From: Guillaume Lours Date: Wed, 18 May 2022 14:43:54 +0200 Subject: [PATCH] add tags property to build section Signed-off-by: Guillaume Lours --- pkg/compose/build.go | 4 ++++ pkg/e2e/compose_build_test.go | 21 +++++++++++++++++++ pkg/e2e/fixtures/build-test/tags/Dockerfile | 17 +++++++++++++++ pkg/e2e/fixtures/build-test/tags/compose.yaml | 9 ++++++++ 4 files changed, 51 insertions(+) create mode 100644 pkg/e2e/fixtures/build-test/tags/Dockerfile create mode 100644 pkg/e2e/fixtures/build-test/tags/compose.yaml diff --git a/pkg/compose/build.go b/pkg/compose/build.go index 4367f71a..eeb2dba2 100644 --- a/pkg/compose/build.go +++ b/pkg/compose/build.go @@ -275,6 +275,10 @@ func (s *composeService) toBuildOptions(project *types.Project, service types.Se sessionConfig = append(sessionConfig, p) } + if len(service.Build.Tags) > 0 { + tags = append(tags, service.Build.Tags...) + } + return build.Options{ Inputs: build.Inputs{ ContextPath: service.Build.Context, diff --git a/pkg/e2e/compose_build_test.go b/pkg/e2e/compose_build_test.go index 771c2b2f..70788028 100644 --- a/pkg/e2e/compose_build_test.go +++ b/pkg/e2e/compose_build_test.go @@ -181,3 +181,24 @@ func TestBuildSecrets(t *testing.T) { res.Assert(t, icmd.Success) }) } + +func TestBuildTags(t *testing.T) { + c := NewParallelE2eCLI(t, binDir) + + t.Run("build with tags", func(t *testing.T) { + + // ensure local test run does not reuse previously build image + c.RunDockerOrExitError("rmi", "build-test-tags") + + c.RunDockerComposeCmd("--project-directory", "./fixtures/build-test/tags", "build", "--no-cache") + + res := c.RunDockerCmd("image", "inspect", "build-test-tags") + expectedOutput := `"RepoTags": [ + "docker/build-test-tags:1.0.0", + "build-test-tags:latest", + "other-image-name:v1.0.0" + ], +` + res.Assert(t, icmd.Expected{Out: expectedOutput}) + }) +} diff --git a/pkg/e2e/fixtures/build-test/tags/Dockerfile b/pkg/e2e/fixtures/build-test/tags/Dockerfile new file mode 100644 index 00000000..09b9df4a --- /dev/null +++ b/pkg/e2e/fixtures/build-test/tags/Dockerfile @@ -0,0 +1,17 @@ +# 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. + +FROM nginx:alpine + +RUN echo "SUCCESS" diff --git a/pkg/e2e/fixtures/build-test/tags/compose.yaml b/pkg/e2e/fixtures/build-test/tags/compose.yaml new file mode 100644 index 00000000..de017802 --- /dev/null +++ b/pkg/e2e/fixtures/build-test/tags/compose.yaml @@ -0,0 +1,9 @@ +services: + nginx: + image: build-test-tags + build: + context: . + tags: + - docker.io/docker/build-test-tags:1.0.0 + - other-image-name:v1.0.0 +