2013-12-19 01:19:19 +00:00
|
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
|
|
# Simple jobs that never fails
|
|
|
|
|
# Each should be taking 0.3-1s and be possible to run in parallel
|
|
|
|
|
# I.e.: No race conditions, no logins
|
2015-07-22 06:28:05 +00:00
|
|
|
|
|
|
|
|
|
SMALLDISK=${SMALLDISK:-/mnt/ram}
|
|
|
|
|
export SMALLDISK
|
|
|
|
|
(
|
|
|
|
|
cd /tmp
|
|
|
|
|
sudo umount -l smalldisk.img
|
|
|
|
|
dd if=/dev/zero of=smalldisk.img bs=100k count=1k
|
|
|
|
|
yes|mkfs smalldisk.img
|
|
|
|
|
mkdir -p /mnt/ram
|
|
|
|
|
sudo mount smalldisk.img /mnt/ram
|
|
|
|
|
sudo chmod 777 /mnt/ram
|
|
|
|
|
) >/dev/null 2>/dev/null
|
|
|
|
|
|
2015-10-17 14:54:15 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2015-08-30 23:57:14 +00:00
|
|
|
|
cat <<'EOF' | sed -e 's/;$/; /;s/$SERVER1/'$SERVER1'/;s/$SERVER2/'$SERVER2'/' | stdout parallel -vj8 -k --joblog /tmp/jl-`basename $0` -L1
|
2015-07-29 00:33:28 +00:00
|
|
|
|
echo '### Test bug #45619: "--halt" erroneous error exit code (should give 0)';
|
|
|
|
|
seq 10 | parallel --halt now,fail=1 true;
|
|
|
|
|
echo $?
|
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2013-12-19 01:19:19 +00:00
|
|
|
|
echo '### Test exit val - true';
|
|
|
|
|
echo true | parallel;
|
|
|
|
|
echo $?
|
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo '### Test exit val - false';
|
|
|
|
|
echo false | parallel;
|
|
|
|
|
echo $?
|
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2014-09-23 18:14:57 +00:00
|
|
|
|
echo '### Test bug #43284: {%} and {#} with --xapply';
|
|
|
|
|
parallel --xapply 'echo {1} {#} {%} {2}' ::: a ::: b;
|
|
|
|
|
parallel -N2 'echo {%}' ::: a b
|
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2014-10-14 20:56:03 +00:00
|
|
|
|
echo '### Test bug #43376: {%} and {#} with --pipe'
|
2015-01-02 21:32:00 +00:00
|
|
|
|
echo foo | parallel -q --pipe -k echo {#}
|
|
|
|
|
echo foo | parallel --pipe -k echo {%}
|
|
|
|
|
echo foo | parallel -q --pipe -k echo {%}
|
|
|
|
|
echo foo | parallel --pipe -k echo {#}
|
2014-10-14 20:56:03 +00:00
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2014-12-12 12:30:54 +00:00
|
|
|
|
echo '### {= and =} in different groups separated by space'
|
2015-01-02 21:32:00 +00:00
|
|
|
|
parallel echo {= s/a/b/ =} ::: a
|
|
|
|
|
parallel echo {= s/a/b/=} ::: a
|
|
|
|
|
parallel echo {= s/a/b/=}{= s/a/b/=} ::: a
|
|
|
|
|
parallel echo {= s/a/b/=}{=s/a/b/=} ::: a
|
|
|
|
|
parallel echo {= s/a/b/=}{= {= s/a/b/=} ::: a
|
|
|
|
|
parallel echo {= s/a/b/=}{={=s/a/b/=} ::: a
|
|
|
|
|
parallel echo {= s/a/b/ =} {={==} ::: a
|
|
|
|
|
parallel echo {={= =} ::: a
|
|
|
|
|
parallel echo {= {= =} ::: a
|
|
|
|
|
parallel echo {= {= =} =} ::: a
|
2014-12-12 12:30:54 +00:00
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo '### {} as part of the command'
|
|
|
|
|
echo p /bin/ls | parallel l{= s/p/s/ =}
|
|
|
|
|
echo /bin/ls-p | parallel --colsep '-' l{=2 s/p/s/ =} {1}
|
|
|
|
|
echo s /bin/ls | parallel l{}
|
|
|
|
|
echo /bin/ls | parallel ls {}
|
|
|
|
|
echo ls /bin/ls | parallel {}
|
|
|
|
|
echo ls /bin/ls | parallel
|
|
|
|
|
|
2014-12-14 08:44:32 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo '### bug #43817: Some JP char cause problems in positional replacement strings'
|
|
|
|
|
parallel -k echo ::: '<27><<3C>>' '<27><1 $_=2<>>' 'ワ'
|
|
|
|
|
parallel -k echo {1} ::: '<27><<3C>>' '<27><1 $_=2<>>' 'ワ'
|
|
|
|
|
parallel -Xj1 echo ::: '<27><<3C>>' '<27><1 $_=2<>>' 'ワ'
|
|
|
|
|
parallel -Xj1 echo {1} ::: '<27><<3C>>' '<27><1 $_=2<>>' 'ワ'
|
|
|
|
|
|
2015-03-16 18:51:08 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
2015-03-17 19:44:09 +00:00
|
|
|
|
echo '### --rpl % that is a substring of longer --rpl %D'
|
2015-03-16 18:51:08 +00:00
|
|
|
|
parallel --plus --rpl '%'
|
|
|
|
|
--rpl '%D $_=::shell_quote(::dirname($_));' --rpl '%B s:.*/::;s:\.[^/.]+$::;' --rpl '%E s:.*\.::'
|
|
|
|
|
'echo {}=%;echo %D={//};echo %B={/.};echo %E={+.};echo %D/%B.%E={}' ::: a.b/c.d/e.f
|
|
|
|
|
|
|
|
|
|
echo '**'
|
2014-12-14 08:44:32 +00:00
|
|
|
|
|
2015-03-17 19:44:09 +00:00
|
|
|
|
echo '### Disk full'
|
2015-07-22 06:28:05 +00:00
|
|
|
|
cat /dev/zero >$SMALLDISK/out;
|
|
|
|
|
parallel --tmpdir $SMALLDISK echo ::: OK;
|
|
|
|
|
rm $SMALLDISK/out
|
2015-03-17 19:44:09 +00:00
|
|
|
|
|
2015-03-22 00:51:30 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo '### bug #44546: If --compress-program fails: fail'
|
|
|
|
|
parallel --line-buffer --compress-program false echo \;ls ::: /no-existing; echo $?
|
|
|
|
|
parallel --tag --line-buffer --compress-program false echo \;ls ::: /no-existing; echo $?
|
|
|
|
|
(parallel --files --tag --line-buffer --compress-program false echo \;sleep 1\;ls ::: /no-existing; echo $?) | tail -n1
|
|
|
|
|
parallel --tag --compress-program false echo \;ls ::: /no-existing; echo $?
|
|
|
|
|
parallel --line-buffer --compress-program false echo \;ls ::: /no-existing; echo $?
|
|
|
|
|
parallel --compress-program false echo \;ls ::: /no-existing; echo $?
|
|
|
|
|
|
2015-04-15 20:32:46 +00:00
|
|
|
|
echo 'bug #41613: --compress --line-buffer - no newline';
|
|
|
|
|
echo 'pipe compress tagstring'
|
|
|
|
|
perl -e 'print "O"'| parallel --compress --tagstring {#} --pipe --line-buffer cat; echo "K"
|
|
|
|
|
echo 'pipe compress notagstring'
|
|
|
|
|
perl -e 'print "O"'| parallel --compress --pipe --line-buffer cat; echo "K"
|
|
|
|
|
echo 'pipe nocompress tagstring'
|
|
|
|
|
perl -e 'print "O"'| parallel --tagstring {#} --pipe --line-buffer cat; echo "K"
|
|
|
|
|
echo 'pipe nocompress notagstring'
|
|
|
|
|
perl -e 'print "O"'| parallel --pipe --line-buffer cat; echo "K"
|
|
|
|
|
echo 'nopipe compress tagstring'
|
|
|
|
|
parallel --compress --tagstring {#} --line-buffer echo {} O ::: -n; echo "K"
|
|
|
|
|
echo 'nopipe compress notagstring'
|
|
|
|
|
parallel --compress --line-buffer echo {} O ::: -n; echo "K"
|
|
|
|
|
echo 'nopipe nocompress tagstring'
|
|
|
|
|
parallel --tagstring {#} --line-buffer echo {} O ::: -n; echo "K"
|
|
|
|
|
echo 'nopipe nocompress notagstring'
|
|
|
|
|
parallel --line-buffer echo {} O ::: -n; echo "K"
|
|
|
|
|
|
|
|
|
|
echo 'Compress with failing (de)compressor'
|
|
|
|
|
parallel -k --tag --compress --compress-program 'cat;true' --decompress-program 'cat;true' echo ::: tag true true
|
|
|
|
|
parallel -k --tag --compress --compress-program 'cat;false' --decompress-program 'cat;true' echo ::: tag false true
|
|
|
|
|
parallel -k --tag --compress --compress-program 'cat;false' --decompress-program 'cat;false' echo ::: tag false false
|
|
|
|
|
parallel -k --tag --compress --compress-program 'cat;true' --decompress-program 'cat;false' echo ::: tag true false
|
|
|
|
|
parallel -k --compress --compress-program 'cat;true' --decompress-program 'cat;true' echo ::: true true
|
|
|
|
|
parallel -k --compress --compress-program 'cat;false' --decompress-program 'cat;true' echo ::: false true
|
|
|
|
|
parallel -k --compress --compress-program 'cat;false' --decompress-program 'cat;false' echo ::: false false
|
|
|
|
|
parallel -k --compress --compress-program 'cat;true' --decompress-program 'cat;false' echo ::: true false
|
|
|
|
|
parallel -k --line-buffer --compress --compress-program 'cat;true' --decompress-program 'cat;true' echo ::: line-buffer true true
|
|
|
|
|
parallel -k --line-buffer --compress --compress-program 'cat;false' --decompress-program 'cat;true' echo ::: line-buffer false true
|
|
|
|
|
parallel -k --line-buffer --compress --compress-program 'cat;false' --decompress-program 'cat;false' echo ::: line-buffer false false
|
|
|
|
|
parallel -k --tag --line-buffer --compress --compress-program 'cat;true' --decompress-program 'cat;false' echo ::: tag line-buffer true false
|
|
|
|
|
parallel -k --tag --line-buffer --compress --compress-program 'cat;true' --decompress-program 'cat;true' echo ::: tag line-buffer true true
|
|
|
|
|
parallel -k --tag --line-buffer --compress --compress-program 'cat;false' --decompress-program 'cat;true' echo ::: tag line-buffer false true
|
|
|
|
|
parallel -k --tag --line-buffer --compress --compress-program 'cat;false' --decompress-program 'cat;false' echo ::: tag line-buffer false false
|
|
|
|
|
parallel -k --tag --line-buffer --compress --compress-program 'cat;true' --decompress-program 'cat;false' echo ::: tag line-buffer true false
|
|
|
|
|
parallel -k --files --compress --compress-program 'cat;true' --decompress-program 'cat;true' echo ::: files true true | parallel rm
|
|
|
|
|
parallel -k --files --compress --compress-program 'cat;false' --decompress-program 'cat;true' echo ::: files false true | parallel rm
|
|
|
|
|
parallel -k --files --compress --compress-program 'cat;false' --decompress-program 'cat;false' echo ::: files false false | parallel rm
|
|
|
|
|
parallel -k --files --compress --compress-program 'cat;true' --decompress-program 'cat;false' echo ::: files true false | parallel rm
|
|
|
|
|
|
|
|
|
|
echo 'bug #44250: pxz complains File format not recognized but decompresses anyway'
|
|
|
|
|
# The first line dumps core if run from make file. Why?!
|
|
|
|
|
stdout parallel --compress --compress-program pxz ls /{} ::: OK-if-missing-file
|
|
|
|
|
stdout parallel --compress --compress-program pixz --decompress-program 'pixz -d' ls /{} ::: OK-if-missing-file
|
|
|
|
|
stdout parallel --compress --compress-program pixz --decompress-program 'pixz -d' true ::: OK-if-no-output
|
|
|
|
|
stdout parallel --compress --compress-program pxz true ::: OK-if-no-output
|
|
|
|
|
|
|
|
|
|
echo 'bug #41613: --compress --line-buffer no newline';
|
|
|
|
|
perl -e 'print "It worked"'| parallel --pipe --compress --line-buffer cat; echo
|
|
|
|
|
|
2015-03-24 23:14:50 +00:00
|
|
|
|
echo '### bug #44614: --pipepart --header off by one'
|
|
|
|
|
seq 10 >/tmp/parallel_44616;
|
|
|
|
|
parallel --pipepart -a /tmp/parallel_44616 -k --block 5 'echo foo; cat';
|
|
|
|
|
parallel --pipepart -a /tmp/parallel_44616 -k --block 2 --regexp --recend 3'\n' 'echo foo; cat';
|
|
|
|
|
rm /tmp/parallel_44616
|
|
|
|
|
|
2015-03-28 11:14:30 +00:00
|
|
|
|
echo '### TMUX not found'
|
|
|
|
|
TMUX=not-existing parallel --tmux echo ::: 1
|
|
|
|
|
|
2015-04-20 22:08:08 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
2015-07-22 06:28:05 +00:00
|
|
|
|
parallel -j4 --halt 2 ::: 'sleep 1' burnP6 false; killall burnP6 && echo ERROR: burnP6 should be killed
|
|
|
|
|
parallel -j4 --halt -2 ::: 'sleep 1' burnP5 true; killall burnP5 && echo ERROR: burnP5 should be killed
|
2015-04-20 22:08:08 +00:00
|
|
|
|
|
2015-05-15 06:47:44 +00:00
|
|
|
|
parallel --halt error echo ::: should not print
|
|
|
|
|
parallel --halt soon echo ::: should not print
|
|
|
|
|
parallel --halt now echo ::: should not print
|
2015-05-14 23:59:57 +00:00
|
|
|
|
|
2015-05-06 22:40:36 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo '### bug #44995: parallel echo {#} ::: 1 2 ::: 1 2'
|
|
|
|
|
|
|
|
|
|
parallel -k echo {#} ::: 1 2 ::: 1 2
|
|
|
|
|
|
2015-05-25 20:07:37 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
2015-05-25 22:08:31 +00:00
|
|
|
|
testquote() { printf '"#&/\n()*=?'"'" | PARALLEL_SHELL=$1 parallel -0 echo; };
|
|
|
|
|
export -f testquote;
|
|
|
|
|
parallel --tag -k testquote ::: ash bash csh dash fdsh fish fizsh ksh ksh93 mksh pdksh posh rbash rc rzsh sash sh static-sh tcsh yash zsh
|
2015-05-25 20:07:37 +00:00
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2015-08-27 20:28:32 +00:00
|
|
|
|
echo '### bug #45769: --round-robin --pipepart gives wrong results'
|
|
|
|
|
|
|
|
|
|
seq 10000 >/tmp/seq10000;
|
|
|
|
|
parallel -j2 --pipepart -a /tmp/seq10000 --block 14 --round-robin wc | wc -l;
|
|
|
|
|
rm /tmp/seq10000
|
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2015-08-30 23:57:14 +00:00
|
|
|
|
echo '### bug #45842: Do not evaluate {= =} twice'
|
|
|
|
|
|
|
|
|
|
parallel -k echo '{= $_=++$::G =}' ::: {1001..1004}
|
|
|
|
|
parallel -k echo '{=1 $_=++$::G =}' ::: {1001..1004}
|
|
|
|
|
parallel -k echo '{= $_=++$::G =}' ::: {1001..1004} ::: {a..c}
|
|
|
|
|
parallel -k echo '{=1 $_=++$::G =}' ::: {1001..1004} ::: {a..c}
|
|
|
|
|
|
|
|
|
|
echo '**'
|
2015-08-27 20:28:32 +00:00
|
|
|
|
|
2015-09-12 15:51:43 +00:00
|
|
|
|
echo '### bug #45939: {2} in {= =} fails'
|
|
|
|
|
parallel echo '{= s/O{2}//=}' ::: OOOK
|
|
|
|
|
parallel echo '{2}-{=1 s/O{2}//=}' ::: OOOK ::: OK
|
|
|
|
|
|
2015-09-18 20:28:47 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo '### bug #45998: --pipe to function broken'
|
|
|
|
|
myfunc() { echo $1; cat; }; export -f myfunc; echo OK | parallel --pipe myfunc {#}
|
|
|
|
|
|
2015-09-21 23:35:52 +00:00
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo 'bug #46016: --joblog should not log when --dryrun'
|
|
|
|
|
parallel --dryrun --joblog - echo ::: Only_this
|
|
|
|
|
|
|
|
|
|
echo '**'
|
2015-09-18 20:28:47 +00:00
|
|
|
|
|
2015-09-24 23:29:34 +00:00
|
|
|
|
echo 'bug #45993: --wd ... should also work when run locally'
|
|
|
|
|
parallel --wd /bi 'pwd; echo $OLDPWD; echo' ::: fail
|
|
|
|
|
parallel --wd /bin 'pwd; echo $OLDPWD; echo' ::: OK
|
|
|
|
|
parallel --wd / 'pwd; echo $OLDPWD; echo' ::: OK
|
|
|
|
|
parallel --wd /tmp 'pwd; echo $OLDPWD; echo' ::: OK
|
|
|
|
|
parallel --wd ... 'pwd; echo $OLDPWD; echo' ::: OK | perl -pe 's/\d+/0/g'
|
|
|
|
|
|
|
|
|
|
parallel --wd . 'pwd; echo $OLDPWD; echo' ::: OK
|
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
2015-10-17 14:54:15 +00:00
|
|
|
|
echo 'bug #46232: {%} with --bar/--eta/--shuf or --halt xx% broken'
|
2015-10-18 13:18:30 +00:00
|
|
|
|
parallel --bar -kj2 --delay 0.1 echo {%} ::: a b ::: c d e 2>/dev/null
|
|
|
|
|
parallel --halt now,fail=10% -kj2 --delay 0.1 echo {%} ::: a b ::: c d e
|
|
|
|
|
parallel --eta -kj2 --delay 0.1 echo {%} ::: a b ::: c d e 2>/dev/null
|
|
|
|
|
parallel --shuf -kj2 --delay 0.1 echo {%} ::: a b ::: c d e 2>/dev/null
|
2015-10-17 14:54:15 +00:00
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
echo 'bug #46231: {%} with --pipepart broken. Should give 1+2'
|
|
|
|
|
seq 10000 > /tmp/num10000;
|
|
|
|
|
parallel --pipepart -ka /tmp/num10000 --block 10k -j2 echo {%};
|
|
|
|
|
rm /tmp/num10000
|
|
|
|
|
|
|
|
|
|
echo '**'
|
2015-09-24 23:29:34 +00:00
|
|
|
|
|
2015-10-18 09:44:02 +00:00
|
|
|
|
echo '{##} bug #45841: Replacement string for total no of jobs'
|
|
|
|
|
|
2015-11-29 23:47:21 +00:00
|
|
|
|
parallel -k --plus echo {##} ::: {a..j};
|
2015-10-18 09:44:02 +00:00
|
|
|
|
parallel -k 'echo {= $::G++ > 3 and ($_=$Global::JobQueue->total_jobs());=}' ::: {1..10}
|
2015-11-29 23:47:21 +00:00
|
|
|
|
parallel -k -N7 --plus echo {#} {##} ::: {1..14}
|
|
|
|
|
parallel -k -N7 --plus echo {#} {##} ::: {1..15}
|
2016-01-03 23:33:09 +00:00
|
|
|
|
parallel -k -S 8/: -X --plus echo {#} {##} ::: {1..15}
|
2015-10-18 09:44:02 +00:00
|
|
|
|
|
|
|
|
|
echo '**'
|
|
|
|
|
|
|
|
|
|
|
2013-12-19 01:19:19 +00:00
|
|
|
|
EOF
|
2015-04-09 23:20:51 +00:00
|
|
|
|
echo '### 1 .par file from --files expected'
|
2015-04-20 22:08:08 +00:00
|
|
|
|
find /tmp{/*,}/*.{par,tms,tmx} 2>/dev/null -mmin -10 | wc -l
|
|
|
|
|
find /tmp{/*,}/*.{par,tms,tmx} 2>/dev/null -mmin -10 | parallel rm
|
|
|
|
|
|
2015-07-22 06:28:05 +00:00
|
|
|
|
sudo umount -l /tmp/smalldisk.img
|