323 lines
6.5 KiB
Go
323 lines
6.5 KiB
Go
package chefclient
|
|
|
|
import (
|
|
"bytes"
|
|
"io/ioutil"
|
|
"os"
|
|
"strings"
|
|
"testing"
|
|
|
|
packersdk "github.com/hashicorp/packer-plugin-sdk/packer"
|
|
)
|
|
|
|
func testConfig() map[string]interface{} {
|
|
return map[string]interface{}{
|
|
"server_url": "foo",
|
|
}
|
|
}
|
|
|
|
func TestProvisioner_Impl(t *testing.T) {
|
|
var raw interface{}
|
|
raw = &Provisioner{}
|
|
if _, ok := raw.(packersdk.Provisioner); !ok {
|
|
t.Fatalf("must be a Provisioner")
|
|
}
|
|
}
|
|
|
|
func TestProvisionerPrepare_chefEnvironment(t *testing.T) {
|
|
var p Provisioner
|
|
|
|
config := testConfig()
|
|
config["chef_environment"] = "some-env"
|
|
|
|
err := p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if p.config.ChefEnvironment != "some-env" {
|
|
t.Fatalf("unexpected: %#v", p.config.ChefEnvironment)
|
|
}
|
|
}
|
|
|
|
func TestProvisionerPrepare_configTemplate(t *testing.T) {
|
|
var err error
|
|
var p Provisioner
|
|
|
|
// Test no config template
|
|
config := testConfig()
|
|
delete(config, "config_template")
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
// Test with a file
|
|
tf, err := ioutil.TempFile("", "packer")
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
defer os.Remove(tf.Name())
|
|
|
|
config = testConfig()
|
|
config["config_template"] = tf.Name()
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
// Test with a directory
|
|
td, err := ioutil.TempDir("", "packer")
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
defer os.RemoveAll(td)
|
|
|
|
config = testConfig()
|
|
config["config_template"] = td
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err == nil {
|
|
t.Fatal("should have err")
|
|
}
|
|
}
|
|
|
|
func TestProvisionerPrepare_commands(t *testing.T) {
|
|
commands := []string{
|
|
"execute_command",
|
|
"install_command",
|
|
"knife_command",
|
|
}
|
|
|
|
for _, command := range commands {
|
|
var p Provisioner
|
|
|
|
// Test not set
|
|
config := testConfig()
|
|
delete(config, command)
|
|
err := p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
// Test invalid template
|
|
config = testConfig()
|
|
config[command] = "{{if NOPE}}"
|
|
err = p.Prepare(config)
|
|
if err == nil {
|
|
t.Fatal("should error")
|
|
}
|
|
|
|
// Test good template
|
|
config = testConfig()
|
|
config[command] = "{{.Foo}}"
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestProvisionerPrepare_serverUrl(t *testing.T) {
|
|
var p Provisioner
|
|
|
|
// Test not set
|
|
config := testConfig()
|
|
delete(config, "server_url")
|
|
err := p.Prepare(config)
|
|
if err == nil {
|
|
t.Fatal("should error")
|
|
}
|
|
|
|
// Test set
|
|
config = testConfig()
|
|
config["server_url"] = "foo"
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
}
|
|
func TestProvisionerPrepare_chefLicense(t *testing.T) {
|
|
var p Provisioner
|
|
|
|
// Test not set
|
|
config := testConfig()
|
|
err := p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatal("should error")
|
|
}
|
|
|
|
if p.config.ChefLicense != "accept-silent" {
|
|
t.Fatalf("unexpected: %#v", p.config.ChefLicense)
|
|
}
|
|
|
|
// Test set
|
|
config = testConfig()
|
|
config["chef_license"] = "accept"
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if p.config.ChefLicense != "accept" {
|
|
t.Fatalf("unexpected: %#v", p.config.ChefLicense)
|
|
}
|
|
|
|
// Test set skipInstall true
|
|
config = testConfig()
|
|
config["skip_install"] = true
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if p.config.ChefLicense != "" {
|
|
t.Fatalf("unexpected: %#v", "empty string")
|
|
}
|
|
|
|
// Test set installCommand true
|
|
config = testConfig()
|
|
config["install_command"] = "install chef"
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if p.config.ChefLicense != "" {
|
|
t.Fatalf("unexpected: %#v", "empty string")
|
|
}
|
|
}
|
|
|
|
func TestProvisionerPrepare_encryptedDataBagSecretPath(t *testing.T) {
|
|
var err error
|
|
var p Provisioner
|
|
|
|
// Test no config template
|
|
config := testConfig()
|
|
delete(config, "encrypted_data_bag_secret_path")
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
// Test with a file
|
|
tf, err := ioutil.TempFile("", "packer")
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
defer os.Remove(tf.Name())
|
|
|
|
config = testConfig()
|
|
config["encrypted_data_bag_secret_path"] = tf.Name()
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
// Test with a directory
|
|
td, err := ioutil.TempDir("", "packer")
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
defer os.RemoveAll(td)
|
|
|
|
config = testConfig()
|
|
config["encrypted_data_bag_secret_path"] = td
|
|
p = Provisioner{}
|
|
err = p.Prepare(config)
|
|
if err == nil {
|
|
t.Fatal("should have err")
|
|
}
|
|
}
|
|
|
|
func TestProvisioner_createDir(t *testing.T) {
|
|
for _, sudo := range []bool{true, false} {
|
|
config := testConfig()
|
|
config["prevent_sudo"] = !sudo
|
|
|
|
p := &Provisioner{}
|
|
comm := &packersdk.MockCommunicator{}
|
|
ui := &packersdk.BasicUi{
|
|
Reader: new(bytes.Buffer),
|
|
Writer: new(bytes.Buffer),
|
|
}
|
|
|
|
err := p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if err := p.createDir(ui, comm, "/tmp/foo"); err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if !sudo && strings.HasPrefix(comm.StartCmd.Command, "sudo") {
|
|
t.Fatalf("createDir should not use sudo, got: \"%s\"", comm.StartCmd.Command)
|
|
}
|
|
|
|
if sudo && !strings.HasPrefix(comm.StartCmd.Command, "sudo") {
|
|
t.Fatalf("createDir should use sudo, got: \"%s\"", comm.StartCmd.Command)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestProvisioner_removeDir(t *testing.T) {
|
|
for _, sudo := range []bool{true, false} {
|
|
config := testConfig()
|
|
config["prevent_sudo"] = !sudo
|
|
|
|
p := &Provisioner{}
|
|
comm := &packersdk.MockCommunicator{}
|
|
ui := &packersdk.BasicUi{
|
|
Reader: new(bytes.Buffer),
|
|
Writer: new(bytes.Buffer),
|
|
}
|
|
|
|
err := p.Prepare(config)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if err := p.removeDir(ui, comm, "/tmp/foo"); err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if !sudo && strings.HasPrefix(comm.StartCmd.Command, "sudo") {
|
|
t.Fatalf("removeDir should not use sudo, got: \"%s\"", comm.StartCmd.Command)
|
|
}
|
|
|
|
if sudo && !strings.HasPrefix(comm.StartCmd.Command, "sudo") {
|
|
t.Fatalf("removeDir should use sudo, got: \"%s\"", comm.StartCmd.Command)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestProvisionerPrepare_policy(t *testing.T) {
|
|
var p Provisioner
|
|
|
|
var policyTests = []struct {
|
|
name string
|
|
group string
|
|
success bool
|
|
}{
|
|
{"", "", true},
|
|
{"a", "b", true},
|
|
{"a", "", false},
|
|
{"", "a", false},
|
|
}
|
|
for _, tt := range policyTests {
|
|
config := testConfig()
|
|
config["policy_name"] = tt.name
|
|
config["policy_group"] = tt.group
|
|
err := p.Prepare(config)
|
|
if (err == nil) != tt.success {
|
|
t.Fatalf("wasn't expecting %+v to fail: %s", tt, err.Error())
|
|
}
|
|
}
|
|
}
|