forked from security/hakurei
This is way higher level than the container package and does not even work unless every path is mounted in the exact same location. This behaviour causes nothing but confusion and problems, Signed-off-by: Ophestra <cat@gensokyo.uk>
41 lines
1.2 KiB
Go
41 lines
1.2 KiB
Go
package helper_test
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
"os"
|
|
"testing"
|
|
|
|
"hakurei.app/container"
|
|
"hakurei.app/helper"
|
|
)
|
|
|
|
func TestContainer(t *testing.T) {
|
|
t.Run("start empty container", func(t *testing.T) {
|
|
h := helper.New(t.Context(), container.MustAbs(container.Nonexistent), "hakurei", argsWt, false, argF, nil, nil)
|
|
|
|
wantErr := "container: starting an empty container"
|
|
if err := h.Start(); err == nil || err.Error() != wantErr {
|
|
t.Errorf("Start: error = %v, wantErr %q",
|
|
err, wantErr)
|
|
}
|
|
})
|
|
|
|
t.Run("valid new helper nil check", func(t *testing.T) {
|
|
if got := helper.New(t.Context(), container.MustAbs(container.Nonexistent), "hakurei", argsWt, false, argF, nil, nil); got == nil {
|
|
t.Errorf("New(%q, %q) got nil",
|
|
argsWt, "hakurei")
|
|
return
|
|
}
|
|
})
|
|
|
|
t.Run("implementation compliance", func(t *testing.T) {
|
|
testHelper(t, func(ctx context.Context, setOutput func(stdoutP, stderrP *io.Writer), stat bool) helper.Helper {
|
|
return helper.New(ctx, container.MustAbs(os.Args[0]), "helper", argsWt, stat, argF, func(z *container.Container) {
|
|
setOutput(&z.Stdout, &z.Stderr)
|
|
z.Bind("/", "/", 0).Proc("/proc").Dev("/dev", true)
|
|
}, nil)
|
|
})
|
|
})
|
|
}
|