From 1278cf2b6e7a5884ed53f2853c987b3350650316 Mon Sep 17 00:00:00 2001 From: Kurtis Rader Date: Mon, 24 Jul 2017 11:58:31 -0700 Subject: [PATCH] document need for double-quotes around `test` args --- doc_src/test.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/doc_src/test.txt b/doc_src/test.txt index 43d9f5e57..c5aa4b0fb 100644 --- a/doc_src/test.txt +++ b/doc_src/test.txt @@ -14,6 +14,8 @@ The first form (`test`) is preferred. For compatibility with other shells, the s This test is mostly POSIX-compatible. +When using a variable as an argument for a test operator you should almost always enclose it in double-quotes. There are only two situations it is safe to omit the quote marks. The first is when the argument is a literal string with no whitespace or other characters special to the shell (e.g., semicolon). For example, `test -b /my/file`. The second is using a variable that expands to exactly one element including if that element is the empty string (e.g., `set x ''`). If the variable is not set, set but with no value, or set to more than one value you must enclose it in double-quotes. For example, `test "$x" = "$y"`. Since it is always safe to enclose variables in double-quotes when used as `test` arguments that is the recommended practice. + \subsection test-files Operators for files and directories - `-b FILE` returns true if `FILE` is a block device.