diff --git a/commands/bake.go b/commands/bake.go index f81d64fe88c..9042b57dfb8 100644 --- a/commands/bake.go +++ b/commands/bake.go @@ -4,7 +4,9 @@ import ( "context" "encoding/json" "fmt" + "io" "os" + "strings" "github.com/containerd/console" "github.com/containerd/containerd/platforms" @@ -98,8 +100,6 @@ func runBake(dockerCli command.Cli, targets []string, in bakeOptions, cFlags com defer cancel() var nodes []builder.Node - var files []bake.File - var inp *bake.Input var progressConsoleDesc, progressTextDesc string // instance only needed for reading remote bake files or building @@ -147,14 +147,7 @@ func runBake(dockerCli command.Cli, targets []string, in bakeOptions, cFlags com } }() - if url != "" { - files, inp, err = bake.ReadRemoteFiles(ctx, nodes, url, in.files, printer) - } else { - progress.Wrap("[internal] load local bake definitions", printer.Write, func(sub progress.SubLogger) error { - files, err = bake.ReadLocalFiles(in.files, dockerCli.In(), sub) - return nil - }) - } + files, inp, err := readBakeFiles(ctx, nodes, url, in.files, dockerCli.In(), printer) if err != nil { return err } @@ -296,3 +289,42 @@ func saveLocalStateGroup(dockerCli command.Cli, ref string, lsg localstate.State } return l.SaveGroup(ref, lsg) } + +func readBakeFiles(ctx context.Context, nodes []builder.Node, url string, names []string, stdin io.Reader, pw progress.Writer) (files []bake.File, inp *bake.Input, err error) { + var lnames []string + var rnames []string + for _, v := range names { + if strings.HasPrefix(v, "cwd://") { + lnames = append(lnames, strings.TrimPrefix(v, "cwd://")) + } else { + rnames = append(rnames, v) + } + } + + if url != "" { + var rfiles []bake.File + rfiles, inp, err = bake.ReadRemoteFiles(ctx, nodes, url, rnames, pw) + if err != nil { + return nil, nil, err + } + files = append(files, rfiles...) + } + + if len(lnames) > 0 || url == "" { + var lfiles []bake.File + progress.Wrap("[internal] load local bake definitions", pw.Write, func(sub progress.SubLogger) error { + if url != "" { + lfiles, err = bake.ReadLocalFiles(lnames, stdin, sub) + } else { + lfiles, err = bake.ReadLocalFiles(append(lnames, rnames...), stdin, sub) + } + return nil + }) + if err != nil { + return nil, nil, err + } + files = append(files, lfiles...) + } + + return +} diff --git a/tests/bake.go b/tests/bake.go index 83a171ea573..329d9a9a351 100644 --- a/tests/bake.go +++ b/tests/bake.go @@ -23,6 +23,7 @@ var bakeTests = []func(t *testing.T, sb integration.Sandbox){ testBakeLocalMulti, testBakeRemote, testBakeRemoteCmdContext, + testBakeRemoteLocalOverride, testBakeRemoteCmdContextOverride, testBakeRemoteContextSubdir, testBakeRemoteCmdContextEscapeRoot, @@ -46,6 +47,7 @@ target "default" { fstest.CreateFile("Dockerfile", dockerfile, 0600), fstest.CreateFile("foo", []byte("foo"), 0600), ) + dirDest := t.TempDir() cmd := buildxCmd(sb, withDir(dir), withArgs("bake", "--progress=plain", "--set", "*.output=type=local,dest="+dirDest)) @@ -79,16 +81,23 @@ services: fstest.CreateFile("Dockerfile", dockerfile, 0600), fstest.CreateFile("foo", []byte("foo"), 0600), ) + dirDest := t.TempDir() cmd := buildxCmd(sb, withDir(dir), withArgs("bake", "--progress=plain", "--set", "*.output=type=local,dest="+dirDest)) - out, err := cmd.CombinedOutput() + dt, err := cmd.CombinedOutput() + require.NoError(t, err, string(dt)) + require.Contains(t, string(dt), `#1 [internal] load local bake definitions`) + require.Contains(t, string(dt), `#1 reading compose.yaml`) + require.Contains(t, string(dt), `#1 reading docker-bake.hcl`) + require.FileExists(t, filepath.Join(dirDest, "foo")) + + dirDest2 := t.TempDir() + + out, err := bakeCmd(sb, withDir(dir), withArgs("--file", "cwd://docker-bake.hcl", "--set", "*.output=type=local,dest="+dirDest2)) require.NoError(t, err, out) - require.Contains(t, string(out), `#1 [internal] load local bake definitions`) - require.Contains(t, string(out), `#1 reading compose.yaml`) - require.Contains(t, string(out), `#1 reading docker-bake.hcl`) - require.FileExists(t, filepath.Join(dirDest, "foo")) + require.FileExists(t, filepath.Join(dirDest2, "foo")) } func testBakeRemote(t *testing.T, sb integration.Sandbox) { @@ -121,6 +130,48 @@ EOT require.FileExists(t, filepath.Join(dirDest, "foo")) } +func testBakeRemoteLocalOverride(t *testing.T, sb integration.Sandbox) { + remoteBakefile := []byte(` +target "default" { + dockerfile-inline = <