mirror of
https://github.com/containers/buildah.git
synced 2025-04-18 07:04:05 +03:00
See issue: https://github.com/containers/buildah/issues/5967 Signed-off-by: flouthoc <flouthoc.git@gmail.com>
89 lines
2.6 KiB
Go
89 lines
2.6 KiB
Go
package buildah
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"os"
|
|
"testing"
|
|
|
|
imagetypes "github.com/containers/image/v5/types"
|
|
"github.com/containers/storage"
|
|
"github.com/containers/storage/types"
|
|
"github.com/sirupsen/logrus"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var testSystemContext = imagetypes.SystemContext{
|
|
SignaturePolicyPath: "tests/policy.json",
|
|
SystemRegistriesConfPath: "tests/registries.conf",
|
|
}
|
|
|
|
func TestMain(m *testing.M) {
|
|
var logLevel string
|
|
debug := false
|
|
if InitReexec() {
|
|
return
|
|
}
|
|
flag.BoolVar(&debug, "debug", false, "turn on debug logging")
|
|
flag.StringVar(&logLevel, "log-level", "error", "log level")
|
|
flag.Parse()
|
|
level, err := logrus.ParseLevel(logLevel)
|
|
if err != nil {
|
|
logrus.Fatalf("error parsing log level %q: %v", logLevel, err)
|
|
}
|
|
if debug && level < logrus.DebugLevel {
|
|
level = logrus.DebugLevel
|
|
}
|
|
logrus.SetLevel(level)
|
|
os.Exit(m.Run())
|
|
}
|
|
|
|
func TestOpenBuilderCommonBuildOpts(t *testing.T) {
|
|
// This test cannot be parallized as this uses NewBuilder()
|
|
// which eventually and indirectly accesses a global variable
|
|
// defined in `go-selinux`, this must be fixed at `go-selinux`
|
|
// or builder must enable sometime of locking mechanism i.e if
|
|
// routine is creating Builder other's must wait for it.
|
|
// Tracked here: https://github.com/containers/buildah/issues/5967
|
|
ctx := context.TODO()
|
|
store, err := storage.GetStore(types.StoreOptions{
|
|
RunRoot: t.TempDir(),
|
|
GraphRoot: t.TempDir(),
|
|
GraphDriverName: "vfs",
|
|
})
|
|
require.NoError(t, err)
|
|
t.Cleanup(func() { _, err := store.Shutdown(true); assert.NoError(t, err) })
|
|
b, err := NewBuilder(ctx, store, BuilderOptions{})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, b.CommonBuildOpts)
|
|
b.CommonBuildOpts = nil
|
|
builderContainerID := b.ContainerID
|
|
err = b.Save()
|
|
require.NoError(t, err)
|
|
b, err = OpenBuilder(store, builderContainerID)
|
|
require.NoError(t, err)
|
|
require.NotNil(t, b.CommonBuildOpts)
|
|
builders, err := OpenAllBuilders(store)
|
|
require.NoError(t, err)
|
|
for _, b := range builders {
|
|
require.NotNil(t, b.CommonBuildOpts)
|
|
}
|
|
imageID, _, _, err := b.Commit(ctx, nil, CommitOptions{})
|
|
require.NoError(t, err)
|
|
b, err = ImportBuilderFromImage(ctx, store, ImportFromImageOptions{
|
|
Image: imageID,
|
|
})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, b.CommonBuildOpts)
|
|
container, err := store.CreateContainer("", nil, imageID, "", "", &storage.ContainerOptions{})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, container)
|
|
b, err = ImportBuilder(ctx, store, ImportOptions{
|
|
Container: container.ID,
|
|
SignaturePolicyPath: testSystemContext.SignaturePolicyPath,
|
|
})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, b.CommonBuildOpts)
|
|
}
|