From 47c487ae159ca0e8f89ae1abe47cdc490cb26410 Mon Sep 17 00:00:00 2001 From: Clark Date: Wed, 27 Jul 2022 00:19:48 +0800 Subject: [PATCH] tests: Migrate member add tests to common framework Signed-off-by: Clark --- tests/common/member_test.go | 56 +++++++++++++++++++++++++++++++++ tests/e2e/ctl_v3_member_test.go | 26 +-------------- tests/framework/e2e/etcdctl.go | 6 ++++ tests/framework/integration.go | 8 +++++ tests/framework/interface.go | 2 ++ 5 files changed, 73 insertions(+), 25 deletions(-) diff --git a/tests/common/member_test.go b/tests/common/member_test.go index f1b6be3aef03..1b3d9610ae58 100644 --- a/tests/common/member_test.go +++ b/tests/common/member_test.go @@ -16,11 +16,15 @@ package common import ( "context" + clientv3 "go.etcd.io/etcd/client/v3" "go.etcd.io/etcd/tests/v3/framework/testutils" "testing" "time" ) +// 240.0.0.0 is reserved for future use according to https://en.wikipedia.org/wiki/Reserved_IP_addresses +var blackHolePeerUrl = "http://240.0.0.0:65535" + func TestMemberList(t *testing.T) { testRunner.BeforeTest(t) @@ -51,3 +55,55 @@ func TestMemberList(t *testing.T) { }) } } + +func TestMemberAdd(t *testing.T) { + testRunner.BeforeTest(t) + + tcs := []struct { + name string + learner bool + }{ + { + name: "NotLearner", + learner: false, + }, + { + name: "Learner", + learner: true, + }, + } + + for _, tc := range tcs { + for _, nc := range clusterTestCases { + t.Run(tc.name+"/"+nc.name, func(t *testing.T) { + ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second) + defer cancel() + clus := testRunner.NewCluster(ctx, t, nc.config) + defer clus.Close() + cc := clus.Client() + + testutils.ExecuteUntil(ctx, t, func() { + var addResp *clientv3.MemberAddResponse + var err error + if tc.learner { + addResp, err = cc.MemberAddAsLearner("newmember", []string{blackHolePeerUrl}) + } else { + addResp, err = cc.MemberAdd("newmember", []string{blackHolePeerUrl}) + } + if err != nil { + t.Fatalf("could not add member, err: %s", err) + } + if addResp.Member == nil || addResp.Member.ID == 0 { + t.Fatalf("member add failed, got nil member") + } + if addResp.Member.ID == 0 { + t.Fatalf("member add failed, got empty member id") + } + if len(addResp.Member.PeerURLs) == 0 { + t.Fatalf("member add failed, got empty peer urls") + } + }) + }) + } + } +} diff --git a/tests/e2e/ctl_v3_member_test.go b/tests/e2e/ctl_v3_member_test.go index a80642398dd3..b6b44acd0a4c 100644 --- a/tests/e2e/ctl_v3_member_test.go +++ b/tests/e2e/ctl_v3_member_test.go @@ -50,19 +50,7 @@ func TestCtlV3MemberRemoveClientAutoTLS(t *testing.T) { func TestCtlV3MemberRemovePeerTLS(t *testing.T) { testCtl(t, memberRemoveTest, withQuorum(), withNoStrictReconfig(), withCfg(*e2e.NewConfigPeerTLS())) } -func TestCtlV3MemberAdd(t *testing.T) { testCtl(t, memberAddTest) } -func TestCtlV3MemberAddNoTLS(t *testing.T) { testCtl(t, memberAddTest, withCfg(*e2e.NewConfigNoTLS())) } -func TestCtlV3MemberAddClientTLS(t *testing.T) { - testCtl(t, memberAddTest, withCfg(*e2e.NewConfigClientTLS())) -} -func TestCtlV3MemberAddClientAutoTLS(t *testing.T) { - testCtl(t, memberAddTest, withCfg(*e2e.NewConfigClientAutoTLS())) -} -func TestCtlV3MemberAddPeerTLS(t *testing.T) { - testCtl(t, memberAddTest, withCfg(*e2e.NewConfigPeerTLS())) -} -func TestCtlV3MemberAddForLearner(t *testing.T) { testCtl(t, memberAddForLearnerTest) } -func TestCtlV3MemberUpdate(t *testing.T) { testCtl(t, memberUpdateTest) } +func TestCtlV3MemberUpdate(t *testing.T) { testCtl(t, memberUpdateTest) } func TestCtlV3MemberUpdateNoTLS(t *testing.T) { testCtl(t, memberUpdateTest, withCfg(*e2e.NewConfigNoTLS())) } @@ -178,18 +166,6 @@ func ctlV3MemberRemove(cx ctlCtx, ep, memberID, clusterID string) error { return e2e.SpawnWithExpectWithEnv(cmdArgs, cx.envMap, fmt.Sprintf("%s removed from cluster %s", memberID, clusterID)) } -func memberAddTest(cx ctlCtx) { - if err := ctlV3MemberAdd(cx, fmt.Sprintf("http://localhost:%d", e2e.EtcdProcessBasePort+11), false); err != nil { - cx.t.Fatal(err) - } -} - -func memberAddForLearnerTest(cx ctlCtx) { - if err := ctlV3MemberAdd(cx, fmt.Sprintf("http://localhost:%d", e2e.EtcdProcessBasePort+11), true); err != nil { - cx.t.Fatal(err) - } -} - func ctlV3MemberAdd(cx ctlCtx, peerURL string, isLearner bool) error { cmdArgs := append(cx.PrefixArgs(), "member", "add", "newmember", fmt.Sprintf("--peer-urls=%s", peerURL)) if isLearner { diff --git a/tests/framework/e2e/etcdctl.go b/tests/framework/e2e/etcdctl.go index 97de1f21f4c6..51c30d65f320 100644 --- a/tests/framework/e2e/etcdctl.go +++ b/tests/framework/e2e/etcdctl.go @@ -235,6 +235,12 @@ func (ctl *EtcdctlV3) MemberList() (*clientv3.MemberListResponse, error) { return &resp, err } +func (ctl *EtcdctlV3) MemberAdd(name string, peerAddrs []string) (*clientv3.MemberAddResponse, error) { + var resp clientv3.MemberAddResponse + err := ctl.spawnJsonCmd(&resp, "member", "add", name, "--peer-urls", strings.Join(peerAddrs, ",")) + return &resp, err +} + func (ctl *EtcdctlV3) MemberAddAsLearner(name string, peerAddrs []string) (*clientv3.MemberAddResponse, error) { var resp clientv3.MemberAddResponse err := ctl.spawnJsonCmd(&resp, "member", "add", name, "--learner", "--peer-urls", strings.Join(peerAddrs, ",")) diff --git a/tests/framework/integration.go b/tests/framework/integration.go index 631b7263e696..9da6aa9418a4 100644 --- a/tests/framework/integration.go +++ b/tests/framework/integration.go @@ -376,3 +376,11 @@ func getOps(ss []string) ([]clientv3.Op, error) { func (c integrationClient) MemberList() (*clientv3.MemberListResponse, error) { return c.Client.MemberList(c.ctx) } + +func (c integrationClient) MemberAdd(_ string, peerAddrs []string) (*clientv3.MemberAddResponse, error) { + return c.Client.MemberAdd(c.ctx, peerAddrs) +} + +func (c integrationClient) MemberAddAsLearner(_ string, peerAddrs []string) (*clientv3.MemberAddResponse, error) { + return c.Client.MemberAddAsLearner(c.ctx, peerAddrs) +} diff --git a/tests/framework/interface.go b/tests/framework/interface.go index a7ded291a884..a4a03f28cc6e 100644 --- a/tests/framework/interface.go +++ b/tests/framework/interface.go @@ -72,4 +72,6 @@ type Client interface { Txn(compares, ifSucess, ifFail []string, o config.TxnOptions) (*clientv3.TxnResponse, error) MemberList() (*clientv3.MemberListResponse, error) + MemberAdd(name string, peerAddrs []string) (*clientv3.MemberAddResponse, error) + MemberAddAsLearner(name string, peerAddrs []string) (*clientv3.MemberAddResponse, error) }