mirror of
				https://github.com/redis/go-redis.git
				synced 2025-10-26 06:51:16 +03:00 
			
		
		
		
	* chore: extract benchmark tests * wip * enable pubsub tests * enable ring tests * stop tests with build redis from source * start all tests * mix of makefile and action * add sentinel configs * fix example test * stop debug on re * wip * enable gears for redis 7.2 * wip * enable sentinel, they are expected to fail * fix: linter configuration * chore: update re versions * return older redis enterprise version * add basic codeql * wip: increase timeout, focus only sentinel tests * sentinels with docker network host * enable all tests * fix flanky test * enable example tests * tidy docker compose * add debug output * stop shutingdown masters * don't test sentinel for re * skip unsuported addscores * Update README bump go version in CI * Update README.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update CONTRIBUTING.md add information about new test setup --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
		
			
				
	
	
		
			155 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package redis_test
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 
 | |
| 	. "github.com/bsm/ginkgo/v2"
 | |
| 	. "github.com/bsm/gomega"
 | |
| 
 | |
| 	"github.com/redis/go-redis/v9"
 | |
| )
 | |
| 
 | |
| var _ = Describe("ScanIterator", func() {
 | |
| 	var client *redis.Client
 | |
| 
 | |
| 	seed := func(n int) error {
 | |
| 		pipe := client.Pipeline()
 | |
| 		for i := 1; i <= n; i++ {
 | |
| 			pipe.Set(ctx, fmt.Sprintf("K%02d", i), "x", 0).Err()
 | |
| 		}
 | |
| 		_, err := pipe.Exec(ctx)
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	extraSeed := func(n int, m int) error {
 | |
| 		pipe := client.Pipeline()
 | |
| 		for i := 1; i <= m; i++ {
 | |
| 			pipe.Set(ctx, fmt.Sprintf("A%02d", i), "x", 0).Err()
 | |
| 		}
 | |
| 		for i := 1; i <= n; i++ {
 | |
| 			pipe.Set(ctx, fmt.Sprintf("K%02d", i), "x", 0).Err()
 | |
| 		}
 | |
| 		_, err := pipe.Exec(ctx)
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	hashKey := "K_HASHTEST"
 | |
| 	hashSeed := func(n int) error {
 | |
| 		pipe := client.Pipeline()
 | |
| 		for i := 1; i <= n; i++ {
 | |
| 			pipe.HSet(ctx, hashKey, fmt.Sprintf("K%02d", i), "x").Err()
 | |
| 		}
 | |
| 		_, err := pipe.Exec(ctx)
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	BeforeEach(func() {
 | |
| 		client = redis.NewClient(redisOptions())
 | |
| 		Expect(client.FlushDB(ctx).Err()).NotTo(HaveOccurred())
 | |
| 	})
 | |
| 
 | |
| 	AfterEach(func() {
 | |
| 		Expect(client.Close()).NotTo(HaveOccurred())
 | |
| 	})
 | |
| 
 | |
| 	It("should scan across empty DBs", func() {
 | |
| 		iter := client.Scan(ctx, 0, "", 10).Iterator()
 | |
| 		Expect(iter.Next(ctx)).To(BeFalse())
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 	})
 | |
| 
 | |
| 	It("should scan across one page", func() {
 | |
| 		Expect(seed(7)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.Scan(ctx, 0, "", 0).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(ConsistOf([]string{"K01", "K02", "K03", "K04", "K05", "K06", "K07"}))
 | |
| 	})
 | |
| 
 | |
| 	It("should scan across multiple pages", func() {
 | |
| 		Expect(seed(71)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.Scan(ctx, 0, "", 10).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(HaveLen(71))
 | |
| 		Expect(vals).To(ContainElement("K01"))
 | |
| 		Expect(vals).To(ContainElement("K71"))
 | |
| 	})
 | |
| 
 | |
| 	It("should hscan across multiple pages", func() {
 | |
| 		SkipBeforeRedisVersion(7.4, "doesn't work with older redis stack images")
 | |
| 		Expect(hashSeed(71)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.HScan(ctx, hashKey, 0, "", 10).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(HaveLen(71 * 2))
 | |
| 		Expect(vals).To(ContainElement("K01"))
 | |
| 		Expect(vals).To(ContainElement("K71"))
 | |
| 		Expect(vals).To(ContainElement("x"))
 | |
| 	})
 | |
| 
 | |
| 	It("should hscan without values across multiple pages", Label("NonRedisEnterprise"), func() {
 | |
| 		SkipBeforeRedisVersion(7.4, "doesn't work with older redis stack images")
 | |
| 		Expect(hashSeed(71)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.HScanNoValues(ctx, hashKey, 0, "", 10).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(HaveLen(71))
 | |
| 		Expect(vals).To(ContainElement("K01"))
 | |
| 		Expect(vals).To(ContainElement("K71"))
 | |
| 		Expect(vals).NotTo(ContainElement("x"))
 | |
| 	})
 | |
| 
 | |
| 	It("should scan to page borders", func() {
 | |
| 		Expect(seed(20)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.Scan(ctx, 0, "", 10).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(HaveLen(20))
 | |
| 	})
 | |
| 
 | |
| 	It("should scan with match", func() {
 | |
| 		Expect(seed(33)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.Scan(ctx, 0, "K*2*", 10).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(HaveLen(13))
 | |
| 	})
 | |
| 
 | |
| 	It("should scan with match across empty pages", func() {
 | |
| 		Expect(extraSeed(2, 10)).NotTo(HaveOccurred())
 | |
| 
 | |
| 		var vals []string
 | |
| 		iter := client.Scan(ctx, 0, "K*", 1).Iterator()
 | |
| 		for iter.Next(ctx) {
 | |
| 			vals = append(vals, iter.Val())
 | |
| 		}
 | |
| 		Expect(iter.Err()).NotTo(HaveOccurred())
 | |
| 		Expect(vals).To(HaveLen(2))
 | |
| 	})
 | |
| })
 |