2016-10-07 15:06:01 +00:00
|
|
|
// +build !race
|
|
|
|
|
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/vault/meta"
|
2017-08-03 17:24:27 +00:00
|
|
|
"github.com/hashicorp/vault/physical"
|
2016-10-07 15:06:01 +00:00
|
|
|
"github.com/mitchellh/cli"
|
2017-08-03 17:24:27 +00:00
|
|
|
|
|
|
|
physConsul "github.com/hashicorp/vault/physical/consul"
|
2016-10-07 15:06:01 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// The following tests have a go-metrics/exp manager race condition
|
|
|
|
func TestServer_CommonHA(t *testing.T) {
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &ServerCommand{
|
|
|
|
Meta: meta.Meta{
|
|
|
|
Ui: ui,
|
|
|
|
},
|
2017-08-03 17:24:27 +00:00
|
|
|
PhysicalBackends: map[string]physical.Factory{
|
|
|
|
"consul": physConsul.NewConsulBackend,
|
|
|
|
},
|
2016-10-07 15:06:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpfile, err := ioutil.TempFile("", "")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("error creating temp dir: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpfile.WriteString(basehcl + consulhcl)
|
|
|
|
tmpfile.Close()
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
|
|
|
args := []string{"-config", tmpfile.Name(), "-verify-only", "true"}
|
|
|
|
|
|
|
|
if code := c.Run(args); code != 0 {
|
2017-02-16 21:29:30 +00:00
|
|
|
t.Fatalf("bad: %d\n\n%s\n\n%s", code, ui.ErrorWriter.String(), ui.OutputWriter.String())
|
2016-10-07 15:06:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if !strings.Contains(ui.OutputWriter.String(), "(HA available)") {
|
|
|
|
t.Fatalf("did not find HA available: %s", ui.OutputWriter.String())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_GoodSeparateHA(t *testing.T) {
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &ServerCommand{
|
|
|
|
Meta: meta.Meta{
|
|
|
|
Ui: ui,
|
|
|
|
},
|
2017-08-03 17:24:27 +00:00
|
|
|
PhysicalBackends: map[string]physical.Factory{
|
|
|
|
"consul": physConsul.NewConsulBackend,
|
|
|
|
},
|
2016-10-07 15:06:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpfile, err := ioutil.TempFile("", "")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("error creating temp dir: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpfile.WriteString(basehcl + consulhcl + haconsulhcl)
|
|
|
|
tmpfile.Close()
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
|
|
|
args := []string{"-config", tmpfile.Name(), "-verify-only", "true"}
|
|
|
|
|
|
|
|
if code := c.Run(args); code != 0 {
|
2017-02-16 21:29:30 +00:00
|
|
|
t.Fatalf("bad: %d\n\n%s\n\n%s", code, ui.ErrorWriter.String(), ui.OutputWriter.String())
|
2016-10-07 15:06:01 +00:00
|
|
|
}
|
|
|
|
|
2017-03-08 14:17:00 +00:00
|
|
|
if !strings.Contains(ui.OutputWriter.String(), "HA Storage:") {
|
|
|
|
t.Fatalf("did not find HA Storage: %s", ui.OutputWriter.String())
|
2016-10-07 15:06:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_BadSeparateHA(t *testing.T) {
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &ServerCommand{
|
|
|
|
Meta: meta.Meta{
|
|
|
|
Ui: ui,
|
|
|
|
},
|
2017-08-03 17:24:27 +00:00
|
|
|
PhysicalBackends: map[string]physical.Factory{
|
|
|
|
"consul": physConsul.NewConsulBackend,
|
|
|
|
},
|
2016-10-07 15:06:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpfile, err := ioutil.TempFile("", "")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("error creating temp dir: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpfile.WriteString(basehcl + consulhcl + badhaconsulhcl)
|
|
|
|
tmpfile.Close()
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
|
|
|
args := []string{"-config", tmpfile.Name()}
|
|
|
|
|
|
|
|
if code := c.Run(args); code == 0 {
|
|
|
|
t.Fatalf("bad: should have gotten an error on a bad HA config")
|
|
|
|
}
|
|
|
|
}
|