Refactor hardware customization
This commit is contained in:
parent
22d4b7e733
commit
a03c91e73a
|
@ -70,8 +70,8 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
|
||||||
&StepCloneVM{
|
&StepCloneVM{
|
||||||
config: b.config,
|
config: b.config,
|
||||||
},
|
},
|
||||||
&StepConfigureHW{
|
&StepConfigureHardware{
|
||||||
config: b.config,
|
config: &b.config.HardwareConfig,
|
||||||
},
|
},
|
||||||
&StepRun{},
|
&StepRun{},
|
||||||
&communicator.StepConnect{
|
&communicator.StepConnect{
|
||||||
|
|
14
config.go
14
config.go
|
@ -8,7 +8,6 @@ import (
|
||||||
"github.com/hashicorp/packer/helper/config"
|
"github.com/hashicorp/packer/helper/config"
|
||||||
"github.com/hashicorp/packer/packer"
|
"github.com/hashicorp/packer/packer"
|
||||||
"github.com/hashicorp/packer/template/interpolate"
|
"github.com/hashicorp/packer/template/interpolate"
|
||||||
"strconv"
|
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -32,8 +31,7 @@ type Config struct {
|
||||||
LinkedClone bool `mapstructure:"linked_clone"`
|
LinkedClone bool `mapstructure:"linked_clone"`
|
||||||
|
|
||||||
// Customization
|
// Customization
|
||||||
CPUs string `mapstructure:"CPUs"`
|
HardwareConfig `mapstructure:",squash"`
|
||||||
RAM string `mapstructure:"RAM"`
|
|
||||||
|
|
||||||
// Provisioning
|
// Provisioning
|
||||||
communicator.Config `mapstructure:",squash"`
|
communicator.Config `mapstructure:",squash"`
|
||||||
|
@ -83,16 +81,6 @@ func NewConfig(raws ...interface{}) (*Config, []string, error) {
|
||||||
errs = packer.MultiErrorAppend(errs, fmt.Errorf("vSphere host is required"))
|
errs = packer.MultiErrorAppend(errs, fmt.Errorf("vSphere host is required"))
|
||||||
}
|
}
|
||||||
|
|
||||||
if c.CPUs != "" {
|
|
||||||
if _, err := strconv.Atoi(c.CPUs); err != nil {
|
|
||||||
errs = packer.MultiErrorAppend(errs, fmt.Errorf("Invalid number of CPU sockets"))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if c.RAM != "" {
|
|
||||||
if _, err := strconv.Atoi(c.RAM); err != nil {
|
|
||||||
errs = packer.MultiErrorAppend(errs, fmt.Errorf("Invalid number for RAM"))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if c.RawShutdownTimeout != "" {
|
if c.RawShutdownTimeout != "" {
|
||||||
timeout, err := time.ParseDuration(c.RawShutdownTimeout)
|
timeout, err := time.ParseDuration(c.RawShutdownTimeout)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -11,20 +11,6 @@ func TestMinimalConfig(t *testing.T) {
|
||||||
testConfigOk(t, warns, errs)
|
testConfigOk(t, warns, errs)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestInvalidCpu(t *testing.T) {
|
|
||||||
raw := minimalConfig()
|
|
||||||
raw["CPUs"] = "string"
|
|
||||||
_, warns, errs := NewConfig(raw)
|
|
||||||
testConfigErr(t, warns, errs)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestInvalidRam(t *testing.T) {
|
|
||||||
raw := minimalConfig()
|
|
||||||
raw["RAM"] = "string"
|
|
||||||
_, warns, errs := NewConfig(raw)
|
|
||||||
testConfigErr(t, warns, errs)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestTimeout(t *testing.T) {
|
func TestTimeout(t *testing.T) {
|
||||||
raw := minimalConfig()
|
raw := minimalConfig()
|
||||||
raw["shutdown_timeout"] = "3m"
|
raw["shutdown_timeout"] = "3m"
|
||||||
|
|
|
@ -3,53 +3,32 @@ package main
|
||||||
import (
|
import (
|
||||||
"github.com/mitchellh/multistep"
|
"github.com/mitchellh/multistep"
|
||||||
"github.com/hashicorp/packer/packer"
|
"github.com/hashicorp/packer/packer"
|
||||||
"strconv"
|
|
||||||
"github.com/vmware/govmomi/vim25/types"
|
"github.com/vmware/govmomi/vim25/types"
|
||||||
"context"
|
"context"
|
||||||
"github.com/vmware/govmomi/object"
|
"github.com/vmware/govmomi/object"
|
||||||
)
|
)
|
||||||
|
|
||||||
type StepConfigureHW struct{
|
type HardwareConfig struct {
|
||||||
config *Config
|
CPUs int32 `mapstructure:"CPUs"`
|
||||||
|
RAM int64 `mapstructure:"RAM"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type ConfigParametersFlag struct {
|
type StepConfigureHardware struct {
|
||||||
NumCPUsPtr *int32
|
config *HardwareConfig
|
||||||
MemoryMBPtr *int64
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *StepConfigureHW) Run(state multistep.StateBag) multistep.StepAction {
|
func (s *StepConfigureHardware) Run(state multistep.StateBag) multistep.StepAction {
|
||||||
vm := state.Get("vm").(*object.VirtualMachine)
|
vm := state.Get("vm").(*object.VirtualMachine)
|
||||||
ctx := state.Get("ctx").(context.Context)
|
ctx := state.Get("ctx").(context.Context)
|
||||||
|
ui := state.Get("ui").(packer.Ui)
|
||||||
|
|
||||||
|
if *s.config != (HardwareConfig{}) {
|
||||||
|
ui.Say("Customizing hardware parameters...")
|
||||||
|
|
||||||
var confSpec types.VirtualMachineConfigSpec
|
var confSpec types.VirtualMachineConfigSpec
|
||||||
parametersFlag := ConfigParametersFlag{}
|
confSpec.NumCPUs = s.config.CPUs
|
||||||
// configure HW
|
confSpec.MemoryMB = s.config.RAM
|
||||||
if s.config.CPUs != "" {
|
|
||||||
CPUs, err := strconv.Atoi(s.config.CPUs)
|
|
||||||
if err != nil {
|
|
||||||
state.Put("error", err)
|
|
||||||
return multistep.ActionHalt
|
|
||||||
}
|
|
||||||
|
|
||||||
confSpec.NumCPUs = int32(CPUs)
|
|
||||||
parametersFlag.NumCPUsPtr = &(confSpec.NumCPUs)
|
|
||||||
}
|
|
||||||
if s.config.RAM != "" {
|
|
||||||
ram, err := strconv.Atoi(s.config.RAM)
|
|
||||||
if err != nil {
|
|
||||||
state.Put("error", err)
|
|
||||||
return multistep.ActionHalt
|
|
||||||
}
|
|
||||||
|
|
||||||
confSpec.MemoryMB = int64(ram)
|
|
||||||
parametersFlag.MemoryMBPtr = &(confSpec.MemoryMB)
|
|
||||||
}
|
|
||||||
|
|
||||||
ui := state.Get("ui").(packer.Ui)
|
|
||||||
if parametersFlag != (ConfigParametersFlag{}) {
|
|
||||||
ui.Say("configuring virtual hardware...")
|
|
||||||
// Reconfigure hardware
|
|
||||||
task, err := vm.Reconfigure(ctx, confSpec)
|
task, err := vm.Reconfigure(ctx, confSpec)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
|
@ -60,11 +39,9 @@ func (s *StepConfigureHW) Run(state multistep.StateBag) multistep.StepAction {
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
return multistep.ActionHalt
|
return multistep.ActionHalt
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
ui.Say("skipping the virtual hardware configration...")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return multistep.ActionContinue
|
return multistep.ActionContinue
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *StepConfigureHW) Cleanup(multistep.StateBag) {}
|
func (s *StepConfigureHardware) Cleanup(multistep.StateBag) {}
|
||||||
|
|
Loading…
Reference in New Issue