package redis3 import ( "context" "fmt" "github.com/go-redis/redis/v8" "github.com/stvp/tempredis" "strconv" "testing" "time" ) var names = []string{ "cassandra.in.sh", "cassandra", "debug-cql.bat", "nodetool", "nodetool.bat", "source-conf.ps1", "sstableloader", "sstableloader.bat", "sstablescrub", "sstablescrub.bat", "sstableupgrade", "sstableupgrade.bat", "sstableutil", "sstableutil.bat", "sstableverify", "sstableverify.bat", "stop-server", "stop-server.bat", "stop-server.ps1", "cassandra.in.bat", "cqlsh.py", "cqlsh", "cassandra.ps1", "cqlsh.bat", "debug-cql", "cassandra.bat", } func TestNameList(t *testing.T) { server, err := tempredis.Start(tempredis.Config{}) if err != nil { panic(err) } defer server.Term() client := redis.NewClient(&redis.Options{ Network: "unix", Addr: server.Socket(), }) store := newSkipListElementStore("/yyy/bin", client) var data []byte for _, name := range names { nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit) nameList.WriteName(name) nameList.ListNames("", func(name string) bool { // println(name) return true }) if nameList.HasChanges() { data = nameList.ToBytes() } // println() } nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit) nameList.ListNames("", func(name string) bool { println(name) return true }) } func xBenchmarkNameList(b *testing.B) { server, err := tempredis.Start(tempredis.Config{}) if err != nil { panic(err) } defer server.Term() client := redis.NewClient(&redis.Options{ Network: "unix", Addr: server.Socket(), }) store := newSkipListElementStore("/yyy/bin", client) var data []byte for i := 0; i < b.N; i++ { nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit) nameList.WriteName(strconv.Itoa(i)+"namexxxxxxxxxxxxxxxxxxx") if nameList.HasChanges() { data = nameList.ToBytes() } } } func xBenchmarkRedis(b *testing.B) { server, err := tempredis.Start(tempredis.Config{}) if err != nil { panic(err) } defer server.Term() client := redis.NewClient(&redis.Options{ Network: "unix", Addr: server.Socket(), }) for i := 0; i < b.N; i++ { client.ZAddNX(context.Background(),"/yyy/bin", &redis.Z{Score: 0, Member: strconv.Itoa(i)+"namexxxxxxxxxxxxxxxxxxx"}) } } func TestNameListAdd(t *testing.T) { server, err := tempredis.Start(tempredis.Config{}) if err != nil { panic(err) } defer server.Term() client := redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", DB: 0, }) client.FlushAll(context.Background()) N := 364800 ts0 := time.Now() store := newSkipListElementStore("/y", client) var data []byte nameList := LoadItemList(data, "/y", client, store, 100000) for i := 0; i < N; i++ { nameList.WriteName(fmt.Sprintf("%8d", i)) } ts1 := time.Now() for i := 0; i < N; i++ { client.ZAddNX(context.Background(),"/x", &redis.Z{Score: 0, Member: fmt.Sprintf("name %8d", i)}) } ts2 := time.Now() fmt.Printf("%v %v", ts1.Sub(ts0), ts2.Sub(ts1)) /* keys := client.Keys(context.Background(), "/*m").Val() for _, k := range keys { println("key", k) for i, v := range client.ZRangeByLex(context.Background(), k, &redis.ZRangeBy{ Min: "-", Max: "+", }).Val() { println(" ", i, v) } } */ } func BenchmarkNameList(b *testing.B) { server, err := tempredis.Start(tempredis.Config{}) if err != nil { panic(err) } defer server.Term() client := redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", DB: 0, }) store := newSkipListElementStore("/yyy/bin", client) var data []byte for i := 0; i < b.N; i++ { nameList := LoadItemList(data, "/yyy/bin", client, store, maxNameBatchSizeLimit) nameList.WriteName(fmt.Sprintf("name %8d", i)) if nameList.HasChanges() { data = nameList.ToBytes() } } } func BenchmarkRedis(b *testing.B) { client := redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", DB: 0, }) for i := 0; i < b.N; i++ { client.ZAddNX(context.Background(),"/xxx/bin", &redis.Z{Score: 0, Member: fmt.Sprintf("name %8d", i)}) } }