integration: fix cleanup of registry data

Signed-off-by: Tonis Tiigi <tonistiigi@gmail.com>
docker-18.09
Tonis Tiigi 2018-09-11 18:28:11 -07:00
parent 75ea12b6c9
commit fe8f2c9910
3 changed files with 70 additions and 23 deletions

View File

@ -132,6 +132,9 @@ disabled_plugins = ["cri"]
if err != nil {
return nil, nil, err
}
deferF.append(func() error {
return os.RemoveAll(dir)
})
buildkitdArgs = append(buildkitdArgs, "--config="+filepath.Join(dir, "buildkitd.toml"))
}

View File

@ -61,16 +61,22 @@ func (s *oci) New(opt ...SandboxOpt) (Sandbox, func() error, error) {
// Include use of --oci-worker-labels to trigger https://github.com/moby/buildkit/pull/603
buildkitdArgs := []string{"buildkitd", "--oci-worker=true", "--containerd-worker=false", "--oci-worker-labels=org.mobyproject.buildkit.worker.sandbox=true"}
deferF := &multiCloser{}
if c.mirror != "" {
dir, err := configWithMirror(c.mirror)
if err != nil {
return nil, nil, err
}
deferF.append(func() error {
return os.RemoveAll(dir)
})
buildkitdArgs = append(buildkitdArgs, "--config="+filepath.Join(dir, "buildkitd.toml"))
}
if s.uid != 0 {
if s.gid == 0 {
deferF.F()()
return nil, nil, errors.Errorf("unsupported id pair: uid=%d, gid=%d", s.uid, s.gid)
}
// TODO: make sure the user exists and subuid/subgid are configured.
@ -78,10 +84,10 @@ func (s *oci) New(opt ...SandboxOpt) (Sandbox, func() error, error) {
}
buildkitdSock, stop, err := runBuildkitd(buildkitdArgs, logs, s.uid, s.gid)
if err != nil {
deferF.F()()
return nil, nil, err
}
deferF := &multiCloser{}
deferF.append(stop)
return &sandbox{address: buildkitdSock, logs: logs, cleanup: deferF, rootless: s.uid != 0}, deferF.F(), nil

View File

@ -10,9 +10,11 @@ import (
"reflect"
"runtime"
"strings"
"sync"
"syscall"
"testing"
"github.com/moby/buildkit/frontend/dockerfile/dockerfile2llb"
"github.com/moby/buildkit/util/contentutil"
"github.com/pkg/errors"
"github.com/stretchr/testify/assert"
@ -61,35 +63,28 @@ func Run(t *testing.T, testCases []Test) {
t.Skip("skipping in short mode")
}
mirrorDir := os.Getenv("BUILDKIT_REGISTRY_MIRROR_DIR")
var f *os.File
if mirrorDir != "" {
var err error
f, err = os.Create(filepath.Join(mirrorDir, "lock"))
require.NoError(t, err)
// defer f.Close() // this defer runs after subtest, cleanup on exit
err = syscall.Flock(int(f.Fd()), syscall.LOCK_EX)
require.NoError(t, err)
}
mirror, cleanup, err := newRegistry(mirrorDir)
require.NoError(t, err)
_ = cleanup
// defer cleanup() // this defer runs after subtest, cleanup on exit
err = copyImagesLocal(t, mirror)
mirror, cleanup, err := runMirror(t)
require.NoError(t, err)
if mirrorDir != "" {
err = syscall.Flock(int(f.Fd()), syscall.LOCK_UN)
require.NoError(t, err)
var mu sync.Mutex
var count int
cleanOnComplete := func() func() {
count++
return func() {
mu.Lock()
count--
if count == 0 {
cleanup()
}
mu.Unlock()
}
}
defer cleanOnComplete()()
for _, br := range List() {
for _, tc := range testCases {
ok := t.Run(getFunctionName(tc)+"/worker="+br.Name(), func(t *testing.T) {
defer cleanOnComplete()()
sb, close, err := br.New(WithMirror(mirror))
if err != nil {
if errors.Cause(err) == ErrorRequirements {
@ -142,6 +137,7 @@ func offlineImages() map[string]string {
return map[string]string{
"library/busybox:latest": "docker.io/" + arch + "/busybox:latest",
"library/alpine:latest": "docker.io/" + arch + "/alpine:latest",
"tonistiigi/copy:v0.1.4": "docker.io/" + dockerfile2llb.DefaultCopyImage,
}
}
@ -158,3 +154,45 @@ mirrors=["%s"]
}
return tmpdir, nil
}
func runMirror(t *testing.T) (host string, cleanup func() error, err error) {
mirrorDir := os.Getenv("BUILDKIT_REGISTRY_MIRROR_DIR")
var f *os.File
if mirrorDir != "" {
f, err = os.Create(filepath.Join(mirrorDir, "lock"))
if err != nil {
return "", nil, err
}
defer func() {
if err != nil {
f.Close()
}
}()
if err := syscall.Flock(int(f.Fd()), syscall.LOCK_EX); err != nil {
return "", nil, err
}
}
mirror, cleanup, err := newRegistry(mirrorDir)
if err != nil {
return "", nil, err
}
defer func() {
if err != nil {
cleanup()
}
}()
if err := copyImagesLocal(t, mirror); err != nil {
return "", nil, err
}
if mirrorDir != "" {
if err := syscall.Flock(int(f.Fd()), syscall.LOCK_UN); err != nil {
return "", nil, err
}
}
return mirror, cleanup, err
}