Remove isfile check from place_loaders_for_boot
isfile will return False for reasons other than the file being missing (such as a permission denied due to /boot/efi being only root readable). Having the isfile check prevents the actual reason from being logged. This change removes the isfile check so that the error can be triggered and logged in the copy2 call. Change-Id: I1d855a7d7c97cabb83cdb3efc284a00bd65d4d5f
This commit is contained in:
parent
5d5d3e8c16
commit
44ac507796
@ -1266,13 +1266,6 @@ def place_loaders_for_boot(base_path):
|
|||||||
raise exception.IncorrectConfiguration(msg)
|
raise exception.IncorrectConfiguration(msg)
|
||||||
|
|
||||||
full_dest = os.path.join(base_path, dest)
|
full_dest = os.path.join(base_path, dest)
|
||||||
if not os.path.isfile(src):
|
|
||||||
msg = ('Was not able to find source path %(src)s '
|
|
||||||
'to copy to %(dest)s.' %
|
|
||||||
{'src': src, 'dest': full_dest})
|
|
||||||
LOG.error(msg)
|
|
||||||
raise exception.IncorrectConfiguration(error=msg)
|
|
||||||
|
|
||||||
LOG.debug('Copying bootloader %(dest)s from %(src)s.',
|
LOG.debug('Copying bootloader %(dest)s from %(src)s.',
|
||||||
{'src': src, 'dest': full_dest})
|
{'src': src, 'dest': full_dest})
|
||||||
try:
|
try:
|
||||||
|
@ -2184,7 +2184,6 @@ class TFTPImageCacheTestCase(db_base.DbTestCase):
|
|||||||
|
|
||||||
|
|
||||||
@mock.patch.object(os, 'makedirs', autospec=True)
|
@mock.patch.object(os, 'makedirs', autospec=True)
|
||||||
@mock.patch.object(os.path, 'isfile', autospec=True)
|
|
||||||
@mock.patch.object(os, 'chmod', autospec=True)
|
@mock.patch.object(os, 'chmod', autospec=True)
|
||||||
@mock.patch.object(shutil, 'copy2', autospec=True)
|
@mock.patch.object(shutil, 'copy2', autospec=True)
|
||||||
class TestPXEUtilsBootloader(db_base.DbTestCase):
|
class TestPXEUtilsBootloader(db_base.DbTestCase):
|
||||||
@ -2193,43 +2192,34 @@ class TestPXEUtilsBootloader(db_base.DbTestCase):
|
|||||||
super(TestPXEUtilsBootloader, self).setUp()
|
super(TestPXEUtilsBootloader, self).setUp()
|
||||||
|
|
||||||
def test_place_loaders_for_boot_default_noop(self, mock_copy2,
|
def test_place_loaders_for_boot_default_noop(self, mock_copy2,
|
||||||
mock_chmod, mock_isfile,
|
mock_chmod, mock_makedirs):
|
||||||
mock_makedirs):
|
|
||||||
res = pxe_utils.place_loaders_for_boot('/httpboot')
|
res = pxe_utils.place_loaders_for_boot('/httpboot')
|
||||||
self.assertIsNone(res)
|
self.assertIsNone(res)
|
||||||
self.assertFalse(mock_copy2.called)
|
self.assertFalse(mock_copy2.called)
|
||||||
self.assertFalse(mock_chmod.called)
|
self.assertFalse(mock_chmod.called)
|
||||||
self.assertFalse(mock_isfile.called)
|
|
||||||
self.assertFalse(mock_makedirs.called)
|
self.assertFalse(mock_makedirs.called)
|
||||||
self.assertFalse(mock_makedirs.called)
|
self.assertFalse(mock_makedirs.called)
|
||||||
|
|
||||||
def test_place_loaders_for_boot_no_source(self, mock_copy2,
|
def test_place_loaders_for_boot_no_source(self, mock_copy2,
|
||||||
mock_chmod, mock_isfile,
|
mock_chmod, mock_makedirs):
|
||||||
mock_makedirs):
|
|
||||||
self.config(loader_file_paths='grubaa64.efi:/path/to/file',
|
self.config(loader_file_paths='grubaa64.efi:/path/to/file',
|
||||||
group='pxe')
|
group='pxe')
|
||||||
mock_isfile.return_value = False
|
mock_copy2.side_effect = FileNotFoundError('No such file or directory')
|
||||||
self.assertRaises(exception.IncorrectConfiguration,
|
self.assertRaises(exception.IncorrectConfiguration,
|
||||||
pxe_utils.place_loaders_for_boot,
|
pxe_utils.place_loaders_for_boot,
|
||||||
'/tftpboot')
|
'/tftpboot')
|
||||||
self.assertFalse(mock_copy2.called)
|
self.assertTrue(mock_copy2.called)
|
||||||
self.assertFalse(mock_chmod.called)
|
self.assertFalse(mock_chmod.called)
|
||||||
self.assertFalse(mock_makedirs.called)
|
self.assertFalse(mock_makedirs.called)
|
||||||
|
|
||||||
def test_place_loaders_for_boot_two_files(self, mock_copy2,
|
def test_place_loaders_for_boot_two_files(self, mock_copy2,
|
||||||
mock_chmod, mock_isfile,
|
mock_chmod, mock_makedirs):
|
||||||
mock_makedirs):
|
|
||||||
self.config(loader_file_paths='bootx64.efi:/path/to/shimx64.efi,'
|
self.config(loader_file_paths='bootx64.efi:/path/to/shimx64.efi,'
|
||||||
'grubx64.efi:/path/to/grubx64.efi',
|
'grubx64.efi:/path/to/grubx64.efi',
|
||||||
group='pxe')
|
group='pxe')
|
||||||
self.config(file_permission=420, group='pxe')
|
self.config(file_permission=420, group='pxe')
|
||||||
mock_isfile.return_value = True
|
|
||||||
res = pxe_utils.place_loaders_for_boot('/tftpboot')
|
res = pxe_utils.place_loaders_for_boot('/tftpboot')
|
||||||
self.assertIsNone(res)
|
self.assertIsNone(res)
|
||||||
mock_isfile.assert_has_calls([
|
|
||||||
mock.call('/path/to/shimx64.efi'),
|
|
||||||
mock.call('/path/to/grubx64.efi'),
|
|
||||||
])
|
|
||||||
mock_copy2.assert_has_calls([
|
mock_copy2.assert_has_calls([
|
||||||
mock.call('/path/to/shimx64.efi', '/tftpboot/bootx64.efi'),
|
mock.call('/path/to/shimx64.efi', '/tftpboot/bootx64.efi'),
|
||||||
mock.call('/path/to/grubx64.efi', '/tftpboot/grubx64.efi')
|
mock.call('/path/to/grubx64.efi', '/tftpboot/grubx64.efi')
|
||||||
@ -2241,19 +2231,31 @@ class TestPXEUtilsBootloader(db_base.DbTestCase):
|
|||||||
self.assertFalse(mock_makedirs.called)
|
self.assertFalse(mock_makedirs.called)
|
||||||
|
|
||||||
def test_place_loaders_for_boot_two_files_exception_on_copy(
|
def test_place_loaders_for_boot_two_files_exception_on_copy(
|
||||||
self, mock_copy2, mock_chmod, mock_isfile, mock_makedirs):
|
self, mock_copy2, mock_chmod, mock_makedirs):
|
||||||
|
self.config(loader_file_paths='bootx64.efi:/path/to/shimx64.efi,'
|
||||||
|
'grubx64.efi:/path/to/grubx64.efi',
|
||||||
|
group='pxe')
|
||||||
|
self.config(file_permission=420, group='pxe')
|
||||||
|
mock_copy2.side_effect = PermissionError('Permission denied')
|
||||||
|
self.assertRaises(exception.IncorrectConfiguration,
|
||||||
|
pxe_utils.place_loaders_for_boot,
|
||||||
|
'/tftpboot')
|
||||||
|
mock_copy2.assert_has_calls([
|
||||||
|
mock.call('/path/to/shimx64.efi', '/tftpboot/bootx64.efi'),
|
||||||
|
])
|
||||||
|
mock_chmod.assert_not_called()
|
||||||
|
self.assertFalse(mock_makedirs.called)
|
||||||
|
|
||||||
|
def test_place_loaders_for_boot_two_files_exception_on_chmod(
|
||||||
|
self, mock_copy2, mock_chmod, mock_makedirs):
|
||||||
self.config(loader_file_paths='bootx64.efi:/path/to/shimx64.efi,'
|
self.config(loader_file_paths='bootx64.efi:/path/to/shimx64.efi,'
|
||||||
'grubx64.efi:/path/to/grubx64.efi',
|
'grubx64.efi:/path/to/grubx64.efi',
|
||||||
group='pxe')
|
group='pxe')
|
||||||
self.config(file_permission=420, group='pxe')
|
self.config(file_permission=420, group='pxe')
|
||||||
mock_isfile.side_effect = iter([True, False, True, False])
|
|
||||||
mock_chmod.side_effect = OSError('Chmod not permitted')
|
mock_chmod.side_effect = OSError('Chmod not permitted')
|
||||||
self.assertRaises(exception.IncorrectConfiguration,
|
self.assertRaises(exception.IncorrectConfiguration,
|
||||||
pxe_utils.place_loaders_for_boot,
|
pxe_utils.place_loaders_for_boot,
|
||||||
'/tftpboot')
|
'/tftpboot')
|
||||||
mock_isfile.assert_has_calls([
|
|
||||||
mock.call('/path/to/shimx64.efi'),
|
|
||||||
])
|
|
||||||
mock_copy2.assert_has_calls([
|
mock_copy2.assert_has_calls([
|
||||||
mock.call('/path/to/shimx64.efi', '/tftpboot/bootx64.efi'),
|
mock.call('/path/to/shimx64.efi', '/tftpboot/bootx64.efi'),
|
||||||
])
|
])
|
||||||
@ -2263,7 +2265,7 @@ class TestPXEUtilsBootloader(db_base.DbTestCase):
|
|||||||
self.assertFalse(mock_makedirs.called)
|
self.assertFalse(mock_makedirs.called)
|
||||||
|
|
||||||
def test_place_loaders_for_boot_raises_exception_with_absolute_path(
|
def test_place_loaders_for_boot_raises_exception_with_absolute_path(
|
||||||
self, mock_copy2, mock_chmod, mock_isfile, mock_makedirs):
|
self, mock_copy2, mock_chmod, mock_makedirs):
|
||||||
self.config(
|
self.config(
|
||||||
loader_file_paths='/tftpboot/bootx64.efi:/path/to/shimx64.efi',
|
loader_file_paths='/tftpboot/bootx64.efi:/path/to/shimx64.efi',
|
||||||
group='pxe')
|
group='pxe')
|
||||||
@ -2275,19 +2277,14 @@ class TestPXEUtilsBootloader(db_base.DbTestCase):
|
|||||||
'/tftpboot/bootx64.efi', str(exc))
|
'/tftpboot/bootx64.efi', str(exc))
|
||||||
|
|
||||||
def test_place_loaders_for_boot_two_files_relative_path(
|
def test_place_loaders_for_boot_two_files_relative_path(
|
||||||
self, mock_copy2, mock_chmod, mock_isfile, mock_makedirs):
|
self, mock_copy2, mock_chmod, mock_makedirs):
|
||||||
self.config(loader_file_paths='grub/bootx64.efi:/path/to/shimx64.efi,'
|
self.config(loader_file_paths='grub/bootx64.efi:/path/to/shimx64.efi,'
|
||||||
'grub/grubx64.efi:/path/to/grubx64.efi',
|
'grub/grubx64.efi:/path/to/grubx64.efi',
|
||||||
group='pxe')
|
group='pxe')
|
||||||
self.config(dir_permission=484, group='pxe')
|
self.config(dir_permission=484, group='pxe')
|
||||||
self.config(file_permission=420, group='pxe')
|
self.config(file_permission=420, group='pxe')
|
||||||
mock_isfile.return_value = True
|
|
||||||
res = pxe_utils.place_loaders_for_boot('/tftpboot')
|
res = pxe_utils.place_loaders_for_boot('/tftpboot')
|
||||||
self.assertIsNone(res)
|
self.assertIsNone(res)
|
||||||
mock_isfile.assert_has_calls([
|
|
||||||
mock.call('/path/to/shimx64.efi'),
|
|
||||||
mock.call('/path/to/grubx64.efi'),
|
|
||||||
])
|
|
||||||
mock_copy2.assert_has_calls([
|
mock_copy2.assert_has_calls([
|
||||||
mock.call('/path/to/shimx64.efi', '/tftpboot/grub/bootx64.efi'),
|
mock.call('/path/to/shimx64.efi', '/tftpboot/grub/bootx64.efi'),
|
||||||
mock.call('/path/to/grubx64.efi', '/tftpboot/grub/grubx64.efi')
|
mock.call('/path/to/grubx64.efi', '/tftpboot/grub/grubx64.efi')
|
||||||
|
Loading…
Reference in New Issue
Block a user