X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Ftest_mutex.c;h=6a0b9f140b4413bddfd60edce218f019ad1f5599;hb=a4f3aed6537286535d1ea9962adb9ab77c528565;hp=52853b14cad0e17c0fd13f3b6f7eac5eb0126cb4;hpb=7993bf125aa3ae6ac06e12a92209f54a863717c8;p=yaz-moved-to-github.git diff --git a/test/test_mutex.c b/test/test_mutex.c index 52853b1..6a0b9f1 100644 --- a/test/test_mutex.c +++ b/test/test_mutex.c @@ -7,6 +7,7 @@ #include #include +#include #if HAVE_SYS_TIME_H #include #endif @@ -71,12 +72,44 @@ static void tst_cond(void) YAZ_CHECK(p == 0); } +static void *my_handler(void *arg) +{ + int *mydata = (int*) arg; + (*mydata)++; + return mydata; +} + +static void tst_create_thread(void) +{ + void *return_data; + int mydata = 42; + yaz_thread_t t[2]; + + t[0] = yaz_thread_create(my_handler, &mydata); + YAZ_CHECK(t[0]); + t[1] = yaz_thread_create(my_handler, &mydata); + YAZ_CHECK(t[1]); + + return_data = 0; + yaz_thread_join(&t[0], &return_data); + YAZ_CHECK(!t[0]); + YAZ_CHECK(return_data == &mydata); + + return_data = 0; + yaz_thread_join(&t[1], &return_data); + YAZ_CHECK(!t[1]); + YAZ_CHECK(return_data == &mydata); + + YAZ_CHECK_EQ(mydata, 44); +} + int main (int argc, char **argv) { YAZ_CHECK_INIT(argc, argv); YAZ_CHECK_LOG(); tst_mutex(); tst_cond(); + tst_create_thread(); YAZ_CHECK_TERM; }