mirror of
https://github.com/kemko/nomad.git
synced 2026-01-06 10:25:42 +03:00
add go-discover
This commit is contained in:
@@ -2,6 +2,7 @@ package agent
|
||||
|
||||
import (
|
||||
"log"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
@@ -33,7 +34,21 @@ func (r *retryJoiner) RetryJoin(config *Config) {
|
||||
r.logger.Printf("[INFO] agent: Joining cluster...")
|
||||
|
||||
for {
|
||||
addrs := config.Server.RetryJoin
|
||||
var addrs []string
|
||||
|
||||
for _, addr := range config.Server.RetryJoin {
|
||||
switch {
|
||||
case strings.Contains(addr, "provider"):
|
||||
servers, err := r.discover.Addrs(addr, r.logger)
|
||||
if err != nil {
|
||||
r.logger.Printf("[ERR] agent: Join error %s", err)
|
||||
} else {
|
||||
addrs = append(addrs, servers...)
|
||||
}
|
||||
default:
|
||||
addrs = append(addrs, addr)
|
||||
}
|
||||
}
|
||||
|
||||
n, err := r.join(addrs)
|
||||
if err == nil {
|
||||
|
||||
@@ -5,7 +5,6 @@ import (
|
||||
"io/ioutil"
|
||||
"log"
|
||||
"os"
|
||||
"strings"
|
||||
"testing"
|
||||
|
||||
"github.com/hashicorp/nomad/testutil"
|
||||
@@ -67,14 +66,14 @@ func TestRetryJoin_Integration(t *testing.T) {
|
||||
type MockDiscover struct{}
|
||||
|
||||
func (m *MockDiscover) Addrs(s string, l *log.Logger) ([]string, error) {
|
||||
return strings.Split(s, " "), nil
|
||||
return []string{s}, nil
|
||||
}
|
||||
func (m *MockDiscover) Help() string { return "" }
|
||||
func (m *MockDiscover) Names() []string {
|
||||
return []string{""}
|
||||
}
|
||||
|
||||
func TestRetryJoin_Unit(t *testing.T) {
|
||||
func TestRetryJoin_NonCloud(t *testing.T) {
|
||||
t.Parallel()
|
||||
require := require.New(t)
|
||||
|
||||
@@ -105,3 +104,68 @@ func TestRetryJoin_Unit(t *testing.T) {
|
||||
require.Equal(1, len(output))
|
||||
require.Equal("127.0.0.1", output[0])
|
||||
}
|
||||
|
||||
func TestRetryJoin_Cloud(t *testing.T) {
|
||||
t.Parallel()
|
||||
require := require.New(t)
|
||||
|
||||
newConfig := &Config{
|
||||
Server: &ServerConfig{
|
||||
RetryMaxAttempts: 1,
|
||||
RetryJoin: []string{"provider=aws, tag_value=foo"},
|
||||
Enabled: true,
|
||||
},
|
||||
}
|
||||
|
||||
var output []string
|
||||
|
||||
mockJoin := func(s []string) (int, error) {
|
||||
output = s
|
||||
return 0, nil
|
||||
}
|
||||
|
||||
joiner := retryJoiner{
|
||||
discover: &MockDiscover{},
|
||||
join: mockJoin,
|
||||
logger: log.New(ioutil.Discard, "", 0),
|
||||
errCh: make(chan struct{}),
|
||||
}
|
||||
|
||||
joiner.RetryJoin(newConfig)
|
||||
|
||||
require.Equal(1, len(output))
|
||||
require.Equal("provider=aws, tag_value=foo", output[0])
|
||||
}
|
||||
|
||||
func TestRetryJoin_MixedProvider(t *testing.T) {
|
||||
t.Parallel()
|
||||
require := require.New(t)
|
||||
|
||||
newConfig := &Config{
|
||||
Server: &ServerConfig{
|
||||
RetryMaxAttempts: 1,
|
||||
RetryJoin: []string{"provider=aws, tag_value=foo", "127.0.0.1"},
|
||||
Enabled: true,
|
||||
},
|
||||
}
|
||||
|
||||
var output []string
|
||||
|
||||
mockJoin := func(s []string) (int, error) {
|
||||
output = s
|
||||
return 0, nil
|
||||
}
|
||||
|
||||
joiner := retryJoiner{
|
||||
discover: &MockDiscover{},
|
||||
join: mockJoin,
|
||||
logger: log.New(ioutil.Discard, "", 0),
|
||||
errCh: make(chan struct{}),
|
||||
}
|
||||
|
||||
joiner.RetryJoin(newConfig)
|
||||
|
||||
require.Equal(2, len(output))
|
||||
require.Equal("provider=aws, tag_value=foo", output[0])
|
||||
require.Equal("127.0.0.1", output[1])
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user