maintenance_test.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. // Copyright 2017 The etcd Authors
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package integration
  15. import (
  16. "context"
  17. "testing"
  18. "github.com/coreos/etcd/etcdserver/api/v3rpc/rpctypes"
  19. "github.com/coreos/etcd/integration"
  20. "github.com/coreos/etcd/pkg/testutil"
  21. )
  22. func TestMaintenanceMoveLeader(t *testing.T) {
  23. defer testutil.AfterTest(t)
  24. clus := integration.NewClusterV3(t, &integration.ClusterConfig{Size: 3})
  25. defer clus.Terminate(t)
  26. oldLeadIdx := clus.WaitLeader(t)
  27. targetIdx := (oldLeadIdx + 1) % 3
  28. target := uint64(clus.Members[targetIdx].ID())
  29. cli := clus.Client(targetIdx)
  30. _, err := cli.MoveLeader(context.Background(), target)
  31. if err != rpctypes.ErrNotLeader {
  32. t.Fatalf("error expected %v, got %v", rpctypes.ErrNotLeader, err)
  33. }
  34. cli = clus.Client(oldLeadIdx)
  35. _, err = cli.MoveLeader(context.Background(), target)
  36. if err != nil {
  37. t.Fatal(err)
  38. }
  39. leadIdx := clus.WaitLeader(t)
  40. lead := uint64(clus.Members[leadIdx].ID())
  41. if target != lead {
  42. t.Fatalf("new leader expected %d, got %d", target, lead)
  43. }
  44. }