X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fe0751fd604792c7a0884e3533d8acb03b6038d9..b61a80b93308582b91e89561dc373a1ea33658a9:/services/fuse/tests/test_unmount.py diff --git a/services/fuse/tests/test_unmount.py b/services/fuse/tests/test_unmount.py index 972edaadc8..1b0fac0d32 100644 --- a/services/fuse/tests/test_unmount.py +++ b/services/fuse/tests/test_unmount.py @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + import os import subprocess import time @@ -32,10 +36,41 @@ class UnmountTest(IntegrationTest): self.assertNotIn(' '+self.mnt+' ', m) def _mounted(self, mounts): - all_mounts = subprocess.check_output(['mount', '-t', 'fuse.test']) + all_mounts = subprocess.check_output(['mount']) return [m for m in mounts if ' '+m+' ' in all_mounts] + def _wait_for_mounts(self, mounts): + deadline = time.time() + 10 + while self._mounted(mounts) != mounts: + time.sleep(0.1) + self.assertLess(time.time(), deadline) + + def test_unmount_subtype(self): + mounts = [] + for d in ['foo', 'bar']: + mnt = self.tmp+'/'+d + os.mkdir(mnt) + self.to_delete.insert(0, mnt) + mounts.append(mnt) + subprocess.check_call( + ['./bin/arv-mount', '--subtype', d, mnt]) + + self._wait_for_mounts(mounts) + self.assertEqual(mounts, self._mounted(mounts)) + subprocess.call(['./bin/arv-mount', '--subtype', 'baz', '--unmount-all', self.tmp]) + self.assertEqual(mounts, self._mounted(mounts)) + subprocess.call(['./bin/arv-mount', '--subtype', 'bar', '--unmount', mounts[0]]) + self.assertEqual(mounts, self._mounted(mounts)) + subprocess.call(['./bin/arv-mount', '--subtype', '', '--unmount', self.tmp]) + self.assertEqual(mounts, self._mounted(mounts)) + subprocess.check_call(['./bin/arv-mount', '--subtype', 'foo', '--unmount', mounts[0]]) + self.assertEqual(mounts[1:], self._mounted(mounts)) + subprocess.check_call(['./bin/arv-mount', '--subtype', '', '--unmount-all', mounts[0]]) + self.assertEqual(mounts[1:], self._mounted(mounts)) + subprocess.check_call(['./bin/arv-mount', '--subtype', 'bar', '--unmount-all', self.tmp]) + self.assertEqual([], self._mounted(mounts)) + def test_unmount_children(self): for d in ['foo', 'foo/bar', 'bar']: mnt = self.tmp+'/'+d @@ -48,12 +83,7 @@ class UnmountTest(IntegrationTest): subprocess.check_call( ['./bin/arv-mount', '--subtype', 'test', mnt]) - # Wait for mounts to attach - deadline = time.time() + 10 - while self._mounted(mounts) != mounts: - time.sleep(0.1) - self.assertLess(time.time(), deadline) - + self._wait_for_mounts(mounts) self.assertEqual(mounts, self._mounted(mounts)) subprocess.check_call(['./bin/arv-mount', '--unmount', self.tmp]) self.assertEqual(mounts, self._mounted(mounts))