Improve logging.
Correct behavior for undefined recipe list. Correct package name to upstream repo.
This commit is contained in:
parent
1fadd03837
commit
a6f3bb3bb2
|
@ -1,8 +1,8 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/jvandyke/packer/provisioner/chef-solo"
|
|
||||||
"github.com/mitchellh/packer/packer/plugin"
|
"github.com/mitchellh/packer/packer/plugin"
|
||||||
|
"github.com/mitchellh/packer/provisioner/chef-solo"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
|
@ -149,8 +149,6 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
return fmt.Errorf("Error running Chef Solo: %s", err)
|
return fmt.Errorf("Error running Chef Solo: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// return fmt.Errorf("Die")
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,6 +176,7 @@ func UploadLocalDirectory(localDir string, comm packer.Communicator) (err error)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
log.Printf("Uploading directory %s", localDir)
|
||||||
err = filepath.Walk(localDir, visitPath)
|
err = filepath.Walk(localDir, visitPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("Error uploading cookbook %s: %s", localDir, err)
|
return fmt.Errorf("Error uploading cookbook %s: %s", localDir, err)
|
||||||
|
@ -187,7 +186,8 @@ func UploadLocalDirectory(localDir string, comm packer.Communicator) (err error)
|
||||||
}
|
}
|
||||||
|
|
||||||
func CreateRemoteDirectory(path string, comm packer.Communicator) (err error) {
|
func CreateRemoteDirectory(path string, comm packer.Communicator) (err error) {
|
||||||
//Ui.Say(fmt.Sprintf("Creating directory: %s", path))
|
log.Printf("Creating remote directory: %s ", path)
|
||||||
|
|
||||||
var copyCommand = []string{"mkdir -p", path}
|
var copyCommand = []string{"mkdir -p", path}
|
||||||
|
|
||||||
var cmd packer.RemoteCmd
|
var cmd packer.RemoteCmd
|
||||||
|
@ -211,6 +211,7 @@ func CreateSoloRb(cookbooksPaths []string, comm packer.Communicator) (str string
|
||||||
Ui.Say(fmt.Sprintf("Creating Chef configuration file..."))
|
Ui.Say(fmt.Sprintf("Creating Chef configuration file..."))
|
||||||
|
|
||||||
remotePath := RemoteStagingPath + "/solo.rb"
|
remotePath := RemoteStagingPath + "/solo.rb"
|
||||||
|
|
||||||
tf, err := ioutil.TempFile("", "packer-chef-solo-rb")
|
tf, err := ioutil.TempFile("", "packer-chef-solo-rb")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", fmt.Errorf("Error preparing Chef solo.rb: %s", err)
|
return "", fmt.Errorf("Error preparing Chef solo.rb: %s", err)
|
||||||
|
@ -234,12 +235,13 @@ func CreateSoloRb(cookbooksPaths []string, comm packer.Communicator) (str string
|
||||||
name := tf.Name()
|
name := tf.Name()
|
||||||
tf.Close()
|
tf.Close()
|
||||||
f, err := os.Open(name)
|
f, err := os.Open(name)
|
||||||
comm.Upload(remotePath, f)
|
|
||||||
|
|
||||||
defer os.Remove(name)
|
defer os.Remove(name)
|
||||||
|
|
||||||
// Upload the Chef Solo configuration file to the cookbook directory.
|
log.Printf("Chef configuration file contents: %s", contents)
|
||||||
|
|
||||||
|
// Upload the Chef Solo configuration file to the cookbook directory.
|
||||||
|
log.Printf("Uploading chef configuration file to %s", remotePath)
|
||||||
|
err = comm.Upload(remotePath, f)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", fmt.Errorf("Error uploading Chef Solo configuration file: %s", err)
|
return "", fmt.Errorf("Error uploading Chef Solo configuration file: %s", err)
|
||||||
}
|
}
|
||||||
|
@ -257,7 +259,10 @@ func CreateAttributesJson(jsonAttrs map[string]interface{}, recipes []string, co
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add Recipes to JSON
|
// Add Recipes to JSON
|
||||||
|
if len(formattedRecipes) > 0 {
|
||||||
|
log.Printf("Overriding node run list: %s", strings.Join(formattedRecipes, ", "))
|
||||||
jsonAttrs["run_list"] = formattedRecipes
|
jsonAttrs["run_list"] = formattedRecipes
|
||||||
|
}
|
||||||
|
|
||||||
// Convert to JSON string
|
// Convert to JSON string
|
||||||
jsonString, err := json.MarshalIndent(jsonAttrs, "", " ")
|
jsonString, err := json.MarshalIndent(jsonAttrs, "", " ")
|
||||||
|
|
Loading…
Reference in New Issue