2016-04-19 13:03:26 -04:00
|
|
|
# test _thread lock object using a single thread
|
|
|
|
#
|
|
|
|
# MIT license; Copyright (c) 2016 Damien P. George on behalf of Pycom Ltd
|
|
|
|
|
|
|
|
import _thread
|
|
|
|
|
|
|
|
# create lock
|
|
|
|
lock = _thread.allocate_lock()
|
|
|
|
|
|
|
|
print(type(lock) == _thread.LockType)
|
|
|
|
|
|
|
|
# should be unlocked
|
|
|
|
print(lock.locked())
|
|
|
|
|
|
|
|
# basic acquire and release
|
|
|
|
print(lock.acquire())
|
|
|
|
print(lock.locked())
|
|
|
|
lock.release()
|
|
|
|
print(lock.locked())
|
|
|
|
|
|
|
|
# try acquire twice (second should fail)
|
|
|
|
print(lock.acquire())
|
|
|
|
print(lock.locked())
|
|
|
|
print(lock.acquire(0))
|
|
|
|
print(lock.locked())
|
|
|
|
lock.release()
|
|
|
|
print(lock.locked())
|
|
|
|
|
|
|
|
# test with capabilities of lock
|
|
|
|
with lock:
|
|
|
|
print(lock.locked())
|
|
|
|
|
|
|
|
# test that lock is unlocked if an error is rasied
|
|
|
|
try:
|
|
|
|
with lock:
|
|
|
|
print(lock.locked())
|
|
|
|
raise KeyError
|
|
|
|
except KeyError:
|
2020-03-22 22:26:08 -04:00
|
|
|
print("KeyError")
|
2016-04-19 13:03:26 -04:00
|
|
|
print(lock.locked())
|
2017-06-14 00:43:50 -04:00
|
|
|
|
|
|
|
# test that we can't release an unlocked lock
|
|
|
|
try:
|
|
|
|
lock.release()
|
|
|
|
except RuntimeError:
|
2020-03-22 22:26:08 -04:00
|
|
|
print("RuntimeError")
|