blob: 1d0701da01fdb91ecac39cd39cb289397b8bdf11 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
# 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 raised
try:
with lock:
print(lock.locked())
raise KeyError
except KeyError:
print("KeyError")
print(lock.locked())
# test that we can't release an unlocked lock
try:
lock.release()
except RuntimeError:
print("RuntimeError")
|