diff --git a/qubesmanager/qube_manager.py b/qubesmanager/qube_manager.py index ab0b332..eb41bca 100644 --- a/qubesmanager/qube_manager.py +++ b/qubesmanager/qube_manager.py @@ -754,7 +754,6 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow): @QtCore.pyqtSlot(name='on_action_pausevm_triggered') def action_pausevm_triggered(self): vm = self.get_selected_vm() - assert vm.is_running() try: vm.pause() self.update_single_row(vm) @@ -769,7 +768,6 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow): @QtCore.pyqtSlot(name='on_action_shutdownvm_triggered') def action_shutdownvm_triggered(self): vm = self.get_selected_vm() - assert vm.is_running() reply = QtGui.QMessageBox.question( None, self.tr("Qube Shutdown Confirmation"), @@ -807,7 +805,6 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow): @QtCore.pyqtSlot(name='on_action_restartvm_triggered') def action_restartvm_triggered(self): vm = self.get_selected_vm() - assert vm.is_running() reply = QtGui.QMessageBox.question( None, self.tr("Qube Restart Confirmation"), @@ -819,7 +816,11 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow): self.qt_app.processEvents() if reply == QtGui.QMessageBox.Yes: - self.shutdown_vm(vm, and_restart=True) + # in case the user shut down the VM in the meantime + if vm.is_running(): + self.shutdown_vm(vm, and_restart=True) + else: + self.start_vm(vm) self.update_single_row(vm) @@ -827,14 +828,20 @@ class VmManagerWindow(ui_qubemanager.Ui_VmManagerWindow, QtGui.QMainWindow): @QtCore.pyqtSlot(name='on_action_killvm_triggered') def action_killvm_triggered(self): vm = self.get_selected_vm() - assert vm.is_running() or vm.is_paused() + if not (vm.is_running() or vm.is_paused()): + info = self.tr("Qube '{0}' is not running. Are you " + "absolutely sure you want to try to kill it?
" + "This will end (not shutdown!) all " + "the running applications within this " + "Qube.").format(vm.name) + else: + info = self.tr("Are you sure you want to kill the Qube " + "'{0}'?
This will end (not " + "shutdown!) all the running applications within " + "this Qube.").format(vm.name) reply = QtGui.QMessageBox.question( - None, self.tr("Qube Kill Confirmation"), - self.tr("Are you sure you want to kill the Qube '{0}'?
" - "This will end (not shutdown!) all the " - "running applications within this Qube.").format( - vm.name), + None, self.tr("Qube Kill Confirmation"), info, QtGui.QMessageBox.Yes | QtGui.QMessageBox.Cancel, QtGui.QMessageBox.Cancel)