/* * 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 version 2 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. * * Further, this software is distributed without any warranty that it is * free of the rightful claim of any third person regarding infringement * or the like. Any license provided herein, whether implied or * otherwise, applies only to this software file. Patent licenses, if * any, provided herein do not apply to combinations of this program with * other software, or any other product whatsoever. * * You should have received a copy of the GNU General Public License along * with this program; if not, write the Free Software Foundation, Inc., 59 * Temple Place - Suite 330, Boston MA 02111-1307, USA. * * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy, * Mountain View, CA 94043, or: * * http://www.sgi.com * * For further information regarding this notice, see: * * http://oss.sgi.com/projects/GenInfo/NoticeExplan/ */ /* $Id$ */ #ifndef __TEST_H__ #define __TEST_H__ #define execve execve_foo #define execv execv_foo #define execvp execvp_foo #include #include #include #include #include #undef execvp #undef execv #undef execve int execve(const char *, char * const [], char * const *); int execv(const char *, char * const []); int execvp(const char *, char * const []); /* CGF: Avoid compilation warnings for undefined functions */ extern int setregid (gid_t, gid_t); int setreuid (uid_t, uid_t); #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 */ /* * To determine if you are on a Umk or Unicos system, * use sysconf(_SC_CRAY_SYSTEM). But since _SC_CRAY_SYSTEM * is not defined until 90, it will be define here if not already * defined. * if ( sysconf(_SC_CRAY_SYSTEM) == 1 ) * on UMK * else # returned 0 or -1 * on Unicos * This is only being done on CRAY systems. */ #ifdef CRAY #ifndef _SC_CRAY_SYSTEM #define _SC_CRAY_SYSTEM 140 #endif /* ! _SC_CRAY_SYSTEM */ #endif /* CRAY */ /* * 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, const char *fname, const char *arg_fmt, ...); extern void tst_resm(int ttype, const char *arg_fmt, ...); extern void tst_brk(int ttype, char *fname, void (*func)(), const char *arg_fmt, ...); extern void tst_brkloop(int ttype, char *fname, void (*func)(), const char *arg_fmt, ...); extern void tst_brkm(int ttype, void (*func)(), const char *arg_fmt, ...); extern void tst_brkloopm(int ttype, void (*func)(), const char *arg_fmt, ...); extern int tst_environ(); extern void tst_exit() __attribute__ ((noreturn)); 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(); #endif /* end of __TEST_H__ */