Remove redundant code and clean up some string concatenation.

Clean up Say statements.
This commit is contained in:
James Van Dyke 2013-07-12 11:09:52 -04:00
parent a6f3bb3bb2
commit ba5d7a9d72
1 changed files with 30 additions and 18 deletions

View File

@ -19,10 +19,12 @@ import (
"text/template"
)
const RemoteStagingPath = "/tmp/provision/chef-solo"
const RemoteFileCachePath = "/tmp/provision/chef-solo"
const RemoteCookbookPath = "/tmp/provision/chef-solo/cookbooks"
const DefaultCookbooksPath = "cookbooks"
const (
RemoteStagingPath = "/tmp/provision/chef-solo"
RemoteFileCachePath = "/tmp/provision/chef-solo"
RemoteCookbookPath = "/tmp/provision/chef-solo/cookbooks"
DefaultCookbooksPath = "cookbooks"
)
var Ui packer.Ui
@ -68,7 +70,6 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
if p.config.CookbooksPaths == nil {
p.config.CookbooksPaths = []string{DefaultCookbooksPath}
}
if p.config.Recipes == nil {
@ -99,9 +100,6 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
}
func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
cookbooksPaths := make([]string, len(p.config.CookbooksPaths))
copy(cookbooksPaths, p.config.CookbooksPaths)
var err error
Ui = ui
@ -128,7 +126,7 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
}
// Upload all cookbooks
for _, path := range cookbooksPaths {
for _, path := range p.config.CookbooksPaths {
ui.Say(fmt.Sprintf("Copying cookbook path: %s", path))
err = UploadLocalDirectory(path, comm)
if err != nil {
@ -149,6 +147,8 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
return fmt.Errorf("Error running Chef Solo: %s", err)
}
return fmt.Errorf("SUCESS")
return nil
}
@ -208,7 +208,7 @@ func CreateRemoteDirectory(path string, comm packer.Communicator) (err error) {
}
func CreateSoloRb(cookbooksPaths []string, comm packer.Communicator) (str string, err error) {
Ui.Say(fmt.Sprintf("Creating Chef configuration file..."))
Ui.Say("Creating Chef configuration file...")
remotePath := RemoteStagingPath + "/solo.rb"
@ -220,11 +220,24 @@ func CreateSoloRb(cookbooksPaths []string, comm packer.Communicator) (str string
// Write our contents to it
writer := bufio.NewWriter(tf)
// Messy, messy...
cbPathsCat := "\"" + RemoteCookbookPath + "/" + strings.Join(cookbooksPaths, "\",\""+RemoteCookbookPath+"/") + "\""
contents := "file_cache_path \"" + RemoteFileCachePath + "\"\ncookbook_path [" + cbPathsCat + "]\n"
var cookbooksPathsFull = make([]string, len(cookbooksPaths))
for i, path := range cookbooksPaths {
cookbooksPathsFull[i] = "\"" + RemoteCookbookPath + "/" + path + "\""
}
if _, err := writer.WriteString(contents); err != nil {
var contents bytes.Buffer
var soloRbText = `
file_cache_path "{{.FileCachePath}}"
cookbook_path [{{.CookbookPath}}]
`
t := template.Must(template.New("soloRb").Parse(soloRbText))
t.Execute(&contents, map[string]string{
"FileCachePath": RemoteFileCachePath,
"CookbookPath": strings.Join(cookbooksPathsFull, ","),
})
if _, err := writer.WriteString(contents.String()); err != nil {
return "", fmt.Errorf("Error preparing solo.rb: %s", err)
}
@ -245,12 +258,12 @@ func CreateSoloRb(cookbooksPaths []string, comm packer.Communicator) (str string
if err != nil {
return "", fmt.Errorf("Error uploading Chef Solo configuration file: %s", err)
}
//executeCommand("sudo cat " + remotePath, comm)
return remotePath, nil
}
func CreateAttributesJson(jsonAttrs map[string]interface{}, recipes []string, comm packer.Communicator) (str string, err error) {
Ui.Say(fmt.Sprintf("Creating and uploading Chef attributes file"))
Ui.Say("Creating and uploading Chef attributes file")
remotePath := RemoteStagingPath + "/node.json"
var formattedRecipes []string
@ -305,7 +318,7 @@ func CreateAttributesJson(jsonAttrs map[string]interface{}, recipes []string, co
}
func InstallChefSolo(preventSudo bool, comm packer.Communicator) (err error) {
Ui.Say(fmt.Sprintf("Installing Chef Solo"))
Ui.Say("Installing Chef Solo")
var command bytes.Buffer
t := template.Must(template.New("install-chef").Parse("curl -L https://www.opscode.com/chef/install.sh | {{if .sudo}}sudo {{end}}bash"))
@ -329,7 +342,6 @@ func executeCommand(command string, comm packer.Communicator) (err error) {
cmd.Stdout = stdout_w
cmd.Stderr = stderr_w
//Ui.Say(fmt.Sprintf("Executing command: %s", cmd.Command))
log.Printf("Executing command: %s", cmd.Command)
err = comm.Start(&cmd)
if err != nil {