Skip to content

Commit 25fb2ef

Browse files
committed
bake: set input:context for remote builds
Signed-off-by: CrazyMax <[email protected]>
1 parent c6ca12a commit 25fb2ef

File tree

4 files changed

+148
-1
lines changed

4 files changed

+148
-1
lines changed

bake/bake.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1289,7 +1289,7 @@ func updateContext(t *build.Inputs, inp *Input) {
12891289
continue
12901290
}
12911291
st := llb.Scratch().File(llb.Copy(*inp.State, v.Path, "/"), llb.WithCustomNamef("set context %s to %s", k, v.Path))
1292-
t.NamedContexts[k] = build.NamedContext{State: &st}
1292+
t.NamedContexts[k] = build.NamedContext{State: &st, Path: inp.URL}
12931293
}
12941294

12951295
if t.ContextPath == "." {
@@ -1309,6 +1309,7 @@ func updateContext(t *build.Inputs, inp *Input) {
13091309
llb.WithCustomNamef("set context to %s", t.ContextPath),
13101310
)
13111311
t.ContextState = &st
1312+
t.ContextPath = inp.URL
13121313
}
13131314

13141315
func isRemoteContext(t build.Inputs, inp *Input) bool {

build/opt.go

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@ import (
3030
"github.com/moby/buildkit/client/llb"
3131
"github.com/moby/buildkit/client/ociindex"
3232
"github.com/moby/buildkit/exporter/containerimage/exptypes"
33+
"github.com/moby/buildkit/frontend/dockerfile/dfgitutil"
3334
"github.com/moby/buildkit/frontend/dockerui"
3435
gateway "github.com/moby/buildkit/frontend/gateway/client"
3536
"github.com/moby/buildkit/identity"
@@ -427,6 +428,9 @@ func loadInputs(ctx context.Context, d *driver.DriverHandle, inp *Inputs, pw pro
427428
}
428429
target.FrontendInputs["context"] = *inp.ContextState
429430
target.FrontendInputs["dockerfile"] = *inp.ContextState
431+
if _, ok, _ := dfgitutil.ParseGitRef(inp.ContextPath); ok {
432+
target.FrontendAttrs["input:context"] = inp.ContextPath
433+
}
430434
case inp.ContextPath == "-":
431435
if inp.DockerfilePath == "-" {
432436
return nil, errors.Errorf("invalid argument: can't use stdin for both build context and dockerfile")
@@ -543,6 +547,9 @@ func loadInputs(ctx context.Context, d *driver.DriverHandle, inp *Inputs, pw pro
543547
caps["moby.buildkit.frontend.contexts+forward"] = struct{}{}
544548
if v.State != nil {
545549
target.FrontendAttrs["context:"+k] = "input:" + k
550+
if _, ok, _ := dfgitutil.ParseGitRef(v.Path); ok {
551+
target.FrontendAttrs["input:git_state_"+k] = v.Path
552+
}
546553
if target.FrontendInputs == nil {
547554
target.FrontendInputs = make(map[string]llb.State)
548555
}

tests/bake.go

Lines changed: 73 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,7 @@ var bakeTests = []func(t *testing.T, sb integration.Sandbox){
4141
testBakePrintSensitive,
4242
testBakePrintOverrideEmpty,
4343
testBakePrintKeepEscaped,
44+
testBakePrintRemoteContextSubdir,
4445
testBakeLocal,
4546
testBakeLocalMulti,
4647
testBakeRemote,
@@ -393,6 +394,78 @@ EOT
393394
require.NoError(t, err, string(out))
394395
}
395396

397+
func testBakePrintRemoteContextSubdir(t *testing.T, sb integration.Sandbox) {
398+
bakefile := []byte(`
399+
target default {
400+
context = "bar"
401+
}
402+
`)
403+
dockerfile := []byte(`
404+
FROM scratch
405+
COPY super-cool.txt /
406+
`)
407+
408+
dir := tmpdir(
409+
t,
410+
fstest.CreateFile("docker-bake.hcl", bakefile, 0600),
411+
fstest.CreateDir("bar", 0700),
412+
fstest.CreateFile("bar/Dockerfile", dockerfile, 0600),
413+
fstest.CreateFile("bar/super-cool.txt", []byte("super cool"), 0600),
414+
)
415+
416+
git, err := gitutil.New(gitutil.WithWorkingDir(dir))
417+
require.NoError(t, err)
418+
gittestutil.GitInit(git, t)
419+
gittestutil.GitAdd(git, t, "docker-bake.hcl", "bar")
420+
gittestutil.GitCommit(git, t, "initial commit")
421+
addr := gittestutil.GitServeHTTP(git, t)
422+
423+
tests := []struct {
424+
name string
425+
ref string
426+
expectedContext string
427+
}{
428+
{
429+
name: "no ref",
430+
expectedContext: addr,
431+
},
432+
{
433+
name: "branch ref",
434+
ref: "main",
435+
expectedContext: addr + "#main",
436+
},
437+
}
438+
for _, tt := range tests {
439+
t.Run(tt.name, func(t *testing.T) {
440+
u := addr
441+
if tt.ref != "" {
442+
u += "#" + tt.ref
443+
}
444+
cmd := buildxCmd(sb, withDir("/tmp"), withArgs("bake", u, "--print"))
445+
stdout := bytes.Buffer{}
446+
stderr := bytes.Buffer{}
447+
cmd.Stdout = &stdout
448+
cmd.Stderr = &stderr
449+
require.NoError(t, cmd.Run(), stdout.String(), stderr.String())
450+
require.JSONEq(t, fmt.Sprintf(`{
451+
"group": {
452+
"default": {
453+
"targets": [
454+
"default"
455+
]
456+
}
457+
},
458+
"target": {
459+
"default": {
460+
"context": %q,
461+
"dockerfile": "Dockerfile"
462+
}
463+
}
464+
}`, tt.expectedContext), stdout.String())
465+
})
466+
}
467+
}
468+
396469
func testBakeLocal(t *testing.T, sb integration.Sandbox) {
397470
dockerfile := []byte(`
398471
FROM scratch

tests/history.go

Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -240,6 +240,72 @@ COPY foo /foo
240240
require.Equal(t, md.BuildRef, rec.Ref)
241241
require.Equal(t, addr+"#main", rec.Name)
242242
})
243+
244+
t.Run("bake git", func(t *testing.T) {
245+
bakefile := []byte(`
246+
target "default" {
247+
dockerfile-inline = <<EOT
248+
FROM scratch
249+
COPY foo /foo
250+
EOT
251+
}
252+
`)
253+
dir := tmpdir(
254+
t,
255+
fstest.CreateFile("docker-bake.hcl", bakefile, 0600),
256+
fstest.CreateFile("foo", []byte("foo"), 0600),
257+
)
258+
dirDest := t.TempDir()
259+
260+
git, err := gitutil.New(gitutil.WithWorkingDir(dir))
261+
require.NoError(t, err)
262+
263+
gittestutil.GitInit(git, t)
264+
gittestutil.GitAdd(git, t, "docker-bake.hcl", "foo")
265+
gittestutil.GitCommit(git, t, "initial commit")
266+
addr := gittestutil.GitServeHTTP(git, t)
267+
268+
out, err := bakeCmd(sb, withDir(dir),
269+
withArgs(addr, "--set", "*.output=type=local,dest="+dirDest, "--metadata-file", filepath.Join(dir, "md.json")),
270+
)
271+
require.NoError(t, err, out)
272+
require.FileExists(t, filepath.Join(dirDest, "foo"))
273+
274+
dt, err := os.ReadFile(filepath.Join(dir, "md.json"))
275+
require.NoError(t, err)
276+
277+
type mdT struct {
278+
Default struct {
279+
BuildRef string `json:"buildx.build.ref"`
280+
} `json:"default"`
281+
}
282+
var md mdT
283+
err = json.Unmarshal(dt, &md)
284+
require.NoError(t, err)
285+
286+
refParts := strings.Split(md.Default.BuildRef, "/")
287+
require.Len(t, refParts, 3)
288+
289+
cmd := buildxCmd(sb, withArgs("history", "ls", "--filter=ref="+refParts[2], "--format=json"))
290+
bout, err := cmd.Output()
291+
require.NoError(t, err, string(bout))
292+
293+
type recT struct {
294+
Ref string `json:"ref"`
295+
Name string `json:"name"`
296+
Status string `json:"status"`
297+
CreatedAt *time.Time `json:"created_at"`
298+
CompletedAt *time.Time `json:"completed_at"`
299+
TotalSteps int32 `json:"total_steps"`
300+
CompletedSteps int32 `json:"completed_steps"`
301+
CachedSteps int32 `json:"cached_steps"`
302+
}
303+
var rec recT
304+
err = json.Unmarshal(bout, &rec)
305+
require.NoError(t, err)
306+
require.Equal(t, md.Default.BuildRef, rec.Ref)
307+
require.Equal(t, addr, rec.Name)
308+
})
243309
}
244310

245311
type buildRef struct {

0 commit comments

Comments
 (0)