| /* | 
 |  * Copyright (c) 2000 Silicon Graphics, Inc. | 
 |  * All Rights Reserved. | 
 |  * | 
 |  * This program is free software; you can redistribute it and/or | 
 |  * modify it under the terms of the GNU General Public License as | 
 |  * published by the Free Software Foundation. | 
 |  * | 
 |  * This program is distributed in the hope that it would be useful, | 
 |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
 |  * GNU General Public License for more details. | 
 |  * | 
 |  * You should have received a copy of the GNU General Public License | 
 |  * along with this program; if not, write the Free Software Foundation, | 
 |  * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA | 
 |  */ | 
 |  | 
 | /* $Id: test.h,v 1.2 2005/11/09 02:50:19 nathans.longdrop.melbourne.sgi.com Exp $ */ | 
 |  | 
 | #ifndef __TEST_H__ | 
 | #define __TEST_H__ | 
 |  | 
 | #include <stdio.h> | 
 | #include <signal.h> | 
 | #include <unistd.h> | 
 | #include <string.h> | 
 | #include <stdlib.h> | 
 |  | 
 | #define TPASS    0    /* Test passed flag */ | 
 | #define TFAIL    1    /* Test failed flag */ | 
 | #define TBROK    2    /* Test broken flag */ | 
 | #define TWARN    4    /* Test warning flag */ | 
 | #define TRETR    8    /* Test retire flag */ | 
 | #define TINFO    16   /* Test information flag */ | 
 | #define TCONF    32   /* Test not appropriate for configuration flag */ | 
 |  | 
 | /* | 
 |  * Ensure that NUMSIGS is defined. | 
 |  * It should be defined in signal.h or sys/signal.h on | 
 |  * UNICOS/mk and IRIX systems.   On UNICOS systems, | 
 |  * it is not defined, thus it is being set to UNICOS's NSIG. | 
 |  * Note:  IRIX's NSIG (signals are 1-(NSIG-1))  | 
 |  *      is not same meaning as UNICOS/UMK's NSIG  (signals 1-NSIG) | 
 |  */ | 
 | #ifndef NUMSIGS | 
 | #define NUMSIGS NSIG | 
 | #endif | 
 |  | 
 |  | 
 | /* defines for unexpected signal setup routine (set_usig.c) */ | 
 | #define FORK    1		/* SIGCLD is to be ignored */ | 
 | #define NOFORK  0		/* SIGCLD is to be caught */ | 
 | #define DEF_HANDLER 0	/* tells set_usig() to use default signal handler */ | 
 |  | 
 | /* | 
 |  * The following defines are used to control tst_res and t_result reporting. | 
 |  */ | 
 |  | 
 | #define TOUTPUT	   "TOUTPUT"		/* The name of the environment variable */ | 
 | 					/* that can be set to one of the following */ | 
 | 					/* strings to control tst_res output */ | 
 | 					/* If not set, TOUT_VERBOSE_S is assumed */ | 
 |  | 
 | #define TOUT_VERBOSE_S  "VERBOSE"	/* All test cases reported */ | 
 | #define TOUT_CONDENSE_S "CONDENSE"	/* ranges are used where identical messages*/ | 
 | 					/* occur for sequential test cases */ | 
 | #define TOUT_NOPASS_S   "NOPASS"	/* No pass test cases are reported */ | 
 | #define TOUT_DISCARD_S  "DISCARD"	/* No output is reported */ | 
 |  | 
 | #define TST_NOBUF	"TST_NOBUF"	/* The name of the environment variable */ | 
 | 					/* that can be set to control whether or not */ | 
 | 					/* tst_res will buffer output into 4096 byte */ | 
 | 					/* blocks of output */ | 
 | 					/* If not set, buffer is done.  If set, no */ | 
 | 					/* internal buffering will be done in tst_res */ | 
 | 					/* t_result does not have internal buffering */ | 
 |  | 
 | /* | 
 |  * The following defines are used to control tst_tmpdir, tst_wildcard and t_mkchdir | 
 |  */ | 
 |  | 
 | #define TDIRECTORY  "TDIRECTORY"	/* The name of the environment variable */ | 
 | 					/* that if is set, the value (directory) */ | 
 | 					/* is used by all tests as their working */ | 
 | 					/* directory.  tst_rmdir and t_rmdir will */ | 
 | 					/* not attempt to clean up. */ | 
 | 					/* This environment variable should only */ | 
 | 					/* be set when doing system testing since */ | 
 | 					/* tests will collide and break and fail */ | 
 | 					/* because of setting it. */ | 
 |  | 
 | #define TEMPDIR	"/tmp"			/* This is the default temporary directory. */ | 
 | 					/* The environment variable TMPDIR is */ | 
 | 					/* used prior to this valid by tempnam(3). */ | 
 | 					/* To control the base location of the */ | 
 | 					/* temporary directory, set the TMPDIR */ | 
 | 					/* environment variable to desired path */ | 
 |  | 
 | /* | 
 |  * The following contains support for error message passing. | 
 |  * See test_error.c for details. | 
 |  */ | 
 | #define  TST_ERR_MESG_SIZE      1023    /* max size of error message */ | 
 | #define  TST_ERR_FILE_SIZE      511     /* max size of module name used by compiler */ | 
 | #define  TST_ERR_FUNC_SIZE      127     /* max size of func name */ | 
 |  | 
 | typedef struct { | 
 |     int  te_line;                       /* line where last error was reported.  Use */ | 
 |                                         /* "__LINE__" and let compiler do the rest */ | 
 |     int  te_level;                      /* If set, will prevent current stored */ | 
 |                                         /* error to not be overwritten */ | 
 |     char te_func[TST_ERR_FUNC_SIZE+1];  /* name of function of last error */ | 
 |                                         /* Name of function or NULL */ | 
 |     char te_file[TST_ERR_FILE_SIZE+1];  /* module of last error.  Use */ | 
 |                                         /* "__FILE__" and let compiler do the rest */ | 
 |     char te_mesg[TST_ERR_MESG_SIZE+1];  /* string of last error */ | 
 |  | 
 | } _TST_ERROR; | 
 |  | 
 | extern _TST_ERROR Tst_error;            /* defined in test_error.c */ | 
 | #if __STDC__ | 
 | extern void tst_set_error(char *file, int line, char *func, char *fmt, ...); | 
 | #else | 
 | extern void tst_set_error(); | 
 | #endif | 
 | extern void tst_clear_error(); | 
 |  | 
 |  | 
 | /* | 
 |  * The following define contains the name of an environmental variable | 
 |  * that can be used to specify the number of iterations. | 
 |  * It is supported in parse_opts.c and USC_setup.c. | 
 |  */ | 
 | #define USC_ITERATION_ENV       "USC_ITERATIONS" | 
 |  | 
 | /* | 
 |  * The following define contains the name of an environmental variable | 
 |  * that can be used to specify to iteration until desired time | 
 |  * in floating point seconds has gone by. | 
 |  * Supported in USC_setup.c. | 
 |  */ | 
 | #define USC_LOOP_WALLTIME	"USC_LOOP_WALLTIME" | 
 |  | 
 | /* | 
 |  * The following define contains the name of an environmental variable | 
 |  * that can be used to specify that no functional checks are wanted. | 
 |  * It is supported in parse_opts.c and USC_setup.c. | 
 |  */ | 
 | #define USC_NO_FUNC_CHECK	"USC_NO_FUNC_CHECK" | 
 |  | 
 | /* | 
 |  * The following define contains the name of an environmental variable | 
 |  * that can be used to specify the delay between each loop iteration. | 
 |  * The value is in seconds (fractional numbers are allowed). | 
 |  * It is supported in parse_opts.c. | 
 |  */ | 
 | #define USC_LOOP_DELAY		"USC_LOOP_DELAY" | 
 |  | 
 | /* | 
 |  * The following prototypes are needed to remove compile errors | 
 |  * on IRIX systems when compiled with -n32 and -64. | 
 |  */ | 
 | extern void tst_res(int ttype, char *fname, char *arg_fmt, ...); | 
 | extern void tst_resm(int ttype, char *arg_fmt, ...); | 
 | extern void tst_brk(int ttype, char *fname, void (*func)(),  | 
 | 							char *arg_fmt, ...); | 
 | extern void tst_brkloop(int ttype, char *fname, void (*func)(),  | 
 | 							char *arg_fmt, ...); | 
 | extern void tst_brkm(int ttype, void (*func)(), char *arg_fmt, ...); | 
 | extern void tst_brkloopm(int ttype, void (*func)(), char *arg_fmt, ...); | 
 |  | 
 | extern int  tst_environ(); | 
 | extern void tst_exit(); | 
 | extern void tst_flush(); | 
 |  | 
 | /* prototypes for the t_res.c functions */ | 
 | extern void t_result(char *tcid, int tnum, int ttype, char *tmesg); | 
 | extern void tt_exit(); | 
 | extern int  t_environ(); | 
 | extern void t_breakum(char *tcid, int total, int typ, char *msg, void (*fnc)()); | 
 |  | 
 | extern void tst_sig(int fork_flag, void (*handler)(), void (*cleanup)()); | 
 | extern void tst_tmpdir(); | 
 | extern void tst_rmdir(); | 
 |  | 
 | extern char * get_high_address(void); | 
 |  | 
 | extern void get_kver(int*, int*, int*); | 
 | extern int tst_kvercmp(int, int, int); | 
 |  | 
 | #endif	/* end of __TEST_H__ */ |