diff options
author | Damien George <damien.p.george@gmail.com> | 2016-05-17 10:54:41 +0000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2016-06-28 11:28:50 +0100 |
commit | 094a0dd11a04f3917b488f526f640ae47e30858f (patch) | |
tree | 9d89335e46d1dab6c556fbefa0a7a3d6f7d51e13 /tests/thread/mutate_dict.py | |
parent | c73cf9d9319fccbacdff648c2addb9120f2b014b (diff) | |
download | micropython-094a0dd11a04f3917b488f526f640ae47e30858f.tar.gz micropython-094a0dd11a04f3917b488f526f640ae47e30858f.zip |
tests/thread: Add tests that mutate shared objects.
Tests concurrent mutating access to: list, dict, set, bytearray.
Diffstat (limited to 'tests/thread/mutate_dict.py')
-rw-r--r-- | tests/thread/mutate_dict.py | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/tests/thread/mutate_dict.py b/tests/thread/mutate_dict.py new file mode 100644 index 0000000000..c57d332d51 --- /dev/null +++ b/tests/thread/mutate_dict.py @@ -0,0 +1,42 @@ +# test concurrent mutating access to a shared dict object +# +# MIT license; Copyright (c) 2016 Damien P. George on behalf of Pycom Ltd + +import _thread + +# the shared dict +di = {'a':'A', 'b':'B', 'c':'C', 'd':'D'} + +# main thread function +def th(n, lo, hi): + for repeat in range(n): + for i in range(lo, hi): + di[i] = repeat + i + assert di[i] == repeat + i + + del di[i] + assert i not in di + + di[i] = repeat + i + assert di[i] == repeat + i + + assert di.pop(i) == repeat + i + + with lock: + global n_finished + n_finished += 1 + +lock = _thread.allocate_lock() +n_thread = 4 +n_finished = 0 + +# spawn threads +for i in range(n_thread): + _thread.start_new_thread(th, (30, i * 300, (i + 1) * 300)) + +# busy wait for threads to finish +while n_finished < n_thread: + pass + +# check dict has correct contents +print(sorted(di.items())) |