Skip to content

Commit

Permalink
[test] Fix test_pthread_run_on_main_thread under asan. NFC (#21301)
Browse files Browse the repository at this point in the history
The output of this test is racey without this change and has been failing on the
emscripten-releases waterfall in the asan configuration.

We only just started caring about the precise output in #21296.
  • Loading branch information
sbc100 authored Feb 8, 2024
1 parent 9c8073d commit 833448b
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 17 deletions.
1 change: 1 addition & 0 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -522,6 +522,7 @@ jobs:
asan.test_wasm_worker_hello
asan.test_externref_emjs_dynlink
asan.test_asyncify_longjmp
asan.test_pthread_run_on_main_thread
lsan.test_stdio_locking
lsan.test_dlfcn_basic
lsan.test_pthread_create
Expand Down
45 changes: 29 additions & 16 deletions test/pthread/test_pthread_run_on_main_thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,80 +8,87 @@
#include <assert.h>
#include <math.h>

int v_called = 0;
_Atomic int v_called = 0;
void v() {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello!");
v_called = 1;
}

int vi_called = 0;
_Atomic int vi_called = 0;
void vi(int param0) {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello %d!", param0);
vi_called = 1;
}

int vii_called = 0;
_Atomic int vii_called = 0;
void vii(int param0, int param1) {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello %d %d!", param0, param1);
vii_called = 1;
}

int viii_called = 0;
_Atomic int viii_called = 0;
void viii(int param0, int param1, int param2) {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello %d %d %d!", param0, param1, param2);
viii_called = 1;
}

int i_called = 0;
_Atomic int i_called = 0;
int i() {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello i!");
i_called = 1;
return 84;
}

int ii_called = 0;
_Atomic int ii_called = 0;
int ii(int param0) {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello ii %d!", param0);
ii_called = 1;
return 85;
}

int iii_called = 0;
_Atomic int iii_called = 0;
int iii(int param0, int param1) {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello iii %d %d!", param0, param1);
iii_called = 1;
return 86;
}

int iiii_called = 0;
_Atomic int iiii_called = 0;
int iiii(int param0, int param1, int param2) {
assert(emscripten_is_main_runtime_thread());
emscripten_outf("Hello iiii %d %d %d!", param0, param1, param2);
iiii_called = 1;
return 87;
}

void reset_state() {
v_called = vi_called = vii_called = viii_called = 0;
i_called = ii_called = iii_called = iiii_called = 0;
}

void test_sync() {
reset_state();
emscripten_outf("Testing sync proxied runs:");
int ret;
v_called = 0; emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_V, v); assert(v_called == 1);
vi_called = 0; emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_VI, vi, 42); assert(vi_called == 1);
vii_called = 0; emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_VII, vii, 42, 43); assert(vii_called == 1);
viii_called = 0; emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_VIII, viii, 42, 43, 44); assert(viii_called == 1);
i_called = 0; ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_I, i); assert(i_called == 1); assert(ret == 84);
ii_called = 0; ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_II, ii, 42); assert(ii_called == 1); assert(ret == 85);
iii_called = 0; ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_III, iii, 42, 43); assert(iii_called == 1); assert(ret == 86);
iiii_called = 0; ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_IIII, iiii, 42, 43, 44); assert(iiii_called == 1); assert(ret == 87);
emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_V, v); assert(v_called == 1);
emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_VI, vi, 42); assert(vi_called == 1);
emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_VII, vii, 42, 43); assert(vii_called == 1);
emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_VIII, viii, 42, 43, 44); assert(viii_called == 1);
ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_I, i); assert(i_called == 1); assert(ret == 84);
ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_II, ii, 42); assert(ii_called == 1); assert(ret == 85);
ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_III, iii, 42, 43); assert(iii_called == 1); assert(ret == 86);
ret = emscripten_sync_run_in_main_runtime_thread(EM_FUNC_SIG_IIII, iiii, 42, 43, 44); assert(iiii_called == 1); assert(ret == 87);
}

void test_async() {
reset_state();
emscripten_outf("Testing async proxied runs:");
emscripten_async_run_in_main_runtime_thread(EM_FUNC_SIG_V, v);
emscripten_async_run_in_main_runtime_thread(EM_FUNC_SIG_VI, vi, 42);
Expand All @@ -91,6 +98,12 @@ void test_async() {
emscripten_async_run_in_main_runtime_thread(EM_FUNC_SIG_II, ii, 42);
emscripten_async_run_in_main_runtime_thread(EM_FUNC_SIG_III, iii, 42, 43);
emscripten_async_run_in_main_runtime_thread(EM_FUNC_SIG_IIII, iiii, 42, 43, 44);

// Busy loop until all the async jobs are done
while (!(v_called && vi_called && vii_called && viii_called &&
i_called && ii_called && iii_called && iiii_called)) {
sched_yield();
}
}

void test_async_waitable() {
Expand Down
2 changes: 1 addition & 1 deletion test/pthread/test_pthread_run_on_main_thread.out
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ Hello ii 42!
Hello iii 42 43!
Hello iiii 42 43 44!
Testing async proxied runs:
Testing waitable async proxied runs:
Hello!
Hello 42!
Hello 42 43!
Expand All @@ -35,6 +34,7 @@ Hello i!
Hello ii 42!
Hello iii 42 43!
Hello iiii 42 43 44!
Testing waitable async proxied runs:
Hello!
Hello 42!
Hello 42 43!
Expand Down

0 comments on commit 833448b

Please sign in to comment.