11 #define TEST(c, ...) \
12 ( (c) || (t_error(#c " failed: " __VA_ARGS__),0) )
21 clock_gettime(CLOCK_REALTIME, &ts);
22 snprintf(buf, sizeof buf, "/testsuite-%d-%d", (int)getpid(), (int)ts.tv_nsec);
24 TEST((sem=sem_open(buf, O_CREAT|O_EXCL, 0700, 1)) != SEM_FAILED,
25 "could not open sem: %s\n", strerror(errno));
27 TEST(sem_open(buf, O_CREAT|O_EXCL, 0700, 1) == SEM_FAILED,
28 "reopening should fail with O_EXCL\n");
30 "after reopen failure errno is \"%s\" (%d); want EEXIST (%d)\n", strerror(errno), errno, EEXIST);
32 TEST(sem_getvalue(sem, &val) == 0, "failed to get sem value\n");
33 TEST(val == 1, "wrong initial semaphore value: %d\n", val);
35 TEST((sem2=sem_open(buf, 0)) == sem,
36 "could not reopen sem: got %p, want %p\n", sem2, sem);
39 TEST(sem_wait(sem) == 0, "%s\n", strerror(errno));
40 TEST(sem_getvalue(sem2, &val) == 0, "%s\n", strerror(errno));
41 TEST(val == 0, "wrong semaphore value on second handle: %d\n", val);
44 TEST(sem_trywait(sem) == -1 && errno == EAGAIN,
45 "trywait on locked sem: got errno \"%s\" (%d), want EAGAIN (%d)\n", strerror(errno), errno, EAGAIN);
47 TEST(sem_post(sem) == 0, "%s\n", strerror(errno));
48 TEST(sem_getvalue(sem2, &val) == 0, "%s\n", strerror(errno));
49 TEST(val == 1, "wrong semaphore value on second handle: %d\n", val);
51 TEST(sem_close(sem) == 0, "%s\n", strerror(errno));
52 TEST(sem_close(sem) == 0, "%s\n", strerror(errno));
53 TEST(sem_unlink(buf) == 0, "%s\n", strerror(errno));