test(C)


test -- test conditions

Syntax

test expr

[ expr ]

Description

The test command evaluates the expression expr, and if its value is true, returns a zero (true) exit status; otherwise, test returns a non-zero exit status if there are no arguments. The following primitives are used to construct expr:


-b file
True if file exists and is a block special file.

-c file
True if file exists and is a character special file.

-d file
True if file exists and is a directory.

-e file
True if file exists.

-f file
True if file exists and is a regular file.

-g file
True if file exists and its set-group-ID bit is set.

-h file
True if file exists and is a symbolic link. With all other primitives (except -L file), the symbolic links are followed. This primitive is identical to -L.

-H file
True if file exists and is a semaphore.

-k file
True if file exists and its sticky bit is set.

-L file
True if file exists and is a symbolic link. With all other primitives (except -h file), the symbolic links are followed by default. This primitive is identical to -h.

-M file
True if file exists and is shared memory.

-n s1
True if the length of string s1 is non-zero.

-p file
True if file is a named pipe (FIFO).

-r file
True if file exists and is readable.

-s file
True if file exists and has a size greater than zero.

-t [fildes]
True if the open file whose file descriptor number is fildes (1 by default) is associated with a terminal device.

-u file
True if file exists and its set-user-ID bit is set.

-w file
True if file exists and is writable. This indicates that the write flag is set on; the file will not be writable on read-only filesystems.

-x file
True if file exists and is executable. This indicates that the execute flag is set on; if file is a directory, it can be searched.

-z s1
True if the length of string s1 is zero.

n1 -eq n2
True if the integers n1 and n2 are algebraically equal.

n1 -ne n2
True if the integers n1 and n2 are not algebraically equal.

n1 -gt n2
True if the integer n1 is algebraically greater than the integer n2.

n1 -ge n2
True if the integer n1 is algebraically greater than or equal to the integer n2.

n1 -lt n2
True if the integer n1 is algebraically less than the integer n2.

n1 -le n2
True if the integer n1 is algebraically less than or equal to the integer n2.

s1
True if s1 is not the null string.

s1 = s2
True if strings s1 and s2 are identical.

s1 != s2
True if strings s1 and s2 are not identical.
These primaries may be combined with the following operators:

!
unary negation operator;
! expr is true if expr is false, and ! expr is false if expr is true.

-a
binary AND operator;
expr1 -a expr2 is true only if both expr1 and expr2 are true.

-o
binary OR operator (-a has higher precedence than -o);
expr1 -o expr2 is true if either expr1 or expr2 is true.

(expr)
True if expr is true. The parentheses can be used to alter the normal precedence and associativity.
Notice that all the operators and flags are separate arguments to test. Notice also, that parentheses are meaningful to the shell and, therefore, must be escaped.

Exit values

test returns 0 if expr evaluates to true; it returns 1 if expr evaluates to false or expr is missing; a value greater than 1 means an error occurred.

Examples

In the following examples, the [ ] form of the test command is used, and the shell script may be used with either sh or ksh.

Test if a file does not exist. In this example, the file .profile is copied from a template file if it does not exist in the user's home directory:

   if  [  !  -f  $HOME/.profile  ]
   then
   	echo ".profile file does not exist - copy from elsewhere"
   	cp  /usr/elsewhere/.profile  $HOME/.profile
   fi
Test whether a file exists and has zero size. This could be used to see if an overnight tape backup reported any errors to a file. The AND -a and negation ! operators are both used in this example:
   FILE=/tmp/backup_err
   if  [  -f  $FILE  -a  !  -s  $FILE  ]
   then
   	echo "The backup produced no errors"
   fi
Note that the test would not work correctly if only the operator combination ! -s were used. This would return true if the file did not exist or had zero size.

Test whether a variable has been defined. This example uses the test in a while loop which exits when a value has been entered:

   while  [  -z  "$VAL"  ]
   do
   	echo  -n  "Input value: "
   	read  VAL
   done
Note that double quotes around $VAL are necessary for the test to work. If the variable VAL is not defined, the expression "$VAL" evaluates to an empty string. If the expression were used without quotes, it would evaluate to nothing at all, and test would report an error.

Test the numeric value of a variable. Here the value of VAL is checked to see if it lies in a particular range:

   if  [  $VAL  -lt  0  -o  $VAL  -gt  7  ]
   then
   	echo  -n  "Value must be in the range 0 to 7"
   fi
Test whether the previous command succeeded. This example tests the result of having tried to change directory to /tmp/mirage:
   DIR=/tmp/mirage
   cd $DIR
   if  [  $?  -ne  0  ]
   then
   	echo  -n  "Could not change directory to $DIR"
   fi

Limitations

In the form of the command that uses [ ] rather than the word test, each of the square brackets must be surrounded by blank space. If this is not done, the command will not be interpreted correctly.

A version of test is built into sh(C), ksh(C). For details, refer to the appropriate section.

See also

find(C), ksh(C), sh(C)

Standards conformance

test is conformant with:

ISO/IEC DIS 9945-2:1992, Information technology - Portable Operating System Interface (POSIX) - Part 2: Shell and Utilities (IEEE Std 1003.2-1992);
AT&T SVID Issue 2;
X/Open CAE Specification, Commands and Utilities, Issue 4, 1992.


© 2005 The SCO Group, Inc. All rights reserved.
SCO OpenServer Release 6.0.0 -- 03 June 2005