Skip to content

Commit

Permalink
bake: display read definition files in build output
Browse files Browse the repository at this point in the history
Signed-off-by: CrazyMax <[email protected]>
  • Loading branch information
crazy-max committed Oct 14, 2023
1 parent 01245e7 commit 5bbf260
Show file tree
Hide file tree
Showing 6 changed files with 176 additions and 19 deletions.
108 changes: 102 additions & 6 deletions bake/bake.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,18 @@ import (
"sort"
"strconv"
"strings"
"time"

composecli "github.com/compose-spec/compose-go/cli"
"github.com/docker/buildx/bake/hclparser"
"github.com/docker/buildx/build"
controllerapi "github.com/docker/buildx/controller/pb"
"github.com/docker/buildx/util/buildflags"
"github.com/docker/buildx/util/platformutil"
"github.com/docker/buildx/util/progress"
"github.com/docker/cli/cli/config"
hcl "github.com/hashicorp/hcl/v2"
"github.com/moby/buildkit/client"
"github.com/moby/buildkit/client/llb"
"github.com/moby/buildkit/session/auth/authprovider"
"github.com/pkg/errors"
Expand Down Expand Up @@ -54,28 +57,34 @@ func defaultFilenames() []string {
return names
}

func ReadLocalFiles(names []string, stdin io.Reader) ([]File, error) {
func ReadLocalFiles(names []string, stdin io.Reader, l progress.SubLogger) ([]File, error) {
isDefault := false
if len(names) == 0 {
isDefault = true
names = defaultFilenames()
}
out := make([]File, 0, len(names))

setStatus := func(st *client.VertexStatus) {
if l != nil {
l.SetStatus(st)
}
}

for _, n := range names {
var dt []byte
var err error
if n == "-" {
dt, err = io.ReadAll(stdin)
dt, err = readWithStatus(stdin, setStatus)
if err != nil {
return nil, err
}
} else {
dt, err = os.ReadFile(n)
dt, err = readFileWithStatus(n, isDefault, setStatus)
if dt == nil && err == nil {
continue
}
if err != nil {
if isDefault && errors.Is(err, os.ErrNotExist) {
continue
}
return nil, err
}
}
Expand All @@ -84,6 +93,93 @@ func ReadLocalFiles(names []string, stdin io.Reader) ([]File, error) {
return out, nil
}

func readFileWithStatus(fname string, isDefault bool, setStatus func(st *client.VertexStatus)) (dt []byte, err error) {
st := &client.VertexStatus{
ID: "reading " + fname,
}

defer func() {
now := time.Now()
st.Completed = &now
if dt != nil || err != nil {
setStatus(st)
}
}()

now := time.Now()
st.Started = &now

f, err := os.Open(fname)
if err != nil {
if isDefault && errors.Is(err, os.ErrNotExist) {
return nil, nil
}
setStatus(st)
return nil, err
}
defer f.Close()
setStatus(st)

info, err := f.Stat()
if err != nil {
return nil, err
}
st.Total = info.Size()
setStatus(st)

buf := make([]byte, 1024)
current := int64(0)
for {
n, err := f.Read(buf)
if err == io.EOF {
break
}
if err != nil {
return nil, err
}
dt = append(dt, buf[:n]...)
current += int64(n)
st.Current = current
setStatus(st)
}

return dt, nil
}

func readWithStatus(r io.Reader, setStatus func(st *client.VertexStatus)) (dt []byte, err error) {
st := &client.VertexStatus{
ID: "reading from stdin",
}

defer func() {
now := time.Now()
st.Completed = &now
setStatus(st)
}()

now := time.Now()
st.Started = &now
setStatus(st)

buf := make([]byte, 1024)
current := int64(0)
for {
n, err := r.Read(buf)
if err == io.EOF {
break
}
if err != nil {
return nil, err
}
dt = append(dt, buf[:n]...)
current += int64(n)
st.Current = current
setStatus(st)
}

return dt, nil
}

func ListTargets(files []File) ([]string, error) {
c, err := ParseFiles(files, nil)
if err != nil {
Expand Down
2 changes: 1 addition & 1 deletion bake/bake_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1408,7 +1408,7 @@ func TestReadLocalFilesDefault(t *testing.T) {
for _, tf := range tt.filenames {
require.NoError(t, os.WriteFile(tf, []byte(tf), 0644))
}
files, err := ReadLocalFiles(nil, nil)
files, err := ReadLocalFiles(nil, nil, nil)
require.NoError(t, err)
if len(files) == 0 {
require.Equal(t, len(tt.expected), len(files))
Expand Down
33 changes: 25 additions & 8 deletions bake/remote.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"archive/tar"
"bytes"
"context"
"time"

"github.com/docker/buildx/builder"
controllerapi "github.com/docker/buildx/controller/pb"
Expand Down Expand Up @@ -76,11 +77,14 @@ func ReadRemoteFiles(ctx context.Context, nodes []builder.Node, url string, name
return nil, err
}

if filename != "" {
files, err = filesFromURLRef(ctx, c, ref, inp, filename, names)
} else {
files, err = filesFromRef(ctx, ref, names)
}
progress.Wrap("[internal] load remote bake definitions", pw.Write, func(sub progress.SubLogger) error {
if filename != "" {
files, err = filesFromURLRef(ctx, c, ref, inp, filename, names, sub)
} else {
files, err = filesFromRef(ctx, ref, names, sub)
}
return nil
})
return nil, err
}, ch)

Expand Down Expand Up @@ -110,7 +114,7 @@ func isArchive(header []byte) bool {
return err == nil
}

func filesFromURLRef(ctx context.Context, c gwclient.Client, ref gwclient.Reference, inp *Input, filename string, names []string) ([]File, error) {
func filesFromURLRef(ctx context.Context, c gwclient.Client, ref gwclient.Reference, inp *Input, filename string, names []string, l progress.SubLogger) ([]File, error) {
stat, err := ref.StatFile(ctx, gwclient.StatRequest{Path: filename})
if err != nil {
return nil, err
Expand Down Expand Up @@ -148,13 +152,20 @@ func filesFromURLRef(ctx context.Context, c gwclient.Client, ref gwclient.Refere
return nil, err
}

return filesFromRef(ctx, ref, names)
return filesFromRef(ctx, ref, names, l)
}

inp.State = nil
name := inp.URL
inp.URL = ""

now := time.Now()
l.SetStatus(&client.VertexStatus{
ID: "reading " + name,
Started: &now,
Completed: &now,
})

if len(dt) > stat.Size() {
if stat.Size() > 1024*512 {
return nil, errors.Errorf("non-archive definition URL bigger than maximum allowed size")
Expand All @@ -171,7 +182,7 @@ func filesFromURLRef(ctx context.Context, c gwclient.Client, ref gwclient.Refere
return []File{{Name: name, Data: dt}}, nil
}

func filesFromRef(ctx context.Context, ref gwclient.Reference, names []string) ([]File, error) {
func filesFromRef(ctx context.Context, ref gwclient.Reference, names []string, l progress.SubLogger) ([]File, error) {
// TODO: auto-remove parent dir in needed
var files []File

Expand All @@ -189,6 +200,12 @@ func filesFromRef(ctx context.Context, ref gwclient.Reference, names []string) (
}
return nil, err
}
now := time.Now()
l.SetStatus(&client.VertexStatus{
ID: "reading " + name,
Started: &now,
Completed: &now,
})
dt, err := ref.ReadFile(ctx, gwclient.ReadRequest{Filename: name})
if err != nil {
return nil, err
Expand Down
5 changes: 4 additions & 1 deletion commands/bake.go
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,10 @@ 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 {
files, err = bake.ReadLocalFiles(in.files, dockerCli.In())
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
})
}
if err != nil {
return err
Expand Down
45 changes: 43 additions & 2 deletions tests/bake.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ func bakeCmd(sb integration.Sandbox, opts ...cmdOpt) (string, error) {

var bakeTests = []func(t *testing.T, sb integration.Sandbox){
testBakeLocal,
testBakeLocalMulti,
testBakeRemote,
testBakeRemoteCmdContext,
testBakeRemoteCmdContextOverride,
Expand All @@ -44,8 +45,45 @@ target "default" {
)
dirDest := t.TempDir()

out, err := bakeCmd(sb, withDir(dir), withArgs("--set", "*.output=type=local,dest="+dirDest))
cmd := buildxCmd(sb, withDir(dir), withArgs("bake", "--progress=plain", "--set", "*.output=type=local,dest="+dirDest))
out, err := cmd.CombinedOutput()
require.NoError(t, err, out)
require.Contains(t, string(out), `#1 [internal] load local bake definitions`)
require.Contains(t, string(out), `#1 [internal] reading docker-bake.hcl`)

Check failure on line 52 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker, ./tests)

Failed: tests/TestIntegration/TestBakeLocal/worker=docker

=== RUN TestIntegration/TestBakeLocal/worker=docker === PAUSE TestIntegration/TestBakeLocal/worker=docker === CONT TestIntegration/TestBakeLocal/worker=docker bake.go:52: Error Trace: /src/tests/bake.go:52 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-7sho4rinpn7g9x1pi214vocif\" instance using docker driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load build definition from Dockerfile\n#2 transferring dockerfile: 66B done\n#2 DONE 0.0s\n\n#3 [internal] load .dockerignore\n#3 transferring context: 2B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeLocal/worker=docker sandbox.go:128: stdout: /usr/bin/dockerd sandbox.go:128: stderr: /usr/bin/dockerd sandbox.go:131: > startCmd 2023-10-14 04:38:18.830278097 +0000 UTC m=+30.123126277 /usr/bin/dockerd --data-root /tmp/integration3778911771/dl19ib90g83pf/root --exec-root /tmp/dxr/dl19ib90g83pf --pidfile /tmp/integration3778911771/dl19ib90g83pf/docker.pid --containerd-namespace dl19ib90g83pf --containerd-plugins-namespace dl19ib90g83pfp --host unix:///tmp/docker-integration/dl19ib90g83pf.sock --config-file /tmp/integration3778911771/daemon.json --userland-proxy=false --tls=false --debug sandbox.go:131: time="2023-10-14T04:38:18.863220332Z" level=info msg="Starting up" sandbox.go:131: time="2023-10-14T04:38:18.864158741Z" level=warning msg="could not change group /tmp/docker-integration/dl19ib90g83pf.sock to docker: group docker not found" sandbox.go:131: time="2023-10-14T04:38:18.864294243Z" level=debug msg="Listener created for HTTP on unix (/tmp/docker-integration/dl19ib90g83pf.sock)" sandbox.go:131: time="2023-10-14T04:38:18.864309943Z" level=info msg="containerd not running, starting managed containerd" sandbox.go:131: time="2023-10-14T04:38:18.864857048Z" level=info msg="started new containerd process" address=/tmp/dxr/dl19ib90g83pf/containerd/containerd.sock module=libcontainerd pid=8315 sandbox.go:131: time="2023-10-14T04:38:18.881700119Z" level=info msg="starting containerd" revision=1677a17964311325ed1c31e2c0a3589ce6d5c30d version=v1.7.1 sandbox.go:131: time="2023-10-14T04:38:18.899562401Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.aufs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:18.900209008Z" level=info msg="skip loading plugin \"io.containerd.snapshotter.v1.aufs\"..." error="aufs is not supported (modprobe aufs failed: exit status 1 \"modprobe: can't change directory to '/lib/modules': No such file or directory\\n\"): skip plugin" type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:18.900233608Z" level=info msg="loading plugin \"io.containerd.content.v1.content\"..." type=io.containerd.content.v1 sandbox.go:131: time="2023-10-14T04:38:18.900325609Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.native\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:18.900386409Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.overlayfs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:18.900553011Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.devmapper\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:18.900570811Z" level=warning msg="failed to load plugin io.containerd.snapshotter.v1.devmapper" error="devmapper not configured" sandbox.go:131: time="2023-10-14T04:38:18.900584411Z" level=info msg="loading plugin \"io.containerd.snapshotter.v

Check failure on line 52 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker\+containerd, ./tests)

Failed: tests/TestIntegration/TestBakeLocal/worker=docker+containerd

=== RUN TestIntegration/TestBakeLocal/worker=docker+containerd === PAUSE TestIntegration/TestBakeLocal/worker=docker+containerd === CONT TestIntegration/TestBakeLocal/worker=docker+containerd bake.go:52: Error Trace: /src/tests/bake.go:52 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-l1wwatio3916k1q3k7xek2mla\" instance using docker driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load .dockerignore\n#2 transferring context: 2B done\n#2 DONE 0.0s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 66B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeLocal/worker=docker+containerd sandbox.go:128: stdout: /usr/bin/dockerd sandbox.go:128: stderr: /usr/bin/dockerd sandbox.go:131: > startCmd 2023-10-14 04:38:24.2430429 +0000 UTC m=+31.486781375 /usr/bin/dockerd --data-root /tmp/integration2010567219/d5m369iw1tf5l/root --exec-root /tmp/dxr/d5m369iw1tf5l --pidfile /tmp/integration2010567219/d5m369iw1tf5l/docker.pid --containerd-namespace d5m369iw1tf5l --containerd-plugins-namespace d5m369iw1tf5lp --host unix:///tmp/docker-integration/d5m369iw1tf5l.sock --config-file /tmp/integration2010567219/daemon.json --userland-proxy=false --tls=false --debug sandbox.go:131: time="2023-10-14T04:38:24.275316501Z" level=info msg="Starting up" sandbox.go:131: time="2023-10-14T04:38:24.276539709Z" level=warning msg="could not change group /tmp/docker-integration/d5m369iw1tf5l.sock to docker: group docker not found" sandbox.go:131: time="2023-10-14T04:38:24.277138212Z" level=debug msg="Listener created for HTTP on unix (/tmp/docker-integration/d5m369iw1tf5l.sock)" sandbox.go:131: time="2023-10-14T04:38:24.277177913Z" level=info msg="containerd not running, starting managed containerd" sandbox.go:131: time="2023-10-14T04:38:24.277794217Z" level=info msg="started new containerd process" address=/tmp/dxr/d5m369iw1tf5l/containerd/containerd.sock module=libcontainerd pid=8191 sandbox.go:131: time="2023-10-14T04:38:24.293630915Z" level=info msg="starting containerd" revision=1677a17964311325ed1c31e2c0a3589ce6d5c30d version=v1.7.1 sandbox.go:131: time="2023-10-14T04:38:24.311217625Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.aufs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:24.312322932Z" level=info msg="skip loading plugin \"io.containerd.snapshotter.v1.aufs\"..." error="aufs is not supported (modprobe aufs failed: exit status 1 \"modprobe: can't change directory to '/lib/modules': No such file or directory\\n\"): skip plugin" type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:24.312351732Z" level=info msg="loading plugin \"io.containerd.content.v1.content\"..." type=io.containerd.content.v1 sandbox.go:131: time="2023-10-14T04:38:24.312466633Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.native\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:24.312529833Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.overlayfs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:24.312733334Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.devmapper\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:24.312752534Z" level=warning msg="failed to load plugin io.containerd.snapshotter.v1.devmapper" error="devmapper not configured" sandbox.go:131: time="2023-10-14T04:38:24.312765934Z" level=info msg="lo

Check failure on line 52 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker-container, ./tests)

Failed: tests/TestIntegration/TestBakeLocal/worker=docker-container

=== RUN TestIntegration/TestBakeLocal/worker=docker-container === PAUSE TestIntegration/TestBakeLocal/worker=docker-container === CONT TestIntegration/TestBakeLocal/worker=docker-container bake.go:52: Error Trace: /src/tests/bake.go:52 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-container-s5zax0885wsqm8zd1sdm8jx1d\" instance using docker-container driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load build definition from Dockerfile\n#2 transferring dockerfile: 66B done\n#2 DONE 0.0s\n\n#3 [internal] load .dockerignore\n#3 transferring context: 2B 0.0s done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B 0.0s done\n#6 DONE 0.0s\n\nView build details: docker-desktop://dashboard/build/integration-container-s5zax0885wsqm8zd1sdm8jx1d/integration-container-s5zax0885wsqm8zd1sdm8jx1d0/m8c32788ymjjfc5donnkbq35z\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeLocal/worker=docker-container --- FAIL: TestIntegration/TestBakeLocal/worker=docker-container (4.19s)

Check failure on line 52 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (remote, ./tests)

Failed: tests/TestIntegration/TestBakeLocal/worker=remote

=== RUN TestIntegration/TestBakeLocal/worker=remote === PAUSE TestIntegration/TestBakeLocal/worker=remote === CONT TestIntegration/TestBakeLocal/worker=remote bake.go:52: Error Trace: /src/tests/bake.go:52 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-remote-83wsfcow70nla9lzss0q23btb\" instance using remote driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load .dockerignore\n#2 transferring context: 2B done\n#2 DONE 0.0s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 66B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeLocal/worker=remote sandbox.go:128: stdout: /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config1495353878/buildkitd.toml --root /tmp/bktest_buildkitd2617457616 --addr unix:///tmp/bktest_buildkitd2617457616/buildkitd.sock --debug sandbox.go:128: stderr: /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config1495353878/buildkitd.toml --root /tmp/bktest_buildkitd2617457616 --addr unix:///tmp/bktest_buildkitd2617457616/buildkitd.sock --debug sandbox.go:131: > StartCmd 2023-10-14 04:38:14.977889452 +0000 UTC m=+11.073929411 /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config1495353878/buildkitd.toml --root /tmp/bktest_buildkitd2617457616 --addr unix:///tmp/bktest_buildkitd2617457616/buildkitd.sock --debug sandbox.go:131: time="2023-10-14T04:38:15Z" level=info msg="auto snapshotter: using overlayfs" sandbox.go:131: time="2023-10-14T04:38:15Z" level=warning msg="using host network as the default" sandbox.go:131: time="2023-10-14T04:38:15Z" level=info msg="found worker \"mgn79ktfwcsbujmyjtd1gx0qc\", labels=map[org.mobyproject.buildkit.worker.executor:oci org.mobyproject.buildkit.worker.hostname:37d19bdce58c org.mobyproject.buildkit.worker.network:host org.mobyproject.buildkit.worker.oci.process-mode:sandbox org.mobyproject.buildkit.worker.sandbox:true org.mobyproject.buildkit.worker.selinux.enabled:false org.mobyproject.buildkit.worker.snapshotter:overlayfs], platforms=[linux/amd64 linux/amd64/v2 linux/amd64/v3 linux/amd64/v4 linux/arm64 linux/riscv64 linux/ppc64le linux/s390x linux/386 linux/mips64le linux/mips64 linux/arm/v7 linux/arm/v6]" sandbox.go:131: time="2023-10-14T04:38:15Z" level=info msg="found 1 workers, default=\"mgn79ktfwcsbujmyjtd1gx0qc\"" sandbox.go:131: time="2023-10-14T04:38:15Z" level=warning msg="currently, only the default worker can be used." sandbox.go:131: time="2023-10-14T04:38:15Z" level=info msg="running server on /tmp/bktest_buildkitd2617457616/buildkitd.sock" sandbox.go:131: time="2023-10-14T04:38:15Z" level=debug msg="session started" spanID=08c2f8f3dc7014ee traceID=ce1b9734d7dae322fb7cf2ccfd6ba603 sandbox.go:131: time="2023-10-14T04:38:15Z" level=debug msg="session finished: <nil>" spanID=08c2f8f3dc7014ee traceID=ce1b9734d7dae322fb7cf2ccfd6ba603 sandbox.go:131: time="2023-10-14T04:38:15Z" level=debug msg="session started" spanID=2874be639d40cb08 traceID=ce1b9734d7dae322fb7cf2ccfd6ba603 sandbox.go:131: time="2023-10-14T04:38:15Z" level=debug msg="new ref for local: ww1nwszollsdizrsahcs6jdov" span="[internal] load .dockerignore" spanID=5023b07a3401888d traceID=ce1b

require.FileExists(t, filepath.Join(dirDest, "foo"))
}

func testBakeLocalMulti(t *testing.T, sb integration.Sandbox) {
dockerfile := []byte(`
FROM scratch
COPY foo /foo
`)
bakefile := []byte(`
target "default" {
}
`)
composefile := []byte(`
services:
app:
build: {}
`)

dir := tmpdir(
t,
fstest.CreateFile("docker-bake.hcl", bakefile, 0600),
fstest.CreateFile("compoose.yaml", composefile, 0600),
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()
require.NoError(t, err, out)
require.Contains(t, string(out), `#1 [internal] load local bake definitions`)
require.Contains(t, string(out), `#1 [internal] reading compose.yaml`)

Check failure on line 85 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker, ./tests)

Failed: tests/TestIntegration/TestBakeLocalMulti/worker=docker

=== RUN TestIntegration/TestBakeLocalMulti/worker=docker === PAUSE TestIntegration/TestBakeLocalMulti/worker=docker === CONT TestIntegration/TestBakeLocalMulti/worker=docker bake.go:85: Error Trace: /src/tests/bake.go:85 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-oud2zmh2jjggp2cl32u6cj5km\" instance using docker driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load .dockerignore\n#2 transferring context: 2B done\n#2 DONE 0.0s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 66B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading compose.yaml" Test: TestIntegration/TestBakeLocalMulti/worker=docker sandbox.go:128: stdout: /usr/bin/dockerd sandbox.go:128: stderr: /usr/bin/dockerd sandbox.go:131: > startCmd 2023-10-14 04:38:17.41951104 +0000 UTC m=+28.712359320 /usr/bin/dockerd --data-root /tmp/integration1726816016/ds7p2x2hlhrbo/root --exec-root /tmp/dxr/ds7p2x2hlhrbo --pidfile /tmp/integration1726816016/ds7p2x2hlhrbo/docker.pid --containerd-namespace ds7p2x2hlhrbo --containerd-plugins-namespace ds7p2x2hlhrbop --host unix:///tmp/docker-integration/ds7p2x2hlhrbo.sock --config-file /tmp/integration1726816016/daemon.json --userland-proxy=false --tls=false --debug sandbox.go:131: time="2023-10-14T04:38:17.454586988Z" level=info msg="Starting up" sandbox.go:131: time="2023-10-14T04:38:17.455560381Z" level=warning msg="could not change group /tmp/docker-integration/ds7p2x2hlhrbo.sock to docker: group docker not found" sandbox.go:131: time="2023-10-14T04:38:17.455697680Z" level=debug msg="Listener created for HTTP on unix (/tmp/docker-integration/ds7p2x2hlhrbo.sock)" sandbox.go:131: time="2023-10-14T04:38:17.455713280Z" level=info msg="containerd not running, starting managed containerd" sandbox.go:131: time="2023-10-14T04:38:17.456306775Z" level=info msg="started new containerd process" address=/tmp/dxr/ds7p2x2hlhrbo/containerd/containerd.sock module=libcontainerd pid=8139 sandbox.go:131: time="2023-10-14T04:38:17.472352660Z" level=info msg="starting containerd" revision=1677a17964311325ed1c31e2c0a3589ce6d5c30d version=v1.7.1 sandbox.go:131: time="2023-10-14T04:38:17.492961512Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.aufs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:17.493737206Z" level=info msg="skip loading plugin \"io.containerd.snapshotter.v1.aufs\"..." error="aufs is not supported (modprobe aufs failed: exit status 1 \"modprobe: can't change directory to '/lib/modules': No such file or directory\\n\"): skip plugin" type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:17.493765606Z" level=info msg="loading plugin \"io.containerd.content.v1.content\"..." type=io.containerd.content.v1 sandbox.go:131: time="2023-10-14T04:38:17.493906205Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.native\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:17.494019104Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.overlayfs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:17.494213203Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.devmapper\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:17.494232502Z" level=warning msg="failed to load plugin io.containerd.snapshotter.v1.devmapper" error="devmapper not configured" sandbox.go:131: time="2023-10-14T04:38:17.494258402Z" level=info msg="loading plugin \"io.containe

Check failure on line 85 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker\+containerd, ./tests)

Failed: tests/TestIntegration/TestBakeLocalMulti/worker=docker+containerd

=== RUN TestIntegration/TestBakeLocalMulti/worker=docker+containerd === PAUSE TestIntegration/TestBakeLocalMulti/worker=docker+containerd === CONT TestIntegration/TestBakeLocalMulti/worker=docker+containerd bake.go:85: Error Trace: /src/tests/bake.go:85 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-kc1qljn6e8mcma6vmj9lzgaiu\" instance using docker driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load .dockerignore\n#2 transferring context: 2B done\n#2 DONE 0.0s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 66B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading compose.yaml" Test: TestIntegration/TestBakeLocalMulti/worker=docker+containerd sandbox.go:128: stderr: /usr/bin/dockerd sandbox.go:131: > startCmd 2023-10-14 04:37:59.398293246 +0000 UTC m=+6.642031721 /usr/bin/dockerd --data-root /tmp/integration3834622412/d04mna0qjx317/root --exec-root /tmp/dxr/d04mna0qjx317 --pidfile /tmp/integration3834622412/d04mna0qjx317/docker.pid --containerd-namespace d04mna0qjx317 --containerd-plugins-namespace d04mna0qjx317p --host unix:///tmp/docker-integration/d04mna0qjx317.sock --config-file /tmp/integration3834622412/daemon.json --userland-proxy=false --tls=false --debug sandbox.go:131: time="2023-10-14T04:37:59.434594672Z" level=info msg="Starting up" sandbox.go:131: time="2023-10-14T04:37:59.435642079Z" level=warning msg="could not change group /tmp/docker-integration/d04mna0qjx317.sock to docker: group docker not found" sandbox.go:131: time="2023-10-14T04:37:59.435819980Z" level=debug msg="Listener created for HTTP on unix (/tmp/docker-integration/d04mna0qjx317.sock)" sandbox.go:131: time="2023-10-14T04:37:59.435836680Z" level=info msg="containerd not running, starting managed containerd" sandbox.go:131: time="2023-10-14T04:37:59.436507484Z" level=info msg="started new containerd process" address=/tmp/dxr/d04mna0qjx317/containerd/containerd.sock module=libcontainerd pid=4719 sandbox.go:131: time="2023-10-14T04:37:59.453674691Z" level=info msg="starting containerd" revision=1677a17964311325ed1c31e2c0a3589ce6d5c30d version=v1.7.1 sandbox.go:131: time="2023-10-14T04:37:59.471795004Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.aufs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:37:59.472509208Z" level=info msg="skip loading plugin \"io.containerd.snapshotter.v1.aufs\"..." error="aufs is not supported (modprobe aufs failed: exit status 1 \"modprobe: can't change directory to '/lib/modules': No such file or directory\\n\"): skip plugin" type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:37:59.472533609Z" level=info msg="loading plugin \"io.containerd.content.v1.content\"..." type=io.containerd.content.v1 sandbox.go:131: time="2023-10-14T04:37:59.472660209Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.native\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:37:59.472736610Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.overlayfs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:37:59.472912311Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.devmapper\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:37:59.472930211Z" level=warning msg="failed to load plugin io.containerd.snapshotter.v1.devmapper" error="devmapper not configured" sandbox.go:131: time="2023-10-14T04:37:59.472943811Z" level=info msg="loading plugin \"io.container

Check failure on line 85 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker-container, ./tests)

Failed: tests/TestIntegration/TestBakeLocalMulti/worker=docker-container

=== RUN TestIntegration/TestBakeLocalMulti/worker=docker-container === PAUSE TestIntegration/TestBakeLocalMulti/worker=docker-container === CONT TestIntegration/TestBakeLocalMulti/worker=docker-container bake.go:85: Error Trace: /src/tests/bake.go:85 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-container-alcxs4skrhyqoqvtn40q5r24d\" instance using docker-container driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load build definition from Dockerfile\n#2 transferring dockerfile: 66B done\n#2 DONE 0.1s\n\n#3 [internal] load .dockerignore\n#3 transferring context: 2B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading compose.yaml" Test: TestIntegration/TestBakeLocalMulti/worker=docker-container --- FAIL: TestIntegration/TestBakeLocalMulti/worker=docker-container (5.96s)

Check failure on line 85 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (remote, ./tests)

Failed: tests/TestIntegration/TestBakeLocalMulti/worker=remote

=== RUN TestIntegration/TestBakeLocalMulti/worker=remote === PAUSE TestIntegration/TestBakeLocalMulti/worker=remote === CONT TestIntegration/TestBakeLocalMulti/worker=remote bake.go:85: Error Trace: /src/tests/bake.go:85 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-remote-qnmvsr1p9upxspl5pogs4c0c6\" instance using remote driver\n\n#1 [internal] load local bake definitions\n#1 reading docker-bake.hcl 22B / 22B done\n#1 DONE 0.0s\n\n#2 [internal] load .dockerignore\n#2 transferring context: 2B done\n#2 DONE 0.0s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 66B done\n#3 DONE 0.0s\n\n#4 [internal] load build context\n#4 transferring context: 33B done\n#4 DONE 0.0s\n\n#5 [1/1] COPY foo /foo\n#5 DONE 0.0s\n\n#6 exporting to client directory\n#6 copying files 29B done\n#6 DONE 0.0s\n" does not contain "#1 [internal] reading compose.yaml" Test: TestIntegration/TestBakeLocalMulti/worker=remote sandbox.go:128: stdout: /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config3041150467/buildkitd.toml --root /tmp/bktest_buildkitd623992112 --addr unix:///tmp/bktest_buildkitd623992112/buildkitd.sock --debug sandbox.go:128: stderr: /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config3041150467/buildkitd.toml --root /tmp/bktest_buildkitd623992112 --addr unix:///tmp/bktest_buildkitd623992112/buildkitd.sock --debug sandbox.go:131: > StartCmd 2023-10-14 04:38:09.308991392 +0000 UTC m=+5.405031451 /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config3041150467/buildkitd.toml --root /tmp/bktest_buildkitd623992112 --addr unix:///tmp/bktest_buildkitd623992112/buildkitd.sock --debug sandbox.go:131: time="2023-10-14T04:38:09Z" level=info msg="auto snapshotter: using overlayfs" sandbox.go:131: time="2023-10-14T04:38:09Z" level=warning msg="using host network as the default" sandbox.go:131: time="2023-10-14T04:38:09Z" level=info msg="found worker \"7i38ntllbdy93bwq5rvi7lar8\", labels=map[org.mobyproject.buildkit.worker.executor:oci org.mobyproject.buildkit.worker.hostname:37d19bdce58c org.mobyproject.buildkit.worker.network:host org.mobyproject.buildkit.worker.oci.process-mode:sandbox org.mobyproject.buildkit.worker.sandbox:true org.mobyproject.buildkit.worker.selinux.enabled:false org.mobyproject.buildkit.worker.snapshotter:overlayfs], platforms=[linux/amd64 linux/amd64/v2 linux/amd64/v3 linux/amd64/v4 linux/arm64 linux/riscv64 linux/ppc64le linux/s390x linux/386 linux/mips64le linux/mips64 linux/arm/v7 linux/arm/v6]" sandbox.go:131: time="2023-10-14T04:38:09Z" level=info msg="found 1 workers, default=\"7i38ntllbdy93bwq5rvi7lar8\"" sandbox.go:131: time="2023-10-14T04:38:09Z" level=warning msg="currently, only the default worker can be used." sandbox.go:131: time="2023-10-14T04:38:09Z" level=info msg="running server on /tmp/bktest_buildkitd623992112/buildkitd.sock" sandbox.go:131: time="2023-10-14T04:38:09Z" level=debug msg="session started" spanID=9620523f20468088 traceID=caf31120a3b48ecadb26160463ff0147 sandbox.go:131: time="2023-10-14T04:38:09Z" level=debug msg="session finished: <nil>" spanID=9620523f20468088 traceID=caf31120a3b48ecadb26160463ff0147 sandbox.go:131: time="2023-10-14T04:38:10Z" level=debug msg="session started" spanID=89112f36472009c0 traceID=caf31120a3b48ecadb26160463ff0147 sandbox.go:131: time="2023-10-14T04:38:10Z" level=debug msg="new ref for local: c09xw3ubflg8c9boynqwh7cm5" span="[internal] load .dockerignore" spanID=45ca56ef7b857092 tra
require.Contains(t, string(out), `#1 [internal] reading docker-bake.hcl`)

require.FileExists(t, filepath.Join(dirDest, "foo"))
}
Expand Down Expand Up @@ -74,8 +112,11 @@ EOT
gitutil.GitCommit(git, t, "initial commit")
addr := gitutil.GitServeHTTP(git, t)

out, err := bakeCmd(sb, withDir(dir), withArgs(addr, "--set", "*.output=type=local,dest="+dirDest))
cmd := buildxCmd(sb, withDir(dir), withArgs("bake", addr, "--progress=plain", "--set", "*.output=type=local,dest="+dirDest))
out, err := cmd.CombinedOutput()
require.NoError(t, err, out)
require.Contains(t, string(out), `#1 [internal] load remote bake definitions`)
require.Contains(t, string(out), `#1 [internal] reading docker-bake.hcl`)

Check failure on line 119 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker, ./tests)

Failed: tests/TestIntegration/TestBakeRemote/worker=docker

=== RUN TestIntegration/TestBakeRemote/worker=docker === PAUSE TestIntegration/TestBakeRemote/worker=docker === CONT TestIntegration/TestBakeRemote/worker=docker bake.go:119: Error Trace: /src/tests/bake.go:119 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-cl5jk4g72pdx34zy9wmdk4okg\" instance using docker driver\n\n#1 [internal] load remote bake definitions\n#1 ...\n\n#2 [internal] load git source http://127.0.0.1:44043/test.git\n#2 0.044 Initialized empty Git repository in /tmp/integration2019153927/dkxnqt68onq2t/root/overlay2/xawg9i7oin8zg4h8zkxmqerhb/diff/\n#2 0.131 ref: refs/heads/main\tHEAD\n#2 0.132 63ced7fef466f7636b4fbc78e7b029995b899ce1\tHEAD\n#2 0.177 63ced7fef466f7636b4fbc78e7b029995b899ce1\trefs/heads/main\n#2 0.046 ref: refs/heads/main\tHEAD\n#2 0.046 63ced7fef466f7636b4fbc78e7b029995b899ce1\tHEAD\n#2 0.095 fatal: dumb http transport does not support shallow capabilities\n#2 0.143 From http://127.0.0.1:44043/test\n#2 0.143 * [new branch] main -> main\n#2 0.143 * [new branch] main -> origin/main\n#2 DONE 0.5s\n\n#1 [internal] load remote bake definitions\n#1 reading docker-bake.hcl done\n#1 DONE 0.5s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 64B done\n#3 DONE 0.0s\n\n#2 [internal] load git source http://127.0.0.1:44043/test.git\n#2 0.045 ref: refs/heads/main\tHEAD\n#2 0.046 63ced7fef466f7636b4fbc78e7b029995b899ce1\tHEAD\n#2 0.089 63ced7fef466f7636b4fbc78e7b029995b899ce1\trefs/heads/main\n#2 CACHED\n\n#4 [1/1] COPY foo /foo\n#4 DONE 0.0s\n\n#5 exporting to client directory\n#5 copying files 29B done\n#5 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeRemote/worker=docker sandbox.go:128: stdout: /usr/bin/dockerd sandbox.go:128: stderr: /usr/bin/dockerd sandbox.go:131: > startCmd 2023-10-14 04:38:15.418422953 +0000 UTC m=+26.711271233 /usr/bin/dockerd --data-root /tmp/integration2019153927/dkxnqt68onq2t/root --exec-root /tmp/dxr/dkxnqt68onq2t --pidfile /tmp/integration2019153927/dkxnqt68onq2t/docker.pid --containerd-namespace dkxnqt68onq2t --containerd-plugins-namespace dkxnqt68onq2tp --host unix:///tmp/docker-integration/dkxnqt68onq2t.sock --config-file /tmp/integration2019153927/daemon.json --userland-proxy=false --tls=false --debug sandbox.go:131: time="2023-10-14T04:38:15.450647281Z" level=info msg="Starting up" sandbox.go:131: time="2023-10-14T04:38:15.451637591Z" level=warning msg="could not change group /tmp/docker-integration/dkxnqt68onq2t.sock to docker: group docker not found" sandbox.go:131: time="2023-10-14T04:38:15.451814393Z" level=debug msg="Listener created for HTTP on unix (/tmp/docker-integration/dkxnqt68onq2t.sock)" sandbox.go:131: time="2023-10-14T04:38:15.451847693Z" level=info msg="containerd not running, starting managed containerd" sandbox.go:131: time="2023-10-14T04:38:15.452444099Z" level=info msg="started new containerd process" address=/tmp/dxr/dkxnqt68onq2t/containerd/containerd.sock module=libcontainerd pid=7766 sandbox.go:131: time="2023-10-14T04:38:15.470814686Z" level=info msg="starting containerd" revision=1677a17964311325ed1c31e2c0a3589ce6d5c30d version=v1.7.1 sandbox.go:131: time="2023-10-14T04:38:15.487675058Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.aufs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:15.488467366Z" level=info msg="skip loading plugin \"io.containerd.snapshotter.v1.aufs\"..." error="aufs is not supported (modprobe aufs failed: exit status 1 \"modprobe: can't change directory to '/lib/modules': No such file or directory\\n\"): skip plugin" type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:15.488556367Z" level=info msg="loading plugin \"io.containerd.content.v1.content\"..." type=io.contai

Check failure on line 119 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker\+containerd, ./tests)

Failed: tests/TestIntegration/TestBakeRemote/worker=docker+containerd

=== RUN TestIntegration/TestBakeRemote/worker=docker+containerd === PAUSE TestIntegration/TestBakeRemote/worker=docker+containerd === CONT TestIntegration/TestBakeRemote/worker=docker+containerd bake.go:119: Error Trace: /src/tests/bake.go:119 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-oy1s2gg4lcel48xk8txfai6ok\" instance using docker driver\n\n#1 [internal] load remote bake definitions\n#1 ...\n\n#2 [internal] load git source http://127.0.0.1:34863/test.git\n#2 0.053 Initialized empty Git repository in /tmp/integration2084492447/d8zouer9rtzcu/root/containerd/daemon/io.containerd.snapshotter.v1.overlayfs/snapshots/1/fs/\n#2 0.140 ref: refs/heads/main\tHEAD\n#2 0.141 12dd6d70b24742301986e98d967b44d3bf26ff40\tHEAD\n#2 0.186 12dd6d70b24742301986e98d967b44d3bf26ff40\trefs/heads/main\n#2 0.046 ref: refs/heads/main\tHEAD\n#2 0.046 12dd6d70b24742301986e98d967b44d3bf26ff40\tHEAD\n#2 0.096 fatal: dumb http transport does not support shallow capabilities\n#2 0.147 From http://127.0.0.1:34863/test\n#2 0.147 * [new branch] main -> main\n#2 0.147 * [new branch] main -> origin/main\n#2 DONE 0.5s\n\n#1 [internal] load remote bake definitions\n#1 reading docker-bake.hcl done\n#1 DONE 0.5s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 64B done\n#3 DONE 0.0s\n\n#2 [internal] load git source http://127.0.0.1:34863/test.git\n#2 0.046 ref: refs/heads/main\tHEAD\n#2 0.047 12dd6d70b24742301986e98d967b44d3bf26ff40\tHEAD\n#2 0.095 12dd6d70b24742301986e98d967b44d3bf26ff40\trefs/heads/main\n#2 CACHED\n\n#4 [1/1] COPY foo /foo\n#4 DONE 0.0s\n\n#5 exporting to client directory\n#5 copying files 29B done\n#5 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeRemote/worker=docker+containerd sandbox.go:128: stdout: /usr/bin/dockerd sandbox.go:128: stderr: /usr/bin/dockerd sandbox.go:131: > startCmd 2023-10-14 04:38:20.211380569 +0000 UTC m=+27.455119144 /usr/bin/dockerd --data-root /tmp/integration2084492447/d8zouer9rtzcu/root --exec-root /tmp/dxr/d8zouer9rtzcu --pidfile /tmp/integration2084492447/d8zouer9rtzcu/docker.pid --containerd-namespace d8zouer9rtzcu --containerd-plugins-namespace d8zouer9rtzcup --host unix:///tmp/docker-integration/d8zouer9rtzcu.sock --config-file /tmp/integration2084492447/daemon.json --userland-proxy=false --tls=false --debug sandbox.go:131: time="2023-10-14T04:38:20.246151175Z" level=info msg="Starting up" sandbox.go:131: time="2023-10-14T04:38:20.247278075Z" level=warning msg="could not change group /tmp/docker-integration/d8zouer9rtzcu.sock to docker: group docker not found" sandbox.go:131: time="2023-10-14T04:38:20.247458775Z" level=debug msg="Listener created for HTTP on unix (/tmp/docker-integration/d8zouer9rtzcu.sock)" sandbox.go:131: time="2023-10-14T04:38:20.247491975Z" level=info msg="containerd not running, starting managed containerd" sandbox.go:131: time="2023-10-14T04:38:20.248117975Z" level=info msg="started new containerd process" address=/tmp/dxr/d8zouer9rtzcu/containerd/containerd.sock module=libcontainerd pid=7592 sandbox.go:131: time="2023-10-14T04:38:20.263491778Z" level=info msg="starting containerd" revision=1677a17964311325ed1c31e2c0a3589ce6d5c30d version=v1.7.1 sandbox.go:131: time="2023-10-14T04:38:20.283438882Z" level=info msg="loading plugin \"io.containerd.snapshotter.v1.aufs\"..." type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:20.284201282Z" level=info msg="skip loading plugin \"io.containerd.snapshotter.v1.aufs\"..." error="aufs is not supported (modprobe aufs failed: exit status 1 \"modprobe: can't change directory to '/lib/modules': No such file or directory\\n\"): skip plugin" type=io.containerd.snapshotter.v1 sandbox.go:131: time="2023-10-14T04:38:20.284227782Z" level=info

Check failure on line 119 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (docker-container, ./tests)

Failed: tests/TestIntegration/TestBakeRemote/worker=docker-container

=== RUN TestIntegration/TestBakeRemote/worker=docker-container === PAUSE TestIntegration/TestBakeRemote/worker=docker-container === CONT TestIntegration/TestBakeRemote/worker=docker-container bake.go:119: Error Trace: /src/tests/bake.go:119 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-container-sd3koveytvkawu3y78ube59rc\" instance using docker-container driver\n\n#1 [internal] load remote bake definitions\n#1 ...\n\n#2 [internal] load git source http://127.0.0.1:34441/test.git\n#2 0.034 Initialized empty Git repository in /var/lib/buildkit/runc-overlayfs/snapshots/snapshots/1/fs/\n#2 0.052 ref: refs/heads/main\tHEAD\n#2 0.053 ae1bf46f4b856da9c643f0c9210a492d42831e46\tHEAD\n#2 0.062 ae1bf46f4b856da9c643f0c9210a492d42831e46\trefs/heads/main\n#2 0.023 ref: refs/heads/main\tHEAD\n#2 0.024 ae1bf46f4b856da9c643f0c9210a492d42831e46\tHEAD\n#2 0.044 fatal: dumb http transport does not support shallow capabilities\n#2 0.075 From http://127.0.0.1:34441/test\n#2 0.075 * [new branch] main -> main\n#2 0.075 * [new branch] main -> origin/main\n#2 DONE 0.2s\n\n#1 [internal] load remote bake definitions\n#1 reading docker-bake.hcl done\n#1 DONE 0.3s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 64B done\n#3 DONE 0.0s\n\n#2 [internal] load git source http://127.0.0.1:34441/test.git\n#2 0.028 ref: refs/heads/main\tHEAD\n#2 0.030 ae1bf46f4b856da9c643f0c9210a492d42831e46\tHEAD\n#2 0.039 ae1bf46f4b856da9c643f0c9210a492d42831e46\trefs/heads/main\n#2 CACHED\n\n#4 [1/1] COPY foo /foo\n#4 DONE 0.0s\n\n#5 exporting to client directory\n#5 copying files 29B done\n#5 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeRemote/worker=docker-container --- FAIL: TestIntegration/TestBakeRemote/worker=docker-container (4.60s)

Check failure on line 119 in tests/bake.go

View workflow job for this annotation

GitHub Actions / test (remote, ./tests)

Failed: tests/TestIntegration/TestBakeRemote/worker=remote

=== RUN TestIntegration/TestBakeRemote/worker=remote === PAUSE TestIntegration/TestBakeRemote/worker=remote === CONT TestIntegration/TestBakeRemote/worker=remote bake.go:119: Error Trace: /src/tests/bake.go:119 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:91 /src/vendor/github.com/moby/buildkit/util/testutil/integration/run.go:205 Error: "#0 building with \"integration-remote-y9rxtrdubibuyt1xhjpz9qovt\" instance using remote driver\n\n#1 [internal] load remote bake definitions\n#1 ...\n\n#2 [internal] load git source http://127.0.0.1:46165/test.git\n#2 0.038 Initialized empty Git repository in /tmp/bktest_buildkitd1052848100/runc-overlayfs/snapshots/snapshots/1/fs/\n#2 0.099 ref: refs/heads/main\tHEAD\n#2 0.101 a784dc96cdecbb28a0e7063021cc48bc696a7591\tHEAD\n#2 0.130 a784dc96cdecbb28a0e7063021cc48bc696a7591\trefs/heads/main\n#2 0.029 ref: refs/heads/main\tHEAD\n#2 0.030 a784dc96cdecbb28a0e7063021cc48bc696a7591\tHEAD\n#2 0.060 fatal: dumb http transport does not support shallow capabilities\n#2 0.118 From http://127.0.0.1:46165/test\n#2 0.118 * [new branch] main -> main\n#2 0.118 * [new branch] main -> origin/main\n#2 DONE 0.3s\n\n#1 [internal] load remote bake definitions\n#1 reading docker-bake.hcl done\n#1 DONE 0.4s\n\n#3 [internal] load build definition from Dockerfile\n#3 transferring dockerfile: 64B done\n#3 DONE 0.0s\n\n#2 [internal] load git source http://127.0.0.1:46165/test.git\n#2 0.035 ref: refs/heads/main\tHEAD\n#2 0.035 a784dc96cdecbb28a0e7063021cc48bc696a7591\tHEAD\n#2 0.062 a784dc96cdecbb28a0e7063021cc48bc696a7591\trefs/heads/main\n#2 CACHED\n\n#4 [1/1] COPY foo /foo\n#4 DONE 0.0s\n\n#5 exporting to client directory\n#5 copying files 29B done\n#5 DONE 0.0s\n" does not contain "#1 [internal] reading docker-bake.hcl" Test: TestIntegration/TestBakeRemote/worker=remote sandbox.go:128: stdout: /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config2026201512/buildkitd.toml --root /tmp/bktest_buildkitd1052848100 --addr unix:///tmp/bktest_buildkitd1052848100/buildkitd.sock --debug sandbox.go:128: stderr: /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config2026201512/buildkitd.toml --root /tmp/bktest_buildkitd1052848100 --addr unix:///tmp/bktest_buildkitd1052848100/buildkitd.sock --debug sandbox.go:131: > StartCmd 2023-10-14 04:38:13.915026041 +0000 UTC m=+10.011066100 /usr/bin/buildkitd --oci-worker=true --containerd-worker=false --oci-worker-gc=false --oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true --config=/tmp/bktest_config2026201512/buildkitd.toml --root /tmp/bktest_buildkitd1052848100 --addr unix:///tmp/bktest_buildkitd1052848100/buildkitd.sock --debug sandbox.go:131: time="2023-10-14T04:38:14Z" level=info msg="auto snapshotter: using overlayfs" sandbox.go:131: time="2023-10-14T04:38:14Z" level=warning msg="using host network as the default" sandbox.go:131: time="2023-10-14T04:38:14Z" level=info msg="found worker \"tg4xvgnm7hshe93zf9gsformp\", labels=map[org.mobyproject.buildkit.worker.executor:oci org.mobyproject.buildkit.worker.hostname:37d19bdce58c org.mobyproject.buildkit.worker.network:host org.mobyproject.buildkit.worker.oci.process-mode:sandbox org.mobyproject.buildkit.worker.sandbox:true org.mobyproject.buildkit.worker.selinux.enabled:false org.mobyproject.buildkit.worker.snapshotter:overlayfs], platforms=[linux/amd64 linux/amd64/v2 linux/amd64/v3 linux/amd64/v4 linux/arm64 linux/riscv64 linux/ppc64le linux/s390x linux/386 linux/mips64le linux/mips64 linux/arm/v7 linux/arm/v6]" sandbox.go:131: time="2023-10-14T04:38:14Z" level=info msg="found 1 workers, default=\"tg4xvgnm7hshe93zf9gsformp\"" sandbox.go:131: time="2023-10-14T04:38:14Z" level=warning msg="currently, on

require.FileExists(t, filepath.Join(dirDest, "foo"))
}
Expand Down
2 changes: 1 addition & 1 deletion util/cobrautil/completion/completion.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ func Disable(cmd *cobra.Command, args []string, toComplete string) ([]string, co

func BakeTargets(files []string) ValidArgsFn {
return func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective) {
f, err := bake.ReadLocalFiles(files, nil)
f, err := bake.ReadLocalFiles(files, nil, nil)
if err != nil {
return nil, cobra.ShellCompDirectiveError
}
Expand Down

0 comments on commit 5bbf260

Please sign in to comment.