From 78616f253147ab4dc37d52e6c32e560860c93668 Mon Sep 17 00:00:00 2001 From: Cameron Adams Date: Sat, 12 Aug 2023 17:42:14 +0200 Subject: [PATCH] command(bake): Specify local and remote bake files This adds the ability to source additional local build definition files when sourcing Bake files via a remote url. Prefixing a file with 'cwd://' will source a bake file on the local machine, instead of the remote location. Local files will be read/have precedence before remote files. Usage: ``` docker buildx bake https://github.com/example/upstream.git --file cwd://docker-bake.override.hcl --print ``` This will source a default file from the example/upstream repository, and also source a build definition from the local machine. Signed-off-by: Cameron Adams --- commands/bake.go | 28 +++++++++++++++++++++++++--- tests/bake.go | 48 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 73 insertions(+), 3 deletions(-) diff --git a/commands/bake.go b/commands/bake.go index 574a68741fe0..d6780d29329e 100644 --- a/commands/bake.go +++ b/commands/bake.go @@ -5,6 +5,7 @@ import ( "encoding/json" "fmt" "os" + "strings" "github.com/containerd/console" "github.com/containerd/containerd/platforms" @@ -142,11 +143,19 @@ func runBake(dockerCli command.Cli, targets []string, in bakeOptions, cFlags com } } }() - + localFilesArg, remoteFilesArg := getFilesArgs(in.files) if url != "" { - files, inp, err = bake.ReadRemoteFiles(ctx, nodes, url, in.files, printer) + files, inp, err = bake.ReadRemoteFiles(ctx, nodes, url, remoteFilesArg, printer) + if len(localFilesArg) > 0 { + var localFiles []bake.File + localFiles, err = bake.ReadLocalFiles(localFilesArg, dockerCli.In()) + files = append(files, localFiles...) + } } else { - files, err = bake.ReadLocalFiles(in.files, dockerCli.In()) + var filesArg []string + filesArg = append(filesArg, localFilesArg...) + filesArg = append(filesArg, remoteFilesArg...) + files, err = bake.ReadLocalFiles(filesArg, dockerCli.In()) } if err != nil { return err @@ -257,3 +266,16 @@ func bakeCmd(dockerCli command.Cli, rootOpts *rootOptions) *cobra.Command { return cmd } + +func getFilesArgs(s []string) ([]string, []string) { + var localFiles []string + var remoteFiles []string + for _, v := range s { + if strings.HasPrefix(v, "cwd://") { + localFiles = append(localFiles, strings.TrimPrefix(v, "cwd://")) + } else { + remoteFiles = append(remoteFiles, v) + } + } + return localFiles, remoteFiles +} diff --git a/tests/bake.go b/tests/bake.go index b76a8bb8a2f2..1791ead443bb 100644 --- a/tests/bake.go +++ b/tests/bake.go @@ -21,6 +21,7 @@ var bakeTests = []func(t *testing.T, sb integration.Sandbox){ testBakeLocal, testBakeRemote, testBakeRemoteCmdContext, + testBakeRemoteLocalOverride, testBakeRemoteCmdContextOverride, testBakeRemoteContextSubdir, testBakeRemoteCmdContextEscapeRoot, @@ -48,6 +49,11 @@ target "default" { require.NoError(t, err, out) require.FileExists(t, filepath.Join(dirDest, "foo")) + + out, err = bakeCmd(sb, withDir(dir), withArgs("--file", "cwd://docker-bake.hcl", "--set", "*.output=type=local,dest="+dirDest)) + require.NoError(t, err, out) + + require.FileExists(t, filepath.Join(dirDest, "foo")) } func testBakeRemote(t *testing.T, sb integration.Sandbox) { @@ -80,6 +86,48 @@ EOT require.FileExists(t, filepath.Join(dirDest, "foo")) } +func testBakeRemoteLocalOverride(t *testing.T, sb integration.Sandbox) { + remoteBakefile := []byte(` +target "default" { + dockerfile-inline = <