summaryrefslogtreecommitdiffstatshomepage
path: root/tests/thread/mutate_bytearray.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_bytearray.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_bytearray.py')
-rw-r--r--tests/thread/mutate_bytearray.py44
1 files changed, 44 insertions, 0 deletions
diff --git a/tests/thread/mutate_bytearray.py b/tests/thread/mutate_bytearray.py
new file mode 100644
index 0000000000..25f7c70714
--- /dev/null
+++ b/tests/thread/mutate_bytearray.py
@@ -0,0 +1,44 @@
+# test concurrent mutating access to a shared bytearray object
+#
+# MIT license; Copyright (c) 2016 Damien P. George on behalf of Pycom Ltd
+
+import _thread
+
+# the shared bytearray
+ba = bytearray()
+
+# main thread function
+def th(n, lo, hi):
+ for repeat in range(n):
+ for i in range(lo, hi):
+ l = len(ba)
+ ba.append(i)
+ assert len(ba) >= l + 1
+
+ l = len(ba)
+ ba.extend(bytearray([i]))
+ assert len(ba) >= l + 1
+
+ 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, (40, i * 256 // n_thread, (i + 1) * 256 // n_thread))
+
+# busy wait for threads to finish
+while n_finished < n_thread:
+ pass
+
+# check bytearray has correct contents
+print(len(ba))
+count = [0 for _ in range(256)]
+for b in ba:
+ count[b] += 1
+print(count)
+