Add support for multiple cdroms for iso builder

This commit is contained in:
Andrei Tonkikh 2018-01-31 20:29:03 +03:00
parent 0861dbc283
commit 9139a6029b
2 changed files with 25 additions and 17 deletions

View File

@ -6,6 +6,7 @@ import (
"testing" "testing"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
"github.com/vmware/govmomi/vim25/types" "github.com/vmware/govmomi/vim25/types"
"fmt"
) )
func TestISOBuilderAcc_default(t *testing.T) { func TestISOBuilderAcc_default(t *testing.T) {
@ -159,7 +160,10 @@ func TestISOBuilderAcc_cdrom(t *testing.T) {
func cdromConfig() string { func cdromConfig() string {
config := defaultConfig() config := defaultConfig()
config["iso_path"] = "[datastore1] alpine-standard-3.6.2-x86_64.iso" config["iso_paths"] = []string{
"[datastore1] test0.iso",
"[datastore1] test1.iso",
}
return commonT.RenderConfig(config) return commonT.RenderConfig(config)
} }
@ -173,17 +177,19 @@ func checkCDRom(t *testing.T) builderT.TestCheckFunc {
t.Fatalf("cannot read VM properties: %v", err) t.Fatalf("cannot read VM properties: %v", err)
} }
cdrom, err := devices.FindCdrom("") cdroms := devices.SelectByType((*types.VirtualCdrom)(nil))
if err != nil { if len(cdroms) != 2 {
t.Fatalf("cannot find cdrom: %v", err) t.Fatalf("expected 2 cdroms, found %v", len(cdroms))
} }
iso, ok := cdrom.Backing.(*types.VirtualCdromIsoBackingInfo) for i := range cdroms {
if !ok { iso, ok := cdroms[i].(*types.VirtualCdrom).Backing.(*types.VirtualCdromIsoBackingInfo)
t.Fatalf("the iso is not connected") if !ok {
} t.Fatalf("the iso 'test%v.iso' is not connected", i)
expectedFileName := "[datastore1] alpine-standard-3.6.2-x86_64.iso" }
if iso.FileName != expectedFileName { expectedFileName := fmt.Sprintf("[datastore1] test%v.iso", i)
t.Fatalf("invalid iso filename: expected '%v', got '%v'", expectedFileName, iso.FileName) if iso.FileName != expectedFileName {
t.Fatalf("invalid iso filename: expected '%v', got '%v'", expectedFileName, iso.FileName)
}
} }
return nil return nil

View File

@ -4,10 +4,11 @@ import (
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
"github.com/jetbrains-infra/packer-builder-vsphere/driver" "github.com/jetbrains-infra/packer-builder-vsphere/driver"
"github.com/mitchellh/multistep" "github.com/mitchellh/multistep"
"fmt"
) )
type CDRomConfig struct { type CDRomConfig struct {
ISOPath string `mapstructure:"iso_path"` ISOPaths []string `mapstructure:"iso_paths"`
} }
func (c *CDRomConfig) Prepare() []error { func (c *CDRomConfig) Prepare() []error {
@ -21,13 +22,14 @@ type StepAddCDRom struct {
func (s *StepAddCDRom) Run(state multistep.StateBag) multistep.StepAction { func (s *StepAddCDRom) Run(state multistep.StateBag) multistep.StepAction {
ui := state.Get("ui").(packer.Ui) ui := state.Get("ui").(packer.Ui)
ui.Say("Adding CDRom...") ui.Say("Adding CDRoms...")
vm := state.Get("vm").(*driver.VirtualMachine) vm := state.Get("vm").(*driver.VirtualMachine)
err := vm.AddCdrom(s.config.ISOPath) for _, path := range s.config.ISOPaths {
if err != nil { if err := vm.AddCdrom(path); err != nil {
state.Put("error", err) state.Put("error", fmt.Errorf("error adding a cdrom: %v", err))
return multistep.ActionHalt return multistep.ActionHalt
}
} }
return multistep.ActionContinue return multistep.ActionContinue