2020-09-04 17:53:09 -04:00
|
|
|
package proxmoxiso
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/Telmate/proxmox-api-go/proxmox"
|
|
|
|
"github.com/hashicorp/packer/packer"
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
2020-09-04 17:53:09 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
type finalizerMock struct {
|
|
|
|
getConfig func() (map[string]interface{}, error)
|
|
|
|
setConfig func(map[string]interface{}) (string, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m finalizerMock) GetVmConfig(*proxmox.VmRef) (map[string]interface{}, error) {
|
|
|
|
return m.getConfig()
|
|
|
|
}
|
|
|
|
func (m finalizerMock) SetVmConfig(vmref *proxmox.VmRef, c map[string]interface{}) (interface{}, error) {
|
|
|
|
return m.setConfig(c)
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ templateFinalizer = finalizerMock{}
|
|
|
|
|
|
|
|
func TestISOTemplateFinalize(t *testing.T) {
|
|
|
|
cs := []struct {
|
|
|
|
name string
|
|
|
|
builderConfig *Config
|
|
|
|
initialVMConfig map[string]interface{}
|
|
|
|
getConfigErr error
|
|
|
|
expectCallSetConfig bool
|
|
|
|
expectedVMConfig map[string]interface{}
|
|
|
|
setConfigErr error
|
|
|
|
expectedAction multistep.StepAction
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "default config does nothing",
|
|
|
|
builderConfig: &Config{},
|
|
|
|
initialVMConfig: map[string]interface{}{
|
|
|
|
"ide2": "local:iso/Fedora-Server-dvd-x86_64-29-1.2.iso,media=cdrom",
|
|
|
|
},
|
|
|
|
expectCallSetConfig: false,
|
|
|
|
expectedVMConfig: map[string]interface{}{
|
|
|
|
"ide2": "local:iso/Fedora-Server-dvd-x86_64-29-1.2.iso,media=cdrom",
|
|
|
|
},
|
|
|
|
expectedAction: multistep.ActionContinue,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "should unmount when configured",
|
|
|
|
builderConfig: &Config{
|
|
|
|
UnmountISO: true,
|
|
|
|
},
|
|
|
|
initialVMConfig: map[string]interface{}{
|
|
|
|
"ide2": "local:iso/Fedora-Server-dvd-x86_64-29-1.2.iso,media=cdrom",
|
|
|
|
},
|
|
|
|
expectCallSetConfig: true,
|
|
|
|
expectedVMConfig: map[string]interface{}{
|
|
|
|
"ide2": "none,media=cdrom",
|
|
|
|
},
|
|
|
|
expectedAction: multistep.ActionContinue,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "no cd-drive with unmount=true should returns halt",
|
|
|
|
builderConfig: &Config{
|
|
|
|
UnmountISO: true,
|
|
|
|
},
|
|
|
|
initialVMConfig: map[string]interface{}{
|
|
|
|
"ide1": "local:iso/Fedora-Server-dvd-x86_64-29-1.2.iso,media=cdrom",
|
|
|
|
},
|
|
|
|
expectCallSetConfig: false,
|
|
|
|
expectedAction: multistep.ActionHalt,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "GetVmConfig error should return halt",
|
|
|
|
builderConfig: &Config{
|
|
|
|
UnmountISO: true,
|
|
|
|
},
|
|
|
|
getConfigErr: fmt.Errorf("some error"),
|
|
|
|
expectCallSetConfig: false,
|
|
|
|
expectedAction: multistep.ActionHalt,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "SetVmConfig error should return halt",
|
|
|
|
builderConfig: &Config{
|
|
|
|
UnmountISO: true,
|
|
|
|
},
|
|
|
|
initialVMConfig: map[string]interface{}{
|
|
|
|
"ide2": "local:iso/Fedora-Server-dvd-x86_64-29-1.2.iso,media=cdrom",
|
|
|
|
},
|
|
|
|
expectCallSetConfig: true,
|
|
|
|
setConfigErr: fmt.Errorf("some error"),
|
|
|
|
expectedAction: multistep.ActionHalt,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, c := range cs {
|
|
|
|
t.Run(c.name, func(t *testing.T) {
|
|
|
|
finalizer := finalizerMock{
|
|
|
|
getConfig: func() (map[string]interface{}, error) {
|
|
|
|
return c.initialVMConfig, c.getConfigErr
|
|
|
|
},
|
|
|
|
setConfig: func(cfg map[string]interface{}) (string, error) {
|
|
|
|
if !c.expectCallSetConfig {
|
|
|
|
t.Error("Did not expect SetVmConfig to be called")
|
|
|
|
}
|
|
|
|
for key, val := range c.expectedVMConfig {
|
|
|
|
if cfg[key] != val {
|
|
|
|
t.Errorf("Expected %q to be %q, got %q", key, val, cfg[key])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return "", c.setConfigErr
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
state := new(multistep.BasicStateBag)
|
|
|
|
state.Put("ui", packer.TestUi(t))
|
|
|
|
state.Put("iso-config", c.builderConfig)
|
|
|
|
state.Put("vmRef", proxmox.NewVmRef(1))
|
|
|
|
state.Put("proxmoxClient", finalizer)
|
|
|
|
|
|
|
|
step := stepFinalizeISOTemplate{}
|
|
|
|
action := step.Run(context.TODO(), state)
|
|
|
|
if action != c.expectedAction {
|
|
|
|
t.Errorf("Expected action to be %v, got %v", c.expectedAction, action)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|