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_bytearray.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_bytearray.py')
-rw-r--r-- | tests/thread/mutate_bytearray.py | 44 |
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) + |