summaryrefslogtreecommitdiffstatshomepage
path: root/tests/thread/mutate_dict.py
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2016-05-17 10:54:41 +0000
committerDamien George <damien.p.george@gmail.com>2016-06-28 11:28:50 +0100
commit094a0dd11a04f3917b488f526f640ae47e30858f (patch)
tree9d89335e46d1dab6c556fbefa0a7a3d6f7d51e13 /tests/thread/mutate_dict.py
parentc73cf9d9319fccbacdff648c2addb9120f2b014b (diff)
downloadmicropython-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.py42
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()))