Parcourir la source

Test changes related to fixes in https://github.com/QubesOS/qubes-manager/pull/176

Marta Marczykowska-Górecka il y a 5 ans
Parent
commit
893764a50c
2 fichiers modifiés avec 137 ajouts et 8 suppressions
  1. 127 0
      qubesmanager/tests/test_backup.py
  2. 10 8
      qubesmanager/tests/test_qube_manager.py

+ 127 - 0
qubesmanager/tests/test_backup.py

@@ -0,0 +1,127 @@
+#!/usr/bin/python3
+#
+# The Qubes OS Project, https://www.qubes-os.org/
+#
+# Copyright (C) 2016 Marta Marczykowska-Górecka
+#                                       <marmarta@invisiblethingslab.com>
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along
+# with this program; if not, write to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+import logging.handlers
+import sys
+import unittest
+import unittest.mock
+
+from PyQt4 import QtGui, QtTest, QtCore
+from qubesadmin import Qubes
+import qubesmanager.backup as backup_gui
+
+
+class BackupTest(unittest.TestCase):
+    def setUp(self):
+        super(QubeManagerTest, self).setUp()
+
+        self.mock_qprogress = unittest.mock.patch('PyQt4.QtGui.QProgressDialog')
+        self.mock_qprogress.start()
+
+        self.addCleanup(self.mock_qprogress.stop)
+
+        self.qapp = Qubes()
+        self.qtapp = QtGui.QApplication(sys.argv)
+        self.dispatcher = events.EventsDispatcher(self.qapp)
+
+        self.loop = quamash.QEventLoop(self.qtapp)
+
+        self.dialog = qube_manager.VmManagerWindow(
+            self.qtapp, self.qapp, self.dispatcher)
+
+    def tearDown(self):
+        self.qtapp.deleteLater()
+        self.dialog.deleteLater()
+        self.qtapp.processEvents()
+        self.qtapp.processEvents()
+        self.qtapp.processEvents()
+        self.loop.run_until_complete(asyncio.sleep(0))
+        self.loop.close()
+        del self.loop
+        del self.qtapp
+        del self.dialog
+        gc.collect()
+        super(QubeManagerTest, self).tearDown()
+
+class BackupTest(unittest.TestCase):
+    def setUp(self):
+        super(BackupTest, self).setUp()
+
+        # mock up nonexistence of saved backup settings
+        self.patcher = unittest.mock.patch('builtins.open')
+        self.mock_open = self.patcher.start()
+        self.mock_open.side_effect = FileNotFoundError()
+        self.addCleanup(self.patcher.stop)
+
+        self.qapp = Qubes()
+        self.qtapp = QtGui.QApplication(sys.argv)
+        self.dialog = backup_gui.BackupVMsWindow(self.qtapp, self.qapp)
+
+    def tearDown(self):
+        del self.dialog
+        del self.qtapp
+        del self.qapp
+        super(BackupTest, self).tearDown()
+
+    def test_00_window_loads(self):
+        self.assertTrue(self.dialog.select_vms_widget is not None)
+
+    def test_01_vms_load_correctly(self):
+        all_vms = len([vm for vm in self.qapp.domains
+                       if not vm.features.get('internal', False)])
+
+        selected_vms = self.dialog.select_vms_widget.selected_list.count()
+        available_vms = self.dialog.select_vms_widget.available_list.count()
+
+        self.assertEqual(all_vms, available_vms + selected_vms)
+
+    def test_02_correct_defaults(self):
+        # backup is compressed
+        self.assertTrue(self.dialog.compress_checkbox.isChecked(),
+                        "Compress backup should be checked by default")
+
+        # correct VMs are selected
+        include_in_backups_no = len([vm for vm in self.qapp.domains
+                                     if not vm.features.get('internal', False)
+                                     and getattr(vm, 'include_in_backups', True)])
+        selected_no = self.dialog.select_vms_widget.selected_list.count()
+        self.assertEqual(include_in_backups_no, selected_no,
+                         "Incorrect VMs selected by default")
+
+        # passphrase is empty
+        self.assertEqual(self.dialog.passphrase_line_edit.text(), "",
+                          "Passphrase should be empty")
+
+        # save defaults
+        self.assertTrue(self.dialog.save_profile_checkbox.isChecked(),
+                        "By default, profile should be saved")
+
+    # Check if target vms are selected
+    # Check if no default file loads correctly - another file??
+    # TODO: make a separate backup testing file to test various backup defaults
+
+
+if __name__ == "__main__":
+    ha_syslog = logging.handlers.SysLogHandler('/dev/log')
+    ha_syslog.setFormatter(
+        logging.Formatter('%(name)s[%(process)d]: %(message)s'))
+    logging.root.addHandler(ha_syslog)
+    unittest.main()

