X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=tests%2Ftest-openpty.c;h=f491e338ab6036c20aac92e8c007ad6aa9c3b077;hb=492fd301bd2018288330c0a20a086b1a8cc611ce;hp=2af25b49cbe03868cf1ac759b7c20a12c3f32fea;hpb=8e7bc4d9d435c2d18be77134896aa823733816a0;p=gnulib.git diff --git a/tests/test-openpty.c b/tests/test-openpty.c index 2af25b49c..f491e338a 100644 --- a/tests/test-openpty.c +++ b/tests/test-openpty.c @@ -1,5 +1,5 @@ /* Test of pty.h and openpty function. - Copyright (C) 2009, 2010 Free Software Foundation, Inc. + Copyright (C) 2009-2011 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -14,7 +14,8 @@ You should have received a copy of the GNU General Public License along with this program. If not, see . */ -/* Written by Simon Josefsson , 2009. */ +/* Written by Simon Josefsson , 2009 + and Bruno Haible , 2010. */ #include @@ -25,20 +26,84 @@ SIGNATURE_CHECK (openpty, int, (int *, int *, char *, struct termios const *, struct winsize const *)); #include +#include +#include +#include int main () { - int res; - int amaster; - int aslave; + { + int master; + int slave; - res = openpty (&amaster, &aslave, NULL, NULL, NULL); - if (res != 0) + /* Open a pseudo-terminal, as a master-slave pair. */ { - printf ("openpty returned %d\n", res); - return 1; + int res = openpty (&master, &slave, NULL, NULL, NULL); + if (res != 0) + { + fprintf (stderr, "openpty returned %d\n", res); + return 1; + } } + /* Set the terminal characteristics. + On Linux or MacOS X, they can be set on either the master or the slave; + the effect is the same. But on Solaris, they have to be set on the + master; tcgetattr on the slave fails. */ + { + int tcfd = slave; /* You can try tcfd = master; here. */ + struct termios attributes; + + if (tcgetattr (tcfd, &attributes) < 0) + { + fprintf (stderr, "tcgetattr failed\n"); + return 1; + } + /* Enable canonical processing, including erase. */ + attributes.c_lflag |= ECHO | ICANON | ECHOE; + attributes.c_cc[VERASE] = '\177'; + if (tcsetattr (tcfd, TCSANOW, &attributes) < 0) + { + fprintf (stderr, "tcsetattr failed\n"); + return 1; + } + } + + /* Write into the master side. */ + { + static const char input[] = "Hello worst\177\177ld!\n"; + + if (write (master, input, strlen (input)) < (int) strlen (input)) + { + fprintf (stderr, "write failed\n"); + return 1; + } + } + + /* Read from the slave side. */ + { + char buf[100]; + int res = read (slave, buf, sizeof (buf)); + static const char expected[] = "Hello world!\n"; + + if (res < 0) + { + fprintf (stderr, "read failed\n"); + return 1; + } + if (!(res == strlen (expected) + && memcmp (buf, expected, strlen (expected)) == 0)) + { + fprintf (stderr, "read result unexpected\n"); + return 1; + } + } + + /* Close the master side before the slave side gets closed. + This is necessary on MacOS X 10.4.11. */ + close (master); + } + return 0; }