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;
 }