2013-12-19 12:18:06 -08:00
|
|
|
package agent
|
|
|
|
|
|
|
|
import (
|
2015-01-19 09:54:12 -08:00
|
|
|
"bytes"
|
2014-10-12 12:27:03 -07:00
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
"log"
|
|
|
|
"os"
|
2015-01-19 09:54:12 -08:00
|
|
|
"strings"
|
2013-12-19 12:18:06 -08:00
|
|
|
"testing"
|
2014-10-12 12:27:03 -07:00
|
|
|
|
|
|
|
"github.com/hashicorp/consul/testutil"
|
|
|
|
"github.com/mitchellh/cli"
|
2013-12-19 12:18:06 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestCommand_implements(t *testing.T) {
|
|
|
|
var _ cli.Command = new(Command)
|
|
|
|
}
|
2014-06-09 11:57:15 -07:00
|
|
|
|
|
|
|
func TestValidDatacenter(t *testing.T) {
|
|
|
|
shouldMatch := []string{
|
|
|
|
"dc1",
|
|
|
|
"east-aws-001",
|
|
|
|
"PROD_aws01-small",
|
|
|
|
}
|
|
|
|
noMatch := []string{
|
|
|
|
"east.aws",
|
|
|
|
"east!aws",
|
|
|
|
"first,second",
|
|
|
|
}
|
|
|
|
for _, m := range shouldMatch {
|
|
|
|
if !validDatacenter.MatchString(m) {
|
|
|
|
t.Fatalf("expected match: %s", m)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for _, m := range noMatch {
|
|
|
|
if validDatacenter.MatchString(m) {
|
|
|
|
t.Fatalf("expected no match: %s", m)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-10-12 12:27:03 -07:00
|
|
|
|
|
|
|
func TestRetryJoin(t *testing.T) {
|
|
|
|
dir, agent := makeAgent(t, nextConfig())
|
|
|
|
defer os.RemoveAll(dir)
|
|
|
|
defer agent.Shutdown()
|
|
|
|
|
|
|
|
conf2 := nextConfig()
|
|
|
|
tmpDir, err := ioutil.TempDir("", "consul")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
defer os.RemoveAll(tmpDir)
|
|
|
|
|
|
|
|
doneCh := make(chan struct{})
|
|
|
|
shutdownCh := make(chan struct{})
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
close(shutdownCh)
|
|
|
|
<-doneCh
|
|
|
|
}()
|
|
|
|
|
|
|
|
cmd := &Command{
|
|
|
|
ShutdownCh: shutdownCh,
|
|
|
|
Ui: new(cli.MockUi),
|
|
|
|
}
|
|
|
|
|
|
|
|
serfAddr := fmt.Sprintf(
|
|
|
|
"%s:%d",
|
|
|
|
agent.config.BindAddr,
|
|
|
|
agent.config.Ports.SerfLan)
|
|
|
|
|
2014-11-19 13:53:17 -08:00
|
|
|
serfWanAddr := fmt.Sprintf(
|
|
|
|
"%s:%d",
|
|
|
|
agent.config.BindAddr,
|
|
|
|
agent.config.Ports.SerfWan)
|
|
|
|
|
2014-10-12 12:27:03 -07:00
|
|
|
args := []string{
|
2014-11-19 13:53:17 -08:00
|
|
|
"-server",
|
2014-10-12 12:27:03 -07:00
|
|
|
"-data-dir", tmpDir,
|
2014-10-14 17:49:17 -07:00
|
|
|
"-node", fmt.Sprintf(`"%s"`, conf2.NodeName),
|
2014-10-12 12:27:03 -07:00
|
|
|
"-retry-join", serfAddr,
|
|
|
|
"-retry-interval", "1s",
|
2014-11-19 13:53:17 -08:00
|
|
|
"-retry-join-wan", serfWanAddr,
|
|
|
|
"-retry-interval-wan", "1s",
|
2014-10-12 12:27:03 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
if code := cmd.Run(args); code != 0 {
|
|
|
|
log.Printf("bad: %d", code)
|
|
|
|
}
|
|
|
|
close(doneCh)
|
|
|
|
}()
|
|
|
|
|
|
|
|
testutil.WaitForResult(func() (bool, error) {
|
|
|
|
mem := agent.LANMembers()
|
|
|
|
if len(mem) != 2 {
|
|
|
|
return false, fmt.Errorf("bad: %#v", mem)
|
|
|
|
}
|
2014-11-19 13:53:17 -08:00
|
|
|
mem = agent.WANMembers()
|
|
|
|
if len(mem) != 2 {
|
|
|
|
return false, fmt.Errorf("bad (wan): %#v", mem)
|
|
|
|
}
|
2014-10-12 12:27:03 -07:00
|
|
|
return true, nil
|
|
|
|
}, func(err error) {
|
|
|
|
t.Fatalf(err.Error())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRetryJoinFail(t *testing.T) {
|
|
|
|
conf := nextConfig()
|
|
|
|
tmpDir, err := ioutil.TempDir("", "consul")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
defer os.RemoveAll(tmpDir)
|
|
|
|
|
|
|
|
shutdownCh := make(chan struct{})
|
|
|
|
defer close(shutdownCh)
|
|
|
|
|
|
|
|
cmd := &Command{
|
|
|
|
ShutdownCh: shutdownCh,
|
|
|
|
Ui: new(cli.MockUi),
|
|
|
|
}
|
|
|
|
|
|
|
|
serfAddr := fmt.Sprintf("%s:%d", conf.BindAddr, conf.Ports.SerfLan)
|
|
|
|
|
|
|
|
args := []string{
|
|
|
|
"-data-dir", tmpDir,
|
|
|
|
"-retry-join", serfAddr,
|
|
|
|
"-retry-max", "1",
|
|
|
|
}
|
|
|
|
|
|
|
|
if code := cmd.Run(args); code == 0 {
|
|
|
|
t.Fatalf("bad: %d", code)
|
|
|
|
}
|
|
|
|
}
|
2014-11-14 10:02:42 -05:00
|
|
|
|
2014-11-17 17:14:59 -05:00
|
|
|
func TestRetryJoinWanFail(t *testing.T) {
|
2014-11-14 10:02:42 -05:00
|
|
|
conf := nextConfig()
|
|
|
|
tmpDir, err := ioutil.TempDir("", "consul")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
defer os.RemoveAll(tmpDir)
|
|
|
|
|
|
|
|
shutdownCh := make(chan struct{})
|
|
|
|
defer close(shutdownCh)
|
|
|
|
|
|
|
|
cmd := &Command{
|
|
|
|
ShutdownCh: shutdownCh,
|
|
|
|
Ui: new(cli.MockUi),
|
|
|
|
}
|
|
|
|
|
|
|
|
serfAddr := fmt.Sprintf("%s:%d", conf.BindAddr, conf.Ports.SerfWan)
|
|
|
|
|
|
|
|
args := []string{
|
2014-11-19 13:53:17 -08:00
|
|
|
"-server",
|
2014-11-14 10:02:42 -05:00
|
|
|
"-data-dir", tmpDir,
|
2014-11-17 17:14:59 -05:00
|
|
|
"-retry-join-wan", serfAddr,
|
2014-11-19 13:53:17 -08:00
|
|
|
"-retry-max-wan", "1",
|
2014-11-14 10:02:42 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if code := cmd.Run(args); code == 0 {
|
|
|
|
t.Fatalf("bad: %d", code)
|
|
|
|
}
|
|
|
|
}
|
2015-01-19 09:54:12 -08:00
|
|
|
|
|
|
|
func TestSetupAgent_UnixSocket_Fails(t *testing.T) {
|
|
|
|
conf := nextConfig()
|
|
|
|
tmpDir, err := ioutil.TempDir("", "consul")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
defer os.RemoveAll(tmpDir)
|
|
|
|
|
|
|
|
tmpFile, err := ioutil.TempFile("", "consul")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
defer os.Remove(tmpFile.Name())
|
|
|
|
socketPath := tmpFile.Name()
|
|
|
|
|
|
|
|
conf.DataDir = tmpDir
|
|
|
|
conf.Server = true
|
|
|
|
conf.Bootstrap = true
|
|
|
|
|
|
|
|
// Set socket address to an existing file. Consul should fail to
|
|
|
|
// start and return an error.
|
|
|
|
conf.Addresses.RPC = "unix://" + socketPath
|
|
|
|
|
|
|
|
shutdownCh := make(chan struct{})
|
|
|
|
defer close(shutdownCh)
|
|
|
|
|
|
|
|
cmd := &Command{
|
|
|
|
ShutdownCh: shutdownCh,
|
|
|
|
Ui: new(cli.MockUi),
|
|
|
|
}
|
|
|
|
|
|
|
|
logWriter := NewLogWriter(512)
|
|
|
|
logOutput := new(bytes.Buffer)
|
|
|
|
|
|
|
|
// Ensure we got an error mentioning the socket file
|
|
|
|
err = cmd.setupAgent(conf, logOutput, logWriter)
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("should have failed")
|
|
|
|
}
|
|
|
|
if !strings.Contains(err.Error(), socketPath) {
|
|
|
|
t.Fatalf("expected socket file error, got: %q", err)
|
|
|
|
}
|
|
|
|
}
|