2018-02-08 17:16:20 -05:00
|
|
|
package logging
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/docker/docker/api/types"
|
2019-08-29 16:52:40 -04:00
|
|
|
"github.com/docker/docker/testutil/fixtures/plugin"
|
2020-09-10 16:15:40 -04:00
|
|
|
"github.com/moby/locker"
|
2018-02-08 17:16:20 -05:00
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
var pluginBuildLock = locker.New()
|
|
|
|
|
|
|
|
func ensurePlugin(t *testing.T, name string) string {
|
|
|
|
pluginBuildLock.Lock(name)
|
|
|
|
defer pluginBuildLock.Unlock(name)
|
|
|
|
|
|
|
|
installPath := filepath.Join(os.Getenv("GOPATH"), "bin", name)
|
|
|
|
if _, err := os.Stat(installPath); err == nil {
|
|
|
|
return installPath
|
|
|
|
}
|
|
|
|
|
|
|
|
goBin, err := exec.LookPath("go")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd := exec.Command(goBin, "build", "-o", installPath, "./"+filepath.Join("cmd", name))
|
2021-05-17 08:12:49 -04:00
|
|
|
cmd.Env = append(os.Environ(), "CGO_ENABLED=0", "GO111MODULE=off")
|
2018-02-08 17:16:20 -05:00
|
|
|
if out, err := cmd.CombinedOutput(); err != nil {
|
|
|
|
t.Fatal(errors.Wrapf(err, "error building basic plugin bin: %s", string(out)))
|
|
|
|
}
|
|
|
|
|
|
|
|
return installPath
|
|
|
|
}
|
|
|
|
|
|
|
|
func withSockPath(name string) func(*plugin.Config) {
|
|
|
|
return func(cfg *plugin.Config) {
|
|
|
|
cfg.Interface.Socket = name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func createPlugin(t *testing.T, client plugin.CreateClient, alias, bin string, opts ...plugin.CreateOpt) {
|
|
|
|
pluginBin := ensurePlugin(t, bin)
|
|
|
|
|
|
|
|
opts = append(opts, withSockPath("plugin.sock"))
|
|
|
|
opts = append(opts, plugin.WithBinary(pluginBin))
|
|
|
|
|
|
|
|
ctx, cancel := context.WithTimeout(context.Background(), 60*time.Second)
|
|
|
|
err := plugin.Create(ctx, client, alias, opts...)
|
|
|
|
cancel()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func asLogDriver(cfg *plugin.Config) {
|
|
|
|
cfg.Interface.Types = []types.PluginInterfaceType{
|
|
|
|
{Capability: "logdriver", Prefix: "docker", Version: "1.0"},
|
|
|
|
}
|
|
|
|
}
|