2005-09-20 21:31:55 +08:00
|
|
|
#
|
2017-08-05 04:33:47 +08:00
|
|
|
# Test function, loops, conditionals and some basic elements
|
2005-09-20 21:31:55 +08:00
|
|
|
#
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg "Comments in odd places don't cause problems"
|
|
|
|
for i in 1 2 # Comment on same line as command
|
|
|
|
# Comment inside loop
|
2005-09-20 21:31:55 +08:00
|
|
|
for j in a b
|
2017-08-05 04:33:47 +08:00
|
|
|
# Double loop
|
2005-09-20 21:31:55 +08:00
|
|
|
echo $i$j
|
|
|
|
end;
|
|
|
|
end
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg Bracket expansion
|
2012-11-21 05:52:53 +08:00
|
|
|
echo x-{1}
|
|
|
|
echo x-{1,2}
|
|
|
|
echo foo-{1,2{3,4}}
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg Escaped newlines
|
2012-11-22 17:09:07 +08:00
|
|
|
echo foo\ bar
|
|
|
|
echo foo\
|
|
|
|
bar
|
|
|
|
echo "foo\
|
|
|
|
bar"
|
|
|
|
echo 'foo\
|
|
|
|
bar'
|
|
|
|
|
2012-11-24 04:03:36 +08:00
|
|
|
for i in \
|
|
|
|
a b c
|
|
|
|
echo $i
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg Simple function tests
|
2005-09-20 21:31:55 +08:00
|
|
|
|
2010-09-18 10:18:26 +08:00
|
|
|
function foo
|
2016-02-07 10:08:22 +08:00
|
|
|
echo >../test/temp/fish_foo.txt $argv
|
2005-09-20 21:31:55 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
foo hello
|
|
|
|
|
2016-02-07 10:08:22 +08:00
|
|
|
cat ../test/temp/fish_foo.txt |read foo
|
2005-09-20 21:31:55 +08:00
|
|
|
|
|
|
|
if test $foo = hello;
|
|
|
|
echo Test 2 pass
|
|
|
|
else
|
|
|
|
echo Test 2 fail
|
|
|
|
end
|
|
|
|
|
2010-09-18 10:18:26 +08:00
|
|
|
function foo
|
2017-07-04 06:36:38 +08:00
|
|
|
printf 'Test %s' $argv[1]; echo ' pass'
|
2005-09-20 21:31:55 +08:00
|
|
|
end
|
|
|
|
|
2017-07-04 06:36:38 +08:00
|
|
|
foo 3a
|
2005-09-20 21:31:55 +08:00
|
|
|
|
|
|
|
for i in Test for continue break and switch builtins problems;
|
|
|
|
switch $i
|
|
|
|
case Test
|
2010-09-18 10:18:26 +08:00
|
|
|
printf "%s " $i
|
2005-09-20 21:31:55 +08:00
|
|
|
case "f??"
|
2017-07-04 06:36:38 +08:00
|
|
|
printf "%s " 3b
|
2005-09-20 21:31:55 +08:00
|
|
|
case "c*"
|
|
|
|
echo pass
|
|
|
|
case break
|
|
|
|
continue
|
|
|
|
echo fail
|
|
|
|
case and
|
|
|
|
break
|
|
|
|
echo fail
|
|
|
|
case "*"
|
|
|
|
echo fail
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-11-23 23:05:21 +08:00
|
|
|
set -l sta
|
|
|
|
if eval true
|
|
|
|
if eval false
|
|
|
|
set sta fail
|
|
|
|
else
|
|
|
|
set sta pass
|
|
|
|
end
|
|
|
|
else
|
|
|
|
set sta fail
|
|
|
|
end
|
|
|
|
echo Test 4 $sta
|
2010-11-24 00:35:56 +08:00
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg "Ensure eval doesn't unnecessarily mess with the exit status"
|
2015-01-18 07:22:37 +08:00
|
|
|
function empty_func ; end
|
|
|
|
false ; eval empty_func ; echo $status
|
|
|
|
true ; eval empty_func ; echo $status
|
|
|
|
|
2010-11-24 00:35:56 +08:00
|
|
|
function test_builtin_status
|
|
|
|
return 1
|
|
|
|
end
|
|
|
|
test_builtin_status
|
|
|
|
if [ $status -eq 1 ]
|
|
|
|
set sta pass
|
|
|
|
else
|
|
|
|
set sta fail
|
|
|
|
end
|
|
|
|
echo Test 5 $sta
|
2012-10-17 17:56:03 +08:00
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg Verify that we can turn stderr into stdout and then pipe it
|
2013-08-19 07:55:01 +08:00
|
|
|
# Note that the order here seems unspecified - 'errput' appears before 'output', why?
|
2016-02-07 10:08:22 +08:00
|
|
|
begin ; echo output ; echo errput 1>&2 ; end 2>&1 | tee ../test/temp/tee_test.txt ; cat ../test/temp/tee_test.txt
|
2013-08-19 07:55:01 +08:00
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg "Test that trailing ^ doesn't trigger redirection, see #1873"
|
2016-06-12 17:16:46 +08:00
|
|
|
echo caret_no_redirect 12345^
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg Verify that we can pipe something other than stdout
|
2014-01-13 18:49:41 +08:00
|
|
|
# The first line should be printed, since we output to stdout but pipe stderr to /dev/null
|
|
|
|
# The second line should not be printed, since we output to stderr and pipe it to /dev/null
|
|
|
|
begin ; echo is_stdout ; end 2>| cat > /dev/null
|
|
|
|
begin ; echo is_stderr 1>&2 ; end 2>| cat > /dev/null
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
####################
|
|
|
|
logmsg echo tests
|
2012-10-17 17:56:03 +08:00
|
|
|
echo 'abc\ndef'
|
|
|
|
echo -e 'abc\ndef'
|
|
|
|
echo -e 'abc\zdef'
|
|
|
|
echo -e 'abc\41def'
|
|
|
|
echo -e 'abc\041def'
|
|
|
|
echo -e 'abc\121def'
|
|
|
|
echo -e 'abc\1212def'
|
2012-10-17 17:59:43 +08:00
|
|
|
echo -e 'abc\cdef' # won't output a newline!
|
|
|
|
echo ''
|
2014-05-16 15:19:07 +08:00
|
|
|
echo -
|
2017-06-19 13:25:00 +08:00
|
|
|
echo -h
|
2017-02-01 10:44:02 +08:00
|
|
|
echo -ne '\376' | display_bytes
|
2012-10-17 17:56:03 +08:00
|
|
|
echo -e Catch your breath
|
|
|
|
echo -e 'abc\x21def'
|
|
|
|
echo -e 'abc\x211def'
|
2014-02-12 17:39:06 +08:00
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg "Verify that pipes don't conflict with fd redirections"
|
2015-01-05 06:18:06 +08:00
|
|
|
# This code is very similar to eval. We go over a bunch of fads
|
|
|
|
# to make it likely that we will nominally conflict with a pipe
|
|
|
|
# fish is supposed to detect this case and dup the pipe to something else
|
|
|
|
echo "/bin/echo pipe 3 <&3 3<&-" | source 3<&0
|
|
|
|
echo "/bin/echo pipe 4 <&4 4<&-" | source 4<&0
|
|
|
|
echo "/bin/echo pipe 5 <&5 5<&-" | source 5<&0
|
|
|
|
echo "/bin/echo pipe 6 <&6 6<&-" | source 6<&0
|
|
|
|
echo "/bin/echo pipe 7 <&7 7<&-" | source 7<&0
|
|
|
|
echo "/bin/echo pipe 8 <&8 8<&-" | source 8<&0
|
|
|
|
echo "/bin/echo pipe 9 <&9 9<&-" | source 9<&0
|
|
|
|
echo "/bin/echo pipe 10 <&10 10<&-" | source 10<&0
|
|
|
|
echo "/bin/echo pipe 11 <&11 11<&-" | source 11<&0
|
|
|
|
echo "/bin/echo pipe 12 <&12 12<&-" | source 12<&0
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg "Make sure while loops don't run forever with no-exec (#1543)"
|
2014-07-12 02:28:10 +08:00
|
|
|
echo "Checking for infinite loops in no-execute"
|
2016-02-07 10:08:22 +08:00
|
|
|
echo "while true; end" | ../test/root/bin/fish --no-execute
|
2014-07-12 02:28:10 +08:00
|
|
|
|
2017-08-21 03:02:45 +08:00
|
|
|
logmsg "For loops with read-only vars is an error (#4342)"
|
|
|
|
for status in a b c
|
|
|
|
echo $status
|
|
|
|
end
|
|
|
|
|
2017-09-09 12:14:26 +08:00
|
|
|
logmsg For loop control vars available outside the for block
|
|
|
|
begin
|
|
|
|
set -l loop_var initial-value
|
|
|
|
for loop_var in a b c
|
|
|
|
# do nothing
|
|
|
|
end
|
|
|
|
set --show loop_var
|
|
|
|
end
|
|
|
|
|
|
|
|
set -g loop_var global_val
|
|
|
|
function loop_test
|
|
|
|
for loop_var in a b c
|
|
|
|
if test $loop_var = b
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
set --show loop_var
|
|
|
|
end
|
|
|
|
loop_test
|
|
|
|
set --show loop_var
|
|
|
|
|
|
|
|
begin
|
|
|
|
set -l loop_var
|
|
|
|
for loop_var in aa bb cc
|
|
|
|
end
|
|
|
|
set --show loop_var
|
|
|
|
end
|
|
|
|
set --show loop_var
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg 'Comments allowed in between lines (#1987)'
|
2015-04-06 14:47:04 +08:00
|
|
|
echo before comment \
|
|
|
|
# comment
|
|
|
|
after comment
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg 'Backslashes are part of comments and do not join lines (#1255)'
|
2015-05-03 09:22:20 +08:00
|
|
|
# This should execute false, not echo it
|
|
|
|
echo -n # comment\
|
|
|
|
false
|
|
|
|
|
2014-02-12 17:39:06 +08:00
|
|
|
function always_fails
|
|
|
|
if true
|
|
|
|
return 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
logmsg 'Verify $argv set correctly in sourced scripts (#139)'
|
2016-04-07 04:04:44 +08:00
|
|
|
echo 'echo "source argv {$argv}"' | source
|
|
|
|
echo 'echo "source argv {$argv}"' | source -
|
|
|
|
echo 'echo "source argv {$argv}"' | source - abc
|
|
|
|
echo 'echo "source argv {$argv}"' | source - abc def
|
2014-02-12 17:39:06 +08:00
|
|
|
|
2017-08-05 04:33:47 +08:00
|
|
|
always_fails
|
|
|
|
echo $status
|