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.

SEE ALSO

sh, find