Merge pull request #1610 from ndeloof/build_args_from_env

This commit is contained in:
Nicolas De loof 2021-04-29 12:15:35 +02:00 committed by GitHub
commit b46015f2f8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 25 additions and 3 deletions

View File

@ -83,7 +83,7 @@ type BuildOptions struct {
// Progress set type of progress output ("auto", "plain", "tty") // Progress set type of progress output ("auto", "plain", "tty")
Progress string Progress string
// Args set build-time args // Args set build-time args
Args types.Mapping Args types.MappingWithEquals
// NoCache disables cache use // NoCache disables cache use
NoCache bool NoCache bool
// Quiet make the build process not output to the console // Quiet make the build process not output to the console

View File

@ -89,7 +89,7 @@ func runBuild(ctx context.Context, backend compose.Service, opts buildOptions, s
return "", backend.Build(ctx, project, compose.BuildOptions{ return "", backend.Build(ctx, project, compose.BuildOptions{
Pull: opts.pull, Pull: opts.pull,
Progress: opts.progress, Progress: opts.progress,
Args: types.NewMapping(opts.args), Args: types.NewMappingWithEquals(opts.args),
NoCache: opts.noCache, NoCache: opts.noCache,
Quiet: opts.quiet, Quiet: opts.quiet,
}) })

View File

@ -42,6 +42,14 @@ func (s *composeService) Build(ctx context.Context, project *types.Project, opti
opts := map[string]build.Options{} opts := map[string]build.Options{}
imagesToBuild := []string{} imagesToBuild := []string{}
args := map[string]string{}
for k, v := range options.Args.Resolve(func(s string) (string, bool) {
s, ok := project.Environment[s]
return s, ok
}).RemoveEmpty() {
args[k] = *v
}
for _, service := range project.Services { for _, service := range project.Services {
if service.Build != nil { if service.Build != nil {
imageName := getImageName(service, project.Name) imageName := getImageName(service, project.Name)
@ -51,7 +59,7 @@ func (s *composeService) Build(ctx context.Context, project *types.Project, opti
return err return err
} }
buildOptions.Pull = options.Pull buildOptions.Pull = options.Pull
buildOptions.BuildArgs = options.Args buildOptions.BuildArgs = args
buildOptions.NoCache = options.NoCache buildOptions.NoCache = options.NoCache
opts[imageName] = buildOptions opts[imageName] = buildOptions
buildOptions.CacheFrom, err = build.ParseCacheEntry(service.Build.CacheFrom) buildOptions.CacheFrom, err = build.ParseCacheEntry(service.Build.CacheFrom)

View File

@ -54,6 +54,20 @@ func TestLocalComposeBuild(t *testing.T) {
res.Assert(t, icmd.Expected{Out: `"FOO": "BAR"`}) res.Assert(t, icmd.Expected{Out: `"FOO": "BAR"`})
}) })
t.Run("build with build-arg set by env", func(t *testing.T) {
// ensure local test run does not reuse previously build image
c.RunDockerOrExitError("rmi", "build-test_nginx")
c.RunDockerOrExitError("rmi", "custom-nginx")
icmd.RunCmd(c.NewDockerCmd("compose", "--project-directory", "fixtures/build-test", "build", "--build-arg", "FOO"),
func(cmd *icmd.Cmd) {
cmd.Env = append(cmd.Env, "FOO=BAR")
})
res := c.RunDockerCmd("image", "inspect", "build-test_nginx")
res.Assert(t, icmd.Expected{Out: `"FOO": "BAR"`})
})
t.Run("build as part of up", func(t *testing.T) { t.Run("build as part of up", func(t *testing.T) {
c.RunDockerOrExitError("rmi", "build-test_nginx") c.RunDockerOrExitError("rmi", "build-test_nginx")
c.RunDockerOrExitError("rmi", "custom-nginx") c.RunDockerOrExitError("rmi", "custom-nginx")