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>
182 lines
2.9 KiB
Go
182 lines
2.9 KiB
Go
// EXAMPLE: set_tutorial
|
|
// HIDE_START
|
|
package example_commands_test
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/redis/go-redis/v9"
|
|
)
|
|
|
|
// HIDE_END
|
|
func ExampleClient_set_get() {
|
|
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, "bike:1")
|
|
// REMOVE_END
|
|
|
|
// STEP_START set_get
|
|
res1, err := rdb.Set(ctx, "bike:1", "Deimos", 0).Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res1) // >>> OK
|
|
|
|
res2, err := rdb.Get(ctx, "bike:1").Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res2) // >>> Deimos
|
|
// STEP_END
|
|
|
|
// Output:
|
|
// OK
|
|
// Deimos
|
|
}
|
|
|
|
func ExampleClient_setnx_xx() {
|
|
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.Set(ctx, "bike:1", "Deimos", 0)
|
|
// REMOVE_END
|
|
|
|
// STEP_START setnx_xx
|
|
res3, err := rdb.SetNX(ctx, "bike:1", "bike", 0).Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res3) // >>> false
|
|
|
|
res4, err := rdb.Get(ctx, "bike:1").Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res4) // >>> Deimos
|
|
|
|
res5, err := rdb.SetXX(ctx, "bike:1", "bike", 0).Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res5) // >>> OK
|
|
// STEP_END
|
|
|
|
// Output:
|
|
// false
|
|
// Deimos
|
|
// true
|
|
}
|
|
|
|
func ExampleClient_mset() {
|
|
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, "bike:1", "bike:2", "bike:3")
|
|
// REMOVE_END
|
|
|
|
// STEP_START mset
|
|
res6, err := rdb.MSet(ctx, "bike:1", "Deimos", "bike:2", "Ares", "bike:3", "Vanth").Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res6) // >>> OK
|
|
|
|
res7, err := rdb.MGet(ctx, "bike:1", "bike:2", "bike:3").Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res7) // >>> [Deimos Ares Vanth]
|
|
// STEP_END
|
|
|
|
// Output:
|
|
// OK
|
|
// [Deimos Ares Vanth]
|
|
}
|
|
|
|
func ExampleClient_incr() {
|
|
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, "total_crashes")
|
|
// REMOVE_END
|
|
|
|
// STEP_START incr
|
|
res8, err := rdb.Set(ctx, "total_crashes", "0", 0).Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res8) // >>> OK
|
|
|
|
res9, err := rdb.Incr(ctx, "total_crashes").Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res9) // >>> 1
|
|
|
|
res10, err := rdb.IncrBy(ctx, "total_crashes", 10).Result()
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
fmt.Println(res10) // >>> 11
|
|
// STEP_END
|
|
|
|
// Output:
|
|
// OK
|
|
// 1
|
|
// 11
|
|
}
|