Use lsblk json output for safety_check_block_device
Change-Id: Ibfc2e203287d92e66567c33dc48f59392852b88e
This commit is contained in:
parent
beb7484858
commit
b5fac66bc3
@ -3016,26 +3016,24 @@ def safety_check_block_device(node, device):
|
|||||||
di_info = node.get('driver_internal_info', {})
|
di_info = node.get('driver_internal_info', {})
|
||||||
if not di_info.get('wipe_special_filesystems', True):
|
if not di_info.get('wipe_special_filesystems', True):
|
||||||
return
|
return
|
||||||
report, _e = il_utils.execute('lsblk', '-Pbia',
|
lsblk_ids = ['UUID', 'PTUUID', 'PARTTYPE', 'PARTUUID']
|
||||||
'-oFSTYPE,UUID,PTUUID,PARTTYPE,PARTUUID',
|
report = il_utils.execute('lsblk', '-bia', '--json',
|
||||||
device)
|
'-o{}'.format(','.join(lsblk_ids)),
|
||||||
|
device, check_exit_code=[0])[0]
|
||||||
|
|
||||||
lines = report.splitlines()
|
try:
|
||||||
|
report_json = json.loads(report)
|
||||||
|
except json.decoder.JSONDecodeError as ex:
|
||||||
|
LOG.error("Unable to decode lsblk output, invalid JSON: %s", ex)
|
||||||
|
|
||||||
|
device_json = report_json['blockdevices'][0]
|
||||||
identified_fs_types = []
|
identified_fs_types = []
|
||||||
identified_ids = []
|
identified_ids = []
|
||||||
for line in lines:
|
|
||||||
device = {}
|
fstype = device_json.get('fstype')
|
||||||
# Split into KEY=VAL pairs
|
identified_fs_types.append(fstype)
|
||||||
vals = shlex.split(line)
|
for key in lsblk_ids:
|
||||||
if not vals:
|
identified_ids.append(device_json.get(key.lower()))
|
||||||
continue
|
|
||||||
for key, val in (v.split('=', 1) for v in vals):
|
|
||||||
if key == 'FSTYPE':
|
|
||||||
identified_fs_types.append(val)
|
|
||||||
if key in ['UUID', 'PTUUID', 'PARTTYPE', 'PARTUUID']:
|
|
||||||
identified_ids.append(val)
|
|
||||||
# Ignore block types not specified
|
|
||||||
|
|
||||||
_check_for_special_partitions_filesystems(
|
_check_for_special_partitions_filesystems(
|
||||||
device,
|
device,
|
||||||
@ -3053,7 +3051,6 @@ def _check_for_special_partitions_filesystems(device, ids, fs_types):
|
|||||||
be discovered which suggests a shared disk clustered filesystem
|
be discovered which suggests a shared disk clustered filesystem
|
||||||
has been discovered.
|
has been discovered.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
guarded_ids = {
|
guarded_ids = {
|
||||||
# Apparently GPFS can used shared volumes....
|
# Apparently GPFS can used shared volumes....
|
||||||
'37AFFC90-EF7D-4E96-91C3-2D7AE055B174': 'IBM GPFS Partition',
|
'37AFFC90-EF7D-4E96-91C3-2D7AE055B174': 'IBM GPFS Partition',
|
||||||
|
@ -5154,29 +5154,31 @@ class TestProtectedDiskSafetyChecks(base.IronicAgentTest):
|
|||||||
mock_execute.assert_not_called()
|
mock_execute.assert_not_called()
|
||||||
|
|
||||||
def test_special_filesystem_guard_enabled_no_results(self, mock_execute):
|
def test_special_filesystem_guard_enabled_no_results(self, mock_execute):
|
||||||
mock_execute.return_value = ('', '')
|
mock_execute.return_value = ('{"blockdevices": [{"foo": "bar"}]}', '')
|
||||||
hardware.safety_check_block_device({}, '/dev/foo')
|
hardware.safety_check_block_device({}, '/dev/foo')
|
||||||
|
|
||||||
def test_special_filesystem_guard_raises(self, mock_execute):
|
def test_special_filesystem_guard_raises(self, mock_execute):
|
||||||
GFS2 = 'FSTYPE="gfs2"\n'
|
GFS2 = '"fstype": "gfs2"'
|
||||||
GPFS1 = 'UUID="37AFFC90-EF7D-4E96-91C3-2D7AE055B174"\n'
|
GPFS1 = '"uuid": "37AFFC90-EF7D-4E96-91C3-2D7AE055B174"'
|
||||||
GPFS2 = 'PTUUID="37AFFC90-EF7D-4E96-91C3-2D7AE055B174"\n'
|
GPFS2 = '"ptuuid": "37AFFC90-EF7D-4E96-91C3-2D7AE055B174"'
|
||||||
GPFS3 = 'PARTTYPE="37AFFC90-EF7D-4E96-91C3-2D7AE055B174"\n'
|
GPFS3 = '"parttype": "37AFFC90-EF7D-4E96-91C3-2D7AE055B174"'
|
||||||
GPFS4 = 'PARTUUID="37AFFC90-EF7D-4E96-91C3-2D7AE055B174"\n'
|
GPFS4 = '"partuuid": "37AFFC90-EF7D-4E96-91C3-2D7AE055B174"'
|
||||||
VMFS1 = 'UUID="AA31E02A-400F-11DB-9590-000C2911D1B8"\n'
|
VMFS1 = '"uuid": "AA31E02A-400F-11DB-9590-000C2911D1B8"'
|
||||||
VMFS2 = 'UUID="AA31E02A-400F-11DB-9590-000C2911D1B8"\n'
|
VMFS2 = '"uuid": "AA31E02A-400F-11DB-9590-000C2911D1B8"'
|
||||||
VMFS3 = 'UUID="AA31E02A-400F-11DB-9590-000C2911D1B8"\n'
|
VMFS3 = '"uuid": "AA31E02A-400F-11DB-9590-000C2911D1B8"'
|
||||||
VMFS4 = 'UUID="AA31E02A-400F-11DB-9590-000C2911D1B8"\n'
|
VMFS4 = '"uuid": "AA31E02A-400F-11DB-9590-000C2911D1B8"'
|
||||||
VMFS5 = 'UUID="0xfb"\n'
|
VMFS5 = '"uuid": "0xfb"'
|
||||||
VMFS6 = 'PTUUID="0xfb"\n'
|
VMFS6 = '"ptuuid": "0xfb"'
|
||||||
VMFS7 = 'PARTTYPE="0xfb"\n'
|
VMFS7 = '"parttype": "0xfb"'
|
||||||
VMFS8 = 'PARTUUID="0xfb"\n'
|
VMFS8 = '"partuuid": "0xfb"'
|
||||||
|
|
||||||
expected_failures = [GFS2, GPFS1, GPFS2, GPFS3, GPFS4, VMFS1, VMFS2,
|
expected_failures = [GFS2, GPFS1, GPFS2, GPFS3, GPFS4, VMFS1, VMFS2,
|
||||||
VMFS3, VMFS4, VMFS5, VMFS6, VMFS7, VMFS8]
|
VMFS3, VMFS4, VMFS5, VMFS6, VMFS7, VMFS8]
|
||||||
for failure in expected_failures:
|
for failure in expected_failures:
|
||||||
mock_execute.reset_mock()
|
mock_execute.reset_mock()
|
||||||
mock_execute.return_value = (failure, '')
|
dev_failure = ('{{"blockdevices": [{{{failure}}}]}}'
|
||||||
|
.format(failure=failure))
|
||||||
|
mock_execute.return_value = (dev_failure, '')
|
||||||
self.assertRaises(errors.ProtectedDeviceError,
|
self.assertRaises(errors.ProtectedDeviceError,
|
||||||
hardware.safety_check_block_device,
|
hardware.safety_check_block_device,
|
||||||
{}, '/dev/foo')
|
{}, '/dev/foo')
|
||||||
|
Loading…
Reference in New Issue
Block a user