[PATCH] POSIX inttypes Testsuite
Aditya Upadhyay
aadit0402 at gmail.com
Sat Oct 20 16:25:39 UTC 2018
On Sat, Oct 20, 2018 at 12:43 AM Joel Sherrill <joel at rtems.org> wrote:
>
> A few administrative changes.
>
> There needs to be a proper commit log message.
>
> init.c does not have a copyright/license notices.
Should It be same as what we are seeing in other testsuite .c files? I
am not familiar
with Copyright and license related things.
>
> There is no .doc file giving a description of the test purposes/cases.
>
Thanks for pointing it. Added it now.
>
>
> On Wed, Sep 26, 2018 at 11:32 AM Aditya Upadhyay <aadit0402 at gmail.com> wrote:
>>
>> ---
>> testsuites/psxtests/Makefile.am | 10 ++
>> testsuites/psxtests/configure.ac | 1 +
>> testsuites/psxtests/psxinttypes01/init.c | 122 +++++++++++++++++++++
>> .../psxtests/psxinttypes01/psxinttypes01.scn | 28 +++++
>> 4 files changed, 161 insertions(+)
>> create mode 100644 testsuites/psxtests/psxinttypes01/init.c
>> create mode 100644 testsuites/psxtests/psxinttypes01/psxinttypes01.scn
>>
>> diff --git a/testsuites/psxtests/Makefile.am b/testsuites/psxtests/Makefile.am
>> index 2a18d54..c7b4899 100644
>> --- a/testsuites/psxtests/Makefile.am
>> +++ b/testsuites/psxtests/Makefile.am
>> @@ -15,6 +15,16 @@ psx_lib =
>> support_includes = -I$(top_srcdir)/../support/include
>>
>> if HAS_POSIX
>> +if TEST_psxinttypes01
>> +psx_tests += psxinttypes01
>> +psx_screens += psxinttypes01/psxinttypes01.scn
>> +psxinttypes01_SOURCES = psxinttypes01/init.c
>> +psxinttypes01_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_FLAGS_psxinttypes01) \
>> + $(support_includes) -I$(top_srcdir)/include
>> +endif
>> +endif
>> +
>> +if HAS_POSIX
>> if TEST_psx01
>> psx_tests += psx01
>> psx01_SOURCES = psx01/init.c psx01/task.c psx01/system.h \
>> diff --git a/testsuites/psxtests/configure.ac b/testsuites/psxtests/configure.ac
>> index cdd6ee7..85559e4 100644
>> --- a/testsuites/psxtests/configure.ac
>> +++ b/testsuites/psxtests/configure.ac
>> @@ -91,6 +91,7 @@ RTEMS_TEST_CHECK([psxid01])
>> RTEMS_TEST_CHECK([psximfs01])
>> RTEMS_TEST_CHECK([psximfs02])
>> RTEMS_TEST_CHECK([psxintrcritical01])
>> +RTEMS_TEST_CHECK([psxinttypes01])
>> RTEMS_TEST_CHECK([psxitimer])
>> RTEMS_TEST_CHECK([psxkey01])
>> RTEMS_TEST_CHECK([psxkey02])
>> diff --git a/testsuites/psxtests/psxinttypes01/init.c b/testsuites/psxtests/psxinttypes01/init.c
>> new file mode 100644
>> index 0000000..7f5942a
>> --- /dev/null
>> +++ b/testsuites/psxtests/psxinttypes01/init.c
>> @@ -0,0 +1,122 @@
>> +#ifdef HAVE_CONFIG_H
>> +#include "config.h"
>> +#endif
>> +
>> +#include <rtems/test.h>
>> +#include <inttypes.h>
>> +#include <stdio.h>
>> +#include <errno.h>
>> +#include <tmacros.h>
>> +#include <stdint.h>
>> +#include <stddef.h>
>> +
>> +const char rtems_test_name[] = "PSXINTTYPE 01";
>> +
>> +/* forward declarations to avoid warnings */
>> +rtems_task Init(rtems_task_argument ignored);
>> +
>> +rtems_task Init(rtems_task_argument ignored)
>> +{
>> + int base = 10;
>> + char *nptr1 = "123abc";
>> + char *endptr1 = NULL;
>> + wchar_t *nptr2 = L"-123junk";
>> + wchar_t *endptr2 = NULL;
>> + intmax_t status1;
>> + uintmax_t status2;
>> +
>> +
>> + TEST_BEGIN();
>> +
>> + puts( "\nChecking invalid base value" );
>> + rtems_test_assert( base >=2 && base <= 36 );
>> +
>> + /*Test for strtoimax */
>> + puts( "Strtoimax Testcases...." );
>> + puts( "Generating Status" );
>> + status1 = strtoimax( nptr1, &endptr1, base );
>> +
>> + rtems_test_assert( status1 != 0);
>> + rtems_test_assert( base != EINVAL);
>> +
>> + puts( "Checking Garbage end of endptr" );
>> + rtems_test_assert( *endptr1 != '\0' );
>> +
>> + puts( "Checking Underflow Case" );
>> + rtems_test_assert( status1 >= INTMAX_MIN );
>> +
>> + puts( "Checking Overflow Case" );
>> + rtems_test_assert( status1 <= INTMAX_MAX ) ;
>> +
>> + printf( "status = %jd \n" , status1 );
>> +
>> + /*Test for strtoumax */
>> + puts( "Strtoumax Testcases...." );
>> + puts( "Generating Status" );
>> + status2 = strtoumax( nptr1, &endptr1, base );
>> +
>> + rtems_test_assert( status2 != 0);
>> + rtems_test_assert( base != EINVAL);
>> +
>> + puts( "Checking Garbage end of endptr" );
>> + rtems_test_assert( *endptr1 != '\0' );
>> +
>> + puts( "Checking Overflow Case" );
>> + rtems_test_assert( status2 <= UINTMAX_MAX );
>> +
>> + printf( "status = %ju \n", status2 );
>> +
>> + /*Test for wcstoimax */
>> + puts( "Wcstoimax Testcases...." );
>> + puts( "Generating Status" );
>> + status1 = wcstoimax( nptr2, &endptr2, base );
>> +
>> + rtems_test_assert( status1 != 0);
>> + rtems_test_assert( base != EINVAL);
>> +
>> + puts( "Checking Garbage end of endptr" );
>> + rtems_test_assert( *endptr2 != '\0' );
>> +
>> + puts( "Checking Underflow Case" );
>> + rtems_test_assert( status1 >= INTMAX_MIN );
>> +
>> + puts( "Checking Overflow Case" );
>> + rtems_test_assert( status1 <= INTMAX_MAX ) ;
>> +
>> + printf( "status = %jd \n", status1 );
>> +
>> + /*Test for wcstoumax */
>> + puts( "wcstoumax Testcases...." );
>> + puts( "Generating Status" );
>> + status2 = wcstoumax( nptr2, &endptr2, base );
>> +
>> + rtems_test_assert( status2 != 0);
>> + rtems_test_assert( base != EINVAL);
>> +
>> + puts( "Checking Garbage end of endptr" );
>> + rtems_test_assert( *endptr2 != '\0' );
>> +
>> + puts( "Checking Overflow Case" );
>> + rtems_test_assert( status2 <= UINTMAX_MAX );
>> +
>> + printf( "status = %ju \n", status2 );
>> +
>> +
>> + TEST_END();
>> + rtems_test_exit(0);
>> +
>> +}
>> +
>> +/* NOTICE: the clock driver is explicitly disabled */
>> +
>> +#define CONFIGURE_APPLICATION_DOES_NOT_NEED_CLOCK_DRIVER
>> +#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
>> +
>> +#define CONFIGURE_MAXIMUM_TASKS 1
>> +
>> +#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
>> +
>> +#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION
>> +
>> +#define CONFIGURE_INIT
>> +#include <rtems/confdefs.h>
>> diff --git a/testsuites/psxtests/psxinttypes01/psxinttypes01.scn b/testsuites/psxtests/psxinttypes01/psxinttypes01.scn
>> new file mode 100644
>> index 0000000..72640b4
>> --- /dev/null
>> +++ b/testsuites/psxtests/psxinttypes01/psxinttypes01.scn
>> @@ -0,0 +1,28 @@
>> +*** BEGIN OF TEST PSXINTTYPE 01 ***
>> +Checking invalid base value
>> +Strtoimax Testcases....
>> +Generating Status
>> +Checking Garbage end of endptr
>> +Checking Underflow Case
>> +Checking Overflow Case
>> +status = 123
>> +Strtoumax Testcases....
>> +Generating Status
>> +Checking Garbage end of endptr
>> +Checking Overflow Case
>> +status = 123
>> +Wcstoimax Testcases....
>> +Generating Status
>> +Checking Garbage end of endptr
>> +Checking Underflow Case
>> +Checking Overflow Case
>> +status = -123
>> +wcstoumax Testcases....
>> +Generating Status
>> +Checking Garbage end of endptr
>> +Checking Overflow Case
>> +status = 18446744073709551493
>> +
>> +*** END OF TEST PSXINTTYPE 01 ***
>> +
>> +
>> --
>> 2.7.4
>>
More information about the devel
mailing list