This commit is contained in:
Marta Marczykowska-Górecka 2019-04-30 20:52:56 +02:00
parent 702ef75d1c
commit 893764a50c
No known key found for this signature in database
GPG Key ID: 9A752C30B26FD04B
2 changed files with 137 additions and 8 deletions

View File

@ -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()

View File

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