mirror of
https://github.com/project-zot/zot.git
synced 2025-02-17 23:45:36 -05:00
* feat: add redis cache support https://github.com/project-zot/zot/pull/2005 Fixes https://github.com/project-zot/zot/issues/2004 * feat: add redis cache support Currently, we have dynamoDB as the remote shared cache but ideal only for the cloud use case. For on-prem use case, add support for redis. Signed-off-by: Ramkumar Chinchani <rchincha@cisco.com> * feat(redis): added blackbox tests for redis Signed-off-by: Petu Eusebiu <peusebiu@cisco.com> * feat(redis): dummy implementation of MetaDB interface for redis cache Signed-off-by: Alexei Dodon <adodon@cisco.com> * feat: check validity of driver configuration on metadb instantiation Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat: multiple fixes for redis cache driver implementation - add missing method GetAllBlobs - add redis cache tests, with and without mocking Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): redis implementation for MetaDB Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): use redsync to block concurrent write access to the redis DB Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): update .github/workflows/cluster.yaml to also test redis Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(metadb): add keyPrefix parameter for redis and remove unneeded method meta.Crate() Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): support RedisCluster configuration and add unit tests Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): more tests for redis metadb implementation Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): add more examples and update examples/README.md Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): move option parsing and redis client initialization under pkg/api/config/redis Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * chore(cachedb): move Cache interface to pkg/storage/types Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): reorganize code in pkg/storage/cache.go Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): call redis.SetLogger() with the zot logger as parameter Signed-off-by: Andrei Aaron <aaaron@luxoft.com> * feat(redis): rename pkg/meta/redisdb to pkg/meta/redis Signed-off-by: Andrei Aaron <aaaron@luxoft.com> --------- Signed-off-by: Ramkumar Chinchani <rchincha@cisco.com> Signed-off-by: Petu Eusebiu <peusebiu@cisco.com> Signed-off-by: Alexei Dodon <adodon@cisco.com> Signed-off-by: Andrei Aaron <aaaron@luxoft.com> Co-authored-by: a <a@tuxpa.in> Co-authored-by: Ramkumar Chinchani <rchincha@cisco.com> Co-authored-by: Petu Eusebiu <peusebiu@cisco.com> Co-authored-by: Alexei Dodon <adodon@cisco.com>
61 lines
2.2 KiB
Go
61 lines
2.2 KiB
Go
package redis
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/alicebob/miniredis/v2"
|
|
"github.com/redis/go-redis/v9"
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
"zotregistry.dev/zot/pkg/log"
|
|
)
|
|
|
|
func Test(t *testing.T) {
|
|
Convey("Test redis metadb key generation", t, func() {
|
|
miniRedis := miniredis.RunT(t)
|
|
|
|
log := log.NewLogger("debug", "")
|
|
So(log, ShouldNotBeNil)
|
|
|
|
opts, err := redis.ParseURL("redis://" + miniRedis.Addr())
|
|
So(err, ShouldBeNil)
|
|
|
|
client := redis.NewClient(opts)
|
|
|
|
params := DBDriverParameters{KeyPrefix: "zot"}
|
|
|
|
metaDB, err := New(client, params, log)
|
|
So(err, ShouldBeNil)
|
|
So(metaDB.ImageMetaKey, ShouldEqual, "zot:ImageMeta")
|
|
So(metaDB.RepoMetaKey, ShouldEqual, "zot:RepoMeta")
|
|
So(metaDB.RepoLastUpdatedKey, ShouldEqual, "zot:RepoLastUpdated")
|
|
So(metaDB.RepoBlobsKey, ShouldEqual, "zot:RepoBlobsMeta")
|
|
So(metaDB.UserDataKey, ShouldEqual, "zot:UserData")
|
|
So(metaDB.UserAPIKeysKey, ShouldEqual, "zot:UserAPIKeys")
|
|
So(metaDB.VersionKey, ShouldEqual, "zot:Version")
|
|
So(metaDB.LocksKey, ShouldEqual, "zot:Locks")
|
|
|
|
So(metaDB.getUserLockKey("user1"), ShouldEqual, "zot:Locks:User:user1")
|
|
So(metaDB.getRepoLockKey("repo1"), ShouldEqual, "zot:Locks:Repo:repo1")
|
|
So(metaDB.getImageLockKey("image1"), ShouldEqual, "zot:Locks:Image:image1")
|
|
So(metaDB.getVersionLockKey(), ShouldEqual, "zot:Locks:Version")
|
|
|
|
params = DBDriverParameters{KeyPrefix: "someprefix"}
|
|
|
|
metaDB, err = New(client, params, log)
|
|
So(err, ShouldBeNil)
|
|
So(metaDB.ImageMetaKey, ShouldEqual, "someprefix:ImageMeta")
|
|
So(metaDB.RepoMetaKey, ShouldEqual, "someprefix:RepoMeta")
|
|
So(metaDB.RepoLastUpdatedKey, ShouldEqual, "someprefix:RepoLastUpdated")
|
|
So(metaDB.RepoBlobsKey, ShouldEqual, "someprefix:RepoBlobsMeta")
|
|
So(metaDB.UserDataKey, ShouldEqual, "someprefix:UserData")
|
|
So(metaDB.UserAPIKeysKey, ShouldEqual, "someprefix:UserAPIKeys")
|
|
So(metaDB.VersionKey, ShouldEqual, "someprefix:Version")
|
|
So(metaDB.LocksKey, ShouldEqual, "someprefix:Locks")
|
|
|
|
So(metaDB.getUserLockKey("user1"), ShouldEqual, "someprefix:Locks:User:user1")
|
|
So(metaDB.getRepoLockKey("repo1"), ShouldEqual, "someprefix:Locks:Repo:repo1")
|
|
So(metaDB.getImageLockKey("image1"), ShouldEqual, "someprefix:Locks:Image:image1")
|
|
So(metaDB.getVersionLockKey(), ShouldEqual, "someprefix:Locks:Version")
|
|
})
|
|
}
|