2016-08-30 02:09:57 +00:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2017-03-10 00:43:07 +00:00
|
|
|
"fmt"
|
2016-08-30 02:09:57 +00:00
|
|
|
"strings"
|
|
|
|
"testing"
|
2016-11-15 02:54:37 +00:00
|
|
|
|
|
|
|
"github.com/hashicorp/consul/testutil"
|
2016-08-30 02:09:57 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestOperator_RaftGetConfiguration(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
c, s := makeClient(t)
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
operator := c.Operator()
|
|
|
|
out, err := operator.RaftGetConfiguration(nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
2016-08-30 18:30:56 +00:00
|
|
|
if len(out.Servers) != 1 ||
|
|
|
|
!out.Servers[0].Leader ||
|
|
|
|
!out.Servers[0].Voter {
|
2016-08-30 02:09:57 +00:00
|
|
|
t.Fatalf("bad: %v", out)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOperator_RaftRemovePeerByAddress(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
c, s := makeClient(t)
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
// If we get this error, it proves we sent the address all the way
|
|
|
|
// through.
|
|
|
|
operator := c.Operator()
|
|
|
|
err := operator.RaftRemovePeerByAddress("nope", nil)
|
|
|
|
if err == nil || !strings.Contains(err.Error(),
|
|
|
|
"address \"nope\" was not found in the Raft configuration") {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
}
|
2016-11-15 02:54:37 +00:00
|
|
|
|
|
|
|
func TestOperator_KeyringInstallListPutRemove(t *testing.T) {
|
|
|
|
oldKey := "d8wu8CSUrqgtjVsvcBPmhQ=="
|
|
|
|
newKey := "qxycTi/SsePj/TZzCBmNXw=="
|
|
|
|
t.Parallel()
|
|
|
|
c, s := makeClientWithConfig(t, nil, func(c *testutil.TestServerConfig) {
|
|
|
|
c.Encrypt = oldKey
|
|
|
|
})
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
operator := c.Operator()
|
2016-11-22 23:24:40 +00:00
|
|
|
if err := operator.KeyringInstall(newKey, nil); err != nil {
|
2016-11-15 02:54:37 +00:00
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
2016-11-22 23:24:40 +00:00
|
|
|
listResponses, err := operator.KeyringList(nil)
|
2016-11-15 02:54:37 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make sure the new key is installed
|
|
|
|
if len(listResponses) != 2 {
|
|
|
|
t.Fatalf("bad: %v", len(listResponses))
|
|
|
|
}
|
|
|
|
for _, response := range listResponses {
|
|
|
|
if len(response.Keys) != 2 {
|
|
|
|
t.Fatalf("bad: %v", len(response.Keys))
|
|
|
|
}
|
|
|
|
if _, ok := response.Keys[oldKey]; !ok {
|
|
|
|
t.Fatalf("bad: %v", ok)
|
|
|
|
}
|
|
|
|
if _, ok := response.Keys[newKey]; !ok {
|
|
|
|
t.Fatalf("bad: %v", ok)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Switch the primary to the new key
|
2016-11-22 23:24:40 +00:00
|
|
|
if err := operator.KeyringUse(newKey, nil); err != nil {
|
2016-11-15 02:54:37 +00:00
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
2016-11-22 23:24:40 +00:00
|
|
|
if err := operator.KeyringRemove(oldKey, nil); err != nil {
|
2016-11-15 02:54:37 +00:00
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
2016-11-22 23:24:40 +00:00
|
|
|
listResponses, err = operator.KeyringList(nil)
|
2016-11-15 02:54:37 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make sure the old key is removed
|
|
|
|
if len(listResponses) != 2 {
|
|
|
|
t.Fatalf("bad: %v", len(listResponses))
|
|
|
|
}
|
|
|
|
for _, response := range listResponses {
|
|
|
|
if len(response.Keys) != 1 {
|
|
|
|
t.Fatalf("bad: %v", len(response.Keys))
|
|
|
|
}
|
|
|
|
if _, ok := response.Keys[oldKey]; ok {
|
|
|
|
t.Fatalf("bad: %v", ok)
|
|
|
|
}
|
|
|
|
if _, ok := response.Keys[newKey]; !ok {
|
|
|
|
t.Fatalf("bad: %v", ok)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-02-24 05:00:15 +00:00
|
|
|
|
|
|
|
func TestOperator_AutopilotGetSetConfiguration(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
c, s := makeClient(t)
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
operator := c.Operator()
|
|
|
|
config, err := operator.AutopilotGetConfiguration(nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
2017-02-28 22:23:14 +00:00
|
|
|
if !config.CleanupDeadServers {
|
2017-02-24 05:00:15 +00:00
|
|
|
t.Fatalf("bad: %v", config)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Change a config setting
|
2017-02-28 22:23:14 +00:00
|
|
|
newConf := &AutopilotConfiguration{CleanupDeadServers: false}
|
2017-02-24 21:08:49 +00:00
|
|
|
if err := operator.AutopilotSetConfiguration(newConf, nil); err != nil {
|
2017-02-24 05:00:15 +00:00
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
config, err = operator.AutopilotGetConfiguration(nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
2017-02-28 22:23:14 +00:00
|
|
|
if config.CleanupDeadServers {
|
2017-02-24 05:00:15 +00:00
|
|
|
t.Fatalf("bad: %v", config)
|
|
|
|
}
|
2017-02-24 21:08:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestOperator_AutopilotCASConfiguration(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
c, s := makeClient(t)
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
operator := c.Operator()
|
|
|
|
config, err := operator.AutopilotGetConfiguration(nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
2017-02-28 22:23:14 +00:00
|
|
|
if !config.CleanupDeadServers {
|
2017-02-24 21:08:49 +00:00
|
|
|
t.Fatalf("bad: %v", config)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pass an invalid ModifyIndex
|
|
|
|
{
|
|
|
|
newConf := &AutopilotConfiguration{
|
2017-02-28 22:23:14 +00:00
|
|
|
CleanupDeadServers: false,
|
|
|
|
ModifyIndex: config.ModifyIndex - 1,
|
2017-02-24 21:08:49 +00:00
|
|
|
}
|
|
|
|
resp, err := operator.AutopilotCASConfiguration(newConf, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
if resp {
|
|
|
|
t.Fatalf("bad: %v", resp)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pass a valid ModifyIndex
|
|
|
|
{
|
|
|
|
newConf := &AutopilotConfiguration{
|
2017-02-28 22:23:14 +00:00
|
|
|
CleanupDeadServers: false,
|
|
|
|
ModifyIndex: config.ModifyIndex,
|
2017-02-24 21:08:49 +00:00
|
|
|
}
|
|
|
|
resp, err := operator.AutopilotCASConfiguration(newConf, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
if !resp {
|
|
|
|
t.Fatalf("bad: %v", resp)
|
|
|
|
}
|
|
|
|
}
|
2017-02-24 23:54:49 +00:00
|
|
|
}
|
2017-03-10 00:43:07 +00:00
|
|
|
|
|
|
|
func TestOperator_ServerHealth(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
c, s := makeClientWithConfig(t, nil, func(c *testutil.TestServerConfig) {
|
|
|
|
c.RaftProtocol = 3
|
|
|
|
})
|
|
|
|
defer s.Stop()
|
|
|
|
|
|
|
|
operator := c.Operator()
|
2017-03-23 22:27:16 +00:00
|
|
|
if err := testutil.WaitForResult(func() (bool, error) {
|
2017-03-10 00:43:07 +00:00
|
|
|
out, err := operator.AutopilotServerHealth(nil)
|
|
|
|
if err != nil {
|
|
|
|
return false, fmt.Errorf("err: %v", err)
|
|
|
|
}
|
|
|
|
if len(out.Servers) != 1 ||
|
|
|
|
!out.Servers[0].Healthy ||
|
|
|
|
out.Servers[0].Name != s.Config.NodeName {
|
|
|
|
return false, fmt.Errorf("bad: %v", out)
|
|
|
|
}
|
|
|
|
|
|
|
|
return true, nil
|
2017-03-23 22:27:16 +00:00
|
|
|
}); err != nil {
|
2017-03-10 00:43:07 +00:00
|
|
|
t.Fatal(err)
|
2017-03-23 22:27:16 +00:00
|
|
|
}
|
2017-03-10 00:43:07 +00:00
|
|
|
}
|