Skip to content

Commit

Permalink
Merge pull request #5818 from hashicorp/b-consul-stanza
Browse files Browse the repository at this point in the history
fix consul stanza parsing when multiple -config arguments are used
  • Loading branch information
Mahmood Ali authored Jun 12, 2019
2 parents b4ff3d9 + 8b49c5e commit ee7803d
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 30 deletions.
15 changes: 5 additions & 10 deletions command/agent/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -1471,30 +1471,25 @@ func (r *Resources) Merge(b *Resources) *Resources {
return &result
}

// LoadConfig loads the configuration at the given path, regardless if
// its a file or directory.
// LoadConfig loads the configuration at the given path, regardless if its a file or
// directory. Called for each -config to build up the runtime config value. Do not apply any
// default values, defaults should be added once in DefaultConfig
func LoadConfig(path string) (*Config, error) {
fi, err := os.Stat(path)
if err != nil {
return nil, err
}

defaults := ParseConfigDefault()

if fi.IsDir() {
config, err := LoadConfigDir(path)
if err != nil {
return nil, err
}
return defaults.Merge(config), nil
return LoadConfigDir(path)
}

cleaned := filepath.Clean(path)
config, err := ParseConfigFile(cleaned)
if err != nil {
return nil, fmt.Errorf("Error loading %s: %s", cleaned, err)
}
config = defaults.Merge(config)

config.Files = append(config.Files, cleaned)
return config, nil
}
Expand Down
9 changes: 0 additions & 9 deletions command/agent/config_parse.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,15 +14,6 @@ import (
"github.com/hashicorp/nomad/nomad/structs/config"
)

// ParseConfigDefault returns the configuration base
func ParseConfigDefault() *Config {
return &Config{
Consul: config.DefaultConsulConfig(),
Autopilot: config.DefaultAutopilotConfig(),
Vault: config.DefaultVaultConfig(),
}
}

func ParseConfigFile(path string) (*Config, error) {
// slurp
var buf bytes.Buffer
Expand Down
84 changes: 73 additions & 11 deletions command/agent/config_parse_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -411,8 +411,16 @@ func TestConfig_Parse(t *testing.T) {
t.Fatalf("file: %s\n\n%s", tc.File, err)
}

// Merge defaults like LoadConfig does
actual = ParseConfigDefault().Merge(actual)
// ParseConfig used to re-merge defaults for these three objects,
// despite them already being merged in LoadConfig. The test structs
// expect these defaults to be set, but not the DefaultConfig
// defaults, which include additional settings
oldDefault := &Config{
Consul: config.DefaultConsulConfig(),
Vault: config.DefaultVaultConfig(),
Autopilot: config.DefaultAutopilotConfig(),
}
actual = oldDefault.Merge(actual)

//panic(fmt.Sprintf("first: %+v \n second: %+v", actual.TLSConfig, tc.Result.TLSConfig))
require.EqualValues(tc.Result, removeHelperAttributes(actual))
Expand Down Expand Up @@ -576,15 +584,70 @@ func TestConfig_ParseSample0(t *testing.T) {
require.EqualValues(t, sample0, c)
}

var sample1 = &Config{
Region: "global",
Datacenter: "dc1",
DataDir: "/opt/data/nomad/data",
LogLevel: "INFO",
BindAddr: "0.0.0.0",
AdvertiseAddrs: &AdvertiseAddrs{
HTTP: "host.example.com",
RPC: "host.example.com",
Serf: "host.example.com",
},
Client: &ClientConfig{ServerJoin: &ServerJoin{}},
Server: &ServerConfig{
Enabled: true,
BootstrapExpect: 3,
RetryJoin: []string{"10.0.0.101", "10.0.0.102", "10.0.0.103"},
EncryptKey: "sHck3WL6cxuhuY7Mso9BHA==",
ServerJoin: &ServerJoin{},
},
ACL: &ACLConfig{
Enabled: true,
},
Telemetry: &Telemetry{
PrometheusMetrics: true,
DisableHostname: true,
CollectionInterval: "60s",
collectionInterval: 60 * time.Second,
PublishAllocationMetrics: true,
PublishNodeMetrics: true,
},
LeaveOnInt: true,
LeaveOnTerm: true,
EnableSyslog: true,
SyslogFacility: "LOCAL0",
Consul: &config.ConsulConfig{
EnableSSL: helper.BoolToPtr(true),
Token: "aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee",
ServerAutoJoin: helper.BoolToPtr(false),
ClientAutoJoin: helper.BoolToPtr(false),
},
Vault: &config.VaultConfig{
Enabled: helper.BoolToPtr(true),
Role: "nomad-cluster",
Addr: "http://host.example.com:8200",
},
TLSConfig: &config.TLSConfig{
EnableHTTP: true,
EnableRPC: true,
VerifyServerHostname: true,
CAFile: "/opt/data/nomad/certs/nomad-ca.pem",
CertFile: "/opt/data/nomad/certs/server.pem",
KeyFile: "/opt/data/nomad/certs/server-key.pem",
},
Autopilot: &config.AutopilotConfig{
CleanupDeadServers: helper.BoolToPtr(true),
},
}

func TestConfig_ParseDir(t *testing.T) {
c, err := LoadConfig("./testdata/sample1")
require.NoError(t, err)

// Defaults
sample1 := ParseConfigDefault().Merge(sample0)

// Merge makes empty maps & slices rather than nil, so set those for the expected
// value
// LoadConfig Merges all the config files in testdata/sample1, which makes empty
// maps & slices rather than nil, so set those
require.Nil(t, sample1.Client.Options)
sample1.Client.Options = map[string]string{}
require.Nil(t, sample1.Client.Meta)
Expand All @@ -593,11 +656,10 @@ func TestConfig_ParseDir(t *testing.T) {
sample1.Client.ChrootEnv = map[string]string{}
require.Nil(t, sample1.Server.StartJoin)
sample1.Server.StartJoin = []string{}
require.Nil(t, sample1.HTTPAPIResponseHeaders)
sample1.HTTPAPIResponseHeaders = map[string]string{}

// This value added to the config file
sample1.Consul.EnableSSL = helper.BoolToPtr(true)

// LoadDir listed the config files
// LoadDir lists the config files
require.Nil(t, sample1.Files)
sample1.Files = []string{
"testdata/sample1/sample0.json",
Expand Down

0 comments on commit ee7803d

Please sign in to comment.