mirror of
https://github.com/redis/go-redis.git
synced 2025-04-16 09:23:06 +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]
|
|
}
|