From 9f5f6f533c2f68314fc2029081480ef612f8a095 Mon Sep 17 00:00:00 2001 From: Joel Sherrill Date: Mon, 7 Jun 2010 18:33:09 +0000 Subject: 2010-06-07 Joel Sherrill * termios01/init.c, termios01/termios01.scn, termios02/init.c, termios02/termios02.scn: Add tests for cfigetspeed(), cfogetspeed(), cfisetspeed(), cfosetspeed(), ctermid(), tcflow(), tcflush(), tcsendbreak(), tcsetpgrp(), and tcgetpgrp(). Some of these methods are minimal implementations so the tests will have to grow as the methods grow. --- testsuites/libtests/termios01/init.c | 86 ++++++++++++++++++++++++++--- testsuites/libtests/termios01/termios01.scn | 82 +++++++++++++++++++++++++++ 2 files changed, 161 insertions(+), 7 deletions(-) (limited to 'testsuites/libtests/termios01') diff --git a/testsuites/libtests/termios01/init.c b/testsuites/libtests/termios01/init.c index b28c0f53e1..206d676b51 100644 --- a/testsuites/libtests/termios01/init.c +++ b/testsuites/libtests/termios01/init.c @@ -135,14 +135,17 @@ void test_termios_baud2index(void) rtems_test_assert( i == -1 ); if ( i != -1 ) - for (i=0 ; baud_table[i].constant != -1 ; i++ ) { - printf( "termios_baud_to_index(B%" PRIdrtems_termios_baud_t ") - OK\n", baud_table[i].baud ); - index = rtems_termios_baud_to_index( baud_table[i].constant ); - if ( index != i ) { - printf( "ERROR - returned %d should be %d\n", index, i ); - rtems_test_exit(0); + for (i=0 ; baud_table[i].constant != -1 ; i++ ) { + printf( + "termios_baud_to_index(B%" PRIdrtems_termios_baud_t ") - OK\n", + baud_table[i].baud + ); + index = rtems_termios_baud_to_index( baud_table[i].constant ); + if ( index != i ) { + printf( "ERROR - returned %d should be %d\n", index, i ); + rtems_test_exit(0); + } } - } } /* @@ -377,6 +380,71 @@ void test_termios_set_stop_bits( } } +void test_termios_cfoutspeed(void) +{ + int i; + int sc; + speed_t speed; + struct termios term; + tcflag_t bad; + + bad = CBAUD << 1; + memset( &term, '\0', sizeof(term) ); + puts( "cfsetospeed(BAD BAUD) - EINVAL" ); + sc = cfsetospeed( &term, bad ); + rtems_test_assert( sc == -1 ); + rtems_test_assert( errno == EINVAL ); + + for (i=0 ; baud_table[i].constant != -1 ; i++ ) { + memset( &term, '\0', sizeof(term) ); + printf( + "cfsetospeed(B%" PRIdrtems_termios_baud_t ") - OK\n", + baud_table[i].baud + ); + sc = cfsetospeed( &term, baud_table[i].constant ); + rtems_test_assert( !sc ); + printf( + "cfgetospeed(B%" PRIdrtems_termios_baud_t ") - OK\n", + baud_table[i].baud + ); + speed = cfgetospeed( &term ); + rtems_test_assert( speed == baud_table[i].constant ); + } +} + +void test_termios_cfinspeed(void) +{ + int i; + int sc; + speed_t speed; + struct termios term; + tcflag_t bad; + + bad = CBAUD << 1; + memset( &term, '\0', sizeof(term) ); + puts( "cfsetispeed(BAD BAUD) - EINVAL" ); + sc = cfsetispeed( &term, bad ); + rtems_test_assert( sc == -1 ); + rtems_test_assert( errno == EINVAL ); + + for (i=0 ; baud_table[i].constant != -1 ; i++ ) { + memset( &term, '\0', sizeof(term) ); + printf( + "cfsetispeed(B%" PRIdrtems_termios_baud_t ") - OK\n", + baud_table[i].baud + ); + sc = cfsetispeed( &term, baud_table[i].constant ); + rtems_test_assert( !sc ); + + printf( + "cfgetispeed(B%" PRIdrtems_termios_baud_t ") - OK\n", + baud_table[i].baud + ); + speed = cfgetispeed( &term ); + rtems_test_assert( speed == baud_table[i].constant ); + } +} + rtems_task Init( rtems_task_argument ignored ) @@ -481,6 +549,10 @@ rtems_task Init( test_termios_set_stop_bits(test); + test_termios_cfoutspeed(); + + test_termios_cfinspeed(); + puts( "Init - close - " TERMIOS_TEST_DRIVER_DEVICE_NAME " - OK" ); rc = close( test ); if ( rc != 0 ) { diff --git a/testsuites/libtests/termios01/termios01.scn b/testsuites/libtests/termios01/termios01.scn index 584923fdf6..4c010d842a 100644 --- a/testsuites/libtests/termios01/termios01.scn +++ b/testsuites/libtests/termios01/termios01.scn @@ -196,5 +196,87 @@ tcsetattr(TCSANOW, 2 bits) - OK set_attributes - B38400 8-NONE-2 tcsetattr(TCSADRAIN, 2 bits) - OK set_attributes - B38400 8-NONE-2 +cfsetospeed(BAD BAUD) - EINVAL +cfsetospeed(B0) - OK +cfgetospeed(B0) - OK +cfsetospeed(B50) - OK +cfgetospeed(B50) - OK +cfsetospeed(B75) - OK +cfgetospeed(B75) - OK +cfsetospeed(B110) - OK +cfgetospeed(B110) - OK +cfsetospeed(B134) - OK +cfgetospeed(B134) - OK +cfsetospeed(B150) - OK +cfgetospeed(B150) - OK +cfsetospeed(B200) - OK +cfgetospeed(B200) - OK +cfsetospeed(B300) - OK +cfgetospeed(B300) - OK +cfsetospeed(B600) - OK +cfgetospeed(B600) - OK +cfsetospeed(B1200) - OK +cfgetospeed(B1200) - OK +cfsetospeed(B1800) - OK +cfgetospeed(B1800) - OK +cfsetospeed(B2400) - OK +cfgetospeed(B2400) - OK +cfsetospeed(B4800) - OK +cfgetospeed(B4800) - OK +cfsetospeed(B9600) - OK +cfgetospeed(B9600) - OK +cfsetospeed(B19200) - OK +cfgetospeed(B19200) - OK +cfsetospeed(B38400) - OK +cfgetospeed(B38400) - OK +cfsetospeed(B57600) - OK +cfgetospeed(B57600) - OK +cfsetospeed(B115200) - OK +cfgetospeed(B115200) - OK +cfsetospeed(B230400) - OK +cfgetospeed(B230400) - OK +cfsetospeed(B460800) - OK +cfgetospeed(B460800) - OK +cfsetispeed(BAD BAUD) - EINVAL +cfsetispeed(B0) - OK +cfgetispeed(B0) - OK +cfsetispeed(B50) - OK +cfgetispeed(B50) - OK +cfsetispeed(B75) - OK +cfgetispeed(B75) - OK +cfsetispeed(B110) - OK +cfgetispeed(B110) - OK +cfsetispeed(B134) - OK +cfgetispeed(B134) - OK +cfsetispeed(B150) - OK +cfgetispeed(B150) - OK +cfsetispeed(B200) - OK +cfgetispeed(B200) - OK +cfsetispeed(B300) - OK +cfgetispeed(B300) - OK +cfsetispeed(B600) - OK +cfgetispeed(B600) - OK +cfsetispeed(B1200) - OK +cfgetispeed(B1200) - OK +cfsetispeed(B1800) - OK +cfgetispeed(B1800) - OK +cfsetispeed(B2400) - OK +cfgetispeed(B2400) - OK +cfsetispeed(B4800) - OK +cfgetispeed(B4800) - OK +cfsetispeed(B9600) - OK +cfgetispeed(B9600) - OK +cfsetispeed(B19200) - OK +cfgetispeed(B19200) - OK +cfsetispeed(B38400) - OK +cfgetispeed(B38400) - OK +cfsetispeed(B57600) - OK +cfgetispeed(B57600) - OK +cfsetispeed(B115200) - OK +cfgetispeed(B115200) - OK +cfsetispeed(B230400) - OK +cfgetispeed(B230400) - OK +cfsetispeed(B460800) - OK +cfgetispeed(B460800) - OK Init - close - /dev/test - OK *** END OF TEST TERMIOS 01 *** -- cgit v1.2.3