milvus/internal/rootcoord/timestamp_bench_test.go
Jiquan Long a5e2d6b6fb
Refactor RootCoord (#18930)
Signed-off-by: longjiquan <jiquan.long@zilliz.com>
Co-authored-by: xaxys <tpnnghd@163.com>

Signed-off-by: longjiquan <jiquan.long@zilliz.com>
Co-authored-by: xaxys <tpnnghd@163.com>
2022-09-05 13:29:11 +08:00

73 lines
1.9 KiB
Go

package rootcoord
import (
"context"
"testing"
"github.com/milvus-io/milvus/internal/proto/rootcoordpb"
"github.com/stretchr/testify/assert"
"github.com/milvus-io/milvus/internal/log"
"go.uber.org/zap"
"github.com/milvus-io/milvus/internal/util/funcutil"
"github.com/milvus-io/milvus/internal/util/etcd"
"github.com/milvus-io/milvus/internal/tso"
"github.com/milvus-io/milvus/internal/util/tsoutil"
clientv3 "go.etcd.io/etcd/client/v3"
)
func getTestEtcdCli() *clientv3.Client {
Params.InitOnce()
cli, err := etcd.GetEtcdClient(&Params.EtcdCfg)
if err != nil {
panic(err)
}
return cli
}
func cleanTestEtcdEnv(cli *clientv3.Client, rootPath string) {
ctx := context.Background()
if _, err := cli.Delete(ctx, rootPath, clientv3.WithPrefix()); err != nil {
panic(err)
}
log.Debug("remove root path on etcd", zap.String("rootPath", rootPath))
}
func newBenchTSOAllocator(etcdCli *clientv3.Client, rootPath, subPath, key string) *tso.GlobalTSOAllocator {
tsoKV := tsoutil.NewTSOKVBase(etcdCli, rootPath, subPath)
tsoAllocator := tso.NewGlobalTSOAllocator(key, tsoKV)
if err := tsoAllocator.Initialize(); err != nil {
panic(err)
}
return tsoAllocator
}
func Benchmark_RootCoord_AllocTimestamp(b *testing.B) {
rootPath := funcutil.GenRandomStr()
subPath := funcutil.GenRandomStr()
key := funcutil.GenRandomStr()
log.Info("benchmark for allocating ts", zap.String("rootPath", rootPath), zap.String("subPath", subPath), zap.String("key", key))
ctx := context.Background()
cli := getTestEtcdCli()
tsoAllocator := newBenchTSOAllocator(cli, rootPath, subPath, key)
c := newTestCore(withHealthyCode(),
withTsoAllocator(tsoAllocator))
defer cleanTestEtcdEnv(cli, rootPath)
b.ResetTimer()
for i := 0; i < b.N; i++ {
req := rootcoordpb.AllocTimestampRequest{
Count: 1,
}
_, err := c.AllocTimestamp(ctx, &req)
assert.Nil(b, err)
}
b.StopTimer()
}