Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
FIX: Check and report mount table parse failures
  • Loading branch information
effigies committed Mar 1, 2018
commit 348f32ffec397b2ad72b0146feadc725e431ef7c
16 changes: 13 additions & 3 deletions nipype/utils/filemanip.py
Original file line number Diff line number Diff line change
Expand Up @@ -289,15 +289,25 @@ def _parse_mount_table(exit_code, output):
# <PATH>^^^^ ^^^^^<FSTYPE>
# OSX mount example: /dev/disk2 on / (hfs, local, journaled)
# <PATH>^ ^^^<FSTYPE>
pattern = re.compile(r'.*? on (/.*?) (?:type |\()([^\s,]+)(?:, |\)| )')
pattern = re.compile(r'.*? on (/.*?) (?:type |\()([^\s,\)]+)')

# Keep line and match for error reporting (match == None on failure)
# Ignore empty lines
matches = [(l, pattern.match(l))
for l in output.strip().splitlines() if l]

# (path, fstype) tuples, sorted by path length (longest first)
mount_info = sorted((pattern.match(l).groups()
for l in output.splitlines()),
mount_info = sorted((match.groups() for _, match in matches
if match is not None),
key=lambda x: len(x[0]), reverse=True)
cifs_paths = [path for path, fstype in mount_info
if fstype.lower() == 'cifs']

# Report failures as warnings
for line, match in matches:
if match is None:
fmlogger.debug("Cannot parse mount line: '%s'", line)

return [
mount for mount in mount_info
if any(mount[0].startswith(path) for path in cifs_paths)
Expand Down
11 changes: 10 additions & 1 deletion nipype/utils/tests/test_filemanip.py
Original file line number Diff line number Diff line change
Expand Up @@ -451,7 +451,16 @@ def test_related_files(file, length, expected_files):
tmpfs on /proc/sched_debug type tmpfs (rw,nosuid,size=65536k,mode=755)
tmpfs on /proc/scsi type tmpfs (ro,relatime)
tmpfs on /sys/firmware type tmpfs (ro,relatime)
''', 0, [('/data', 'cifs')])
''', 0, [('/data', 'cifs')]),
# From @yarikoptic - added blank lines to test for resilience
(r'''/proc on /proc type proc (rw,relatime)
sysfs on /sys type sysfs (rw,nosuid,nodev,noexec,relatime)
tmpfs on /dev/shm type tmpfs (rw,relatime)
devpts on /dev/pts type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=666)

devpts on /dev/ptmx type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=666)

''', 0, []),
)


Expand Down