mirror of
https://github.com/project-zot/zot.git
synced 2025-01-06 22:40:28 -05:00
767f81d4f5
This commit includes support for periodic repo sync in a scale-out cluster. Before this commit, all cluster members would sync all the repos as the config is shared. With this change, in periodic sync, the cluster member checks whether it manages the repo. If it does not manage the repo, it will skip the sync. This commit also includes a unit test to test on-demand sync too, but there are no logic changes for it as it is implicitly handled by the proxying logic. Signed-off-by: Vishwas Rajashekar <vrajashe@cisco.com>
25 lines
784 B
Go
25 lines
784 B
Go
package cluster_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
"zotregistry.dev/zot/pkg/cluster"
|
|
)
|
|
|
|
func TestComputeTargetMember(t *testing.T) {
|
|
Convey("Should panic when the hashKey is not long enough", t, func() {
|
|
So(func() { cluster.ComputeTargetMember("lorem", []string{"member1", "member2"}, "zot-test") }, ShouldPanic)
|
|
})
|
|
|
|
Convey("Should panic when there are no members", t, func() {
|
|
So(func() { cluster.ComputeTargetMember("loremipsumdolors", []string{}, "zot-test") }, ShouldPanic)
|
|
})
|
|
|
|
Convey("Should return a valid result when input is valid", t, func() {
|
|
index, member := cluster.ComputeTargetMember("loremipsumdolors", []string{"member1", "member2"}, "zot-test")
|
|
So(index, ShouldEqual, 1)
|
|
So(member, ShouldEqual, "member2")
|
|
})
|
|
}
|