diff options
Diffstat (limited to 'src/check/check.c')
-rw-r--r-- | src/check/check.c | 36 |
1 files changed, 23 insertions, 13 deletions
diff --git a/src/check/check.c b/src/check/check.c index bbc22eb..9d28129 100644 --- a/src/check/check.c +++ b/src/check/check.c @@ -4,13 +4,16 @@ #include <fcntl.h> #include <sys/stat.h> #include <sys/wait.h> +#include <semaphore.h> #include <mqueue.h> -#define myassert(x) if ((x)) { ret &= 0xFF; } else { ret &= 0x00; } -static volatile unsigned char ret = 0xFF; +#define myassert(x, emask) if ((x)) { ret &= ret; } else { ret |= emask; } + +static volatile unsigned long long int ret = 0x0; static mqd_t mq_test; static mqd_t mq_recv; +static sem_t *sp_test; static const size_t bufsiz = 256; int main(int argc, char **argv) @@ -32,24 +35,31 @@ int main(int argc, char **argv) m_attr.mq_curmsgs = 0; mq_unlink("/testmq"); - myassert( (mq_test = mq_open( "/testmq", O_NONBLOCK | O_CREAT | O_EXCL | O_RDWR, S_IRWXU | S_IRWXG, &m_attr )) != (mqd_t)-1 ); - myassert( mq_getattr(mq_test, &m_attr) == 0 ); + myassert( (mq_test = mq_open( "/testmq", O_NONBLOCK | O_CREAT | O_EXCL | O_RDWR, S_IRWXU | S_IRWXG, &m_attr )) != (mqd_t)-1, 0x1 ); + myassert( mq_getattr(mq_test, &m_attr) == 0, 0x2 ); strcpy(buf, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVQXYZ"); - myassert( mq_send(mq_test, buf, bufsiz, 0) == 0 ); - myassert( (sz_recv = mq_receive(mq_test, recv, bufsiz, &prio)) > 0 ); + myassert( mq_send(mq_test, buf, bufsiz, 0) == 0, 0x4 ); + myassert( (sz_recv = mq_receive(mq_test, recv, bufsiz, &prio)) > 0, 0x8 ); memset(recv, '\0', bufsiz); if (fork() > 0) { - myassert( (mq_recv = mq_open( "/testmq", O_RDONLY, S_IRWXU | S_IRWXG, &m_attr )) != (mqd_t)-1 ); - myassert( (sz_recv = mq_receive(mq_recv, recv, bufsiz, &prio)) > 0 ); + myassert( (mq_recv = mq_open( "/testmq", O_RDONLY, S_IRWXU | S_IRWXG, &m_attr )) != (mqd_t)-1, 0x10 ); + myassert( (sz_recv = mq_receive(mq_recv, recv, bufsiz, &prio)) > 0, 0x20 ); return ret; } - myassert( mq_send(mq_test, buf, bufsiz, 0) == 0 ); + myassert( mq_send(mq_test, buf, bufsiz, 0) == 0, 0x40 ); wait(&c_stat); - myassert( c_stat == 0xFF ); - myassert( mq_close(mq_test) == 0 ); - myassert( mq_unlink("/testmq") == 0 ); + myassert( c_stat == 0xFF, 0x80 ); + myassert( mq_close(mq_test) == 0, 0x100 ); + myassert( mq_unlink("/testmq") == 0, 0x200 ); + + myassert( sem_unlink("/testsem") == 0, 0x400 ); + myassert( (sp_test = sem_open("/testsem", O_CREAT | O_EXCL, S_IRUSR | S_IWUSR, 0)), 0x800 ); + myassert( sem_post(sp_test) == 0, 0x1000 ); + myassert( sem_wait(sp_test) == 0, 0x1200 ); + myassert( sem_close(sp_test) == 0, 0x1400 ); + myassert( sem_unlink("/testsem") == 0, 0x1800 ); - return ~ret; + return ret; } |