consul/command/util_test.go

155 lines
3.6 KiB
Go
Raw Normal View History

2013-12-31 13:06:33 -08:00
package command
import (
"fmt"
"io"
"io/ioutil"
"math/rand"
"net"
"os"
2016-09-26 10:10:58 -05:00
"strings"
2013-12-31 13:06:33 -08:00
"sync/atomic"
"testing"
"time"
"github.com/hashicorp/consul/api"
"github.com/hashicorp/consul/command/agent"
"github.com/hashicorp/consul/consul"
"github.com/hashicorp/consul/logger"
2016-09-26 10:10:58 -05:00
"github.com/mitchellh/cli"
2013-12-31 13:06:33 -08:00
)
var offset uint64
func init() {
// Seed the random number generator
rand.Seed(time.Now().UnixNano())
}
type agentWrapper struct {
2014-08-21 16:08:21 -07:00
dir string
config *agent.Config
agent *agent.Agent
rpc *agent.AgentRPC
http *agent.HTTPServer
addr string
httpAddr string
2013-12-31 13:06:33 -08:00
}
func (a *agentWrapper) Shutdown() {
a.rpc.Shutdown()
a.agent.Shutdown()
2014-08-21 16:08:21 -07:00
a.http.Shutdown()
2013-12-31 13:06:33 -08:00
os.RemoveAll(a.dir)
}
func testAgent(t *testing.T) *agentWrapper {
return testAgentWithConfig(t, nil)
2014-09-10 08:49:16 -07:00
}
func testAgentWithAPIClient(t *testing.T) (*agentWrapper, *api.Client) {
agent := testAgentWithConfig(t, func(c *agent.Config) {})
client, err := api.NewClient(&api.Config{Address: agent.httpAddr})
if err != nil {
t.Fatalf("consul client: %#v", err)
}
return agent, client
}
func testAgentWithConfig(t *testing.T, cb func(c *agent.Config)) *agentWrapper {
return testAgentWithConfigReload(t, cb, nil)
}
func testAgentWithConfigReload(t *testing.T, cb func(c *agent.Config), reloadCh chan chan error) *agentWrapper {
2013-12-31 13:06:33 -08:00
l, err := net.Listen("tcp", "127.0.0.1:0")
if err != nil {
t.Fatalf("err: %s", err)
}
lw := logger.NewLogWriter(512)
2013-12-31 13:06:33 -08:00
mult := io.MultiWriter(os.Stderr, lw)
conf := nextConfig()
if cb != nil {
cb(conf)
}
2013-12-31 13:06:33 -08:00
dir, err := ioutil.TempDir("", "agent")
if err != nil {
t.Fatalf(fmt.Sprintf("err: %v", err))
}
conf.DataDir = dir
a, err := agent.Create(conf, lw, nil, reloadCh)
2013-12-31 13:06:33 -08:00
if err != nil {
os.RemoveAll(dir)
t.Fatalf(fmt.Sprintf("err: %v", err))
}
rpc := agent.NewAgentRPC(a, l, mult, lw)
2014-08-21 16:08:21 -07:00
conf.Addresses.HTTP = "127.0.0.1"
2014-08-21 16:08:21 -07:00
httpAddr := fmt.Sprintf("127.0.0.1:%d", conf.Ports.HTTP)
http, err := agent.NewHTTPServers(a, conf, os.Stderr)
2014-08-21 16:08:21 -07:00
if err != nil {
os.RemoveAll(dir)
t.Fatalf(fmt.Sprintf("err: %v", err))
}
if http == nil || len(http) == 0 {
os.RemoveAll(dir)
t.Fatalf(fmt.Sprintf("Could not create HTTP server to listen on: %s", httpAddr))
}
2013-12-31 13:06:33 -08:00
return &agentWrapper{
2014-08-21 16:08:21 -07:00
dir: dir,
config: conf,
agent: a,
rpc: rpc,
http: http[0],
2014-08-21 16:08:21 -07:00
addr: l.Addr().String(),
httpAddr: httpAddr,
2013-12-31 13:06:33 -08:00
}
}
func nextConfig() *agent.Config {
2014-04-11 16:34:29 -07:00
idx := int(atomic.AddUint64(&offset, 1))
2013-12-31 13:06:33 -08:00
conf := agent.DefaultConfig()
conf.Bootstrap = true
conf.Datacenter = "dc1"
conf.NodeName = fmt.Sprintf("Node %d", idx)
2014-04-11 16:34:29 -07:00
conf.BindAddr = "127.0.0.1"
2013-12-31 13:06:33 -08:00
conf.Server = true
2014-04-11 16:34:29 -07:00
conf.Ports.HTTP = 10000 + 10*idx
conf.Ports.HTTPS = 10401 + 10*idx
2014-04-11 16:34:29 -07:00
conf.Ports.RPC = 10100 + 10*idx
conf.Ports.SerfLan = 10201 + 10*idx
conf.Ports.SerfWan = 10202 + 10*idx
conf.Ports.Server = 10300 + 10*idx
2013-12-31 13:06:33 -08:00
cons := consul.DefaultConfig()
conf.ConsulConfig = cons
cons.SerfLANConfig.MemberlistConfig.ProbeTimeout = 100 * time.Millisecond
cons.SerfLANConfig.MemberlistConfig.ProbeInterval = 100 * time.Millisecond
cons.SerfLANConfig.MemberlistConfig.GossipInterval = 100 * time.Millisecond
cons.SerfWANConfig.MemberlistConfig.ProbeTimeout = 100 * time.Millisecond
cons.SerfWANConfig.MemberlistConfig.ProbeInterval = 100 * time.Millisecond
cons.SerfWANConfig.MemberlistConfig.GossipInterval = 100 * time.Millisecond
cons.RaftConfig.LeaderLeaseTimeout = 20 * time.Millisecond
2013-12-31 13:06:33 -08:00
cons.RaftConfig.HeartbeatTimeout = 40 * time.Millisecond
cons.RaftConfig.ElectionTimeout = 40 * time.Millisecond
return conf
}
2016-09-26 10:10:58 -05:00
func assertNoTabs(t *testing.T, c cli.Command) {
if strings.ContainsRune(c.Help(), '\t') {
t.Errorf("%#v help output contains tabs", c)
}
}