summaryrefslogtreecommitdiff
path: root/lib/libc_r/TEST/test_select.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libc_r/TEST/test_select.c')
-rw-r--r--lib/libc_r/TEST/test_select.c151
1 files changed, 86 insertions, 65 deletions
diff --git a/lib/libc_r/TEST/test_select.c b/lib/libc_r/TEST/test_select.c
index 4202a06439c..c210504610d 100644
--- a/lib/libc_r/TEST/test_select.c
+++ b/lib/libc_r/TEST/test_select.c
@@ -1,3 +1,8 @@
+/* $OpenBSD: test_select.c,v 1.4 1999/11/28 12:31:42 d Exp $ */
+/*
+ * Rudimentary test of select().
+ */
+
#include <pthread.h>
#include <pthread_np.h>
#include <stdio.h>
@@ -7,7 +12,8 @@
#include <errno.h>
#include <unistd.h>
#include "test.h"
-#define NLOOPS 1000
+
+#define NLOOPS 10000
int ntouts = 0;
@@ -15,84 +21,99 @@ void *
bg_routine(arg)
void *arg;
{
- char dot = '.';
- SET_NAME("bg");
- write(STDOUT_FILENO,"bg routine running\n",19);
- /*pthread_dump_state();*/
- while (1) {
- int n;
- pthread_yield();
- write(STDOUT_FILENO, &dot, sizeof dot);
- pthread_yield();
- n = NLOOPS;
- while (n-- > 0)
- pthread_yield();
- }
+ char dot = '.';
+ int n;
+
+ SET_NAME("bg");
+
+ /* Busy loop, printing dots */
+ for (;;) {
+ pthread_yield();
+ write(STDOUT_FILENO, &dot, sizeof dot);
+ pthread_yield();
+ n = NLOOPS;
+ while (n-- > 0)
+ pthread_yield();
+ }
}
void *
fg_routine(arg)
void *arg;
{
- int flags;
- /* static struct timeval tout = { 0, 500000 }; */
- int n;
- fd_set r;
-
- SET_NAME("fg");
-
- flags = fcntl(STDIN_FILENO, F_GETFL);
- CHECKr(fcntl(STDIN_FILENO, F_SETFL, flags | O_NONBLOCK));
-
- while (1) {
- int maxfd;
-
- FD_ZERO(&r);
- FD_SET(STDIN_FILENO,&r);
- maxfd = STDIN_FILENO;
-
- errno = 0;
- printf("select>");
- CHECKe(n = select(maxfd+1, &r, (fd_set*)0, (fd_set*)0,
- (struct timeval *)0));
-
- if (n > 0) {
- int nb;
- char buf[128];
-
- printf("=> select returned: %d\n", n);
- while ((nb = read(STDIN_FILENO, buf, sizeof(buf)-1)) >= 0) {
- buf[nb] = '\0';
- printf("read %d: |%s|\n", nb, buf);
- }
- printf("=> out of read loop: len = %d / %s\n", nb, strerror(errno));
- if (nb < 0)
- ASSERTe(errno, == EWOULDBLOCK || errno == EAGAIN);
- } else
- ntouts++;
- }
+ int flags;
+ int n;
+ fd_set r;
+ int fd = fileno((FILE *) arg);
+ int tty = isatty(fd);
+ int maxfd;
+ int nb;
+ char buf[128];
+
+ SET_NAME("fg");
+
+ /* Set the file descriptor to non-blocking */
+ flags = fcntl(fd, F_GETFL);
+ CHECKr(fcntl(fd, F_SETFL, flags | O_NONBLOCK));
+
+ for (;;) {
+
+ /* Print a prompt if it's a tty: */
+ if (tty) {
+ printf("type something> ");
+ fflush(stdout);
+ }
+
+ /* Select on the fdesc: */
+ FD_ZERO(&r);
+ FD_SET(fd, &r);
+ maxfd = fd;
+ errno = 0;
+ CHECKe(n = select(maxfd + 1, &r, (fd_set *) 0, (fd_set *) 0,
+ (struct timeval *) 0));
+
+ if (n > 0) {
+ /* Something was ready for read. */
+ printf("select returned %d\n", n);
+ while ((nb = read(fd, buf, sizeof(buf) - 1)) > 0) {
+ printf("read %d: `%.*s'\n", nb, nb, buf);
+ }
+ printf("last read was %d, errno = %d %s\n", nb, errno,
+ errno == 0 ? "success" : strerror(errno));
+ if (nb < 0)
+ ASSERTe(errno, == EWOULDBLOCK ||
+ errno == EAGAIN);
+ if (nb == 0)
+ break;
+ } else
+ ntouts++;
+ }
+ printf("read finished\n");
+ return (NULL);
}
int
main(argc, argv)
int argc;
- char **argv;
+ char *argv[];
{
- pthread_t bg_thread, fg_thread;
- int junk;
+ pthread_t bg_thread, fg_thread;
+ FILE * slpr;
- setbuf(stdout,NULL);
- setbuf(stderr,NULL);
+ /* Create a fdesc that will block for a while on read: */
+ CHECKn(slpr = popen("sleep 2; echo foo", "r"));
+ /* Create a busy loop thread that yields a lot: */
CHECKr(pthread_create(&bg_thread, NULL, bg_routine, 0));
- CHECKr(pthread_create(&fg_thread, NULL, fg_routine, 0));
-
- printf("threads forked: bg=%p fg=%p\n", bg_thread, fg_thread);
- /*pthread_dump_state();*/
- /*
- printf("initial thread %p joining fg...\n", pthread_self());
- CHECKr(pthread_join(fg_thread, (void **)&junk));
- */
- sleep(20);
+
+ /* Create the thread that reads the fdesc: */
+ CHECKr(pthread_create(&fg_thread, NULL, fg_routine, (void *) slpr));
+
+ /* Wait for the reader thread to finish */
+ CHECKr(pthread_join(fg_thread, NULL));
+
+ /* Clean up*/
+ CHECKe(pclose(slpr));
+
SUCCEED;
}