+ 10 - 8
qubesmanager/tests/test_qube_manager.py

@@ -47,7 +47,7 @@ class QubeManagerTest(unittest.TestCase):
         self.addCleanup(self.mock_qprogress.stop)
 
         self.qapp = Qubes()
-        self.qtapp = QtGui.QApplication(sys.argv)
+        self.qtapp = QtGui.QApplication(["test", "-style", "cleanlooks"])
         self.dispatcher = events.EventsDispatcher(self.qapp)
 
         self.loop = quamash.QEventLoop(self.qtapp)
@@ -64,8 +64,8 @@ class QubeManagerTest(unittest.TestCase):
         self.loop.run_until_complete(asyncio.sleep(0))
         self.loop.close()
         del self.loop
-        del self.qtapp
         del self.dialog
+        del self.qtapp
         gc.collect()
         super(QubeManagerTest, self).tearDown()
 
@@ -238,7 +238,6 @@ class QubeManagerTest(unittest.TestCase):
                 displayed_power_state, correct_power_state,
                 "Wrong power state displayed for {}".format(vm.name))
 
-    @unittest.expectedFailure
     def test_013_incorrect_settings_file(self):
         mock_settings = unittest.mock.MagicMock(spec=QtCore.QSettings)
 
@@ -250,9 +249,12 @@ class QubeManagerTest(unittest.TestCase):
         mock_settings.side_effect = (
             lambda x, *args, **kwargs: settings_result_dict.get(x))
 
-        with unittest.mock.patch('PyQt4.QtCore.QSettings.value', mock_settings):
+        with unittest.mock.patch('PyQt4.QtCore.QSettings.value', mock_settings),\
+                unittest.mock.patch('PyQt4.QtGui.QMessageBox.warning')\
+                as mock_warning:
             self.dialog = qube_manager.VmManagerWindow(
                 self.qtapp, self.qapp, self.dispatcher)
+            self.assertEqual(mock_warning.call_count, 1)
 
     def test_100_sorting(self):
 
@@ -654,14 +656,15 @@ class QubeManagerTest(unittest.TestCase):
         selected_vm = self._select_non_admin_vm()
         self.assertTrue(action.isEnabled())
 
-        mock_input.return_value = (selected_vm.name + "1", False)
+        mock_input.return_value = (selected_vm.name + "clone1", False)
         action.trigger()
         self.assertEqual(mock_thread.call_count, 0,
                          "Ignores cancelling clone VM")
 
-        mock_input.return_value = (selected_vm.name + "1", True)
+        mock_input.return_value = (selected_vm.name + "clone1", True)
         action.trigger()
-        mock_thread.assert_called_once_with(selected_vm, selected_vm.name + "1")
+        mock_thread.assert_called_once_with(selected_vm,
+                                            selected_vm.name + "clone1")
         mock_thread().finished.connect.assert_called_once_with(
             self.dialog.clear_threads)
         mock_thread().start.assert_called_once_with()
@@ -1143,7 +1146,6 @@ class QubeManagerTest(unittest.TestCase):
             else:
                 self.assertEqual(call_count, 0)
 
-    @unittest.expectedFailure
     def test_500_logs(self):
         self._select_admin_vm()