summaryrefslogtreecommitdiff
path: root/libevent/test/test-weof.c
diff options
context:
space:
mode:
authorSergey Petrunya <psergey@askmonty.org>2013-08-07 17:21:37 +0400
committerSergey Petrunya <psergey@askmonty.org>2013-08-07 17:21:37 +0400
commita3d79f2e58562c7b50d50827a0149234c225ea43 (patch)
treec266edef9eaf41a612e77972163d3d8eb0d280ba /libevent/test/test-weof.c
parent8e36dde7e1f149d8973fe14d8288e678d1ba9b61 (diff)
parenta765e035a0c40ee04df42fba5c02484e83d31483 (diff)
downloadmariadb-git-a3d79f2e58562c7b50d50827a0149234c225ea43.tar.gz
Merge 10.0-serg -> 10.0
Diffstat (limited to 'libevent/test/test-weof.c')
-rw-r--r--libevent/test/test-weof.c80
1 files changed, 80 insertions, 0 deletions
diff --git a/libevent/test/test-weof.c b/libevent/test/test-weof.c
new file mode 100644
index 00000000000..5d87ceb8eb7
--- /dev/null
+++ b/libevent/test/test-weof.c
@@ -0,0 +1,80 @@
+/*
+ * Compile with:
+ * cc -I/usr/local/include -o time-test time-test.c -L/usr/local/lib -levent
+ */
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+
+#ifdef WIN32
+#include <winsock2.h>
+#endif
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <sys/time.h>
+#ifdef HAVE_SYS_SOCKET_H
+#include <sys/socket.h>
+#endif
+#include <fcntl.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+#include <signal.h>
+#include <unistd.h>
+#include <errno.h>
+
+#include <event.h>
+#include <evutil.h>
+
+int pair[2];
+int test_okay = 1;
+int called = 0;
+
+static void
+write_cb(int fd, short event, void *arg)
+{
+ const char *test = "test string";
+ int len;
+
+ len = write(fd, test, strlen(test) + 1);
+
+ printf("%s: write %d%s\n", __func__,
+ len, len ? "" : " - means EOF");
+
+ if (len > 0) {
+ if (!called)
+ event_add(arg, NULL);
+ close(pair[0]);
+ } else if (called == 1)
+ test_okay = 0;
+
+ called++;
+}
+
+int
+main (int argc, char **argv)
+{
+ struct event ev;
+
+#ifndef WIN32
+ if (signal(SIGPIPE, SIG_IGN) == SIG_ERR)
+ return (1);
+#endif
+
+ if (evutil_socketpair(AF_UNIX, SOCK_STREAM, 0, pair) == -1)
+ return (1);
+
+ /* Initalize the event library */
+ event_init();
+
+ /* Initalize one event */
+ event_set(&ev, pair[1], EV_WRITE, write_cb, &ev);
+
+ event_add(&ev, NULL);
+
+ event_dispatch();
+
+ return (test_okay);
+}
+