2015-05-08 23:25:24 +02:00
|
|
|
package chef
|
2015-05-08 18:17:57 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/communicator"
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
)
|
|
|
|
|
2015-06-25 14:29:48 +02:00
|
|
|
func TestResourceProvider_linuxInstallChefClient(t *testing.T) {
|
2015-05-08 18:17:57 +02:00
|
|
|
cases := map[string]struct {
|
|
|
|
Config *terraform.ResourceConfig
|
|
|
|
Commands map[string]bool
|
|
|
|
}{
|
|
|
|
"Sudo": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
2015-05-08 23:25:24 +02:00
|
|
|
"sudo curl -LO https://www.chef.io/chef/install.sh": true,
|
|
|
|
"sudo bash ./install.sh -v ": true,
|
|
|
|
"sudo rm -f install.sh": true,
|
2015-05-08 18:17:57 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"NoSudo": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
2015-05-08 23:25:24 +02:00
|
|
|
"curl -LO https://www.chef.io/chef/install.sh": true,
|
|
|
|
"bash ./install.sh -v ": true,
|
|
|
|
"rm -f install.sh": true,
|
2015-05-08 18:17:57 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"HTTPProxy": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"http_proxy": "http://proxy.local",
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
2015-05-08 23:25:24 +02:00
|
|
|
"proxy_http='http://proxy.local' curl -LO https://www.chef.io/chef/install.sh": true,
|
|
|
|
"proxy_http='http://proxy.local' bash ./install.sh -v ": true,
|
|
|
|
"proxy_http='http://proxy.local' rm -f install.sh": true,
|
2015-05-08 18:17:57 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"NOProxy": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"http_proxy": "http://proxy.local",
|
|
|
|
"no_proxy": []interface{}{"http://local.local", "http://local.org"},
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
2015-05-08 23:25:24 +02:00
|
|
|
"proxy_http='http://proxy.local' no_proxy='http://local.local,http://local.org' " +
|
|
|
|
"curl -LO https://www.chef.io/chef/install.sh": true,
|
|
|
|
"proxy_http='http://proxy.local' no_proxy='http://local.local,http://local.org' " +
|
|
|
|
"bash ./install.sh -v ": true,
|
|
|
|
"proxy_http='http://proxy.local' no_proxy='http://local.local,http://local.org' " +
|
2015-05-08 18:17:57 +02:00
|
|
|
"rm -f install.sh": true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"Version": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "validator.pem",
|
|
|
|
"version": "11.18.6",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
2015-05-08 23:25:24 +02:00
|
|
|
"curl -LO https://www.chef.io/chef/install.sh": true,
|
|
|
|
"bash ./install.sh -v 11.18.6": true,
|
|
|
|
"rm -f install.sh": true,
|
2015-05-08 18:17:57 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
r := new(ResourceProvisioner)
|
|
|
|
o := new(terraform.MockUIOutput)
|
|
|
|
c := new(communicator.MockCommunicator)
|
|
|
|
|
|
|
|
for k, tc := range cases {
|
|
|
|
c.Commands = tc.Commands
|
|
|
|
|
|
|
|
p, err := r.decodeConfig(tc.Config)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Error: %v", err)
|
|
|
|
}
|
|
|
|
|
2015-05-12 10:37:38 +02:00
|
|
|
p.useSudo = !p.PreventSudo
|
|
|
|
|
2015-06-25 14:29:48 +02:00
|
|
|
err = p.linuxInstallChefClient(o, c)
|
2015-05-08 18:17:57 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Test %q failed: %v", k, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-25 14:29:48 +02:00
|
|
|
func TestResourceProvider_linuxCreateConfigFiles(t *testing.T) {
|
2015-05-08 18:17:57 +02:00
|
|
|
cases := map[string]struct {
|
|
|
|
Config *terraform.ResourceConfig
|
|
|
|
Commands map[string]bool
|
|
|
|
Uploads map[string]string
|
|
|
|
}{
|
|
|
|
"Sudo": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "test-fixtures/validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
|
|
|
"sudo mkdir -p " + linuxConfDir: true,
|
|
|
|
"sudo chmod 777 " + linuxConfDir: true,
|
|
|
|
"sudo chmod 755 " + linuxConfDir: true,
|
|
|
|
"sudo chown -R root.root " + linuxConfDir: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
Uploads: map[string]string{
|
|
|
|
"/etc/chef/validation.pem": "VALIDATOR-PEM-FILE",
|
2015-06-25 14:29:48 +02:00
|
|
|
"/etc/chef/client.rb": defaultLinuxClientConf,
|
2015-05-08 18:17:57 +02:00
|
|
|
"/etc/chef/first-boot.json": `{"run_list":["cookbook::recipe"]}`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"NoSudo": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "test-fixtures/validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
|
|
|
"mkdir -p " + linuxConfDir: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
Uploads: map[string]string{
|
|
|
|
"/etc/chef/validation.pem": "VALIDATOR-PEM-FILE",
|
2015-06-25 14:29:48 +02:00
|
|
|
"/etc/chef/client.rb": defaultLinuxClientConf,
|
2015-05-08 18:17:57 +02:00
|
|
|
"/etc/chef/first-boot.json": `{"run_list":["cookbook::recipe"]}`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"Proxy": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"http_proxy": "http://proxy.local",
|
|
|
|
"https_proxy": "https://proxy.local",
|
|
|
|
"no_proxy": []interface{}{"http://local.local", "https://local.local"},
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "test-fixtures/validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
|
|
|
"mkdir -p " + linuxConfDir: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
Uploads: map[string]string{
|
|
|
|
"/etc/chef/validation.pem": "VALIDATOR-PEM-FILE",
|
2015-06-25 14:29:48 +02:00
|
|
|
"/etc/chef/client.rb": proxyLinuxClientConf,
|
2015-05-08 18:17:57 +02:00
|
|
|
"/etc/chef/first-boot.json": `{"run_list":["cookbook::recipe"]}`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
"Attributes": {
|
|
|
|
Config: testConfig(t, map[string]interface{}{
|
|
|
|
"attributes": []map[string]interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"key1": []map[string]interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"subkey1": []map[string]interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"subkey2a": []interface{}{
|
|
|
|
"val1", "val2", "val3",
|
|
|
|
},
|
|
|
|
"subkey2b": []map[string]interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"subkey3": "value3",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"key2": "value2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"node_name": "nodename1",
|
|
|
|
"prevent_sudo": true,
|
|
|
|
"run_list": []interface{}{"cookbook::recipe"},
|
|
|
|
"server_url": "https://chef.local",
|
|
|
|
"validation_client_name": "validator",
|
|
|
|
"validation_key_path": "test-fixtures/validator.pem",
|
|
|
|
}),
|
|
|
|
|
|
|
|
Commands: map[string]bool{
|
|
|
|
"mkdir -p " + linuxConfDir: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
Uploads: map[string]string{
|
|
|
|
"/etc/chef/validation.pem": "VALIDATOR-PEM-FILE",
|
2015-06-25 14:29:48 +02:00
|
|
|
"/etc/chef/client.rb": defaultLinuxClientConf,
|
2015-05-08 18:17:57 +02:00
|
|
|
"/etc/chef/first-boot.json": `{"key1":{"subkey1":{"subkey2a":["val1","val2","val3"],` +
|
|
|
|
`"subkey2b":{"subkey3":"value3"}}},"key2":"value2","run_list":["cookbook::recipe"]}`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
r := new(ResourceProvisioner)
|
|
|
|
o := new(terraform.MockUIOutput)
|
|
|
|
c := new(communicator.MockCommunicator)
|
|
|
|
|
|
|
|
for k, tc := range cases {
|
|
|
|
c.Commands = tc.Commands
|
|
|
|
c.Uploads = tc.Uploads
|
|
|
|
|
|
|
|
p, err := r.decodeConfig(tc.Config)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Error: %v", err)
|
|
|
|
}
|
|
|
|
|
2015-05-12 10:37:38 +02:00
|
|
|
p.useSudo = !p.PreventSudo
|
|
|
|
|
2015-06-25 14:29:48 +02:00
|
|
|
err = p.linuxCreateConfigFiles(o, c)
|
2015-05-08 18:17:57 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Test %q failed: %v", k, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-25 14:29:48 +02:00
|
|
|
const defaultLinuxClientConf = `log_location STDOUT
|
2015-05-08 18:17:57 +02:00
|
|
|
chef_server_url "https://chef.local"
|
|
|
|
validation_client_name "validator"
|
|
|
|
node_name "nodename1"`
|
|
|
|
|
2015-06-25 14:29:48 +02:00
|
|
|
const proxyLinuxClientConf = `log_location STDOUT
|
2015-05-08 18:17:57 +02:00
|
|
|
chef_server_url "https://chef.local"
|
|
|
|
validation_client_name "validator"
|
|
|
|
node_name "nodename1"
|
|
|
|
|
|
|
|
|
|
|
|
http_proxy "http://proxy.local"
|
|
|
|
ENV['http_proxy'] = "http://proxy.local"
|
|
|
|
ENV['HTTP_PROXY'] = "http://proxy.local"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
https_proxy "https://proxy.local"
|
|
|
|
ENV['https_proxy'] = "https://proxy.local"
|
|
|
|
ENV['HTTPS_PROXY'] = "https://proxy.local"
|
|
|
|
|
|
|
|
|
|
|
|
no_proxy "http://local.local,https://local.local"`
|