Test if container_sweep is executed on unmounted devices

This change ensures that container_sweep is not run if a device is not mounted
and mount_check is set to True.

Change-Id: I823083c8431d9e61fd426508033ec9188503957b
This commit is contained in:
Christian Schwede 2015-09-02 10:52:34 +00:00
parent 5b01c5eadc
commit 58fcc07523

View File

@ -75,7 +75,8 @@ class TestContainerUpdater(unittest.TestCase):
self.assertTrue(cu.get_account_ring() is not None) self.assertTrue(cu.get_account_ring() is not None)
@mock.patch.object(container_updater, 'ismount') @mock.patch.object(container_updater, 'ismount')
def test_run_once_with_device_unmounted(self, mock_ismount): @mock.patch.object(container_updater.ContainerUpdater, 'container_sweep')
def test_run_once_with_device_unmounted(self, mock_sweep, mock_ismount):
mock_ismount.return_value = False mock_ismount.return_value = False
cu = container_updater.ContainerUpdater({ cu = container_updater.ContainerUpdater({
@ -89,9 +90,17 @@ class TestContainerUpdater(unittest.TestCase):
}) })
containers_dir = os.path.join(self.sda1, DATADIR) containers_dir = os.path.join(self.sda1, DATADIR)
os.mkdir(containers_dir) os.mkdir(containers_dir)
partition_dir = os.path.join(containers_dir, "a")
os.mkdir(partition_dir)
cu.run_once() cu.run_once()
self.assertTrue(os.path.exists(containers_dir)) # sanity check self.assertTrue(os.path.exists(containers_dir)) # sanity check
# only called if a partition dir exists
self.assertTrue(mock_sweep.called)
mock_sweep.reset_mock()
cu = container_updater.ContainerUpdater({ cu = container_updater.ContainerUpdater({
'devices': self.devices_dir, 'devices': self.devices_dir,
'mount_check': 'true', 'mount_check': 'true',
@ -107,6 +116,8 @@ class TestContainerUpdater(unittest.TestCase):
self.assertTrue(len(log_lines) > 0) self.assertTrue(len(log_lines) > 0)
msg = 'sda1 is not mounted' msg = 'sda1 is not mounted'
self.assertEqual(log_lines[0], msg) self.assertEqual(log_lines[0], msg)
# Ensure that the container_sweep did not run
self.assertFalse(mock_sweep.called)
def test_run_once(self): def test_run_once(self):
cu = container_updater.ContainerUpdater({ cu = container_updater.ContainerUpdater({