package common import ( "context" "io/ioutil" "os" "testing" "github.com/hashicorp/packer/packer-plugin-sdk/multistep" ) func TestStepCleanVMX_impl(t *testing.T) { var _ multistep.Step = new(StepCleanVMX) } func TestStepCleanVMX(t *testing.T) { state := testState(t) step := new(StepCleanVMX) vmxPath := testVMXFile(t) defer os.Remove(vmxPath) state.Put("vmx_path", vmxPath) // Test the run if action := step.Run(context.Background(), state); action != multistep.ActionContinue { t.Fatalf("bad action: %#v", action) } if _, ok := state.GetOk("error"); ok { t.Fatal("should NOT have error") } } func TestStepCleanVMX_floppyPath(t *testing.T) { state := testState(t) step := new(StepCleanVMX) vmxPath := testVMXFile(t) defer os.Remove(vmxPath) if err := ioutil.WriteFile(vmxPath, []byte(testVMXFloppyPath), 0644); err != nil { t.Fatalf("err: %s", err) } // Set the path to the temporary vmx state.Put("vmx_path", vmxPath) // Add the floppy device to the list of temporary build devices state.Put("temporaryDevices", []string{"floppy0"}) // Test the run if action := step.Run(context.Background(), state); action != multistep.ActionContinue { t.Fatalf("bad action: %#v", action) } if _, ok := state.GetOk("error"); ok { t.Fatal("should NOT have error") } // Test the resulting data vmxContents, err := ioutil.ReadFile(vmxPath) if err != nil { t.Fatalf("err: %s", err) } vmxData := ParseVMX(string(vmxContents)) cases := []struct { Key string Value string }{ {"floppy0.present", "FALSE"}, {"floppy0.filetype", ""}, {"floppy0.filename", ""}, } for _, tc := range cases { if tc.Value == "" { if _, ok := vmxData[tc.Key]; ok { t.Fatalf("should not have key: %s", tc.Key) } } else { if vmxData[tc.Key] != tc.Value { t.Fatalf("bad: %s %#v", tc.Key, vmxData[tc.Key]) } } } } func TestStepCleanVMX_isoPath(t *testing.T) { state := testState(t) step := new(StepCleanVMX) vmxPath := testVMXFile(t) defer os.Remove(vmxPath) if err := ioutil.WriteFile(vmxPath, []byte(testVMXISOPath), 0644); err != nil { t.Fatalf("err: %s", err) } // Set the path to the temporary vmx state.Put("vmx_path", vmxPath) // Add the cdrom device to the list of temporary build devices state.Put("temporaryDevices", []string{"ide0:0"}) // Test the run if action := step.Run(context.Background(), state); action != multistep.ActionContinue { t.Fatalf("bad action: %#v", action) } if _, ok := state.GetOk("error"); ok { t.Fatal("should NOT have error") } // Test the resulting data vmxContents, err := ioutil.ReadFile(vmxPath) if err != nil { t.Fatalf("err: %s", err) } vmxData := ParseVMX(string(vmxContents)) cases := []struct { Key string Value string }{ {"ide0:0.filename", "auto detect"}, {"ide0:0.devicetype", "cdrom-raw"}, {"ide0:1.filename", "bar"}, {"foo", "bar"}, } for _, tc := range cases { if tc.Value == "" { if _, ok := vmxData[tc.Key]; ok { t.Fatalf("should not have key: %s", tc.Key) } } else { if vmxData[tc.Key] != tc.Value { t.Fatalf("bad: %s %#v", tc.Key, vmxData[tc.Key]) } } } } func TestStepCleanVMX_ethernet(t *testing.T) { state := testState(t) step := &StepCleanVMX{ RemoveEthernetInterfaces: true, } vmxPath := testVMXFile(t) defer os.Remove(vmxPath) if err := ioutil.WriteFile(vmxPath, []byte(testVMXEthernet), 0644); err != nil { t.Fatalf("err: %s", err) } // Set the path to the temporary vmx state.Put("vmx_path", vmxPath) // TODO: Add the ethernet devices to the list of temporary build devices // state.Put("temporaryDevices", []string{"ethernet0", "ethernet1"}) // Test the run if action := step.Run(context.Background(), state); action != multistep.ActionContinue { t.Fatalf("bad action: %#v", action) } if _, ok := state.GetOk("error"); ok { t.Fatal("should NOT have error") } // Test the resulting data vmxContents, err := ioutil.ReadFile(vmxPath) if err != nil { t.Fatalf("err: %s", err) } vmxData := ParseVMX(string(vmxContents)) cases := []struct { Key string Value string }{ {"ethernet0.addresstype", ""}, {"ethernet0.bsdname", ""}, {"ethernet0.connectiontype", ""}, {"ethernet1.addresstype", ""}, {"ethernet1.bsdname", ""}, {"ethernet1.connectiontype", ""}, {"foo", "bar"}, } for _, tc := range cases { if tc.Value == "" { if _, ok := vmxData[tc.Key]; ok { t.Fatalf("should not have key: %s", tc.Key) } } else { if vmxData[tc.Key] != tc.Value { t.Fatalf("bad: %s %#v", tc.Key, vmxData[tc.Key]) } } } } const testVMXFloppyPath = ` floppy0.present = "TRUE" floppy0.filetype = "file" ` const testVMXISOPath = ` ide0:0.devicetype = "cdrom-image" ide0:0.filename = "foo" ide0:1.filename = "bar" foo = "bar" ` const testVMXEthernet = ` ethernet0.addresstype = "generated" ethernet0.bsdname = "en0" ethernet0.connectiontype = "nat" ethernet1.addresstype = "generated" ethernet1.bsdname = "en1" ethernet1.connectiontype = "nat" foo = "bar" `