Skip to content

Commit

Permalink
AppleHV: Fix machine rm error message
Browse files Browse the repository at this point in the history
Fix machine not found error message on rm to be consistent with qemu.

Signed-off-by: Ashley Cui <[email protected]>
  • Loading branch information
ashley-cui committed Nov 1, 2023
1 parent 0cd2009 commit f6ec210
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 13 deletions.
9 changes: 4 additions & 5 deletions pkg/machine/applehv/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,12 +53,11 @@ func (v AppleHVVirtualization) CheckExclusiveActiveVM() (bool, string, error) {
}

func (v AppleHVVirtualization) IsValidVMName(name string) (bool, error) {
mm := MacMachine{Name: name}
configDir, err := machine.GetConfDir(machine.AppleHvVirt)
if err != nil {
return false, err
}
if err := loadMacMachineFromJSON(configDir, &mm); err != nil {
if _, err := loadMacMachineFromJSON(configDir); err != nil {
return false, err
}
return true, nil
Expand Down Expand Up @@ -183,14 +182,14 @@ func (v AppleHVVirtualization) loadFromLocalJson() ([]*MacMachine, error) {
}

for _, jsonFile := range jsonFiles {
mm := MacMachine{}
if err := loadMacMachineFromJSON(jsonFile, &mm); err != nil {
mm, err := loadMacMachineFromJSON(jsonFile)
if err != nil {
return nil, err
}
if err != nil {
return nil, err
}
mms = append(mms, &mm)
mms = append(mms, mm)
}
return mms, nil
}
19 changes: 12 additions & 7 deletions pkg/machine/applehv/machine.go
Original file line number Diff line number Diff line change
Expand Up @@ -761,9 +761,9 @@ func (m *MacMachine) loadFromFile() (*MacMachine, error) {
if err != nil {
return nil, err
}
mm := MacMachine{}

if err := loadMacMachineFromJSON(jsonPath, &mm); err != nil {
mm, err := loadMacMachineFromJSON(jsonPath)
if err != nil {
return nil, err
}

Expand All @@ -773,18 +773,23 @@ func (m *MacMachine) loadFromFile() (*MacMachine, error) {
}
mm.lock = lock

return &mm, nil
return mm, nil
}

func loadMacMachineFromJSON(fqConfigPath string, macMachine *MacMachine) error {
func loadMacMachineFromJSON(fqConfigPath string) (*MacMachine, error) {
b, err := os.ReadFile(fqConfigPath)
if err != nil {
if errors.Is(err, fs.ErrNotExist) {
return fmt.Errorf("%q: %w", fqConfigPath, machine.ErrNoSuchVM)
name := strings.TrimSuffix(filepath.Base(fqConfigPath), ".json")
return nil, fmt.Errorf("%s: %w", name, machine.ErrNoSuchVM)
}
return err
return nil, err
}
mm := new(MacMachine)
if err := json.Unmarshal(b, mm); err != nil {
return nil, err
}
return json.Unmarshal(b, macMachine)
return mm, nil
}

func (m *MacMachine) jsonConfigPath() (string, error) {
Expand Down
9 changes: 8 additions & 1 deletion pkg/machine/e2e/rm_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,9 @@ var _ = Describe("podman machine rm", func() {
})

It("Remove machine", func() {
name := randomString()
i := new(initMachine)
session, err := mb.setCmd(i.withImagePath(mb.imagePath)).run()
session, err := mb.setName(name).setCmd(i.withImagePath(mb.imagePath)).run()
Expect(err).ToNot(HaveOccurred())
Expect(session).To(Exit(0))
rm := rmMachine{}
Expand All @@ -46,6 +47,12 @@ var _ = Describe("podman machine rm", func() {
_, ec, err := mb.toQemuInspectInfo()
Expect(err).ToNot(HaveOccurred())
Expect(ec).To(Equal(125))

// Removing non-existent machine should fail
removeSession2, err := mb.setCmd(rm.withForce()).run()
Expect(err).ToNot(HaveOccurred())
Expect(removeSession2).To(Exit(125))
Expect(removeSession2.errorToString()).To(ContainSubstring(fmt.Sprintf("%s: VM does not exist", name)))
})

It("Remove running machine", func() {
Expand Down

0 comments on commit f6ec210

Please sign in to comment.