NAME
test - condition evaluation utility
SYNOPSIS
test expression
[ expression ]
DESCRIPTION
The test utility evaluates the expression and, if it evaluates to true, returns a zero (true) exit status; otherwise it returns 1 (false). If no expression is given, test also returns 1 (false).
All operators and flags are separate arguments to the test utility.
The following primaries are used to construct expression:
- -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 (regardless of type).
 - -f file
 - 
True if file exists and is a regular file.
 - -g file
 - 
True if file exists and its set-group-ID flag is set.
 - -h file
 - 
True if file exists and is a symbolic link. This operator is for COMPATABILITY purposes, do not rely on its existence. Use -L instead.
 - -k file
 - 
True if file exists and its sticky bit is set.
 - -n string
 - 
True if the length of string is nonzero.
 - -p file
 - 
True if file is a named pipe (FIFO).
 - -r file
 - 
True if file exists and is readable by the effective user/group.
 - -s file
 - 
True if file exists and has a size greater than zero.
 - -t file_descriptor
 - 
True if the file whose file descriptor number is file_descriptor is open and is associated with a terminal.
 - -t
 - 
Same as above with an implicit file descriptor number of "1" (e.g.: -t 1).
 - -u file
 - 
True if file exists and its set-user-ID flag is set.
 - -w file
 - 
True if file exists and is writable by the effective user/group. True indicates only that the write flag is on. The file is not writable on a read-only file system even if this test indicates true.
 - -x file
 - 
True if file exists and is executable by the effective user/group. True indicates only that the execute flag is on. If file is a directory, true indicates that file can be searched.
 - -z string
 - 
True if the length of string is zero.
 - -B file
 - 
True if file exists and is a binary file.
 - -L file
 - 
True if file exists and is a symbolic link.
 - -O file
 - 
True if file exists and its owner matches the effective user ID of this process.
 - -R file
 - 
True if file exists and is readable by the real user/group.
 - -S file
 - 
True if file exists and is a socket.
 - -T file
 - 
True if file exists and is a text file.
 - -W file
 - 
True if file exists and is writable by the real user/group. True indicates only that the write flag is on. The file is not writable on a read-only file system even if this test indicates true.
 - -X file
 - 
True if file exists and is executable by the real user/group. True indicates only that the execute flag is on. If file is a directory, true indicates that file can be searched.
 - file1 -nt file2
 - 
True if file1 exists and is newer than file2.
 - file1 -ot file2
 - 
True if file1 exists and is older than file2.
 - string
 - 
True if string is not the null string.
 - s1 = s2
 - 
True if the strings s1 and s2 are identical.
 - s1 != s2
 - 
True if the strings s1 and s2 are not identical.
 - s1 < s2
 - 
True if string s1 comes before s2 based on the ASCII value of their characters.
 - s1 > s2
 - 
True if string s1 comes after s2 based on the ASCII value of their characters.
 - s1
 - 
True if s1 is not the null string.
 - 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.
 
These primaries can be combined with the following operators:
- ! expression
 - 
True if expression is false.
 - expression1 -a expression2
 - 
True if both expression1 and expression2 are true.
 - expression1 -o expression2
 - 
True if either expression1 or expression2 are true.
 - (expression)
 - 
True if expression is true (uses parentheses for grouping).
 
Note that the -a operator has higher precedence than the -o operator. Notice also that all the operators and flags are separate arguments to test.
RETURN VALUES
The test utility exits with one of the following values:
- $return_val == 0
 - 
Expression evaluated to true.
 - $return_val == 1
 - 
Expression evaluated to false or expression was missing.
 - $return_val > 1
 - 
An error occurred.
 
CAVEATS
Command line arguments like parentheses and arithmetic operators (e.g.: '(', ')', '!', '>', '<', etc.) may be meaningful to the command-line interpreter (shell) and therefore may need to be escaped from any special shell interpretation.