2020-09-08 20:02:22 -04:00
|
|
|
package qemu
|
|
|
|
|
|
|
|
import (
|
2020-09-15 19:14:52 -04:00
|
|
|
"fmt"
|
2020-09-08 20:02:22 -04:00
|
|
|
"testing"
|
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
"github.com/hashicorp/packer/helper/communicator"
|
2020-09-08 20:02:22 -04:00
|
|
|
"github.com/hashicorp/packer/packer"
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep/commonsteps"
|
2020-09-08 20:02:22 -04:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2020-09-15 19:14:52 -04:00
|
|
|
func runTestState(t *testing.T, config *Config) multistep.StateBag {
|
|
|
|
state := new(multistep.BasicStateBag)
|
|
|
|
state.Put("config", config)
|
|
|
|
|
|
|
|
d := new(DriverMock)
|
|
|
|
d.VersionResult = "3.0.0"
|
|
|
|
state.Put("driver", d)
|
|
|
|
|
|
|
|
state.Put("commHostPort", 5000)
|
|
|
|
state.Put("floppy_path", "fake_floppy_path")
|
|
|
|
state.Put("http_ip", "127.0.0.1")
|
|
|
|
state.Put("http_port", 1234)
|
|
|
|
state.Put("iso_path", "/path/to/test.iso")
|
|
|
|
state.Put("qemu_disk_paths", []string{})
|
|
|
|
state.Put("vnc_port", 5905)
|
|
|
|
state.Put("vnc_password", "fake_vnc_password")
|
|
|
|
|
|
|
|
return state
|
2020-09-08 20:02:22 -04:00
|
|
|
}
|
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
func Test_UserOverrides(t *testing.T) {
|
|
|
|
type testCase struct {
|
|
|
|
Config *Config
|
|
|
|
Expected []string
|
|
|
|
Reason string
|
2020-09-15 19:14:52 -04:00
|
|
|
}
|
2020-09-18 12:39:32 -04:00
|
|
|
testcases := []testCase{
|
|
|
|
{
|
|
|
|
&Config{
|
2020-11-11 18:04:28 -05:00
|
|
|
HTTPConfig: commonsteps.HTTPConfig{
|
2020-09-18 12:39:32 -04:00
|
|
|
HTTPDir: "http/directory",
|
|
|
|
},
|
|
|
|
OutputDir: "output/directory",
|
|
|
|
VMName: "myvm",
|
|
|
|
QemuArgs: [][]string{
|
|
|
|
{"-randomflag1", "{{.HTTPIP}}-{{.HTTPPort}}-{{.HTTPDir}}"},
|
|
|
|
{"-randomflag2", "{{.OutputDir}}-{{.Name}}"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
"-randomflag1", "127.0.0.1-1234-http/directory",
|
|
|
|
"-randomflag2", "output/directory-myvm",
|
|
|
|
"-device", ",netdev=user.0",
|
|
|
|
},
|
|
|
|
"Test that interpolation overrides work.",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
VMName: "myvm",
|
|
|
|
QemuArgs: [][]string{{"-display", "partydisplay"}},
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "partydisplay",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
"-device", ",netdev=user.0",
|
|
|
|
},
|
|
|
|
"User input overrides default, rest is populated as normal",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
VMName: "myvm",
|
|
|
|
NetDevice: "mynetdevice",
|
|
|
|
QemuArgs: [][]string{{"-device", "somerandomdevice"}},
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-device", "somerandomdevice",
|
|
|
|
"-device", "mynetdevice,netdev=user.0",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"Net device gets added",
|
|
|
|
},
|
2020-09-15 19:14:52 -04:00
|
|
|
}
|
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
for _, tc := range testcases {
|
|
|
|
state := runTestState(t, tc.Config)
|
2020-09-15 19:14:52 -04:00
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
step := &stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
}
|
|
|
|
args, err := step.getCommandArgs(tc.Config, state)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("should not have an error getting args. Error: %s", err)
|
|
|
|
}
|
2020-09-08 20:02:22 -04:00
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
expected := append([]string{
|
|
|
|
"-m", "0M",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-fda", "fake_floppy_path",
|
|
|
|
"-name", "myvm",
|
|
|
|
"-netdev", "user,id=user.0,hostfwd=tcp::5000-:0",
|
|
|
|
"-vnc", ":5905",
|
|
|
|
"-machine", "type=,accel="},
|
|
|
|
tc.Expected...)
|
2020-09-15 19:14:52 -04:00
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
assert.ElementsMatch(t, args, expected,
|
|
|
|
fmt.Sprintf("%s, \nRecieved: %#v", tc.Reason, args))
|
2020-09-15 19:14:52 -04:00
|
|
|
}
|
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
}
|
2020-09-15 19:42:08 -04:00
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
func Test_DriveAndDeviceArgs(t *testing.T) {
|
|
|
|
type testCase struct {
|
|
|
|
Config *Config
|
|
|
|
ExtraState map[string]interface{}
|
|
|
|
Step *stepRun
|
|
|
|
Expected []string
|
|
|
|
Reason string
|
2020-09-15 19:14:52 -04:00
|
|
|
}
|
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
testcases := []testCase{
|
|
|
|
{
|
|
|
|
&Config{},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"Boot value should default to once=d when diskImage isn't set",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
DiskImage: true,
|
|
|
|
DiskInterface: "virtio-scsi",
|
2020-09-15 19:14:52 -04:00
|
|
|
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
DetectZeroes: "off",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
DiskImage: true,
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "c",
|
|
|
|
"-device", "virtio-scsi-pci,id=scsi0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive0",
|
2020-10-08 14:36:36 -04:00
|
|
|
"-drive", "if=none,file=path_to_output,id=drive0,cache=writeback,discard=,format=qcow2",
|
2020-09-18 12:39:32 -04:00
|
|
|
"-drive", "file=fake_cd_path.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio-scsi interface, DiskImage true, extra cdrom, detectZeroes off",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
DiskImage: true,
|
|
|
|
DiskInterface: "virtio-scsi",
|
|
|
|
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
DetectZeroes: "on",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
DiskImage: true,
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "c",
|
|
|
|
"-device", "virtio-scsi-pci,id=scsi0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive0",
|
2020-10-08 14:36:36 -04:00
|
|
|
"-drive", "if=none,file=path_to_output,id=drive0,cache=writeback,discard=,format=qcow2,detect-zeroes=on",
|
2020-09-18 12:39:32 -04:00
|
|
|
"-drive", "file=fake_cd_path.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio-scsi interface, DiskImage true, extra cdrom, detectZeroes on",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
DiskInterface: "virtio-scsi",
|
|
|
|
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
DetectZeroes: "off",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
// when disk image is false, we will always have at least one
|
|
|
|
// disk path: the one we create to be the main disk.
|
|
|
|
"qemu_disk_paths": []string{"qemupath1", "qemupath2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-device", "virtio-scsi-pci,id=scsi0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive1",
|
|
|
|
"-drive", "if=none,file=qemupath1,id=drive0,cache=writeback,discard=,format=qcow2",
|
|
|
|
"-drive", "if=none,file=qemupath2,id=drive1,cache=writeback,discard=,format=qcow2",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
"-drive", "file=fake_cd_path.iso,index=1,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio-scsi interface, bootable iso, cdrom",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
DiskInterface: "virtio-scsi",
|
|
|
|
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
DetectZeroes: "on",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
// when disk image is false, we will always have at least one
|
|
|
|
// disk path: the one we create to be the main disk.
|
|
|
|
"qemu_disk_paths": []string{"qemupath1", "qemupath2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-device", "virtio-scsi-pci,id=scsi0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive1",
|
|
|
|
"-drive", "if=none,file=qemupath1,id=drive0,cache=writeback,discard=,format=qcow2,detect-zeroes=on",
|
|
|
|
"-drive", "if=none,file=qemupath2,id=drive1,cache=writeback,discard=,format=qcow2,detect-zeroes=on",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
"-drive", "file=fake_cd_path.iso,index=1,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio-scsi interface, DiskImage false, extra cdrom, detect zeroes on",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
DiskInterface: "virtio-scsi",
|
|
|
|
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
// when disk image is false, we will always have at least one
|
|
|
|
// disk path: the one we create to be the main disk.
|
|
|
|
"qemu_disk_paths": []string{"output/dir/path/mydisk.qcow2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-device", "virtio-scsi-pci,id=scsi0",
|
|
|
|
"-device", "scsi-hd,bus=scsi0.0,drive=drive0",
|
|
|
|
"-drive", "if=none,file=output/dir/path/mydisk.qcow2,id=drive0,cache=writeback,discard=,format=qcow2,detect-zeroes=",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio-scsi interface, DiskImage false, no extra disks or cds",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
"qemu_disk_paths": []string{"output/dir/path/mydisk.qcow2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-drive", "file=output/dir/path/mydisk.qcow2,if=,cache=,discard=,format=,detect-zeroes=",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
"-drive", "file=fake_cd_path.iso,index=1,media=cdrom",
|
|
|
|
},
|
|
|
|
"cd_path is set and DiskImage is false",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{},
|
|
|
|
map[string]interface{}{
|
|
|
|
// when disk image is false, we will always have at least one
|
|
|
|
// disk path: the one we create to be the main disk.
|
|
|
|
"qemu_disk_paths": []string{"output/dir/path/mydisk.qcow2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-drive", "file=output/dir/path/mydisk.qcow2,if=,cache=,discard=,format=,detect-zeroes=",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"empty config",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskInterface: "virtio",
|
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
// when disk image is false, we will always have at least one
|
|
|
|
// disk path: the one we create to be the main disk.
|
|
|
|
"qemu_disk_paths": []string{"output/dir/path/mydisk.qcow2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: false,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-boot", "once=d",
|
2020-10-08 14:36:36 -04:00
|
|
|
"-drive", "file=path_to_output,if=virtio,cache=writeback,format=qcow2",
|
2020-09-18 12:39:32 -04:00
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"version less than 2",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskInterface: "virtio",
|
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
"qemu_disk_paths": []string{"qemupath1", "qemupath2"},
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-drive", "file=qemupath1,if=virtio,cache=writeback,discard=,format=qcow2,detect-zeroes=",
|
|
|
|
"-drive", "file=qemupath2,if=virtio,cache=writeback,discard=,format=qcow2,detect-zeroes=",
|
|
|
|
"-drive", "file=fake_cd_path.iso,index=1,media=cdrom",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio interface with extra disks",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
DiskImage: true,
|
2020-10-08 14:36:36 -04:00
|
|
|
OutputDir: "path_to_output",
|
2020-09-18 12:39:32 -04:00
|
|
|
DiskInterface: "virtio",
|
|
|
|
DiskCache: "writeback",
|
|
|
|
Format: "qcow2",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"cd_path": "fake_cd_path.iso",
|
|
|
|
},
|
|
|
|
&stepRun{
|
|
|
|
DiskImage: true,
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-boot", "c",
|
2020-10-08 14:36:36 -04:00
|
|
|
"-drive", "file=path_to_output,if=virtio,cache=writeback,discard=,format=qcow2,detect-zeroes=",
|
2020-09-18 12:39:32 -04:00
|
|
|
"-drive", "file=fake_cd_path.iso,index=0,media=cdrom",
|
|
|
|
},
|
|
|
|
"virtio interface with disk image",
|
|
|
|
},
|
2020-09-15 19:14:52 -04:00
|
|
|
}
|
2020-09-18 12:39:32 -04:00
|
|
|
for _, tc := range testcases {
|
|
|
|
state := runTestState(t, &Config{})
|
|
|
|
for k, v := range tc.ExtraState {
|
|
|
|
state.Put(k, v)
|
|
|
|
}
|
2020-09-15 19:14:52 -04:00
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
args, err := tc.Step.getCommandArgs(tc.Config, state)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("should not have an error getting args. Error: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := append([]string{
|
|
|
|
"-m", "0M",
|
|
|
|
"-fda", "fake_floppy_path",
|
|
|
|
"-name", "",
|
|
|
|
"-netdev", "user,id=user.0,hostfwd=tcp::5000-:0",
|
|
|
|
"-vnc", ":5905",
|
|
|
|
"-machine", "type=,accel=",
|
|
|
|
"-device", ",netdev=user.0"},
|
|
|
|
tc.Expected...)
|
|
|
|
|
|
|
|
assert.ElementsMatch(t, args, expected,
|
|
|
|
fmt.Sprintf("%s, \nRecieved: %#v", tc.Reason, args))
|
|
|
|
}
|
2020-09-15 19:14:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func Test_OptionalConfigOptionsGetSet(t *testing.T) {
|
|
|
|
c := &Config{
|
|
|
|
VNCUsePassword: true,
|
|
|
|
QMPEnable: true,
|
|
|
|
QMPSocketPath: "qmp_path",
|
|
|
|
VMName: "MyFancyName",
|
|
|
|
MachineType: "pc",
|
|
|
|
Accelerator: "hvf",
|
|
|
|
}
|
|
|
|
|
|
|
|
state := runTestState(t, c)
|
2020-09-18 12:39:32 -04:00
|
|
|
step := &stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
}
|
|
|
|
args, err := step.getCommandArgs(c, state)
|
2020-09-15 19:14:52 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("should not have an error getting args. Error: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := []string{
|
|
|
|
"-display", "gtk",
|
|
|
|
"-m", "0M",
|
|
|
|
"-boot", "once=d",
|
|
|
|
"-fda", "fake_floppy_path",
|
|
|
|
"-name", "MyFancyName",
|
|
|
|
"-netdev", "user,id=user.0,hostfwd=tcp::5000-:0",
|
|
|
|
"-vnc", ":5905,password",
|
|
|
|
"-machine", "type=pc,accel=hvf",
|
|
|
|
"-device", ",netdev=user.0",
|
|
|
|
"-drive", "file=/path/to/test.iso,index=0,media=cdrom",
|
|
|
|
"-qmp", "unix:qmp_path,server,nowait",
|
|
|
|
}
|
|
|
|
|
2020-09-18 12:39:32 -04:00
|
|
|
assert.ElementsMatch(t, args, expected, "password flag should be set, and d drive should be set: %s", args)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tests for presence of Packer-generated arguments. Doesn't test that
|
|
|
|
// arguments which shouldn't be there are absent.
|
|
|
|
func Test_Defaults(t *testing.T) {
|
|
|
|
type testCase struct {
|
|
|
|
Config *Config
|
|
|
|
ExtraState map[string]interface{}
|
|
|
|
Step *stepRun
|
|
|
|
Expected []string
|
|
|
|
Reason string
|
|
|
|
}
|
|
|
|
|
|
|
|
testcases := []testCase{
|
|
|
|
{
|
|
|
|
&Config{},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-boot", "once=d"},
|
|
|
|
"Boot value should default to once=d",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{
|
|
|
|
DiskImage: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{"-boot", "c"},
|
|
|
|
"Boot value should be set to c when DiskImage is set on step",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
QMPEnable: true,
|
|
|
|
QMPSocketPath: "/path/to/socket",
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-qmp", "unix:/path/to/socket,server,nowait"},
|
|
|
|
"Args should contain -qmp when qmp_enable is set",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
QMPEnable: true,
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-qmp", "unix:,server,nowait"},
|
|
|
|
"Args contain -qmp even when socket path isn't set, if qmp enabled",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
VMName: "partyname",
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-name", "partyname"},
|
|
|
|
"Name is set from config",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-name", ""},
|
|
|
|
"Name is set from config, even when name is blank (which won't " +
|
|
|
|
"happen for real thanks to defaulting in build prepare)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
Accelerator: "none",
|
|
|
|
MachineType: "fancymachine",
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-machine", "type=fancymachine"},
|
|
|
|
"Don't add accelerator tag when no accelerator is set.",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
Accelerator: "kvm",
|
|
|
|
MachineType: "fancymachine",
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-machine", "type=fancymachine,accel=kvm"},
|
|
|
|
"Add accelerator tag when accelerator is set.",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
NetBridge: "fakebridge",
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-netdev", "bridge,id=user.0,br=fakebridge"},
|
|
|
|
"Add netbridge tag when netbridge is set.",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
CommConfig: CommConfig{
|
|
|
|
Comm: communicator.Config{
|
|
|
|
Type: "none",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-netdev", "user,id=user.0"},
|
|
|
|
"No host forwarding when no net bridge and no communicator",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
CommConfig: CommConfig{
|
|
|
|
Comm: communicator.Config{
|
|
|
|
Type: "ssh",
|
|
|
|
SSH: communicator.SSH{
|
|
|
|
SSHPort: 4567,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"commHostPort": 1111,
|
|
|
|
},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-netdev", "user,id=user.0,hostfwd=tcp::1111-:4567"},
|
|
|
|
"Host forwarding when a communicator is configured",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
VNCBindAddress: "1.1.1.1",
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"vnc_port": 5959,
|
|
|
|
},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-vnc", "1.1.1.1:5959"},
|
|
|
|
"no VNC password should be set",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
VNCBindAddress: "1.1.1.1",
|
|
|
|
VNCUsePassword: true,
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"vnc_port": 5959,
|
|
|
|
},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-vnc", "1.1.1.1:5959,password"},
|
|
|
|
"VNC password should be set",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
MemorySize: 2345,
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-m", "2345M"},
|
|
|
|
"Memory is set, with unit M",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
CpuCount: 2,
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-smp", "cpus=2,sockets=2"},
|
|
|
|
"both cpus and sockets are set to config's CpuCount",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
CpuCount: 2,
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-smp", "cpus=2,sockets=2"},
|
|
|
|
"both cpus and sockets are set to config's CpuCount",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
CpuCount: 2,
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"floppy_path": "/path/to/floppy",
|
|
|
|
},
|
|
|
|
&stepRun{ui: packer.TestUi(t)},
|
|
|
|
[]string{"-fda", "/path/to/floppy"},
|
|
|
|
"floppy path should be set under fda flag, when it exists",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
Headless: false,
|
|
|
|
Display: "fakedisplay",
|
|
|
|
UseDefaultDisplay: false,
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{"-display", "fakedisplay"},
|
|
|
|
"Display option should value config display",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
&Config{
|
|
|
|
Headless: false,
|
|
|
|
},
|
|
|
|
map[string]interface{}{},
|
|
|
|
&stepRun{
|
|
|
|
atLeastVersion2: true,
|
|
|
|
ui: packer.TestUi(t),
|
|
|
|
},
|
|
|
|
[]string{"-display", "gtk"},
|
|
|
|
"Display option should default to gtk",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range testcases {
|
|
|
|
state := runTestState(t, &Config{})
|
|
|
|
for k, v := range tc.ExtraState {
|
|
|
|
state.Put(k, v)
|
|
|
|
}
|
|
|
|
|
|
|
|
args, err := tc.Step.getCommandArgs(tc.Config, state)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("should not have an error getting args. Error: %s", err)
|
|
|
|
}
|
|
|
|
if !matchArgument(args, tc.Expected) {
|
|
|
|
t.Fatalf("Couldn't find %#v in result. Got: %#v, Reason: %s",
|
|
|
|
tc.Expected, args, tc.Reason)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// This test makes sure that arguments don't end up in the final boot command
|
|
|
|
// if they aren't configured in the config.
|
|
|
|
// func TestDefaultsAbsentValues(t *testing.T) {}
|
|
|
|
func matchArgument(actual []string, expected []string) bool {
|
|
|
|
key := expected[0]
|
|
|
|
for i, k := range actual {
|
|
|
|
if key == k {
|
|
|
|
if expected[1] == actual[i+1] {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
2020-09-08 20:02:22 -04:00
|
|
|
}
|