mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
e2e: test 'endpoint hashkv' command
Signed-off-by: Gyu-Ho Lee <gyuhox@gmail.com>
This commit is contained in:
parent
5176b63fa0
commit
43ccc549fb
@ -15,12 +15,18 @@
|
||||
package e2e
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"net/url"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"github.com/coreos/etcd/clientv3"
|
||||
)
|
||||
|
||||
func TestCtlV3EndpointHealth(t *testing.T) { testCtl(t, endpointHealthTest, withQuorum()) }
|
||||
func TestCtlV3EndpointStatus(t *testing.T) { testCtl(t, endpointStatusTest, withQuorum()) }
|
||||
func TestCtlV3EndpointHashKV(t *testing.T) { testCtl(t, endpointHashKVTest, withQuorum()) }
|
||||
|
||||
func endpointHealthTest(cx ctlCtx) {
|
||||
if err := ctlV3EndpointHealth(cx); err != nil {
|
||||
@ -52,3 +58,35 @@ func ctlV3EndpointStatus(cx ctlCtx) error {
|
||||
}
|
||||
return spawnWithExpects(cmdArgs, eps...)
|
||||
}
|
||||
|
||||
func endpointHashKVTest(cx ctlCtx) {
|
||||
if err := ctlV3EndpointHashKV(cx); err != nil {
|
||||
cx.t.Fatalf("endpointHashKVTest ctlV3EndpointHashKV error (%v)", err)
|
||||
}
|
||||
}
|
||||
|
||||
func ctlV3EndpointHashKV(cx ctlCtx) error {
|
||||
eps := cx.epc.EndpointsV3()
|
||||
|
||||
// get latest hash to compare
|
||||
cli, err := clientv3.New(clientv3.Config{
|
||||
Endpoints: eps,
|
||||
DialTimeout: 3 * time.Second,
|
||||
})
|
||||
if err != nil {
|
||||
cx.t.Fatal(err)
|
||||
}
|
||||
defer cli.Close()
|
||||
hresp, err := cli.HashKV(context.TODO(), eps[0], 0)
|
||||
if err != nil {
|
||||
cx.t.Fatal(err)
|
||||
}
|
||||
|
||||
cmdArgs := append(cx.PrefixArgs(), "endpoint", "hashkv")
|
||||
var ss []string
|
||||
for _, ep := range cx.epc.EndpointsV3() {
|
||||
u, _ := url.Parse(ep)
|
||||
ss = append(ss, fmt.Sprintf("%s, %d", u.Host, hresp.Hash))
|
||||
}
|
||||
return spawnWithExpects(cmdArgs, ss...)
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user