2023-07-18 12:27:26 -05:00
|
|
|
package boltdb_test
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2023-07-07 11:27:10 -05:00
|
|
|
"crypto/rand"
|
|
|
|
"encoding/base64"
|
2023-01-09 15:37:44 -05:00
|
|
|
"encoding/json"
|
2023-07-07 11:27:10 -05:00
|
|
|
"math"
|
2023-01-09 15:37:44 -05:00
|
|
|
"testing"
|
2023-09-08 02:03:58 -05:00
|
|
|
"time"
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
"github.com/opencontainers/go-digest"
|
|
|
|
ispec "github.com/opencontainers/image-spec/specs-go/v1"
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
"go.etcd.io/bbolt"
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
zerr "zotregistry.io/zot/errors"
|
2023-08-19 00:52:03 -05:00
|
|
|
zcommon "zotregistry.io/zot/pkg/common"
|
2023-03-28 12:20:09 -05:00
|
|
|
"zotregistry.io/zot/pkg/log"
|
2023-07-18 12:27:26 -05:00
|
|
|
"zotregistry.io/zot/pkg/meta/boltdb"
|
|
|
|
mTypes "zotregistry.io/zot/pkg/meta/types"
|
2023-09-01 13:13:53 -05:00
|
|
|
reqCtx "zotregistry.io/zot/pkg/requestcontext"
|
2023-09-27 13:34:48 -05:00
|
|
|
. "zotregistry.io/zot/pkg/test/image-utils"
|
2023-01-09 15:37:44 -05:00
|
|
|
)
|
|
|
|
|
2023-09-08 02:03:58 -05:00
|
|
|
type imgTrustStore struct{}
|
|
|
|
|
|
|
|
func (its imgTrustStore) VerifySignature(
|
|
|
|
signatureType string, rawSignature []byte, sigKey string, manifestDigest digest.Digest, manifestContent []byte,
|
|
|
|
repo string,
|
|
|
|
) (string, time.Time, bool, error) {
|
|
|
|
return "", time.Time{}, false, nil
|
|
|
|
}
|
|
|
|
|
2023-01-09 15:37:44 -05:00
|
|
|
func TestWrapperErrors(t *testing.T) {
|
|
|
|
Convey("Errors", t, func() {
|
|
|
|
tmpDir := t.TempDir()
|
2023-07-18 12:27:26 -05:00
|
|
|
boltDBParams := boltdb.DBParameters{RootDir: tmpDir}
|
|
|
|
boltDriver, err := boltdb.GetBoltDriver(boltDBParams)
|
2023-03-28 12:20:09 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
log := log.NewLogger("debug", "")
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
boltdbWrapper, err := boltdb.New(boltDriver, log)
|
2023-01-09 15:37:44 -05:00
|
|
|
So(boltdbWrapper, ShouldNotBeNil)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-09-08 02:03:58 -05:00
|
|
|
boltdbWrapper.SetImageTrustStore(imgTrustStore{})
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta := mTypes.RepoMetadata{
|
|
|
|
Tags: map[string]mTypes.Descriptor{},
|
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
repoMetaBlob, err := json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("test")
|
2023-07-07 11:27:10 -05:00
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
Convey("AddUserAPIKey", func() {
|
|
|
|
Convey("no userid found", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.AddUserAPIKey(ctx, "", &mTypes.APIKeyDetails{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.AddUserAPIKey(ctx, "", &mTypes.APIKeyDetails{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserDataBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.AddUserAPIKey(ctx, "test", &mTypes.APIKeyDetails{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserAPIKeysBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.AddUserAPIKey(ctx, "", &mTypes.APIKeyDetails{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldEqual, zerr.ErrBucketDoesNotExist)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("UpdateUserAPIKey", func() {
|
|
|
|
err = boltdbWrapper.UpdateUserAPIKeyLastUsed(ctx, "")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
err = boltdbWrapper.UpdateUserAPIKeyLastUsed(ctx, "") //nolint: contextcheck
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("DeleteUserAPIKey", func() {
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetUserData(ctx, mTypes.UserData{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.AddUserAPIKey(ctx, "hashedKey", &mTypes.APIKeyDetails{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
Convey("no such bucket", func() {
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserAPIKeysBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("test")
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteUserAPIKey(ctx, "")
|
|
|
|
So(err, ShouldEqual, zerr.ErrBucketDoesNotExist)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("userdata not found", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("test")
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
err := boltdbWrapper.DeleteUserData(ctx)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteUserAPIKey(ctx, "")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteUserAPIKey(ctx, "test") //nolint: contextcheck
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserDataBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteUserAPIKey(ctx, "") //nolint: contextcheck
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("GetUserAPIKeyInfo", func() {
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserAPIKeysBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetUserAPIKeyInfo("")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("GetUserData", func() {
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
buck := tx.Bucket([]byte(boltdb.UserDataBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
So(buck, ShouldNotBeNil)
|
|
|
|
|
|
|
|
return buck.Put([]byte("test"), []byte("dsa8"))
|
|
|
|
})
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetUserData(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserAPIKeysBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetUserData(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("SetUserData", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetUserData(ctx, mTypes.UserData{})
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
buff := make([]byte, int(math.Ceil(float64(1000000)/float64(1.33333333333))))
|
|
|
|
_, err := rand.Read(buff)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
longString := base64.RawURLEncoding.EncodeToString(buff)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc = reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername(longString)
|
|
|
|
ctx = userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetUserData(ctx, mTypes.UserData{}) //nolint: contextcheck
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserDataBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc = reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("test")
|
|
|
|
ctx = userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetUserData(ctx, mTypes.UserData{}) //nolint: contextcheck
|
2023-07-07 11:27:10 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("DeleteUserData", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc = reqCtx.NewUserAccessControl()
|
|
|
|
ctx = userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteUserData(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
return tx.DeleteBucket([]byte(boltdb.UserDataBucket))
|
2023-07-07 11:27:10 -05:00
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc = reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("test")
|
|
|
|
ctx = userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteUserData(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("GetUserGroups and SetUserGroups", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc = reqCtx.NewUserAccessControl()
|
|
|
|
ctx = userAc.DeriveContext(context.Background())
|
2023-07-07 11:27:10 -05:00
|
|
|
|
|
|
|
_, err := boltdbWrapper.GetUserGroups(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.SetUserGroups(ctx, []string{})
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-01-09 15:37:44 -05:00
|
|
|
Convey("GetManifestData", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
dataBuck := tx.Bucket([]byte(boltdb.ManifestDataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return dataBuck.Put([]byte("digest1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetManifestData("digest1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetManifestMeta("repo1", "digest1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("SetManifestMeta", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
|
|
|
dataBuck := tx.Bucket([]byte(boltdb.ManifestDataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
err := dataBuck.Put([]byte("digest1"), repoMetaBlob)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetManifestMeta("repo1", "digest1", mTypes.ManifestMetadata{})
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetManifestMeta("repo1", "digest1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-04-24 13:13:15 -05:00
|
|
|
Convey("FilterRepos", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
buck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-04-24 13:13:15 -05:00
|
|
|
err := buck.Put([]byte("badRepo"), []byte("bad repo"))
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.FilterRepos(context.Background(),
|
|
|
|
func(repoMeta mTypes.RepoMetadata) bool { return true })
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-03-10 13:37:29 -05:00
|
|
|
Convey("SetReferrer", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-03-10 13:37:29 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetReferrer("repo", "ref", mTypes.ReferrerInfo{})
|
2023-03-10 13:37:29 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("DeleteReferrer", func() {
|
|
|
|
Convey("RepoMeta not found", func() {
|
|
|
|
err := boltdbWrapper.DeleteReferrer("r", "dig", "dig")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("bad repo meta blob", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-03-10 13:37:29 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteReferrer("repo", "dig", "dig")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
Convey("SetRepoReference", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-03-10 13:37:29 -05:00
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
2023-03-10 13:37:29 -05:00
|
|
|
})
|
2023-03-20 11:14:17 -05:00
|
|
|
So(err, ShouldBeNil)
|
2023-03-10 13:37:29 -05:00
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
err = boltdbWrapper.SetRepoReference("repo1", "tag", "digest", ispec.MediaTypeImageManifest)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-03-10 13:37:29 -05:00
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
Convey("GetRepoMeta", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-03-10 13:37:29 -05:00
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
2023-03-10 13:37:29 -05:00
|
|
|
})
|
2023-03-20 11:14:17 -05:00
|
|
|
So(err, ShouldBeNil)
|
2023-03-10 13:37:29 -05:00
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
_, err = boltdbWrapper.GetRepoMeta("repo1")
|
|
|
|
So(err, ShouldNotBeNil)
|
2023-03-10 13:37:29 -05:00
|
|
|
})
|
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
Convey("DeleteRepoTag", func() {
|
2023-01-09 15:37:44 -05:00
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
err = boltdbWrapper.DeleteRepoTag("repo1", "tag")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
Convey("GetReferrersInfo", func() {
|
|
|
|
_, err = boltdbWrapper.GetReferrersInfo("repo1", "tag", nil)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-01-09 15:37:44 -05:00
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-03-20 11:14:17 -05:00
|
|
|
_, err = boltdbWrapper.GetReferrersInfo("repo1", "tag", nil)
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("IncrementRepoStars", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.IncrementRepoStars("repo2")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.IncrementRepoStars("repo1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("DecrementRepoStars", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DecrementRepoStars("repo2")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DecrementRepoStars("repo1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("GetRepoStars", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.GetRepoStars("repo1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("GetMultipleRepoMeta", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
_, err = boltdbWrapper.GetMultipleRepoMeta(context.TODO(), func(repoMeta mTypes.RepoMetadata) bool {
|
2023-01-09 15:37:44 -05:00
|
|
|
return true
|
2023-07-31 14:16:09 -05:00
|
|
|
})
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("IncrementImageDownloads", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.IncrementImageDownloads("repo2", "tag")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.IncrementImageDownloads("repo1", "tag")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), repoMetaBlob)
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.IncrementImageDownloads("repo1", "tag")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("AddManifestSignature", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.AddManifestSignature("repo1", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{})
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), repoMetaBlob)
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
// signatures not found
|
|
|
|
err = boltdbWrapper.AddManifestSignature("repo1", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{})
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
//
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta := mTypes.RepoMetadata{
|
|
|
|
Tags: map[string]mTypes.Descriptor{},
|
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{
|
2023-01-09 15:37:44 -05:00
|
|
|
"digest1": {
|
|
|
|
"cosgin": {{}},
|
|
|
|
},
|
|
|
|
"digest2": {
|
|
|
|
"notation": {{}},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
repoMetaBlob, err := json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), repoMetaBlob)
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.AddManifestSignature("repo1", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{
|
2023-01-09 15:37:44 -05:00
|
|
|
SignatureType: "cosign",
|
|
|
|
SignatureDigest: "digest1",
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-05-24 11:46:16 -05:00
|
|
|
err = boltdbWrapper.AddManifestSignature("repo1", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{
|
2023-05-24 11:46:16 -05:00
|
|
|
SignatureType: "cosign",
|
|
|
|
SignatureDigest: "digest2",
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
repoData, err := boltdbWrapper.GetRepoMeta("repo1")
|
|
|
|
So(err, ShouldBeNil)
|
2023-08-19 00:52:03 -05:00
|
|
|
So(len(repoData.Signatures[string(digest.FromString("dig"))][zcommon.CosignSignature]),
|
2023-05-24 11:46:16 -05:00
|
|
|
ShouldEqual, 1)
|
2023-08-19 00:52:03 -05:00
|
|
|
So(repoData.Signatures[string(digest.FromString("dig"))][zcommon.CosignSignature][0].SignatureManifestDigest,
|
2023-05-24 11:46:16 -05:00
|
|
|
ShouldEqual, "digest2")
|
|
|
|
|
2023-01-09 15:37:44 -05:00
|
|
|
err = boltdbWrapper.AddManifestSignature("repo1", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{
|
2023-01-09 15:37:44 -05:00
|
|
|
SignatureType: "notation",
|
|
|
|
SignatureDigest: "digest2",
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("DeleteSignature", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteSignature("repo2", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{})
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteSignature("repo1", digest.FromString("dig"),
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{})
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta := mTypes.RepoMetadata{
|
|
|
|
Tags: map[string]mTypes.Descriptor{},
|
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{
|
2023-01-09 15:37:44 -05:00
|
|
|
"digest1": {
|
2023-07-18 12:27:26 -05:00
|
|
|
"cosgin": []mTypes.SignatureInfo{
|
2023-01-09 15:37:44 -05:00
|
|
|
{
|
|
|
|
SignatureManifestDigest: "sigDigest1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
SignatureManifestDigest: "sigDigest2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"digest2": {
|
|
|
|
"notation": {{}},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
repoMetaBlob, err := json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), repoMetaBlob)
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DeleteSignature("repo1", "digest1",
|
2023-07-18 12:27:26 -05:00
|
|
|
mTypes.SignatureMetadata{
|
2023-01-09 15:37:44 -05:00
|
|
|
SignatureType: "cosgin",
|
|
|
|
SignatureDigest: "sigDigest2",
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("SearchRepos", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchRepos(context.Background(), "")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
|
|
|
dataBuck := tx.Bucket([]byte(boltdb.ManifestDataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
err := dataBuck.Put([]byte("dig1"), []byte("wrong json"))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta := mTypes.RepoMetadata{
|
2023-04-27 10:11:13 -05:00
|
|
|
Name: "repo1",
|
2023-07-18 12:27:26 -05:00
|
|
|
Tags: map[string]mTypes.Descriptor{
|
2023-01-09 15:37:44 -05:00
|
|
|
"tag1": {Digest: "dig1", MediaType: ispec.MediaTypeImageManifest},
|
|
|
|
},
|
2023-07-18 12:27:26 -05:00
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
repoMetaBlob, err := json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = repoBuck.Put([]byte("repo1"), repoMetaBlob)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta = mTypes.RepoMetadata{
|
2023-04-27 10:11:13 -05:00
|
|
|
Name: "repo2",
|
2023-07-18 12:27:26 -05:00
|
|
|
Tags: map[string]mTypes.Descriptor{
|
2023-01-09 15:37:44 -05:00
|
|
|
"tag2": {Digest: "dig2", MediaType: ispec.MediaTypeImageManifest},
|
|
|
|
},
|
2023-07-18 12:27:26 -05:00
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
repoMetaBlob, err = json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo2"), repoMetaBlob)
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchRepos(context.Background(), "repo1")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchRepos(context.Background(), "repo2")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-02-27 14:23:18 -05:00
|
|
|
Convey("Index Errors", func() {
|
|
|
|
Convey("Bad index data", func() {
|
|
|
|
indexDigest := digest.FromString("indexDigest")
|
|
|
|
|
2023-03-09 13:41:48 -05:00
|
|
|
err := boltdbWrapper.SetRepoReference("repo", "tag1", indexDigest, ispec.MediaTypeImageIndex) //nolint:contextcheck
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = setBadIndexData(boltdbWrapper.DB, indexDigest.String())
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchRepos(ctx, "")
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "repo:")
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Bad indexBlob in IndexData", func() {
|
|
|
|
indexDigest := digest.FromString("indexDigest")
|
|
|
|
|
2023-03-09 13:41:48 -05:00
|
|
|
err := boltdbWrapper.SetRepoReference("repo", "tag1", indexDigest, ispec.MediaTypeImageIndex) //nolint:contextcheck
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetIndexData(indexDigest, mTypes.IndexData{
|
2023-02-27 14:23:18 -05:00
|
|
|
IndexBlob: []byte("bad json"),
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchRepos(ctx, "")
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "repo:")
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2023-01-09 15:37:44 -05:00
|
|
|
Convey("SearchTags", func() {
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "repo1:")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
|
|
|
dataBuck := tx.Bucket([]byte(boltdb.ManifestDataBucket))
|
2023-01-09 15:37:44 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
manifestMeta := mTypes.ManifestMetadata{
|
2023-01-09 15:37:44 -05:00
|
|
|
ManifestBlob: []byte("{}"),
|
|
|
|
ConfigBlob: []byte("wrong json"),
|
2023-07-18 12:27:26 -05:00
|
|
|
Signatures: mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
manifestMetaBlob, err := json.Marshal(manifestMeta)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
err = dataBuck.Put([]byte("dig1"), manifestMetaBlob)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
err = dataBuck.Put([]byte("wrongManifestData"), []byte("wrong json"))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// manifest data doesn't exist
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta = mTypes.RepoMetadata{
|
2023-04-27 10:11:13 -05:00
|
|
|
Name: "repo1",
|
2023-07-18 12:27:26 -05:00
|
|
|
Tags: map[string]mTypes.Descriptor{
|
2023-01-09 15:37:44 -05:00
|
|
|
"tag2": {Digest: "dig2", MediaType: ispec.MediaTypeImageManifest},
|
|
|
|
},
|
2023-07-18 12:27:26 -05:00
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
repoMetaBlob, err = json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = repoBuck.Put([]byte("repo1"), repoMetaBlob)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// manifest data is wrong
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta = mTypes.RepoMetadata{
|
2023-04-27 10:11:13 -05:00
|
|
|
Name: "repo2",
|
2023-07-18 12:27:26 -05:00
|
|
|
Tags: map[string]mTypes.Descriptor{
|
2023-01-09 15:37:44 -05:00
|
|
|
"tag2": {Digest: "wrongManifestData", MediaType: ispec.MediaTypeImageManifest},
|
|
|
|
},
|
2023-07-18 12:27:26 -05:00
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
repoMetaBlob, err = json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = repoBuck.Put([]byte("repo2"), repoMetaBlob)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
repoMeta = mTypes.RepoMetadata{
|
2023-04-27 10:11:13 -05:00
|
|
|
Name: "repo3",
|
2023-07-18 12:27:26 -05:00
|
|
|
Tags: map[string]mTypes.Descriptor{
|
2023-01-09 15:37:44 -05:00
|
|
|
"tag1": {Digest: "dig1", MediaType: ispec.MediaTypeImageManifest},
|
|
|
|
},
|
2023-07-18 12:27:26 -05:00
|
|
|
Signatures: map[string]mTypes.ManifestSignatures{},
|
2023-01-09 15:37:44 -05:00
|
|
|
}
|
|
|
|
repoMetaBlob, err = json.Marshal(repoMeta)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo3"), repoMetaBlob)
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "repo1:")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "repo2:")
|
2023-01-09 15:37:44 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-02-27 14:23:18 -05:00
|
|
|
|
|
|
|
Convey("FilterTags Index errors", func() {
|
|
|
|
Convey("FilterTags bad IndexData", func() {
|
|
|
|
indexDigest := digest.FromString("indexDigest")
|
|
|
|
|
2023-03-09 13:41:48 -05:00
|
|
|
err := boltdbWrapper.SetRepoReference("repo", "tag1", indexDigest, ispec.MediaTypeImageIndex) //nolint:contextcheck
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = setBadIndexData(boltdbWrapper.DB, indexDigest.String())
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.FilterTags(ctx,
|
|
|
|
func(repoMeta mTypes.RepoMetadata, manifestMeta mTypes.ManifestMetadata) bool { return true })
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("FilterTags bad indexBlob in IndexData", func() {
|
|
|
|
indexDigest := digest.FromString("indexDigest")
|
|
|
|
|
2023-03-09 13:41:48 -05:00
|
|
|
err := boltdbWrapper.SetRepoReference("repo", "tag1", indexDigest, ispec.MediaTypeImageIndex) //nolint:contextcheck
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetIndexData(indexDigest, mTypes.IndexData{
|
2023-02-27 14:23:18 -05:00
|
|
|
IndexBlob: []byte("bad json"),
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.FilterTags(ctx,
|
|
|
|
func(repoMeta mTypes.RepoMetadata, manifestMeta mTypes.ManifestMetadata) bool { return true })
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("FilterTags didn't match any index manifest", func() {
|
|
|
|
var (
|
|
|
|
indexDigest = digest.FromString("indexDigest")
|
|
|
|
manifestDigestFromIndex1 = digest.FromString("manifestDigestFromIndex1")
|
|
|
|
manifestDigestFromIndex2 = digest.FromString("manifestDigestFromIndex2")
|
|
|
|
)
|
|
|
|
|
2023-03-09 13:41:48 -05:00
|
|
|
err := boltdbWrapper.SetRepoReference("repo", "tag1", indexDigest, ispec.MediaTypeImageIndex) //nolint:contextcheck
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-09-27 13:34:48 -05:00
|
|
|
indexBlob, err := GetIndexBlobWithManifests([]digest.Digest{
|
2023-02-27 14:23:18 -05:00
|
|
|
manifestDigestFromIndex1, manifestDigestFromIndex2,
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetIndexData(indexDigest, mTypes.IndexData{
|
2023-02-27 14:23:18 -05:00
|
|
|
IndexBlob: indexBlob,
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetManifestData(manifestDigestFromIndex1, mTypes.ManifestData{
|
2023-02-27 14:23:18 -05:00
|
|
|
ManifestBlob: []byte("{}"),
|
|
|
|
ConfigBlob: []byte("{}"),
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err = boltdbWrapper.SetManifestData(manifestDigestFromIndex2, mTypes.ManifestData{
|
2023-02-27 14:23:18 -05:00
|
|
|
ManifestBlob: []byte("{}"),
|
|
|
|
ConfigBlob: []byte("{}"),
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.FilterTags(ctx,
|
|
|
|
func(repoMeta mTypes.RepoMetadata, manifestMeta mTypes.ManifestMetadata) bool { return false })
|
2023-07-11 11:29:04 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
2023-02-27 14:23:18 -05:00
|
|
|
})
|
|
|
|
|
2023-04-24 13:13:15 -05:00
|
|
|
Convey("ToggleStarRepo bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
|
|
|
_, err := boltdbWrapper.ToggleStarRepo(ctx, "repo")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("ToggleStarRepo, no repoMeta found", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("username")
|
|
|
|
userAc.SetGlobPatterns("read", map[string]bool{
|
|
|
|
"repo": true,
|
|
|
|
})
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-04-24 13:13:15 -05:00
|
|
|
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
err := repoBuck.Put([]byte("repo"), []byte("bad repo"))
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = boltdbWrapper.ToggleStarRepo(ctx, "repo")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("ToggleStarRepo, bad repoMeta found", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("username")
|
|
|
|
userAc.SetGlobPatterns("read", map[string]bool{
|
|
|
|
"repo": true,
|
|
|
|
})
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
_, err = boltdbWrapper.ToggleStarRepo(ctx, "repo")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("ToggleBookmarkRepo bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
_, err := boltdbWrapper.ToggleBookmarkRepo(ctx, "repo")
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("GetUserData bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
_, err := boltdbWrapper.GetUserData(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("SetUserData bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err := boltdbWrapper.SetUserData(ctx, mTypes.UserData{})
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("GetUserGroups bad context errors", func() {
|
|
|
|
_, err := boltdbWrapper.GetUserGroups(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
_, err = boltdbWrapper.GetUserGroups(ctx) //nolint: contextcheck
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("SetUserGroups bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
err := boltdbWrapper.SetUserGroups(ctx, []string{})
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("AddUserAPIKey bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-18 12:27:26 -05:00
|
|
|
err := boltdbWrapper.AddUserAPIKey(ctx, "", &mTypes.APIKeyDetails{})
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("DeleteUserAPIKey bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
err := boltdbWrapper.DeleteUserAPIKey(ctx, "")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("UpdateUserAPIKeyLastUsed bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
err := boltdbWrapper.UpdateUserAPIKeyLastUsed(ctx, "")
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("DeleteUserData bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
err := boltdbWrapper.DeleteUserData(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
Convey("GetStarredRepos bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
2023-07-07 11:27:10 -05:00
|
|
|
_, err := boltdbWrapper.GetStarredRepos(ctx)
|
2023-04-24 13:13:15 -05:00
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("GetBookmarkedRepos bad context errors", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
uacKey := reqCtx.GetContextKey()
|
|
|
|
ctx := context.WithValue(context.Background(), uacKey, "bad context")
|
2023-04-24 13:13:15 -05:00
|
|
|
|
|
|
|
_, err := boltdbWrapper.GetBookmarkedRepos(ctx)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
2023-02-27 14:23:18 -05:00
|
|
|
Convey("Unsuported type", func() {
|
|
|
|
digest := digest.FromString("digest")
|
|
|
|
|
2023-03-09 13:41:48 -05:00
|
|
|
err := boltdbWrapper.SetRepoReference("repo", "tag1", digest, "invalid type") //nolint:contextcheck
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchRepos(ctx, "")
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.SearchTags(ctx, "repo:")
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2023-07-31 14:16:09 -05:00
|
|
|
_, _, _, err = boltdbWrapper.FilterTags(ctx,
|
|
|
|
func(repoMeta mTypes.RepoMetadata, manifestMeta mTypes.ManifestMetadata) bool { return true })
|
2023-02-27 14:23:18 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
2023-05-04 11:51:21 -05:00
|
|
|
|
|
|
|
Convey("GetUserRepoMeta unmarshal error", func() {
|
2023-09-01 13:13:53 -05:00
|
|
|
userAc := reqCtx.NewUserAccessControl()
|
|
|
|
userAc.SetUsername("username")
|
|
|
|
userAc.SetGlobPatterns("read", map[string]bool{
|
|
|
|
"repo": true,
|
|
|
|
})
|
|
|
|
ctx := userAc.DeriveContext(context.Background())
|
2023-05-04 11:51:21 -05:00
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-05-04 11:51:21 -05:00
|
|
|
|
|
|
|
err := repoBuck.Put([]byte("repo"), []byte("bad repo"))
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err := boltdbWrapper.GetUserRepoMeta(ctx, "repo")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
2023-05-24 11:46:16 -05:00
|
|
|
|
|
|
|
Convey("UpdateSignaturesValidity", func() {
|
|
|
|
Convey("manifestMeta of signed manifest not found", func() {
|
|
|
|
err := boltdbWrapper.UpdateSignaturesValidity("repo", digest.FromString("dig"))
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("repoMeta of signed manifest not found", func() {
|
|
|
|
// repo Meta not found
|
2023-07-18 12:27:26 -05:00
|
|
|
err := boltdbWrapper.SetManifestData(digest.FromString("dig"), mTypes.ManifestData{
|
2023-05-24 11:46:16 -05:00
|
|
|
ManifestBlob: []byte("Bad Manifest"),
|
|
|
|
ConfigBlob: []byte("Bad Manifest"),
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.UpdateSignaturesValidity("repo", digest.FromString("dig"))
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("manifest - bad content", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
dataBuck := tx.Bucket([]byte(boltdb.ManifestDataBucket))
|
2023-05-24 11:46:16 -05:00
|
|
|
|
|
|
|
return dataBuck.Put([]byte("digest1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.UpdateSignaturesValidity("repo1", "digest1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("index - bad content", func() {
|
|
|
|
err := boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
dataBuck := tx.Bucket([]byte(boltdb.IndexDataBucket))
|
2023-05-24 11:46:16 -05:00
|
|
|
|
|
|
|
return dataBuck.Put([]byte("digest1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.UpdateSignaturesValidity("repo1", "digest1")
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("repo - bad content", func() {
|
|
|
|
// repo Meta not found
|
2023-07-18 12:27:26 -05:00
|
|
|
err := boltdbWrapper.SetManifestData(digest.FromString("dig"), mTypes.ManifestData{
|
2023-05-24 11:46:16 -05:00
|
|
|
ManifestBlob: []byte("Bad Manifest"),
|
|
|
|
ConfigBlob: []byte("Bad Manifest"),
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.DB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
repoBuck := tx.Bucket([]byte(boltdb.RepoMetadataBucket))
|
2023-05-24 11:46:16 -05:00
|
|
|
|
|
|
|
return repoBuck.Put([]byte("repo1"), []byte("wrong json"))
|
|
|
|
})
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
err = boltdbWrapper.UpdateSignaturesValidity("repo1", digest.FromString("dig"))
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
})
|
2023-02-27 14:23:18 -05:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func setBadIndexData(dB *bbolt.DB, digest string) error {
|
|
|
|
return dB.Update(func(tx *bbolt.Tx) error {
|
2023-07-18 12:27:26 -05:00
|
|
|
indexDataBuck := tx.Bucket([]byte(boltdb.IndexDataBucket))
|
2023-02-27 14:23:18 -05:00
|
|
|
|
|
|
|
return indexDataBuck.Put([]byte(digest), []byte("bad json"))
|
2023-01-09 15:37:44 -05:00
|
|
|
})
|
|
|
|
}
|