diff options
Diffstat (limited to 'gnulib/tests/test-openpty.c')
m--------- | gnulib | 0 | ||||
-rw-r--r-- | gnulib/tests/test-openpty.c | 109 |
2 files changed, 109 insertions, 0 deletions
diff --git a/gnulib b/gnulib deleted file mode 160000 -Subproject 443bc5ffcf7429e557f4a371b0661abe98ddbc1 diff --git a/gnulib/tests/test-openpty.c b/gnulib/tests/test-openpty.c new file mode 100644 index 0000000..f491e33 --- /dev/null +++ b/gnulib/tests/test-openpty.c @@ -0,0 +1,109 @@ +/* Test of pty.h and openpty function. + 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 + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + 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 + and Bruno Haible <bruno@clisp.org>, 2010. */ + +#include <config.h> + +#include <pty.h> + +#include "signature.h" +SIGNATURE_CHECK (openpty, int, (int *, int *, char *, struct termios const *, + struct winsize const *)); + +#include <stdio.h> +#include <string.h> +#include <termios.h> +#include <unistd.h> + +int +main () +{ + { + 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; + + 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; +} |