diff options
author | Bjorn Larsson <bjornlarsson@oarcorp.com> | 2014-03-25 13:48:30 -0500 |
---|---|---|
committer | Jennifer Averett <jennifer.averett@oarcorp.com> | 2014-03-28 12:32:47 -0500 |
commit | a3707d893c158b8b7178f3aeb17754c7f66f1176 (patch) | |
tree | 149001b648d52eb4982644efdf33c1f97aef005e /testsuites/sptests/spmsgq_err01/init.c | |
parent | spport_err01: New test split from sp09 (diff) | |
download | rtems-a3707d893c158b8b7178f3aeb17754c7f66f1176.tar.bz2 |
sptests: Split sp09 screens 7,8 into spmsg1_err01 and spmsgq_err02.
spmsgq_err01 test replaces rtems_message_queue_XXX error tests from
sp09 screen 7. spmsgq_err02 replaces rtems_message_queue_XXX error
tests from sp09 screen 8.
Diffstat (limited to 'testsuites/sptests/spmsgq_err01/init.c')
-rw-r--r-- | testsuites/sptests/spmsgq_err01/init.c | 406 |
1 files changed, 406 insertions, 0 deletions
diff --git a/testsuites/sptests/spmsgq_err01/init.c b/testsuites/sptests/spmsgq_err01/init.c new file mode 100644 index 0000000000..7b21005672 --- /dev/null +++ b/testsuites/sptests/spmsgq_err01/init.c @@ -0,0 +1,406 @@ +/* + * COPYRIGHT (c) 2014. + * On-Line Applications Research Corporation (OAR). + * + * The license and distribution terms for this file may be + * found in the file LICENSE in this distribution or at + * http://www.rtems.com/license/LICENSE. + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#define CONFIGURE_INIT +#include "system.h" +#define MESSAGE_SIZE (sizeof(long) * 4) + +const char rtems_test_name[] = "SP MESSAGE QUEUE ERROR 1"; + +rtems_task Init( + rtems_task_argument argument +) +{ + long buffer[ 4 ]; + uint32_t count; + size_t size; + rtems_status_code status; + + TEST_BEGIN(); + Queue_name[ 1 ] = rtems_build_name( 'M', 'Q', '1', ' ' ); + Queue_name[ 2 ] = rtems_build_name( 'M', 'Q', '2', ' ' ); + + status = rtems_message_queue_broadcast( 100, buffer, MESSAGE_SIZE, &count ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_broadcast with illegal id" + ); + puts( "TA1 - rtems_message_queue_broadcast - RTEMS_INVALID_ID" ); + + /* null ID parameter */ + status = rtems_message_queue_create( + Queue_name[ 1 ], + 3, + MESSAGE_SIZE, + RTEMS_DEFAULT_ATTRIBUTES, + NULL + ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_create with null param" + ); + puts( "TA1 - rtems_message_queue_create - NULL Id - RTEMS_INVALID_ADDRESS" ); + + /* count == 0 */ + status = rtems_message_queue_create( + Queue_name[ 1 ], + 0, + MESSAGE_SIZE, + RTEMS_DEFAULT_ATTRIBUTES, + &Junk_id + ); + fatal_directive_status( + status, + RTEMS_INVALID_NUMBER, + "rtems_message_queue_create with 0 count" + ); + puts( "TA1 - rtems_message_queue_create - count = 0 - RTEMS_INVALID_NUMBER" ); + + /* max size == 0 */ + status = rtems_message_queue_create( + Queue_name[ 1 ], + 3, + 0, + RTEMS_DEFAULT_ATTRIBUTES, + &Junk_id + ); + fatal_directive_status( + status, + RTEMS_INVALID_SIZE, + "rtems_message_queue_create with 0 msg size" + ); + puts( "TA1 - rtems_message_queue_create - size = 0 - RTEMS_INVALID_SIZE" ); + + /* bad name parameter */ + status = rtems_message_queue_create( + 0, + 3, + MESSAGE_SIZE, + RTEMS_DEFAULT_ATTRIBUTES, + &Junk_id + ); + fatal_directive_status( + status, + RTEMS_INVALID_NAME, + "rtems_message_queue_create with illegal name" + ); + puts( "TA1 - rtems_message_queue_create - Q 1 - RTEMS_INVALID_NAME" ); + + /* + * The check for an object being global is only made if + * multiprocessing is enabled. + */ + +#if defined(RTEMS_MULTIPROCESSING) + status = rtems_message_queue_create( + Queue_name[ 1 ], + 1, + MESSAGE_SIZE, + RTEMS_GLOBAL, + &Junk_id + ); + fatal_directive_status( + status, + RTEMS_MP_NOT_CONFIGURED, + "rtems_message_queue_create of mp not configured" + ); +#endif + puts( "TA1 - rtems_message_queue_create - Q 1 - RTEMS_MP_NOT_CONFIGURED" ); + + /* not enough memory for messages */ + status = rtems_message_queue_create( + Queue_name[ 1 ], + INT_MAX, + MESSAGE_SIZE, + RTEMS_DEFAULT_ATTRIBUTES, + &Queue_id[ 1 ] + ); + fatal_directive_status( + status, + RTEMS_UNSATISFIED, + "rtems_message_queue_create unsatisfied" + ); + puts( "TA1 - rtems_message_queue_create - Q 2 - RTEMS_UNSATISFIED" ); + + /* too large a request for messages */ + status = rtems_message_queue_create( + Queue_name[ 1 ], + INT_MAX, + INT_MAX, + RTEMS_DEFAULT_ATTRIBUTES, + &Queue_id[ 1 ] + ); + fatal_directive_status( + status, + RTEMS_UNSATISFIED, + "rtems_message_queue_create unsatisfied" + ); + puts( "TA1 - rtems_message_queue_create - Q 2 - RTEMS_UNSATISFIED #2" ); + + status = rtems_message_queue_create( + Queue_name[ 1 ], + 2, + MESSAGE_SIZE, + RTEMS_DEFAULT_ATTRIBUTES, + &Queue_id[ 1 ] + ); + directive_failed( status, "rtems_message_queue_create successful" ); + puts( "TA1 - rtems_message_queue_create - Q 1 - 2 DEEP - RTEMS_SUCCESSFUL" ); + + status = rtems_message_queue_create( + Queue_name[ 2 ], + 1, + MESSAGE_SIZE, + RTEMS_DEFAULT_ATTRIBUTES, + &Junk_id + ); + fatal_directive_status( + status, + RTEMS_TOO_MANY, + "rtems_message_queue_create of too many" + ); + puts( "TA1 - rtems_message_queue_create - Q 2 - RTEMS_TOO_MANY" ); + + status = rtems_message_queue_delete( 100 ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_create with illegal id" + ); + puts( "TA1 - rtems_message_queue_delete - unknown RTEMS_INVALID_ID" ); + + status = rtems_message_queue_delete( rtems_build_id( 1, 1, 1, 256 ) ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_delete with local illegal id" + ); + puts( "TA1 - rtems_message_queue_delete - local RTEMS_INVALID_ID" ); + + status = rtems_message_queue_ident( 100, RTEMS_SEARCH_ALL_NODES, &Junk_id ); + fatal_directive_status( + status, + RTEMS_INVALID_NAME, + "rtems_message_queue_ident with illegal name" + ); + puts( "TA1 - rtems_message_queue_ident - RTEMS_INVALID_NAME" ); + + /* number pending - bad Id */ + status = rtems_message_queue_get_number_pending( Queue_id[ 1 ], NULL ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_get_number_pending with NULL param" + ); + puts("TA1 - rtems_message_queue_get_number_pending - RTEMS_INVALID_ADDRESS"); + + /* number pending - bad Id */ + status = rtems_message_queue_get_number_pending( 100, &count ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_get_number_pending with illegal id" + ); + puts( "TA1 - rtems_message_queue_get_number_pending - RTEMS_INVALID_ID" ); + + /* flush null param */ + status = rtems_message_queue_flush( Queue_id[ 1 ], NULL ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_flush with NULL param" + ); + puts( "TA1 - rtems_message_queue_flush - RTEMS_INVALID_ADDRESS" ); + + /* flush invalid id */ + status = rtems_message_queue_flush( 100, &count ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_flush with illegal id" + ); + puts( "TA1 - rtems_message_queue_flush - RTEMS_INVALID_ID" ); + + status = rtems_message_queue_receive( + 100, + (long (*)[4]) buffer, + &size, + RTEMS_DEFAULT_OPTIONS, + 0 + ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_receive with illegal id" + ); + puts( "TA1 - rtems_message_queue_receive - RTEMS_INVALID_ID" ); + + status = rtems_message_queue_receive( + Queue_id[ 1 ], + NULL, + &size, + RTEMS_NO_WAIT, + RTEMS_NO_TIMEOUT + ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_receive NULL buffer" + ); + puts( + "TA1 - rtems_message_queue_receive - Q 1 - " + "RTEMS_INVALID_ADDRESS NULL buffer" + ); + + status = rtems_message_queue_receive( + Queue_id[ 1 ], + (long (*)[4]) buffer, + NULL, + RTEMS_NO_WAIT, + RTEMS_NO_TIMEOUT + ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_receive NULL size" + ); + puts( + "TA1 - rtems_message_queue_receive - Q 1 - " + "RTEMS_INVALID_ADDRESS NULL size" + ); + + status = rtems_message_queue_receive( + Queue_id[ 1 ], + (long (*)[4]) buffer, + &size, + RTEMS_NO_WAIT, + RTEMS_NO_TIMEOUT + ); + fatal_directive_status( + status, + RTEMS_UNSATISFIED, + "rtems_message_queue_receive unsatisfied" + ); + puts( "TA1 - rtems_message_queue_receive - Q 1 - RTEMS_UNSATISFIED" ); + + puts( "TA1 - rtems_message_queue_receive - Q 1 - timeout in 3 seconds" ); + status = rtems_message_queue_receive( + Queue_id[ 1 ], + (long (*)[4]) buffer, + &size, + RTEMS_DEFAULT_OPTIONS, + 3 * rtems_clock_get_ticks_per_second() + ); + fatal_directive_status( + status, + RTEMS_TIMEOUT, + "rtems_message_queue_receive 3 second timeout" + ); + + puts( + "TA1 - rtems_message_queue_receive - Q 1 - woke up with RTEMS_TIMEOUT" + ); + + /* send NULL message*/ + status = rtems_message_queue_send( Queue_id[ 1 ], NULL, MESSAGE_SIZE ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_send with NULL buffer" + ); + puts( + "TA1 - rtems_message_queue_send - NULL buffer - RTEMS_INVALID_ADDRESS" + ); + + /* send bad id */ + status = rtems_message_queue_send( 100, buffer, MESSAGE_SIZE ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_send with illegal id" + ); + puts( "TA1 - rtems_message_queue_send - RTEMS_INVALID_ID" ); + + status = rtems_message_queue_send( Queue_id[ 1 ], buffer, MESSAGE_SIZE ); + directive_failed( status, "rtems_message_queue_send" ); + puts( "TA1 - rtems_message_queue_send - BUFFER 1 TO Q 1 - RTEMS_SUCCESSFUL" ); + + status = rtems_message_queue_send( Queue_id[ 1 ], buffer, MESSAGE_SIZE ); + directive_failed( status, "rtems_message_queue_send" ); + puts( "TA1 - rtems_message_queue_send - BUFFER 2 TO Q 1 - RTEMS_SUCCESSFUL" ); + + status = rtems_message_queue_send( Queue_id[ 1 ], buffer, MESSAGE_SIZE ); + fatal_directive_status( + status, + RTEMS_TOO_MANY, + "rtems_message_queue_send too many to a limited queue" + ); + puts( "TA1 - rtems_message_queue_send - BUFFER 3 TO Q 1 - RTEMS_TOO_MANY" ); + + /* urgent NULL message*/ + status = rtems_message_queue_urgent( Queue_id[ 1 ], NULL, MESSAGE_SIZE ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_urgent with NULL buffer" + ); + puts( + "TA1 - rtems_message_queue_urgent - NULL buffer - RTEMS_INVALID_ADDRESS" + ); + + /* urgent bad Id */ + status = rtems_message_queue_urgent( 100, buffer, MESSAGE_SIZE ); + fatal_directive_status( + status, + RTEMS_INVALID_ID, + "rtems_message_queue_urgent with illegal id" + ); + puts( "TA1 - rtems_message_queue_urgent - RTEMS_INVALID_ID" ); + + status = rtems_message_queue_broadcast( + Queue_id[ 1 ], NULL, MESSAGE_SIZE, &count ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_broadcast with NULL count" + ); + puts( + "TA1 - rtems_message_queue_broadcast - NULL buffer - RTEMS_INVALID_ADDRESS" + ); + + status = rtems_message_queue_broadcast( + Queue_id[ 1 ], buffer, MESSAGE_SIZE + 1, &count ); + fatal_directive_status( + status, + RTEMS_INVALID_SIZE, + "rtems_message_queue_broadcast with too large" + ); + puts( + "TA1 - rtems_message_queue_broadcast - too large - RTEMS_INVALID_SIZE" + ); + + status = rtems_message_queue_broadcast( + Queue_id[ 1 ], buffer, MESSAGE_SIZE, NULL ); + fatal_directive_status( + status, + RTEMS_INVALID_ADDRESS, + "rtems_message_queue_broadcast with NULL count" + ); + puts( + "TA1 - rtems_message_queue_broadcast - NULL count - RTEMS_INVALID_ADDRESS" + ); + + TEST_END(); +} |