diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/spack/llnl/util/lock.py | 5 | ||||
-rw-r--r-- | lib/spack/spack/test/llnl/util/lock.py | 20 |
2 files changed, 25 insertions, 0 deletions
diff --git a/lib/spack/llnl/util/lock.py b/lib/spack/llnl/util/lock.py index 10e552bdb5..b685091e9b 100644 --- a/lib/spack/llnl/util/lock.py +++ b/lib/spack/llnl/util/lock.py @@ -150,6 +150,11 @@ class Lock(object): def _ensure_parent_directory(self): parent = os.path.dirname(self.path) + + # relative paths to lockfiles in the current directory have no parent + if not parent: + return '.' + try: os.makedirs(parent) except OSError as e: diff --git a/lib/spack/spack/test/llnl/util/lock.py b/lib/spack/spack/test/llnl/util/lock.py index 7401ecdc2d..89434d82f1 100644 --- a/lib/spack/spack/test/llnl/util/lock.py +++ b/lib/spack/spack/test/llnl/util/lock.py @@ -1047,3 +1047,23 @@ def test_lock_with_no_parent_directory(tmpdir): lock = lk.Lock('foo/bar/baz/lockfile') with lk.WriteTransaction(lock): pass + + +def test_lock_in_current_directory(tmpdir): + """Make sure locks work even when their parent directory does not exist.""" + with tmpdir.as_cwd(): + # test we can create a lock in the current directory + lock = lk.Lock('lockfile') + for i in range(10): + with lk.ReadTransaction(lock): + pass + with lk.WriteTransaction(lock): + pass + + # and that we can do the same thing after it's already there + lock = lk.Lock('lockfile') + for i in range(10): + with lk.ReadTransaction(lock): + pass + with lk.WriteTransaction(lock): + pass |