mirror of
https://github.com/project-zot/zot.git
synced 2026-06-18 05:28:07 +08:00
b1842ab9e0
* fix: migrate from github.com/rs/zerolog to golang-native log/slog We have been using zerolog for a really long time. golang now has structured logging using slog. Best to move to this in interests of long-term support. This is a tech debt item. Signed-off-by: Ramkumar Chinchani <rchincha.dev@gmail.com> * fix: a few changes on top Signed-off-by: Ramkumar Chinchani <rchincha.dev@gmail.com> * fix: address comments Signed-off-by: Ramkumar Chinchani <rchincha.dev@gmail.com> --------- Signed-off-by: Ramkumar Chinchani <rchincha.dev@gmail.com>
67 lines
1.5 KiB
Go
67 lines
1.5 KiB
Go
package cache
|
|
|
|
import (
|
|
"io"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/opencontainers/go-digest"
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
"go.etcd.io/bbolt"
|
|
|
|
"zotregistry.dev/zot/pkg/log"
|
|
"zotregistry.dev/zot/pkg/storage/constants"
|
|
)
|
|
|
|
func TestBoltDriverErrors(t *testing.T) {
|
|
Convey("Make a new cache", t, func() {
|
|
tmpDir := t.TempDir()
|
|
|
|
boltDB, err := bbolt.Open(filepath.Join(tmpDir, "bolt.db"), 0o644, bbolt.DefaultOptions)
|
|
So(err, ShouldBeNil)
|
|
|
|
driver := BoltDBDriver{
|
|
db: boltDB,
|
|
log: log.NewLoggerWithWriter("debug", io.Discard),
|
|
}
|
|
|
|
Convey("Empty boltdb", func() {
|
|
// bucket not found
|
|
err = driver.PutBlob(digest.FromString("s"), "path")
|
|
So(err, ShouldNotBeNil)
|
|
|
|
_, err = driver.GetBlob(digest.FromString("s"))
|
|
So(err, ShouldNotBeNil)
|
|
|
|
has := driver.HasBlob(digest.FromString("s"), "blob")
|
|
So(has, ShouldBeFalse)
|
|
|
|
err = driver.DeleteBlob(digest.FromString("s"), "blob")
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
|
|
Convey("cache miss", func() {
|
|
goodDigest := digest.FromString("s")
|
|
|
|
err := driver.db.Update(func(tx *bbolt.Tx) error {
|
|
buck, err := tx.CreateBucketIfNotExists([]byte(constants.BlobsCache))
|
|
So(err, ShouldBeNil)
|
|
|
|
_, err = buck.CreateBucket([]byte(goodDigest))
|
|
So(err, ShouldBeNil)
|
|
|
|
return nil
|
|
})
|
|
So(err, ShouldBeNil)
|
|
|
|
// digest bucket not found
|
|
err = driver.DeleteBlob(digest.FromString("bad-digest"), "path")
|
|
So(err, ShouldNotBeNil)
|
|
|
|
// duplicate bucket not exist
|
|
err = driver.DeleteBlob(goodDigest, "path")
|
|
So(err, ShouldNotBeNil)
|
|
})
|
|
})
|
|
}
|