From 1e9b0f7b8f7bdff29c10b8c0934aa904999b2561 Mon Sep 17 00:00:00 2001 From: Jimmy The Dog Date: Fri, 10 Mar 2017 10:43:45 +0000 Subject: [PATCH] Replace export output dir in state bag with params step_export now has the OutputDir as a param instead of getting it from the state bag, on the advice of @mwhooker in PR comment --- builder/vmware/iso/builder.go | 2 +- builder/vmware/iso/step_export.go | 15 +++++++++------ 2 files changed, 10 insertions(+), 7 deletions(-) diff --git a/builder/vmware/iso/builder.go b/builder/vmware/iso/builder.go index b01cb1f32..9a0738842 100644 --- a/builder/vmware/iso/builder.go +++ b/builder/vmware/iso/builder.go @@ -215,7 +215,6 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe state.Put("debug", b.config.PackerDebug) state.Put("dir", dir) state.Put("driver", driver) - state.Put("exportPath", exportOutputPath) state.Put("hook", hook) state.Put("ui", ui) @@ -309,6 +308,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe &StepExport{ Format: b.config.Format, SkipExport: b.config.SkipExport, + OutputDir: exportOutputPath, }, } diff --git a/builder/vmware/iso/step_export.go b/builder/vmware/iso/step_export.go index 04c526aae..d8c91f82c 100644 --- a/builder/vmware/iso/step_export.go +++ b/builder/vmware/iso/step_export.go @@ -16,9 +16,10 @@ import ( type StepExport struct { Format string SkipExport bool + OutputDir string } -func (s *StepExport) generateArgs(c *Config, outputPath string, hidePassword bool) []string { +func (s *StepExport) generateArgs(c *Config, hidePassword bool) []string { password := url.QueryEscape(c.RemotePassword) if hidePassword { password = "****" @@ -28,7 +29,7 @@ func (s *StepExport) generateArgs(c *Config, outputPath string, hidePassword boo "--skipManifestCheck", "-tt=" + s.Format, "vi://" + c.RemoteUser + ":" + password + "@" + c.RemoteHost + "/" + c.VMName, - outputPath, + s.OutputDir, } return append(c.OVFToolOptions, args...) } @@ -60,16 +61,18 @@ func (s *StepExport) Run(state multistep.StateBag) multistep.StepAction { } // Export the VM - outputPath := state.Get("exportPath").(string) + if s.OutputDir == "" { + s.OutputDir = c.VMName + "." + s.Format + } if s.Format == "ova" { - os.MkdirAll(outputPath, 0755) + os.MkdirAll(s.OutputDir, 0755) } ui.Say("Exporting virtual machine...") - ui.Message(fmt.Sprintf("Executing: %s %s", ovftool, strings.Join(s.generateArgs(c, outputPath, true), " "))) + ui.Message(fmt.Sprintf("Executing: %s %s", ovftool, strings.Join(s.generateArgs(c, true), " "))) var out bytes.Buffer - cmd := exec.Command(ovftool, s.generateArgs(c, outputPath, false)...) + cmd := exec.Command(ovftool, s.generateArgs(c, false)...) cmd.Stdout = &out if err := cmd.Run(); err != nil { err := fmt.Errorf("Error exporting virtual machine: %s\n%s\n", err, out.String())