More safeguards for a VM that started in a weird way

If for any reason adding a VM failed, Qube Manager will attempt to add it on the next state event it receives.

references QubesOS/qubes-issues#5066
This commit is contained in:
Marta Marczykowska-Górecka 2019-06-03 21:21:48 +02:00
parent 492b8705b6
commit 8c1a9e5120
No known key found for this signature in database
GPG Key ID: 9A752C30B26FD04B

View File

@ -586,7 +586,7 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow):
row_to_delete = row row_to_delete = row
qid_to_delete = qid qid_to_delete = qid
if not row_to_delete: if not row_to_delete:
return # for some reason, the VM was removed in some other way return # for some reason, the VM was removed in some other way
del self.vms_in_table[qid_to_delete] del self.vms_in_table[qid_to_delete]
self.table.removeRow(row_to_delete.name_widget.row()) self.table.removeRow(row_to_delete.name_widget.row())
@ -596,6 +596,8 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow):
self.vms_in_table[vm.qid].info_widget.update_vm_state() self.vms_in_table[vm.qid].info_widget.update_vm_state()
except exc.QubesPropertyAccessError: except exc.QubesPropertyAccessError:
return # the VM was deleted before its status could be updated return # the VM was deleted before its status could be updated
except KeyError: # adding the VM failed for some reason
self.on_domain_added(None, None, vm)
if vm == self.get_selected_vm(): if vm == self.get_selected_vm():
self.table_selection_changed() self.table_selection_changed()