mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 18:13:42 +08:00 
			
		
		
		
	- tests: implement NetNSDetached method
full diff: 6e200afad5...6bd81372ad
Co-authored-by: CrazyMax <1951866+crazy-max@users.noreply.github.com>
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
		
	
		
			
				
	
	
		
			77 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package workers
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"os"
 | 
						|
	"os/exec"
 | 
						|
 | 
						|
	"github.com/moby/buildkit/identity"
 | 
						|
	"github.com/moby/buildkit/util/testutil/integration"
 | 
						|
	bkworkers "github.com/moby/buildkit/util/testutil/workers"
 | 
						|
	"github.com/pkg/errors"
 | 
						|
)
 | 
						|
 | 
						|
func InitRemoteWorker() {
 | 
						|
	integration.Register(&remoteWorker{
 | 
						|
		id: "remote",
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
type remoteWorker struct {
 | 
						|
	id          string
 | 
						|
	unsupported []string
 | 
						|
}
 | 
						|
 | 
						|
func (w remoteWorker) Name() string {
 | 
						|
	return w.id
 | 
						|
}
 | 
						|
 | 
						|
func (w remoteWorker) Rootless() bool {
 | 
						|
	return false
 | 
						|
}
 | 
						|
 | 
						|
func (w remoteWorker) NetNSDetached() bool {
 | 
						|
	return false
 | 
						|
}
 | 
						|
 | 
						|
func (w remoteWorker) New(ctx context.Context, cfg *integration.BackendConfig) (b integration.Backend, cl func() error, err error) {
 | 
						|
	oci := bkworkers.OCI{ID: w.id}
 | 
						|
	bk, bkclose, err := oci.New(ctx, cfg)
 | 
						|
	if err != nil {
 | 
						|
		return bk, cl, err
 | 
						|
	}
 | 
						|
 | 
						|
	name := "integration-remote-" + identity.NewID()
 | 
						|
	cmd := exec.Command("buildx", "create",
 | 
						|
		"--bootstrap",
 | 
						|
		"--name="+name,
 | 
						|
		"--driver=remote",
 | 
						|
		bk.Address(),
 | 
						|
	)
 | 
						|
	cmd.Env = append(os.Environ(), "BUILDX_CONFIG=/tmp/buildx-"+name)
 | 
						|
	if err := cmd.Run(); err != nil {
 | 
						|
		return nil, nil, errors.Wrapf(err, "failed to create buildx instance %s", name)
 | 
						|
	}
 | 
						|
 | 
						|
	cl = func() error {
 | 
						|
		var err error
 | 
						|
		if err1 := bkclose(); err == nil {
 | 
						|
			err = err1
 | 
						|
		}
 | 
						|
		cmd := exec.Command("buildx", "rm", "-f", name)
 | 
						|
		if err1 := cmd.Run(); err == nil {
 | 
						|
			err = err1
 | 
						|
		}
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	return &backend{
 | 
						|
		builder:             name,
 | 
						|
		unsupportedFeatures: w.unsupported,
 | 
						|
	}, cl, nil
 | 
						|
}
 | 
						|
 | 
						|
func (w remoteWorker) Close() error {
 | 
						|
	return nil
 | 
						|
}
 |