Clear CommonBuildOpts when loading Builder status

When creating or loading a builder, ensure that its CommonBuildOpts
struct is not nil, to comply with an assumption that we keep making.

Signed-off-by: Nalin Dahyabhai <nalin@redhat.com>
This commit is contained in:
Nalin Dahyabhai 2023-08-11 20:25:21 -04:00
parent 795c15532d
commit e3cd4d7904
3 changed files with 79 additions and 0 deletions

View File

@ -433,6 +433,9 @@ func OpenBuilder(store storage.Store, container string) (*Builder, error) {
b.store = store
b.fixupConfig(nil)
b.setupLogger()
if b.CommonBuildOpts == nil {
b.CommonBuildOpts = &CommonBuildOptions{}
}
return b, nil
}
@ -469,6 +472,9 @@ func OpenBuilderByPath(store storage.Store, path string) (*Builder, error) {
b.store = store
b.fixupConfig(nil)
b.setupLogger()
if b.CommonBuildOpts == nil {
b.CommonBuildOpts = &CommonBuildOptions{}
}
return b, nil
}
if err != nil {
@ -506,6 +512,9 @@ func OpenAllBuilders(store storage.Store) (builders []*Builder, err error) {
b.store = store
b.setupLogger()
b.fixupConfig(nil)
if b.CommonBuildOpts == nil {
b.CommonBuildOpts = &CommonBuildOptions{}
}
builders = append(builders, b)
continue
}

69
buildah_test.go Normal file
View File

@ -0,0 +1,69 @@
package buildah
import (
"context"
"flag"
"os"
"testing"
"github.com/containers/storage"
"github.com/containers/storage/types"
"github.com/sirupsen/logrus"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestMain(m *testing.M) {
debug := false
if InitReexec() {
return
}
flag.BoolVar(&debug, "debug", false, "turn on debug logging")
flag.Parse()
logrus.SetLevel(logrus.ErrorLevel)
if debug {
logrus.SetLevel(logrus.DebugLevel)
}
os.Exit(m.Run())
}
func TestOpenBuilderCommonBuildOpts(t *testing.T) {
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,
})
require.NoError(t, err)
require.NotNil(t, b.CommonBuildOpts)
}

View File

@ -107,6 +107,7 @@ func importBuilderDataFromImage(ctx context.Context, store storage.Store, system
GIDMap: gidmap,
},
NetworkInterface: netInt,
CommonBuildOpts: &CommonBuildOptions{},
}
if err := builder.initConfig(ctx, image, systemContext); err != nil {