diff options
author | Markus Friedl <markus@cvs.openbsd.org> | 2004-01-05 19:23:05 +0000 |
---|---|---|
committer | Markus Friedl <markus@cvs.openbsd.org> | 2004-01-05 19:23:05 +0000 |
commit | 58305188ee7cc98831887ace149141a9ebde3b53 (patch) | |
tree | 9ff498c6089a674511907dad859a31cab475286c /regress/lib | |
parent | 4f1bcb70b733d47bbc51a0560077b16633f94da1 (diff) |
regress test for kqueue+EOF; marius aamodt eriksen
Diffstat (limited to 'regress/lib')
-rw-r--r-- | regress/lib/libevent/eventtest.c | 68 |
1 files changed, 64 insertions, 4 deletions
diff --git a/regress/lib/libevent/eventtest.c b/regress/lib/libevent/eventtest.c index c6cff9a401d..89765f96241 100644 --- a/regress/lib/libevent/eventtest.c +++ b/regress/lib/libevent/eventtest.c @@ -1,4 +1,4 @@ -/* $OpenBSD: eventtest.c,v 1.2 2003/07/31 21:48:04 deraadt Exp $ */ +/* $OpenBSD: eventtest.c,v 1.3 2004/01/05 19:23:04 markus Exp $ */ /* $NetBSD: eventtest.c,v 1.2 2003/06/13 04:09:18 itojun Exp $ */ /* @@ -173,11 +173,39 @@ signal_cb(int fd, short event, void *arg) } struct both { - struct event ev; + struct event ev, ev1; int nread; }; static void +eof_read_cb(int fd, short event, void *arg) +{ + struct both *both = arg; + char buf[256]; + int ret; + + ret = read(fd, buf, sizeof(buf)); + test_ok = both->nread == 0 && ret == 0; + + if (both->nread > 0) + event_add(&both->ev, NULL); + else + event_del(&both->ev1); + + both->nread -= ret; +} + +static void +eof_timeout_cb(int fd, short event, void *arg) +{ + struct both *both = arg; + + event_del(&both->ev); + + test_ok = 0; +} + +static void combined_read_cb(int fd, short event, void *arg) { struct both *both = arg; @@ -258,7 +286,8 @@ main(int argc, char **argv) struct timeval tv; struct itimerval itv; struct both r1, r2, w1, w2; - int i; + int i, fd, n, tmp; + char template[] = "/tmp/eventXXXX"; setvbuf(stdout, NULL, _IONBF, 0); @@ -379,6 +408,37 @@ main(int argc, char **argv) cleanup_test(); + setup_test("EOF Behavior: "); + + if ((fd = mkstemp(template)) == -1) + return (1); + + unlink(template); + + n = strlen(TEST1) + 1; + r1.nread = n; + + while (n > 0) { + if ((tmp = write(fd, TEST1, n)) == -1) + return (1); + + n -= tmp; + } + + if (lseek(fd, 0, SEEK_SET) == -1) + return (1); + + event_set(&r1.ev, fd, EV_READ, eof_read_cb, &r1); + event_add(&r1.ev, NULL); + + tv.tv_usec = 0; + tv.tv_sec = SECONDS; + evtimer_set(&r1.ev1, eof_timeout_cb, &r1); + evtimer_add(&r1.ev1, &tv); + + event_dispatch(); + + cleanup_test(); + return (0); } - |