Manpage logo

test - condition evaluation utility

NAME  SYNOPSIS  DESCRIPTION  RETURN VALUES  CAVEATS  SEE ALSO 

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


Updated 2026-06-01 - jenkler.se | uex.se