testing/ostest: More improvements to getopt() testing/ostest
Fix optind range checking. optind may index through argc (to the NULL argv entry) on the last option since optind is required to always point to the next command line argument. Add two more test cases were the final thing on the command line is an invalid long option. Fix a check that used an older, obsoleted hard-coded value that was not updated. This should have no impact other than to the getopt() test cases of the OS test. Tested on the simulator using a modified NSH configuration.
This commit is contained in:
parent
02ef45980b
commit
6a679043e6
@ -192,7 +192,11 @@ static int getopt_short_test(int noptions, int argc, FAR char **argv,
|
|||||||
(ret = getopt(argc, argv, optstring)) != ERROR && ndx < noptions;
|
(ret = getopt(argc, argv, optstring)) != ERROR && ndx < noptions;
|
||||||
ndx++)
|
ndx++)
|
||||||
{
|
{
|
||||||
if (optind < 1 || optind >= argc)
|
/* optind may index through argc (to the NULL argv entry) since it is
|
||||||
|
* required to always point to the next command line argument.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (optind < 1 || optind > argc)
|
||||||
{
|
{
|
||||||
printf("ERROR: optind=%d\n", optind);
|
printf("ERROR: optind=%d\n", optind);
|
||||||
}
|
}
|
||||||
@ -250,7 +254,11 @@ static int getopt_long_test(int noptions, int argc, FAR char **argv,
|
|||||||
longindex)) != ERROR;
|
longindex)) != ERROR;
|
||||||
ndx++)
|
ndx++)
|
||||||
{
|
{
|
||||||
if (optind < 1 || optind >= argc)
|
/* optind may index through argc (to the NULL argv entry) since it is
|
||||||
|
* required to always point to the next command line argument.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (optind < 1 || optind > argc)
|
||||||
{
|
{
|
||||||
printf("ERROR: optind=%d\n", optind);
|
printf("ERROR: optind=%d\n", optind);
|
||||||
}
|
}
|
||||||
@ -315,7 +323,11 @@ static int getopt_longonly_test(int noptions, int argc, FAR char **argv,
|
|||||||
longindex)) != ERROR;
|
longindex)) != ERROR;
|
||||||
ndx++)
|
ndx++)
|
||||||
{
|
{
|
||||||
if (optind < 1 || optind > 7)
|
/* optind may index through argc (to the NULL argv entry) since it is
|
||||||
|
* required to always point to the next command line argument.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (optind < 1 || optind > argc)
|
||||||
{
|
{
|
||||||
printf("ERROR: optind=%d\n", optind);
|
printf("ERROR: optind=%d\n", optind);
|
||||||
}
|
}
|
||||||
@ -413,6 +425,9 @@ int getopt_test(void)
|
|||||||
|
|
||||||
getopt_short_test(5, 9, argv, g_optstring, results);
|
getopt_short_test(5, 9, argv, g_optstring, results);
|
||||||
|
|
||||||
|
argv[8] = NULL;
|
||||||
|
getopt_short_test(5, 8, argv, g_optstring, results);
|
||||||
|
|
||||||
printf("getopt(): Missing optional argument\n");
|
printf("getopt(): Missing optional argument\n");
|
||||||
|
|
||||||
argv[0] = NULL;
|
argv[0] = NULL;
|
||||||
@ -490,6 +505,10 @@ int getopt_test(void)
|
|||||||
getopt_long_test(5, 9, argv, g_optstring, long_options, NULL,
|
getopt_long_test(5, 9, argv, g_optstring, long_options, NULL,
|
||||||
results);
|
results);
|
||||||
|
|
||||||
|
argv[8] = NULL;
|
||||||
|
getopt_long_test(5, 8, argv, g_optstring, long_options, NULL,
|
||||||
|
results);
|
||||||
|
|
||||||
printf("getopt_long(): Mixed long and short options\n");
|
printf("getopt_long(): Mixed long and short options\n");
|
||||||
|
|
||||||
argv[0] = NULL;
|
argv[0] = NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user