Add support for multiple cdroms for iso builder
This commit is contained in:
parent
0861dbc283
commit
9139a6029b
|
@ -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,18 +177,20 @@ 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 {
|
||||||
|
iso, ok := cdroms[i].(*types.VirtualCdrom).Backing.(*types.VirtualCdromIsoBackingInfo)
|
||||||
if !ok {
|
if !ok {
|
||||||
t.Fatalf("the iso is not connected")
|
t.Fatalf("the iso 'test%v.iso' is not connected", i)
|
||||||
}
|
}
|
||||||
expectedFileName := "[datastore1] alpine-standard-3.6.2-x86_64.iso"
|
expectedFileName := fmt.Sprintf("[datastore1] test%v.iso", i)
|
||||||
if iso.FileName != expectedFileName {
|
if iso.FileName != expectedFileName {
|
||||||
t.Fatalf("invalid iso filename: expected '%v', got '%v'", expectedFileName, iso.FileName)
|
t.Fatalf("invalid iso filename: expected '%v', got '%v'", expectedFileName, iso.FileName)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,14 +22,15 @@ 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
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue