Mercurial > hg > octave-kai > gnulib-hg
changeset 13033:939f5a4753f9
Tests for openpty: Make stricter.
author | Bruno Haible <bruno@clisp.org> |
---|---|
date | Mon, 22 Mar 2010 00:13:13 +0100 |
parents | 64faceabf217 |
children | 083838281860 |
files | ChangeLog modules/openpty-tests tests/test-openpty.c |
diffstat | 3 files changed, 76 insertions(+), 9 deletions(-) [+] |
line wrap: on
line diff
--- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,11 @@ 2010-03-21 Bruno Haible <bruno@clisp.org> + Tests for openpty: Make stricter. + * tests/test-openpty.c (main): Add test of canonical processing and + erase. + * modules/openpty-tests (test_openpty_LDADD): Verify that PTY_LIB is + defined. + openpty: Provide replacement on AIX, HP-UX, IRIX, Solaris. * lib/openpty.c (openpty): New replacement function. * lib/pty.in.h: Include <termios.h>.
--- a/modules/openpty-tests +++ b/modules/openpty-tests @@ -5,4 +5,4 @@ Makefile.am: TESTS += test-openpty check_PROGRAMS += test-openpty -test_openpty_LDADD = $(LDADD) $(PTY_LIB) +test_openpty_LDADD = $(LDADD) @PTY_LIB@
--- a/tests/test-openpty.c +++ b/tests/test-openpty.c @@ -14,7 +14,8 @@ You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ -/* Written by Simon Josefsson <simon@josefsson.org>, 2009. */ +/* Written by Simon Josefsson <simon@josefsson.org>, 2009 + and Bruno Haible <bruno@clisp.org>, 2010. */ #include <config.h> @@ -25,20 +26,80 @@ struct winsize const *)); #include <stdio.h> +#include <string.h> +#include <termios.h> +#include <unistd.h> int main () { - int res; - int amaster; - int aslave; + { + int master; + int slave; + + /* Open a pseudo-terminal, as a master-slave pair. */ + { + 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; - res = openpty (&amaster, &aslave, NULL, NULL, NULL); - if (res != 0) + 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. */ { - printf ("openpty returned %d\n", res); - return 1; + 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; + } + } + } + return 0; }