milvus/internal/util/etcd/etcd_util_test.go
jaime 91df8f2d6a
Use log id instead of log path of the binlog in metastore (#19123)
Signed-off-by: yun.zhang <yun.zhang@zilliz.com>

Signed-off-by: yun.zhang <yun.zhang@zilliz.com>
2022-09-25 15:56:51 +08:00

236 lines
5.4 KiB
Go

// Licensed to the LF AI & Data foundation under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package etcd
import (
"context"
"errors"
"os"
"path"
"testing"
"github.com/milvus-io/milvus/internal/util/paramtable"
"github.com/stretchr/testify/assert"
)
var Params paramtable.ServiceParam
func TestEtcd(t *testing.T) {
Params.Init()
Params.EtcdCfg.UseEmbedEtcd = true
Params.EtcdCfg.DataDir = "/tmp/data"
err := InitEtcdServer(&Params.EtcdCfg)
assert.NoError(t, err)
defer os.RemoveAll(Params.EtcdCfg.DataDir)
defer StopEtcdServer()
etcdCli, err := GetEtcdClient(&Params.EtcdCfg)
assert.NoError(t, err)
key := path.Join("test", "test")
_, err = etcdCli.Put(context.TODO(), key, "value")
assert.NoError(t, err)
resp, err := etcdCli.Get(context.TODO(), key)
assert.NoError(t, err)
assert.False(t, resp.Count < 1)
assert.Equal(t, string(resp.Kvs[0].Value), "value")
Params.EtcdCfg.UseEmbedEtcd = false
Params.EtcdCfg.EtcdUseSSL = true
Params.EtcdCfg.EtcdTLSMinVersion = "1.3"
Params.EtcdCfg.EtcdTLSCACert = "../../../configs/cert/ca.pem"
Params.EtcdCfg.EtcdTLSCert = "../../../configs/cert/client.pem"
Params.EtcdCfg.EtcdTLSKey = "../../../configs/cert/client.key"
etcdCli, err = GetEtcdClient(&Params.EtcdCfg)
assert.NoError(t, err)
Params.EtcdCfg.EtcdTLSMinVersion = "some not right word"
etcdCli, err = GetEtcdClient(&Params.EtcdCfg)
assert.NotNil(t, err)
Params.EtcdCfg.EtcdTLSMinVersion = "1.2"
Params.EtcdCfg.EtcdTLSCACert = "wrong/file"
etcdCli, err = GetEtcdClient(&Params.EtcdCfg)
assert.NotNil(t, err)
Params.EtcdCfg.EtcdTLSCACert = "../../../configs/cert/ca.pem"
Params.EtcdCfg.EtcdTLSCert = "wrong/file"
assert.NotNil(t, err)
}
func Test_buildKvGroup(t *testing.T) {
t.Run("length not equal", func(t *testing.T) {
keys := []string{"k1", "k2"}
values := []string{"v1"}
_, err := buildKvGroup(keys, values)
assert.Error(t, err)
})
t.Run("duplicate", func(t *testing.T) {
keys := []string{"k1", "k1"}
values := []string{"v1", "v2"}
_, err := buildKvGroup(keys, values)
assert.Error(t, err)
})
t.Run("normal case", func(t *testing.T) {
keys := []string{"k1", "k2"}
values := []string{"v1", "v2"}
kvs, err := buildKvGroup(keys, values)
assert.NoError(t, err)
for i, k := range keys {
v, ok := kvs[k]
assert.True(t, ok)
assert.Equal(t, values[i], v)
}
})
}
func Test_SaveByBatch(t *testing.T) {
t.Run("empty kvs", func(t *testing.T) {
kvs := map[string]string{}
group := 0
count := 0
saveFn := func(partialKvs map[string]string) error {
group++
count += len(partialKvs)
return nil
}
maxTxnNum = 2
err := SaveByBatch(kvs, saveFn)
assert.NoError(t, err)
assert.Equal(t, 0, group)
assert.Equal(t, 0, count)
})
t.Run("normal case", func(t *testing.T) {
kvs := map[string]string{
"k1": "v1",
"k2": "v2",
"k3": "v3",
}
group := 0
count := 0
saveFn := func(partialKvs map[string]string) error {
group++
count += len(partialKvs)
return nil
}
maxTxnNum = 2
err := SaveByBatch(kvs, saveFn)
assert.NoError(t, err)
assert.Equal(t, 2, group)
assert.Equal(t, 3, count)
})
t.Run("multi save failed", func(t *testing.T) {
saveFn := func(partialKvs map[string]string) error {
return errors.New("mock")
}
kvs := map[string]string{
"k1": "v1",
"k2": "v2",
"k3": "v3",
}
maxTxnNum = 2
err := SaveByBatch(kvs, saveFn)
assert.Error(t, err)
})
}
func Test_RemoveByBatch(t *testing.T) {
t.Run("empty kvs case", func(t *testing.T) {
var kvs []string
group := 0
count := 0
removeFn := func(partialKvs []string) error {
group++
count += len(partialKvs)
return nil
}
maxTxnNum = 2
err := RemoveByBatch(kvs, removeFn)
assert.NoError(t, err)
assert.Equal(t, 0, group)
assert.Equal(t, 0, count)
})
t.Run("normal case", func(t *testing.T) {
kvs := []string{"k1", "k2", "k3", "k4", "k5"}
group := 0
count := 0
removeFn := func(partialKvs []string) error {
group++
count += len(partialKvs)
return nil
}
maxTxnNum = 2
err := RemoveByBatch(kvs, removeFn)
assert.NoError(t, err)
assert.Equal(t, 3, group)
assert.Equal(t, 5, count)
})
t.Run("multi remove failed", func(t *testing.T) {
removeFn := func(partialKvs []string) error {
return errors.New("mock")
}
kvs := []string{"k1", "k2", "k3", "k4", "k5"}
maxTxnNum = 2
err := RemoveByBatch(kvs, removeFn)
assert.Error(t, err)
})
}
func Test_min(t *testing.T) {
type args struct {
a int
b int
}
tests := []struct {
name string
args args
want int
}{
{
args: args{a: 1, b: 2},
want: 1,
},
{
args: args{a: 4, b: 3},
want: 3,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := min(tt.args.a, tt.args.b); got != tt.want {
t.Errorf("min() = %v, want %v", got, tt.want)
}
})
}
}