mirror of
https://github.com/status-im/consul.git
synced 2025-01-15 16:26:06 +00:00
rpc: bind rpc test server to port 0
This commit is contained in:
parent
e9e2c599db
commit
53eab7e970
@ -85,6 +85,11 @@ type Config struct {
|
|||||||
// as a voting member of the Raft cluster.
|
// as a voting member of the Raft cluster.
|
||||||
NonVoter bool
|
NonVoter bool
|
||||||
|
|
||||||
|
// NotifyListen is called after the RPC listener has been configured.
|
||||||
|
// RPCAdvertise will be set to the listener address if it hasn't been
|
||||||
|
// configured at this point.
|
||||||
|
NotifyListen func()
|
||||||
|
|
||||||
// RPCAddr is the RPC address used by Consul. This should be reachable
|
// RPCAddr is the RPC address used by Consul. This should be reachable
|
||||||
// by the WAN and LAN
|
// by the WAN and LAN
|
||||||
RPCAddr *net.TCPAddr
|
RPCAddr *net.TCPAddr
|
||||||
@ -92,7 +97,8 @@ type Config struct {
|
|||||||
// RPCAdvertise is the address that is advertised to other nodes for
|
// RPCAdvertise is the address that is advertised to other nodes for
|
||||||
// the RPC endpoint. This can differ from the RPC address, if for example
|
// the RPC endpoint. This can differ from the RPC address, if for example
|
||||||
// the RPCAddr is unspecified "0.0.0.0:8300", but this address must be
|
// the RPCAddr is unspecified "0.0.0.0:8300", but this address must be
|
||||||
// reachable
|
// reachable. If RPCAdvertise is nil then it will be set to the Listener
|
||||||
|
// address after the listening socket is configured.
|
||||||
RPCAdvertise *net.TCPAddr
|
RPCAdvertise *net.TCPAddr
|
||||||
|
|
||||||
// RPCSrcAddr is the source address for outgoing RPC connections.
|
// RPCSrcAddr is the source address for outgoing RPC connections.
|
||||||
|
@ -49,7 +49,7 @@ const (
|
|||||||
func (s *Server) listen() {
|
func (s *Server) listen() {
|
||||||
for {
|
for {
|
||||||
// Accept a connection
|
// Accept a connection
|
||||||
conn, err := s.rpcListener.Accept()
|
conn, err := s.Listener.Accept()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if s.shutdown {
|
if s.shutdown {
|
||||||
return
|
return
|
||||||
|
@ -150,9 +150,9 @@ type Server struct {
|
|||||||
// Enterprise user-defined areas.
|
// Enterprise user-defined areas.
|
||||||
router *servers.Router
|
router *servers.Router
|
||||||
|
|
||||||
// rpcListener is used to listen for incoming connections
|
// Listener is used to listen for incoming connections
|
||||||
rpcListener net.Listener
|
Listener net.Listener
|
||||||
rpcServer *rpc.Server
|
rpcServer *rpc.Server
|
||||||
|
|
||||||
// rpcTLS is the TLS config for incoming TLS requests
|
// rpcTLS is the TLS config for incoming TLS requests
|
||||||
rpcTLS *tls.Config
|
rpcTLS *tls.Config
|
||||||
@ -392,7 +392,7 @@ func NewServerLogger(config *Config, logger *log.Logger) (*Server, error) {
|
|||||||
|
|
||||||
// setupSerf is used to setup and initialize a Serf
|
// setupSerf is used to setup and initialize a Serf
|
||||||
func (s *Server) setupSerf(conf *serf.Config, ch chan serf.Event, path string, wan bool) (*serf.Serf, error) {
|
func (s *Server) setupSerf(conf *serf.Config, ch chan serf.Event, path string, wan bool) (*serf.Serf, error) {
|
||||||
addr := s.rpcListener.Addr().(*net.TCPAddr)
|
addr := s.Listener.Addr().(*net.TCPAddr)
|
||||||
conf.Init()
|
conf.Init()
|
||||||
if wan {
|
if wan {
|
||||||
conf.NodeName = fmt.Sprintf("%s.%s", s.config.NodeName, s.config.Datacenter)
|
conf.NodeName = fmt.Sprintf("%s.%s", s.config.NodeName, s.config.Datacenter)
|
||||||
@ -645,7 +645,14 @@ func (s *Server) setupRPC(tlsWrap tlsutil.DCWrapper) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
s.rpcListener = ln
|
s.Listener = ln
|
||||||
|
if s.config.NotifyListen != nil {
|
||||||
|
s.config.NotifyListen()
|
||||||
|
}
|
||||||
|
// todo(fs): we should probably guard this
|
||||||
|
if s.config.RPCAdvertise == nil {
|
||||||
|
s.config.RPCAdvertise = ln.Addr().(*net.TCPAddr)
|
||||||
|
}
|
||||||
|
|
||||||
// Verify that we have a usable advertise address
|
// Verify that we have a usable advertise address
|
||||||
if s.config.RPCAdvertise.IP.IsUnspecified() {
|
if s.config.RPCAdvertise.IP.IsUnspecified() {
|
||||||
@ -714,8 +721,8 @@ func (s *Server) Shutdown() error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if s.rpcListener != nil {
|
if s.Listener != nil {
|
||||||
s.rpcListener.Close()
|
s.Listener.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close the connection pool
|
// Close the connection pool
|
||||||
|
@ -35,25 +35,30 @@ func testServerConfig(t *testing.T, NodeName string) (string, *Config) {
|
|||||||
config.Bootstrap = true
|
config.Bootstrap = true
|
||||||
config.Datacenter = "dc1"
|
config.Datacenter = "dc1"
|
||||||
config.DataDir = dir
|
config.DataDir = dir
|
||||||
config.RPCAddr = &net.TCPAddr{
|
|
||||||
IP: []byte{127, 0, 0, 1},
|
// bind the rpc server to a random port. config.RPCAdvertise will be
|
||||||
Port: getPort(),
|
// set to the listen address unless it was set in the configuration.
|
||||||
}
|
// In that case get the address from srv.Listener.Addr().
|
||||||
config.RPCAdvertise = config.RPCAddr
|
config.RPCAddr = &net.TCPAddr{IP: []byte{127, 0, 0, 1}}
|
||||||
|
|
||||||
nodeID, err := uuid.GenerateUUID()
|
nodeID, err := uuid.GenerateUUID()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
config.NodeID = types.NodeID(nodeID)
|
config.NodeID = types.NodeID(nodeID)
|
||||||
|
|
||||||
|
// set the memberlist bind port to 0 to bind to a random port.
|
||||||
|
// memberlist will update the value of BindPort after bind
|
||||||
|
// to the actual value.
|
||||||
config.SerfLANConfig.MemberlistConfig.BindAddr = "127.0.0.1"
|
config.SerfLANConfig.MemberlistConfig.BindAddr = "127.0.0.1"
|
||||||
config.SerfLANConfig.MemberlistConfig.BindPort = getPort()
|
config.SerfLANConfig.MemberlistConfig.BindPort = 0
|
||||||
config.SerfLANConfig.MemberlistConfig.SuspicionMult = 2
|
config.SerfLANConfig.MemberlistConfig.SuspicionMult = 2
|
||||||
config.SerfLANConfig.MemberlistConfig.ProbeTimeout = 50 * time.Millisecond
|
config.SerfLANConfig.MemberlistConfig.ProbeTimeout = 50 * time.Millisecond
|
||||||
config.SerfLANConfig.MemberlistConfig.ProbeInterval = 100 * time.Millisecond
|
config.SerfLANConfig.MemberlistConfig.ProbeInterval = 100 * time.Millisecond
|
||||||
config.SerfLANConfig.MemberlistConfig.GossipInterval = 100 * time.Millisecond
|
config.SerfLANConfig.MemberlistConfig.GossipInterval = 100 * time.Millisecond
|
||||||
|
|
||||||
config.SerfWANConfig.MemberlistConfig.BindAddr = "127.0.0.1"
|
config.SerfWANConfig.MemberlistConfig.BindAddr = "127.0.0.1"
|
||||||
config.SerfWANConfig.MemberlistConfig.BindPort = getPort()
|
config.SerfWANConfig.MemberlistConfig.BindPort = 0
|
||||||
config.SerfWANConfig.MemberlistConfig.SuspicionMult = 2
|
config.SerfWANConfig.MemberlistConfig.SuspicionMult = 2
|
||||||
config.SerfWANConfig.MemberlistConfig.ProbeTimeout = 50 * time.Millisecond
|
config.SerfWANConfig.MemberlistConfig.ProbeTimeout = 50 * time.Millisecond
|
||||||
config.SerfWANConfig.MemberlistConfig.ProbeInterval = 100 * time.Millisecond
|
config.SerfWANConfig.MemberlistConfig.ProbeInterval = 100 * time.Millisecond
|
||||||
@ -107,14 +112,50 @@ func testServerDCExpect(t *testing.T, dc string, expect int) (string, *Server) {
|
|||||||
func testServerWithConfig(t *testing.T, cb func(c *Config)) (string, *Server) {
|
func testServerWithConfig(t *testing.T, cb func(c *Config)) (string, *Server) {
|
||||||
name := fmt.Sprintf("Node %d", getPort())
|
name := fmt.Sprintf("Node %d", getPort())
|
||||||
dir, config := testServerConfig(t, name)
|
dir, config := testServerConfig(t, name)
|
||||||
cb(config)
|
if cb != nil {
|
||||||
server, err := NewServer(config)
|
cb(config)
|
||||||
|
}
|
||||||
|
server, err := newServer(config)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
return dir, server
|
return dir, server
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newServer(c *Config) (*Server, error) {
|
||||||
|
// chain server up notification
|
||||||
|
oldNotify := c.NotifyListen
|
||||||
|
up := make(chan struct{})
|
||||||
|
c.NotifyListen = func() {
|
||||||
|
close(up)
|
||||||
|
if oldNotify != nil {
|
||||||
|
oldNotify()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// start server
|
||||||
|
srv, err := NewServer(c)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// wait until after listen
|
||||||
|
<-up
|
||||||
|
|
||||||
|
// get the real address
|
||||||
|
//
|
||||||
|
// the server already sets the RPCAdvertise address
|
||||||
|
// if it wasn't configured since it needs it for
|
||||||
|
// some initialization
|
||||||
|
//
|
||||||
|
// todo(fs): setting RPCAddr should probably be guarded
|
||||||
|
// todo(fs): but for now it is a shortcut to avoid fixing
|
||||||
|
// todo(fs): tests which depend on that value. They should
|
||||||
|
// todo(fs): just get the listener address instead.
|
||||||
|
c.RPCAddr = srv.Listener.Addr().(*net.TCPAddr)
|
||||||
|
return srv, nil
|
||||||
|
}
|
||||||
|
|
||||||
func TestServer_StartStop(t *testing.T) {
|
func TestServer_StartStop(t *testing.T) {
|
||||||
// Start up a server and then stop it.
|
// Start up a server and then stop it.
|
||||||
dir1, s1 := testServer(t)
|
dir1, s1 := testServer(t)
|
||||||
@ -381,7 +422,7 @@ func TestServer_JoinLAN_TLS(t *testing.T) {
|
|||||||
conf1.VerifyIncoming = true
|
conf1.VerifyIncoming = true
|
||||||
conf1.VerifyOutgoing = true
|
conf1.VerifyOutgoing = true
|
||||||
configureTLS(conf1)
|
configureTLS(conf1)
|
||||||
s1, err := NewServer(conf1)
|
s1, err := newServer(conf1)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
@ -393,7 +434,7 @@ func TestServer_JoinLAN_TLS(t *testing.T) {
|
|||||||
conf2.VerifyIncoming = true
|
conf2.VerifyIncoming = true
|
||||||
conf2.VerifyOutgoing = true
|
conf2.VerifyOutgoing = true
|
||||||
configureTLS(conf2)
|
configureTLS(conf2)
|
||||||
s2, err := NewServer(conf2)
|
s2, err := newServer(conf2)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -13,7 +13,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func rpcClient(t *testing.T, s *Server) rpc.ClientCodec {
|
func rpcClient(t *testing.T, s *Server) rpc.ClientCodec {
|
||||||
addr := s.config.RPCAddr
|
addr := s.config.RPCAdvertise
|
||||||
conn, err := net.DialTimeout("tcp", addr.String(), time.Second)
|
conn, err := net.DialTimeout("tcp", addr.String(), time.Second)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user