aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Auchter <michael.auchter@ni.com>2020-10-22 10:34:56 -0500
committerAaron Rossetto <aaron.rossetto@ni.com>2021-02-09 07:36:08 -0600
commitfa6e7a7430b3f4e4b534ac6d8f7d07b3319e0e39 (patch)
tree3c0b2ae125322eecf75f88a2d5165e908c8e91de
parent5824046ff307f62b22207c53fb9f7ccc0f13980b (diff)
downloaduhd-fa6e7a7430b3f4e4b534ac6d8f7d07b3319e0e39.tar.gz
uhd-fa6e7a7430b3f4e4b534ac6d8f7d07b3319e0e39.tar.bz2
uhd-fa6e7a7430b3f4e4b534ac6d8f7d07b3319e0e39.zip
mpm: filesystem_status: tolerate absence of mender
If the mender utility is not installed or exits with a failure, return NULL for the artifact rather than raising an exception (and disrupting device initialization).
-rw-r--r--mpm/python/usrp_mpm/periph_manager/base.py4
-rw-r--r--mpm/python/usrp_mpm/sys_utils/filesystem_status.py12
2 files changed, 10 insertions, 6 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py
index 324e47dc9..a6bffafed 100644
--- a/mpm/python/usrp_mpm/periph_manager/base.py
+++ b/mpm/python/usrp_mpm/periph_manager/base.py
@@ -168,7 +168,9 @@ class PeriphManagerBase(object):
version_string = ""
mboard_info["mpm_sw_version"] = version_string
- mboard_info["fs_version"] = get_fs_version()
+ fs_version = get_fs_version()
+ if fs_version is not None:
+ mboard_info["fs_version"] = fs_version
# Mender artifacts are generally not present on a machine hosting
# a simulated device--let it slide if not found on sim devices
try:
diff --git a/mpm/python/usrp_mpm/sys_utils/filesystem_status.py b/mpm/python/usrp_mpm/sys_utils/filesystem_status.py
index 865741316..b9617cf0a 100644
--- a/mpm/python/usrp_mpm/sys_utils/filesystem_status.py
+++ b/mpm/python/usrp_mpm/sys_utils/filesystem_status.py
@@ -38,16 +38,18 @@ def get_mender_artifact(filesystem_root='/', parse_manually=False):
# parse mender artifact manually
file = pathlib.Path(filesystem_root, 'etc/mender/artifact_info')
if not file.exists():
- return 'FILE NOT FOUND'
+ return None
return parse_artifact(file.read_text())
- else:
+ try:
output = subprocess.check_output(['/usr/bin/mender', '-show-artifact']).decode('utf-8')
return output.splitlines()[0]
+ except:
+ return None
def get_fs_version(filesystem_root='/'):
file = pathlib.Path(filesystem_root, 'etc/version')
if not file.exists():
- return 'FILE NOT FOUND'
+ return None
return file.read_text().splitlines()[0]
def get_opkg_status_date(date_only=False, filesystem_root='/'):
@@ -57,11 +59,11 @@ def get_opkg_status_date(date_only=False, filesystem_root='/'):
tformat = "%Y-%m-%d %H:%M:%S"
file = pathlib.Path(filesystem_root, 'var/lib/opkg/status')
if not file.exists():
- return 'FILE NOT FOUND'
+ return None
return time.strftime(tformat, time.gmtime(file.stat().st_mtime))
def get_opkg_status_md5sum(filesystem_root='/'):
file = pathlib.Path(filesystem_root, 'var/lib/opkg/status')
if not file.exists():
- return 'FILE NOT FOUND'
+ return None
return hashlib.md5sum(file.read_text()).hexdigest()