On Tue, Jul 30, 2019 at 12:11 AM Joel Sherrill <j...@rtems.org> wrote:
> > > On Mon, Jul 29, 2019 at 1:07 PM Vaibhav Gupta <vaibhavgupt...@gmail.com> > wrote: > >> >> >> On Mon, Jul 29, 2019 at 10:44 PM Joel Sherrill <j...@rtems.org> wrote: >> >>> >>> >>> On Mon, Jul 29, 2019 at 11:35 AM Vaibhav Gupta <vaibhavgupt...@gmail.com> >>> wrote: >>> >>>> Thanks Joel! >>>> . >>>> Now when the testsuite patch is successfully accepted, I would like >>>> to add an example in: >>>> https://devel.rtems.org/wiki/Developer/Coding/80_characters_per_line, >>>> about wrapping a "function call" in "80 characters per line". >>>> >>> >>> Pull. I pushed the test. It just won't get built unless your toolset has >>> ndbm.h >>> >>> Thanks >> >>> This sounds like helpful guidance. >>> >>> What's next for fenv? >>> >> I am following what You and Gedare suggested me. I won't directly import >> fenv files, >> as sources are mixed (FreeBSD and NetBSD), I am trying to unify them. >> > > One newlib patch per architecture even if you are merging implementations. > > >> . >> I will be approaching in this manner: >> >> 1. I will make a header file `libc/include/fenv.h`. All function >> definitons will be mentioned. All definitons/macros which are architecture >> specific will be kept between #if / #elif / #else directives. >> >> > Avoid adding if's to the main fenv.h if you are doing bodies of the > implementation. As one example, RISC-V has its own fenv.h in > libc/machine/riscv/include and bodies of the methods in libm/machine/riscv. > Okay. > > fenv.h looks to be portable if sys/fenv.h is "machine" dependent. Your > if's could be factored out into machine/ARCH/include/fenv.h. Then the > portable method prototypes are in libc/include/fenv.h. > > Let me ask about that on the newlib list. > Yeah, I saw your mail on newlib just now, So you are proposing same structure as followed by NetBSD. They too have general fenv.h present in incliude : https://github.com/NetBSD/src/blob/trunk/include/fenv.h and a minimal working header which is architecture dependent.: https://github.com/NetBSD/src/blob/trunk/sys/arch/sparc/include/fenv.h . I wasn't sure if this approach can applied in newlib too, so I was going for if's directive thing. Thanks Vaibhav Gupta > > >> >> 1. Make architecture specific folders where I will Place `fenv.c` >> files. >> >> > > >> - Vaibhav Gupta >> >>> >>> >>>> . >>>> Gedare and me discussed about it on a thread. That time he guided me >>>> for this >>>> as there is no example about in on the trac pag. >>>> . >>>> Vaibhav Gupta >>>> >>>> >>>> On Mon, Jul 29, 2019 at 9:33 PM Joel Sherrill <j...@rtems.org> wrote: >>>> >>>>> Hi >>>>> >>>>> Now pushed. Thanks. >>>>> >>>>> I finally got a local sparc tool chain built with the git master of >>>>> newlib to build and run this test. It was a bit more complicated than I >>>>> expected. >>>>> >>>>> I did add a bit of logic to the psxtests configure.ac and Makefile.am >>>>> to ensure the test was not built unless the toolset included <ndbm.h>. >>>>> This >>>>> ensures that builds don't break when the toolset doesn't include it and >>>>> that git bisect will continue to work. >>>>> >>>>> The RSB will need to be bumped to the git master once the github >>>>> mirror updates to include my push to libm. >>>>> >>>>> On Thu, Jul 25, 2019 at 2:34 PM Joel Sherrill <j...@rtems.org> wrote: >>>>> >>>>>> Hi >>>>>> >>>>>> I just wanted to let everyone know that I have this pending on a >>>>>> branch and can build it using the current but there is a problem linking >>>>>> libm on the newlib git master. Once I have the RSB updated, I will look >>>>>> at >>>>>> pushing this. >>>>>> >>>>>> To let Vaibhav continue pushing on fenv, if we decide the >>>>>> configure.ac should check for the newly added dbm methods before >>>>>> building the test, I will merge that into the patch. >>>>>> >>>>>> --joel >>>>>> >>>>>> On Tue, Jul 23, 2019 at 8:42 AM Vaibhav Gupta < >>>>>> vaibhavgupt...@gmail.com> wrote: >>>>>> >>>>>>> --- >>>>>>> testsuites/psxtests/Makefile.am | 9 + >>>>>>> testsuites/psxtests/configure.ac | 1 + >>>>>>> testsuites/psxtests/psxndbm01/init.c | 299 >>>>>>> ++++++++++++++++++++ >>>>>>> testsuites/psxtests/psxndbm01/psxndbm01.doc | 36 +++ >>>>>>> testsuites/psxtests/psxndbm01/psxndbm01.scn | 29 ++ >>>>>>> 5 files changed, 374 insertions(+) >>>>>>> create mode 100644 testsuites/psxtests/psxndbm01/init.c >>>>>>> create mode 100644 testsuites/psxtests/psxndbm01/psxndbm01.doc >>>>>>> create mode 100644 testsuites/psxtests/psxndbm01/psxndbm01.scn >>>>>>> >>>>>>> diff --git a/testsuites/psxtests/Makefile.am >>>>>>> b/testsuites/psxtests/Makefile.am >>>>>>> index 59c9f2085b..36da591ccc 100755 >>>>>>> --- a/testsuites/psxtests/Makefile.am >>>>>>> +++ b/testsuites/psxtests/Makefile.am >>>>>>> @@ -694,6 +694,15 @@ psxmutexattr01_CPPFLAGS = $(AM_CPPFLAGS) >>>>>>> $(TEST_FLAGS_psxmutexattr01) \ >>>>>>> $(support_includes) -I$(top_srcdir)/include >>>>>>> endif >>>>>>> >>>>>>> +if TEST_psxndbm01 >>>>>>> +psx_tests += psxndbm01 >>>>>>> +psx_screens += psxndbm01/psxndbm01.scn >>>>>>> +psx_docs += psxndbm01/psxndbm01.doc >>>>>>> +psxndbm01_SOURCES = psxndbm01/init.c >>>>>>> +psxndbm01_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_FLAGS_psxndbm01) \ >>>>>>> + $(support_includes) >>>>>>> +endif >>>>>>> + >>>>>>> if TEST_psxobj01 >>>>>>> psx_tests += psxobj01 >>>>>>> psx_screens += psxobj01/psxobj01.scn >>>>>>> diff --git a/testsuites/psxtests/configure.ac b/testsuites/psxtests/ >>>>>>> configure.ac >>>>>>> index 85559e4aa5..07d7ccaf55 100644 >>>>>>> --- a/testsuites/psxtests/configure.ac >>>>>>> +++ b/testsuites/psxtests/configure.ac >>>>>>> @@ -110,6 +110,7 @@ RTEMS_TEST_CHECK([psxmsgq02]) >>>>>>> RTEMS_TEST_CHECK([psxmsgq03]) >>>>>>> RTEMS_TEST_CHECK([psxmsgq04]) >>>>>>> RTEMS_TEST_CHECK([psxmutexattr01]) >>>>>>> +RTEMS_TEST_CHECK([psxndbm01]) >>>>>>> RTEMS_TEST_CHECK([psxobj01]) >>>>>>> RTEMS_TEST_CHECK([psxonce01]) >>>>>>> RTEMS_TEST_CHECK([psxpasswd01]) >>>>>>> diff --git a/testsuites/psxtests/psxndbm01/init.c >>>>>>> b/testsuites/psxtests/psxndbm01/init.c >>>>>>> new file mode 100644 >>>>>>> index 0000000000..a1eff4bd67 >>>>>>> --- /dev/null >>>>>>> +++ b/testsuites/psxtests/psxndbm01/init.c >>>>>>> @@ -0,0 +1,299 @@ >>>>>>> +/** >>>>>>> + * @file >>>>>>> + * @brief Test suite for ndbm.h methods >>>>>>> + */ >>>>>>> + >>>>>>> +/* >>>>>>> + * SPDX-License-Identifier: BSD-2-Clause >>>>>>> + * >>>>>>> + * Copyright (C) 2019 Vaibhav Gupta >>>>>>> + * >>>>>>> + * Redistribution and use in source and binary forms, with or >>>>>>> without >>>>>>> + * modification, are permitted provided that the following >>>>>>> conditions >>>>>>> + * are met: >>>>>>> + * 1. Redistributions of source code must retain the above copyright >>>>>>> + * notice, this list of conditions and the following disclaimer. >>>>>>> + * 2. Redistributions in binary form must reproduce the above >>>>>>> copyright >>>>>>> + * notice, this list of conditions and the following disclaimer >>>>>>> in the >>>>>>> + * documentation and/or other materials provided with the >>>>>>> distribution. >>>>>>> + * >>>>>>> + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND >>>>>>> CONTRIBUTORS "AS IS" >>>>>>> + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT >>>>>>> LIMITED TO, THE >>>>>>> + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A >>>>>>> PARTICULAR PURPOSE >>>>>>> + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR >>>>>>> CONTRIBUTORS BE >>>>>>> + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, >>>>>>> OR >>>>>>> + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, >>>>>>> PROCUREMENT OF >>>>>>> + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR >>>>>>> BUSINESS >>>>>>> + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, >>>>>>> WHETHER IN >>>>>>> + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR >>>>>>> OTHERWISE) >>>>>>> + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF >>>>>>> ADVISED OF THE >>>>>>> + * POSSIBILITY OF SUCH DAMAGE. >>>>>>> + */ >>>>>>> + >>>>>>> +#ifdef HAVE_CONFIG_H >>>>>>> +#include "config.h" >>>>>>> +#endif >>>>>>> + >>>>>>> +/* header files are listed in lexical/lexicographical/alphabetical >>>>>>> order */ >>>>>>> + >>>>>>> +#include <errno.h> >>>>>>> +#include <fcntl.h> /* contains definitions of 'open_flags' */ >>>>>>> +#include <limits.h> >>>>>>> +#include <ndbm.h> /* contains declarations of ndbm methods */ >>>>>>> +#include <stddef.h> >>>>>>> +#include <stdint.h> >>>>>>> +#include <stdio.h> >>>>>>> +#include <sys/stat.h> /* contains definitions of 'file_mode' */ >>>>>>> +#include <string.h> >>>>>>> +#include <rtems/test.h> >>>>>>> +#include <tmacros.h> >>>>>>> + >>>>>>> +const char rtems_test_name[] = "PSXNDBM 01"; >>>>>>> + >>>>>>> +#define NAME "VARoDeK" >>>>>>> +#define PHONE_NO "123-321-777-888" >>>>>>> +#define DB_NAME "phones_test" >>>>>>> +#define NAME2 "VG" >>>>>>> +#define PHONE_NO2 "321-123-888-777" >>>>>>> + >>>>>>> +/* forward declarations to avoid warnings */ >>>>>>> +rtems_task Init(rtems_task_argument ignored); >>>>>>> + >>>>>>> +/* >>>>>>> +* This Function takes DBM* as a argument and count the number of >>>>>>> records in the >>>>>>> +* database pointed by it. >>>>>>> +*/ >>>>>>> +static int count_no_of_records( DBM *db_local ) >>>>>>> +{ >>>>>>> + int count = 0; >>>>>>> + datum temp; >>>>>>> + >>>>>>> + for ( >>>>>>> + temp = dbm_firstkey( db_local ); >>>>>>> + temp.dptr != NULL; >>>>>>> + temp = dbm_nextkey( db_local ), count++ >>>>>>> + ); >>>>>>> + >>>>>>> + return count; >>>>>>> +} >>>>>>> + >>>>>>> +/* Test Function Begins */ >>>>>>> +rtems_task Init(rtems_task_argument ignored) >>>>>>> +{ >>>>>>> + datum name = { NAME, sizeof( NAME ) }; >>>>>>> + datum put_phone_no = { PHONE_NO, sizeof( PHONE_NO ) }; >>>>>>> + datum name2 = { NAME2, sizeof( NAME2 ) }; >>>>>>> + datum put_phone_no2 = { PHONE_NO2, sizeof( PHONE_NO2 ) }; >>>>>>> + >>>>>>> + datum get_phone_no, key; >>>>>>> + >>>>>>> + int i; >>>>>>> + char *test_strings; >>>>>>> + >>>>>>> + DBM *db; >>>>>>> + >>>>>>> + TEST_BEGIN(); >>>>>>> + >>>>>>> +/* A Simple test to check if ndbm methods are call-able */ >>>>>>> + >>>>>>> +/* >>>>>>> + * A Simple test to check if NDBM methods are call-able >>>>>>> + * >>>>>>> + * We will try to open a database and then close it. >>>>>>> + * If it successful, hence we can have further tests. >>>>>>> + * Also, while opening it for first time, will create that database, >>>>>>> + * hence we will be able to test for 'O_RDWR | O_EXCL' case later. >>>>>>> + * Meanwhile we will also store one record, this record will be >>>>>>> helpful in >>>>>>> + * further tests. >>>>>>> + * And fetch it, to make sure if basic NDBM methods are working >>>>>>> correctly. >>>>>>> + */ >>>>>>> + >>>>>>> + puts( "\nOpen Database." ); >>>>>>> + db = dbm_open( DB_NAME, O_RDWR | O_CREAT | O_TRUNC, S_IRWXU ); >>>>>>> + rtems_test_assert( db != NULL ); >>>>>>> + >>>>>>> + /* This data will be useful in further tests */ >>>>>>> + puts( "Store Records in Database." ); >>>>>>> + dbm_store( db, name, put_phone_no, DBM_INSERT ); >>>>>>> + >>>>>>> + puts( "Fetch Records from Database and check." ); >>>>>>> + get_phone_no = dbm_fetch( db, name ); >>>>>>> + rtems_test_assert( strcmp( (const char*)get_phone_no.dptr, >>>>>>> PHONE_NO ) == 0 ); >>>>>>> + >>>>>>> + puts( "Close Database." ); >>>>>>> + dbm_close( db ); >>>>>>> + >>>>>>> +/* dbm_open() */ >>>>>>> + >>>>>>> + puts( "\nTestcases for 'dbm_open()'." ); >>>>>>> + >>>>>>> +/* The 'DB_NAME' is already created, hence 'O_RDWR | O_EXCL' should >>>>>>> fail. */ >>>>>>> + puts( "Use 'O_CREAT | O_EXCL' to open existing file and confirm >>>>>>> error." ); >>>>>>> + db = dbm_open( DB_NAME, O_RDWR | O_CREAT | O_EXCL, S_IRWXU ); >>>>>>> + rtems_test_assert( db == NULL ); >>>>>>> + rtems_test_assert( errno == EEXIST ); >>>>>>> + >>>>>>> +/* Some implementations use 3 characters for the suffix and others >>>>>>> use >>>>>>> + * 4 characters for the suffix, applications should ensure that the >>>>>>> maximum >>>>>>> + * portable pathname length passed to dbm_open() is no greater than >>>>>>> + * {PATH_MAX}-4 bytes, with the last component of the pathname no >>>>>>> greater >>>>>>> + * than {NAME_MAX}-4 bytes. >>>>>>> + */ >>>>>>> + >>>>>>> +/* inside 'ndbm.h' ; '#define DBM_SUFFIX ".db"' ; >>>>>>> + * 2 alphabets and 1 period, hence 3 characters are used for suffix >>>>>>> + * in this implementation. >>>>>>> + */ >>>>>>> + >>>>>>> + puts( "Use path name larger than '{PATH_MAX}-3 bytes.' and >>>>>>> confirm error." ); >>>>>>> + test_strings = (char*)malloc( PATH_MAX - 2 ); >>>>>>> + for ( i = 0; i < PATH_MAX - 3; i++ ) { >>>>>>> + test_strings[i] = 'r'; >>>>>>> + } >>>>>>> + test_strings[i] = '\0'; >>>>>>> + db = dbm_open( >>>>>>> + (const char*)test_strings, >>>>>>> + O_RDWR | O_CREAT | O_TRUNC, >>>>>>> + S_IRWXU >>>>>>> + ); >>>>>>> + rtems_test_assert( db == NULL ); >>>>>>> + rtems_test_assert( errno == ENAMETOOLONG ); >>>>>>> + free( test_strings ); >>>>>>> + >>>>>>> +/* database opened for write-only access opens the files for read >>>>>>> and >>>>>>> + * write access or it will fail. >>>>>>> + */ >>>>>>> + >>>>>>> +/* Implementation of __hash_open in newlib does not support >>>>>>> `O_WRONLY` */ >>>>>>> + >>>>>>> + puts( "Open file with write access only and confirm error." ); >>>>>>> + db = dbm_open( DB_NAME, O_WRONLY, S_IRWXU ); >>>>>>> + rtems_test_assert( db == NULL ); >>>>>>> + rtems_test_assert( errno == EINVAL ); >>>>>>> + >>>>>>> +/* dbm_store() */ >>>>>>> + >>>>>>> + puts( "\nTestcases for 'dbm_store()'" ); >>>>>>> + db = dbm_open( DB_NAME, O_RDWR, S_IRWXU ); >>>>>>> + rtems_test_assert( db != NULL ); >>>>>>> + >>>>>>> + puts( "Insert new record with same key using 'DBM_INSERT' mode >>>>>>> and " >>>>>>> + "confirm error." ); >>>>>>> + rtems_test_assert( dbm_store( db, name, put_phone_no2, DBM_INSERT >>>>>>> ) == 1 ); >>>>>>> + >>>>>>> + get_phone_no = dbm_fetch( db, name ); >>>>>>> + rtems_test_assert( strcmp( (const char*)get_phone_no.dptr, >>>>>>> PHONE_NO ) == 0 ); >>>>>>> + >>>>>>> + puts( "Insert new record with same key using 'DBM_REPLACE' mode >>>>>>> and " >>>>>>> + "confirm changes." ); >>>>>>> + rtems_test_assert( dbm_store( db, name, put_phone_no2, >>>>>>> DBM_REPLACE ) == 0 ); >>>>>>> + >>>>>>> + get_phone_no = dbm_fetch( db, name ); >>>>>>> + rtems_test_assert( strcmp( (const char*)get_phone_no.dptr, >>>>>>> PHONE_NO2 ) == 0 ); >>>>>>> + >>>>>>> +/* Revert for next tests */ >>>>>>> + rtems_test_assert( dbm_store( db, name, put_phone_no, DBM_REPLACE >>>>>>> ) == 0 ); >>>>>>> + >>>>>>> + puts( "Store a new record and " >>>>>>> + "confirm that total number of records is successful 2." ); >>>>>>> + rtems_test_assert( dbm_store( db, name2, put_phone_no2, >>>>>>> DBM_INSERT ) == 0 ); >>>>>>> + >>>>>>> +/* Confirm number of records */ >>>>>>> + rtems_test_assert( count_no_of_records( db ) == 2 ); >>>>>>> + >>>>>>> + dbm_close( db ); >>>>>>> + >>>>>>> +/* dbm_fetch() */ >>>>>>> + >>>>>>> + puts( "\nTestcases for 'dbm_fetch()'" ); >>>>>>> + db = dbm_open( DB_NAME, O_RDONLY, S_IRWXU ); >>>>>>> + rtems_test_assert( db != NULL ); >>>>>>> + >>>>>>> + puts( "Fetch existing records and confirm results." ); >>>>>>> + get_phone_no = dbm_fetch( db, name ); >>>>>>> + rtems_test_assert( strcmp( (const char*)get_phone_no.dptr, >>>>>>> PHONE_NO ) == 0 ); >>>>>>> + >>>>>>> + get_phone_no = dbm_fetch( db, name2 ); >>>>>>> + rtems_test_assert( strcmp( (const char*)get_phone_no.dptr, >>>>>>> PHONE_NO2 ) == 0 ); >>>>>>> + >>>>>>> + puts( "Fetch non-existing record and confirm error." ); >>>>>>> + test_strings = (char*)malloc(6); >>>>>>> + strncpy( test_strings, "Hello", 5 ); >>>>>>> + >>>>>>> + test_strings[5] = '\0'; >>>>>>> + >>>>>>> +/* The data pointed by test_string is now pointed by key.dptr */ >>>>>>> + key.dptr = test_strings; >>>>>>> + key.dsize = sizeof( test_strings ); >>>>>>> + get_phone_no = dbm_fetch( db, key ); >>>>>>> + rtems_test_assert( get_phone_no.dptr == NULL ); >>>>>>> + dbm_close( db ); >>>>>>> + >>>>>>> +/* We need the 'key' object, hence we cannot free 'test_strings' >>>>>>> */ >>>>>>> + >>>>>>> +/* dbm_delete() */ >>>>>>> + >>>>>>> + puts( "\nTestcases for 'dbm_delete()'" ); >>>>>>> + db = dbm_open( DB_NAME, O_RDWR, S_IRWXU ); >>>>>>> + rtems_test_assert( db != NULL ); >>>>>>> + >>>>>>> + puts( "Delete non-existing record and confirm error." ); >>>>>>> + rtems_test_assert( dbm_delete( db, key ) != 0 ); >>>>>>> + free( test_strings ); >>>>>>> + rtems_test_assert( count_no_of_records( db ) == 2); >>>>>>> + >>>>>>> + puts( "Delete existing record and " >>>>>>> + "confirm that total number of records is successful 1." ); >>>>>>> + rtems_test_assert( dbm_delete( db, name ) == 0 ); >>>>>>> + rtems_test_assert( count_no_of_records( db ) == 1); >>>>>>> + >>>>>>> + puts( "Confirm if correct record is deleted." ); >>>>>>> + get_phone_no = dbm_fetch( db, name ); >>>>>>> + rtems_test_assert( get_phone_no.dptr == NULL ); >>>>>>> + >>>>>>> +/* record returned by 'dbm_firstkey()' should be the only record >>>>>>> + * left, this should be checked to confirm correct working of >>>>>>> + * 'dbm_firstkey()'. >>>>>>> + * Check if the data is not corrupted after usage of 'dbm_delete()' >>>>>>> + */ >>>>>>> + >>>>>>> + puts( "Check if the data is not corrupted after usage of >>>>>>> 'dbm_delete()'." ); >>>>>>> + get_phone_no = dbm_fetch( db, dbm_firstkey( db ) ); >>>>>>> + rtems_test_assert( strcmp( (const char*)get_phone_no.dptr, >>>>>>> PHONE_NO2 ) == 0 ); >>>>>>> + >>>>>>> +/* Empty the database and then try to use 'dbm_firstkey()', the >>>>>>> + * dptr pointer should point to NULL. >>>>>>> + */ >>>>>>> + >>>>>>> + puts( "Empty records in database and check results of >>>>>>> 'dbm_firstkey()'." ); >>>>>>> + rtems_test_assert( dbm_delete( db, dbm_firstkey( db ) ) == 0 ); >>>>>>> + key = dbm_firstkey( db ); >>>>>>> + rtems_test_assert( key.dptr == NULL ); >>>>>>> + dbm_close( db ); >>>>>>> + >>>>>>> +/* >>>>>>> +* All cases for 'dbm_firstkey()' and 'dbm_nextkey()' were tested >>>>>>> while >>>>>>> +* performing other tests. >>>>>>> +* One such case be found in count_number_of_records() function. >>>>>>> +*/ >>>>>>> + >>>>>>> + 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_LIBIO_MAXIMUM_FILE_DESCRIPTORS 6 >>>>>>> + >>>>>>> +#define CONFIGURE_RTEMS_INIT_TASKS_TABLE >>>>>>> + >>>>>>> +#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION >>>>>>> + >>>>>>> +#define CONFIGURE_INIT >>>>>>> +#include <rtems/confdefs.h> >>>>>>> +/* end of file */ >>>>>>> diff --git a/testsuites/psxtests/psxndbm01/psxndbm01.doc >>>>>>> b/testsuites/psxtests/psxndbm01/psxndbm01.doc >>>>>>> new file mode 100644 >>>>>>> index 0000000000..cdaeb40911 >>>>>>> --- /dev/null >>>>>>> +++ b/testsuites/psxtests/psxndbm01/psxndbm01.doc >>>>>>> @@ -0,0 +1,36 @@ >>>>>>> +This File describes the concepts tested by this test suite. >>>>>>> + >>>>>>> +ndbm.h - routines to manage data files that contain key/data pairs. >>>>>>> + >>>>>>> +test suite name: PSXNDBM 01 >>>>>>> + >>>>>>> +- A Simple test to check if NDBM methods are call-able. >>>>>>> + - Check if able to run the routine to Open Database. >>>>>>> + - Check if able to run the routine to store a record in database. >>>>>>> + - Check if able to run the routine to fetch a record from >>>>>>> database. >>>>>>> + - Check if able to run the routine to close the database. >>>>>>> + >>>>>>> +- Test Cases for 'dbm_open()'. >>>>>>> + - Verify the error when trying to open existing file with 'O_RDWR >>>>>>> | O_EXCL' >>>>>>> + flags. >>>>>>> + - Verify the error when trying to open file with pathname longer >>>>>>> than >>>>>>> + {PATHMAX}-3 bytes. >>>>>>> + - Verify the error when trying to open file with only write >>>>>>> access. >>>>>>> + >>>>>>> +- Test Cases for 'dbm_store()'. >>>>>>> + - Verify the error when trying to insert a record using same key >>>>>>> with >>>>>>> + 'DBM_INSERT' mode. >>>>>>> + - Verify the updated record when trying to insert a record using >>>>>>> same key >>>>>>> + with 'DBM_REPLACE' mode. >>>>>>> + - Verify if able to save more than one record in database. >>>>>>> + >>>>>>> +- Test Cases for 'dbm_fetch()'. >>>>>>> + - Verify the data fetched from database. >>>>>>> + - Verify the error when tring to fetch non-existing record. >>>>>>> + >>>>>>> +- Test Cases for 'dbm_delete()'. >>>>>>> + - Veriy the error when trying to delete non-existing record. >>>>>>> + - Delete one record and verify results. >>>>>>> + - Check if correct record is deleted. >>>>>>> + - Verify if other data is not corrupted during delete. >>>>>>> + - Empty the databse and verify the value returned by >>>>>>> 'dbm_firstkey()'. >>>>>>> \ No newline at end of file >>>>>>> diff --git a/testsuites/psxtests/psxndbm01/psxndbm01.scn >>>>>>> b/testsuites/psxtests/psxndbm01/psxndbm01.scn >>>>>>> new file mode 100644 >>>>>>> index 0000000000..3fa386630a >>>>>>> --- /dev/null >>>>>>> +++ b/testsuites/psxtests/psxndbm01/psxndbm01.scn >>>>>>> @@ -0,0 +1,29 @@ >>>>>>> +*** PSXNDBM 01 Test *** >>>>>>> + >>>>>>> +Open Database. >>>>>>> +Store Records in Database. >>>>>>> +Fetch Records from Database and check. >>>>>>> +Close Database. >>>>>>> + >>>>>>> +Testcases for 'dbm_open()'. >>>>>>> +Use 'O_CREAT | O_EXCL' to open existing file and confirm error. >>>>>>> +Use path name larger than '{PATH_MAX}-3 bytes.' and confirm error. >>>>>>> +Open file with write access only and confirm error. >>>>>>> + >>>>>>> +Testcases for 'dbm_store()' >>>>>>> +Insert new record with same key using 'DBM_INSERT' mode and confirm >>>>>>> error. >>>>>>> +Insert new record with same key using 'DBM_REPLACE' mode and >>>>>>> confirm changes. >>>>>>> +Store a new record and confirm that total number of records is >>>>>>> successful 2. >>>>>>> + >>>>>>> +Testcases for 'dbm_fetch()' >>>>>>> +Fetch existing records and confirm results. >>>>>>> +Fetch non-existing record and confirm error. >>>>>>> + >>>>>>> +Testcases for 'dbm_delete()' >>>>>>> +Delete non-existing record and confirm error. >>>>>>> +Delete existing record and confirm that total number of records is >>>>>>> successful 1. >>>>>>> +Confirm if correct record is deleted. >>>>>>> +Check if the data is not corrupted after usage of 'dbm_delete()'. >>>>>>> +Empty records in database and check results of 'dbm_firstkey()'. >>>>>>> + >>>>>>> +*** END OF TEST PSXNDBM 01 *** >>>>>>> \ No newline at end of file >>>>>>> -- >>>>>>> 2.21.0 >>>>>>> >>>>>>>
_______________________________________________ devel mailing list devel@rtems.org http://lists.rtems.org/mailman/listinfo/devel