mirror of
				https://github.com/redis/go-redis.git
				synced 2025-11-04 02:33:24 +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>
		
			
				
	
	
		
			229 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			229 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// EXAMPLE: cmds_sorted_set
 | 
						|
// HIDE_START
 | 
						|
package example_commands_test
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"fmt"
 | 
						|
 | 
						|
	"github.com/redis/go-redis/v9"
 | 
						|
)
 | 
						|
 | 
						|
// HIDE_END
 | 
						|
 | 
						|
func ExampleClient_zadd_cmd() {
 | 
						|
	ctx := context.Background()
 | 
						|
 | 
						|
	rdb := redis.NewClient(&redis.Options{
 | 
						|
		Addr:     "localhost:6379",
 | 
						|
		Password: "", // no password docs
 | 
						|
		DB:       0,  // use default DB
 | 
						|
	})
 | 
						|
 | 
						|
	// REMOVE_START
 | 
						|
	// make sure we are working with fresh database
 | 
						|
	rdb.FlushDB(ctx)
 | 
						|
	rdb.Del(ctx, "myzset")
 | 
						|
	// REMOVE_END
 | 
						|
 | 
						|
	// STEP_START zadd
 | 
						|
	zAddResult1, err := rdb.ZAdd(ctx, "myzset",
 | 
						|
		redis.Z{Member: "one", Score: 1},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zAddResult1) // >>> 1
 | 
						|
 | 
						|
	zAddResult2, err := rdb.ZAdd(ctx, "myzset",
 | 
						|
		redis.Z{Member: "uno", Score: 1},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zAddResult2)
 | 
						|
 | 
						|
	zAddResult3, err := rdb.ZAdd(ctx, "myzset",
 | 
						|
		redis.Z{Member: "two", Score: 2},
 | 
						|
		redis.Z{Member: "three", Score: 3},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zAddResult3) // >>> 2
 | 
						|
 | 
						|
	zAddResult4, err := rdb.ZRangeWithScores(ctx, "myzset", 0, -1).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zAddResult4) // >>> [{1 one} {1 uno} {2 two} {3 three}]
 | 
						|
	// STEP_END
 | 
						|
 | 
						|
	// Output:
 | 
						|
	// 1
 | 
						|
	// 1
 | 
						|
	// 2
 | 
						|
	// [{1 one} {1 uno} {2 two} {3 three}]
 | 
						|
}
 | 
						|
 | 
						|
func ExampleClient_zrange1() {
 | 
						|
	ctx := context.Background()
 | 
						|
 | 
						|
	rdb := redis.NewClient(&redis.Options{
 | 
						|
		Addr:     "localhost:6379",
 | 
						|
		Password: "", // no password docs
 | 
						|
		DB:       0,  // use default DB
 | 
						|
	})
 | 
						|
 | 
						|
	// REMOVE_START
 | 
						|
	// start with fresh database
 | 
						|
	rdb.FlushDB(ctx)
 | 
						|
	rdb.Del(ctx, "myzset")
 | 
						|
	// REMOVE_END
 | 
						|
 | 
						|
	// STEP_START zrange1
 | 
						|
	zrangeResult1, err := rdb.ZAdd(ctx, "myzset",
 | 
						|
		redis.Z{Member: "one", Score: 1},
 | 
						|
		redis.Z{Member: "two", Score: 2},
 | 
						|
		redis.Z{Member: "three", Score: 3},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zrangeResult1) // >>> 3
 | 
						|
 | 
						|
	zrangeResult2, err := rdb.ZRange(ctx, "myzset", 0, -1).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zrangeResult2) // >>> [one two three]
 | 
						|
 | 
						|
	zrangeResult3, err := rdb.ZRange(ctx, "myzset", 2, 3).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zrangeResult3) // >>> [three]
 | 
						|
 | 
						|
	zrangeResult4, err := rdb.ZRange(ctx, "myzset", -2, -1).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zrangeResult4) // >>> [two three]
 | 
						|
	// STEP_END
 | 
						|
 | 
						|
	// Output:
 | 
						|
	// 3
 | 
						|
	// [one two three]
 | 
						|
	// [three]
 | 
						|
	// [two three]
 | 
						|
}
 | 
						|
 | 
						|
func ExampleClient_zrange2() {
 | 
						|
	ctx := context.Background()
 | 
						|
 | 
						|
	rdb := redis.NewClient(&redis.Options{
 | 
						|
		Addr:     "localhost:6379",
 | 
						|
		Password: "", // no password docs
 | 
						|
		DB:       0,  // use default DB
 | 
						|
	})
 | 
						|
 | 
						|
	// REMOVE_START
 | 
						|
	// start with fresh database
 | 
						|
	rdb.FlushDB(ctx)
 | 
						|
	rdb.Del(ctx, "myzset")
 | 
						|
	// REMOVE_END
 | 
						|
 | 
						|
	// STEP_START zrange2
 | 
						|
	zRangeResult5, err := rdb.ZAdd(ctx, "myzset",
 | 
						|
		redis.Z{Member: "one", Score: 1},
 | 
						|
		redis.Z{Member: "two", Score: 2},
 | 
						|
		redis.Z{Member: "three", Score: 3},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zRangeResult5) // >>> 3
 | 
						|
 | 
						|
	zRangeResult6, err := rdb.ZRangeWithScores(ctx, "myzset", 0, 1).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zRangeResult6) // >>> [{1 one} {2 two}]
 | 
						|
	// STEP_END
 | 
						|
 | 
						|
	// Output:
 | 
						|
	// 3
 | 
						|
	// [{1 one} {2 two}]
 | 
						|
}
 | 
						|
 | 
						|
func ExampleClient_zrange3() {
 | 
						|
	ctx := context.Background()
 | 
						|
 | 
						|
	rdb := redis.NewClient(&redis.Options{
 | 
						|
		Addr:     "localhost:6379",
 | 
						|
		Password: "", // no password docs
 | 
						|
		DB:       0,  // use default DB
 | 
						|
	})
 | 
						|
 | 
						|
	// REMOVE_START
 | 
						|
	// start with fresh database
 | 
						|
	rdb.FlushDB(ctx)
 | 
						|
	rdb.Del(ctx, "myzset")
 | 
						|
	// REMOVE_END
 | 
						|
 | 
						|
	// STEP_START zrange3
 | 
						|
	zRangeResult7, err := rdb.ZAdd(ctx, "myzset",
 | 
						|
		redis.Z{Member: "one", Score: 1},
 | 
						|
		redis.Z{Member: "two", Score: 2},
 | 
						|
		redis.Z{Member: "three", Score: 3},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zRangeResult7) // >>> 3
 | 
						|
 | 
						|
	zRangeResult8, err := rdb.ZRangeArgs(ctx,
 | 
						|
		redis.ZRangeArgs{
 | 
						|
			Key:     "myzset",
 | 
						|
			ByScore: true,
 | 
						|
			Start:   "(1",
 | 
						|
			Stop:    "+inf",
 | 
						|
			Offset:  1,
 | 
						|
			Count:   1,
 | 
						|
		},
 | 
						|
	).Result()
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Println(zRangeResult8) // >>> [three]
 | 
						|
	// STEP_END
 | 
						|
 | 
						|
	// Output:
 | 
						|
	// 3
 | 
						|
	// [three]
 | 
						|
}
 |