[CentOS] bash test ?

Thu Apr 20 06:35:29 UTC 2023
Simon Matter <simon.matter at invoca.ch>

> On Wed, Apr 19, 2023 at 09:16:26PM +0200, lejeczek via CentOS wrote:
>>On 19/04/2023 08:46, wwp wrote:
>>> Hello lejeczek,
> ...
>>>>> Surround ${_Val} with double quotes (as you should) and things will
>>>>> be different:
>>>>>
>>>>> $ unset _Val; test -n "${_Val}"; echo $?
>>>>> 1
>>>>>
>>>>> Now you get it? :-)
>>>>>
>>>> I don't know, am not sure, I remembered it differently, did not think
>>>> enclosing quotes were necessary(always?) for that were {}
>>> {} does not prevent this (at least not in bash):
>>>
>>> $ FOO="a b"
>>>
>>> $ test -z $FOO
>>> bash: test: a: binary operator expected
>>>
>>> $ test -z ${FOO}
>>> bash: test: a: binary operator expected
>>>
>>> Because after $FOO or ${FOO} variable expansion, bash parsed:
>>> test -z a b
>>> 'b' is unexpected, from a grammar point of view.
>>>
>>> Quoting is expected, here:
>>> $ test -z "$FOO"
>>> <no error>
>>>
>>> When FOO is unset, apparently it's a different matter, where you end up
>>> with $?=0 in all unquoted -n/-z cases, interestingly. I could not find
>>> this specific case in the bash documentation. That may not be portable
>>> to other shells, BTW. I only use {} when necessary (because of what
>>> bash allows to do between {}, plenty!, or when inserting $FOO into a
>>> literal string that may lead the parser to take the whole string for a
>>> variable name: echo $FOObar != echo ${FOO}bar).
>>>
>>>
>>> Regards,
>>There is a several ways to run tests in shell, but 'test'
>>which is own binary as I understand, defeats me..
>
> Yes, there is a binary for test (and its alternate '[').
>
> But most shells, including bash have incorporated code for test
> (and other commands) into the shell code itself for efficiency.
>
> $ type test
> test is a shell builtin
>
>>
>>I'd expect a consistency, like with what I usually do to
>>test for empty var:
>>-> $ export _Val=some; [[ -v _Val ]]; echo $?
>>0
>>-> $ unset _Val; [[ -v _Val ]]; echo $?
>>1
>>
>
> I do hope you don't use -v to test for empty variables as
> it tests for "set" variables and valid name syntax.
>
> Set variables can be "empty"  ( name= ).
>
> But in your last example _Val is "un"set, it does not
> exist.  Thus it can neither be empty nor occupied.

And to know if a variable is declared or not, this can be used:

if (( ${VAR+1} )); then
  echo "variable \$VAR is set"
else
  echo "variable \$VAR is NOT set"
fi

Regards,
Simon