mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 14:55:02 +00:00
45646ac3f4
* Changes default Raft protocol to 3. * Changes numPeers() to report only voters. This should have been there before, but it's more obvious that this is incorrect now that we default the Raft protocol to 3, which puts new servers in a read-only state while Autopilot waits for them to become healthy. * Fixes TestLeader_RollRaftServer. * Fixes TestOperator_RaftRemovePeerByAddress. * Fixes TestServer_*. Relaxed the check for a given number of voter peers and instead do a thorough check that all servers see each other in their Raft configurations. * Fixes TestACL_*. These now just check for Raft replication to be set up, and don't care about the number of voter peers. * Fixes TestOperator_Raft_ListPeers. * Fixes TestAutopilot_CleanupDeadServerPeriodic. * Fixes TestCatalog_ListNodes_ConsistentRead_Fail. * Fixes TestLeader_ChangeServerID and adjusts the conn pool to throw away sockets when it sees io.EOF. * Changes version to 1.0.0 in the options doc. * Makes metrics test more deterministic with autopilot metrics possible.
61 lines
1.4 KiB
Go
61 lines
1.4 KiB
Go
package command
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/consul/agent"
|
|
"github.com/mitchellh/cli"
|
|
)
|
|
|
|
func TestOperator_Raft_ListPeers_Implements(t *testing.T) {
|
|
t.Parallel()
|
|
var _ cli.Command = &OperatorRaftListCommand{}
|
|
}
|
|
|
|
func TestOperator_Raft_ListPeers(t *testing.T) {
|
|
t.Parallel()
|
|
a := agent.NewTestAgent(t.Name(), ``)
|
|
defer a.Shutdown()
|
|
|
|
expected := fmt.Sprintf("%s %s 127.0.0.1:%d leader true 3",
|
|
a.Config.NodeName, a.Config.NodeID, a.Config.ServerPort)
|
|
|
|
// Test the legacy mode with 'consul operator raft -list-peers'
|
|
{
|
|
ui, c := testOperatorRaftCommand(t)
|
|
args := []string{"-http-addr=" + a.HTTPAddr(), "-list-peers"}
|
|
|
|
code := c.Run(args)
|
|
if code != 0 {
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
}
|
|
output := strings.TrimSpace(ui.OutputWriter.String())
|
|
if !strings.Contains(output, expected) {
|
|
t.Fatalf("bad: %q, %q", output, expected)
|
|
}
|
|
}
|
|
|
|
// Test the list-peers subcommand directly
|
|
{
|
|
ui := cli.NewMockUi()
|
|
c := OperatorRaftListCommand{
|
|
BaseCommand: BaseCommand{
|
|
UI: ui,
|
|
Flags: FlagSetHTTP,
|
|
},
|
|
}
|
|
args := []string{"-http-addr=" + a.HTTPAddr()}
|
|
|
|
code := c.Run(args)
|
|
if code != 0 {
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
}
|
|
output := strings.TrimSpace(ui.OutputWriter.String())
|
|
if !strings.Contains(output, expected) {
|
|
t.Fatalf("bad: %q, %q", output, expected)
|
|
}
|
|
}
|
|
}
|