Merge branch 'master' of https://github.com/mitchellh/packer
This commit is contained in:
commit
d98735a37d
|
@ -1,10 +1,10 @@
|
||||||
package vsphere
|
package vsphere
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -121,20 +121,49 @@ func (p *PostProcessor) PostProcess(ui packer.Ui, artifact packer.Artifact) (pac
|
||||||
ovftool_uri += "/Resources/" + p.config.ResourcePool
|
ovftool_uri += "/Resources/" + p.config.ResourcePool
|
||||||
}
|
}
|
||||||
|
|
||||||
args := []string{
|
ui.Message(fmt.Sprintf("Uploading %s to vSphere", source))
|
||||||
fmt.Sprintf("--noSSLVerify=%t", p.config.Insecure),
|
|
||||||
"--acceptAllEulas",
|
args, err := p.BuildArgs(source, ovftool_uri)
|
||||||
fmt.Sprintf("--name=\"%s\"", p.config.VMName),
|
if err != nil {
|
||||||
fmt.Sprintf("--datastore=\"%s\"", p.config.Datastore),
|
ui.Message(fmt.Sprintf("Failed: %s\n", err))
|
||||||
fmt.Sprintf("--diskMode=\"%s\"", p.config.DiskMode),
|
|
||||||
fmt.Sprintf("--network=\"%s\"", p.config.VMNetwork),
|
|
||||||
fmt.Sprintf("--vmFolder=\"%s\"", p.config.VMFolder),
|
|
||||||
fmt.Sprintf("%s", source),
|
|
||||||
fmt.Sprintf("\"%s\"", ovftool_uri),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ui.Message(fmt.Sprintf("Uploading %s to vSphere", source))
|
ui.Message(fmt.Sprintf("Uploading %s to vSphere", source))
|
||||||
|
|
||||||
|
log.Printf("Starting ovftool with parameters: %s", strings.Join(args, " "))
|
||||||
|
cmd := exec.Command("ovftool", args...)
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
if err := cmd.Run(); err != nil {
|
||||||
|
return nil, false, fmt.Errorf("Failed: %s\n", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return artifact, false, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PostProcessor) BuildArgs(source, ovftool_uri string) ([]string, error) {
|
||||||
|
args := []string{
|
||||||
|
"--acceptAllEulas",
|
||||||
|
fmt.Sprintf(`--name=%s`, p.config.VMName),
|
||||||
|
fmt.Sprintf(`--datastore=%s`, p.config.Datastore),
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.config.Insecure {
|
||||||
|
args = append(args, fmt.Sprintf(`--noSSLVerify=%t`, p.config.Insecure))
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.config.DiskMode != "" {
|
||||||
|
args = append(args, fmt.Sprintf(`--diskMode=%s`, p.config.DiskMode))
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.config.VMFolder != "" {
|
||||||
|
args = append(args, fmt.Sprintf(`--vmFolder=%s`, p.config.VMFolder))
|
||||||
|
}
|
||||||
|
|
||||||
|
if p.config.VMNetwork != "" {
|
||||||
|
args = append(args, fmt.Sprintf(`--network=%s`, p.config.VMNetwork))
|
||||||
|
}
|
||||||
|
|
||||||
if p.config.Overwrite == true {
|
if p.config.Overwrite == true {
|
||||||
args = append(args, "--overwrite")
|
args = append(args, "--overwrite")
|
||||||
}
|
}
|
||||||
|
@ -143,16 +172,8 @@ func (p *PostProcessor) PostProcess(ui packer.Ui, artifact packer.Artifact) (pac
|
||||||
args = append(args, p.config.Options...)
|
args = append(args, p.config.Options...)
|
||||||
}
|
}
|
||||||
|
|
||||||
ui.Message(fmt.Sprintf("Uploading %s to vSphere", source))
|
args = append(args, fmt.Sprintf(`%s`, source))
|
||||||
var out bytes.Buffer
|
args = append(args, fmt.Sprintf(`%s`, ovftool_uri))
|
||||||
log.Printf("Starting ovftool with parameters: %s", strings.Join(args, " "))
|
|
||||||
cmd := exec.Command("ovftool", args...)
|
|
||||||
cmd.Stdout = &out
|
|
||||||
if err := cmd.Run(); err != nil {
|
|
||||||
return nil, false, fmt.Errorf("Failed: %s\nStdout: %s", err, out.String())
|
|
||||||
}
|
|
||||||
|
|
||||||
ui.Message(fmt.Sprintf("%s", out.String()))
|
return args, nil
|
||||||
|
|
||||||
return artifact, false, nil
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1 +1,42 @@
|
||||||
package vsphere
|
package vsphere
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/url"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestArgs(t *testing.T) {
|
||||||
|
var p PostProcessor
|
||||||
|
|
||||||
|
p.config.Username = "me"
|
||||||
|
p.config.Password = "notpassword"
|
||||||
|
p.config.Host = "myhost"
|
||||||
|
p.config.Datacenter = "mydc"
|
||||||
|
p.config.Cluster = "mycluster"
|
||||||
|
p.config.VMName = "my vm"
|
||||||
|
p.config.Datastore = "my datastore"
|
||||||
|
p.config.Insecure = true
|
||||||
|
p.config.DiskMode = "thin"
|
||||||
|
p.config.VMFolder = "my folder"
|
||||||
|
|
||||||
|
source := "something.vmx"
|
||||||
|
ovftool_uri := fmt.Sprintf("vi://%s:%s@%s/%s/host/%s",
|
||||||
|
url.QueryEscape(p.config.Username),
|
||||||
|
url.QueryEscape(p.config.Password),
|
||||||
|
p.config.Host,
|
||||||
|
p.config.Datacenter,
|
||||||
|
p.config.Cluster)
|
||||||
|
|
||||||
|
if p.config.ResourcePool != "" {
|
||||||
|
ovftool_uri += "/Resources/" + p.config.ResourcePool
|
||||||
|
}
|
||||||
|
|
||||||
|
args, err := p.BuildArgs(source, ovftool_uri)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Error: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
t.Logf("ovftool %s", strings.Join(args, " "))
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue