Home | History | Annotate | Download | only in ulimit
      1 /*
      2  * Copyright (c) 2000 Silicon Graphics, Inc.  All Rights Reserved.
      3  *
      4  * This program is free software; you can redistribute it and/or modify it
      5  * under the terms of version 2 of the GNU General Public License as
      6  * published by the Free Software Foundation.
      7  *
      8  * This program is distributed in the hope that it would be useful, but
      9  * WITHOUT ANY WARRANTY; without even the implied warranty of
     10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
     11  *
     12  * Further, this software is distributed without any warranty that it is
     13  * free of the rightful claim of any third person regarding infringement
     14  * or the like.  Any license provided herein, whether implied or
     15  * otherwise, applies only to this software file.  Patent licenses, if
     16  * any, provided herein do not apply to combinations of this program with
     17  * other software, or any other product whatsoever.
     18  *
     19  * You should have received a copy of the GNU General Public License along
     20  * with this program; if not, write the Free Software Foundation, Inc.,
     21  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
     22  *
     23  * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
     24  * Mountain View, CA  94043, or:
     25  *
     26  * http://www.sgi.com
     27  *
     28  * For further information regarding this notice, see:
     29  *
     30  * http://oss.sgi.com/projects/GenInfo/NoticeExplan/
     31  */
     32 /* $Id: ulimit01.c,v 1.6 2009/11/02 13:57:19 subrata_modak Exp $ */
     33 /**********************************************************
     34  *
     35  *    OS Test - Silicon Graphics, Inc.
     36  *
     37  *    TEST IDENTIFIER	: ulimit01
     38  *
     39  *    EXECUTED BY	: anyone
     40  *
     41  *    TEST TITLE	: Basic test for ulimit(2)
     42  *
     43  *    PARENT DOCUMENT	: usctpl01
     44  *
     45  *    TEST CASE TOTAL	: 6
     46  *
     47  *    WALL CLOCK TIME	: 1
     48  *
     49  *    CPU TYPES		: ALL
     50  *
     51  *    AUTHOR		: William Roske
     52  *
     53  *    CO-PILOT		: Dave Fenner
     54  *
     55  *    DATE STARTED	: 03/30/92
     56  *
     57  *    INITIAL RELEASE	: UNICOS 7.0
     58  *
     59  *    TEST CASES
     60  *
     61  * 	1.) ulimit(2) returns...(See Description)
     62  *
     63  *    INPUT SPECIFICATIONS
     64  * 	The standard options for system call tests are accepted.
     65  *	(See the parse_opts(3) man page).
     66  *
     67  *    OUTPUT SPECIFICATIONS
     68  *$
     69  *    DURATION
     70  * 	Terminates - with frequency and infinite modes.
     71  *
     72  *    SIGNALS
     73  * 	Uses SIGUSR1 to pause before test if option set.
     74  * 	(See the parse_opts(3) man page).
     75  *
     76  *    RESOURCES
     77  * 	None
     78  *
     79  *    ENVIRONMENTAL NEEDS
     80  * 	The libcuts.a and libsys.a libraries must be included in
     81  *	the compilation of this test.
     82  *
     83  *    SPECIAL PROCEDURAL REQUIREMENTS
     84  * 	None
     85  *
     86  *    INTERCASE DEPENDENCIES
     87  * 	None
     88  *
     89  *    DETAILED DESCRIPTION
     90  *	This is a Phase I test for the ulimit(2) system call.  It is intended
     91  *	to provide a limited exposure of the system call, for now.  It
     92  *	should/will be extended when full functional tests are written for
     93  *	ulimit(2).
     94  *
     95  * 	Setup:
     96  * 	  Setup signal handling.
     97  *	  Pause for SIGUSR1 if option specified.
     98  *
     99  * 	Test:
    100  *	 Loop if the proper options are given.
    101  * 	  Execute system call
    102  *	  Check return code, if system call failed (return=-1)
    103  *		Log the errno and Issue a FAIL message.
    104  *	  Otherwise, Issue a PASS message.
    105  *
    106  * 	Cleanup:
    107  * 	  Print errno log and/or timing stats if options given
    108  *
    109  *
    110  *#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#**/
    111 
    112 #include <ulimit.h>
    113 #include <errno.h>
    114 #include <string.h>
    115 #include <signal.h>
    116 #include "test.h"
    117 
    118 void setup();
    119 void cleanup();
    120 
    121 char *TCID = "ulimit01";
    122 int TST_TOTAL = 6;
    123 
    124 int cmd;
    125 long limit;			/* saved limit */
    126 
    127 struct limits_t {
    128 	int cmd;
    129 	long newlimit;
    130 	int nlim_flag;		/* special flag for UL_SETFSIZE records  */
    131 	int exp_fail;
    132 } Scenarios[] = {
    133 
    134 	{
    135 	UL_GETFSIZE, -1, 0, 0}, {
    136 	UL_SETFSIZE, -2, 1, 0},	/* case case: must be after UL_GETFSIZE */
    137 	{
    138 	UL_SETFSIZE, -2, 2, 0},	/* case case: must be after UL_GETFSIZE */
    139 #if UL_GMEMLIM
    140 	{
    141 	UL_GMEMLIM, -1, 0, 0},
    142 #endif
    143 #if UL_GDESLIM
    144 	{
    145 	UL_GDESLIM, -1, 0, 0},
    146 #endif
    147 #if UL_GSHMEMLIM
    148 	{
    149 	UL_GSHMEMLIM, -1, 0, 0},
    150 #endif
    151 };
    152 
    153 int main(int ac, char **av)
    154 {
    155 	int lc;
    156 	int i;
    157 	int tmp;
    158 
    159 	TST_TOTAL = sizeof(Scenarios) / sizeof(struct limits_t);
    160 
    161     /***************************************************************
    162      * parse standard options
    163      ***************************************************************/
    164 	tst_parse_opts(ac, av, NULL, NULL);
    165 
    166     /***************************************************************
    167      * perform global setup for test
    168      ***************************************************************/
    169 	setup();
    170 
    171     /***************************************************************
    172      * check looping state if -c option given
    173      ***************************************************************/
    174 	for (lc = 0; TEST_LOOPING(lc); lc++) {
    175 
    176 		tst_count = 0;
    177 
    178 		for (i = 0; i < TST_TOTAL; i++) {
    179 
    180 			cmd = Scenarios[i].cmd;
    181 			limit = Scenarios[i].newlimit;
    182 
    183 			/*
    184 			 * Call ulimit(2)
    185 			 */
    186 			TEST(ulimit(cmd, limit));
    187 
    188 			/* check return code */
    189 			if (TEST_RETURN == -1) {
    190 				if (Scenarios[i].exp_fail) {
    191 					tst_resm(TPASS | TTERRNO,
    192 						 "ulimit(%d, %ld) Failed expectedly",
    193 						 cmd, limit);
    194 				} else {
    195 					tst_resm(TFAIL | TTERRNO,
    196 						 "ulimit(%d, %ld) Failed",
    197 						 cmd, limit);
    198 				}
    199 			} else {
    200 				if (Scenarios[i].exp_fail) {
    201 					tst_resm(TFAIL,
    202 						 "ulimit(%d, %ld) returned %ld, succeeded unexpectedly",
    203 						 cmd, limit, TEST_RETURN);
    204 				} else {
    205 					tst_resm(TPASS,
    206 						 "ulimit(%d, %ld) returned %ld",
    207 						 cmd, limit, TEST_RETURN);
    208 				}
    209 
    210 				/*
    211 				 * Save the UL_GETFSIZE return value in the newlimit field
    212 				 * for UL_SETFSIZE test cases.
    213 				 */
    214 				if (cmd == UL_GETFSIZE) {
    215 					for (tmp = i + 1; tmp < TST_TOTAL;
    216 					     tmp++) {
    217 						if (Scenarios[tmp].nlim_flag ==
    218 						    1) {
    219 							Scenarios[tmp].newlimit
    220 							    = TEST_RETURN;
    221 						}
    222 						if (Scenarios[tmp].nlim_flag ==
    223 						    2) {
    224 							Scenarios[tmp].newlimit
    225 							    = TEST_RETURN - 1;
    226 						}
    227 					}
    228 				}
    229 			}
    230 		}
    231 	}
    232 
    233     /***************************************************************
    234      * cleanup and exit
    235      ***************************************************************/
    236 	cleanup();
    237 
    238 	tst_exit();
    239 }
    240 
    241 /***************************************************************
    242  * setup() - performs all ONE TIME setup for this test.
    243  ***************************************************************/
    244 void setup(void)
    245 {
    246 
    247 	tst_sig(NOFORK, DEF_HANDLER, cleanup);
    248 
    249 	TEST_PAUSE;
    250 
    251 }
    252 
    253 /***************************************************************
    254  * cleanup() - performs all ONE TIME cleanup for this test at
    255  *		completion or premature exit.
    256  ***************************************************************/
    257 void cleanup(void)
    258 {
    259 
    260 }
    261