mirror of
https://git.savannah.gnu.org/git/parallel.git
synced 2024-11-22 22:17:54 +00:00
42a5f4e0cc
max_jobs_running could be resat if -j is a changed file. dummy children was not killed if cmd line was too long. default number of jobs for --semaphore set to 1. test25 had race condition. test22 -j10 added. test13 -j9 added. test47 remote cleanup added before test. test17 remote cleanup added before test.
197 lines
10 KiB
Bash
Executable file
197 lines
10 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
SERVER1=parallel-server3
|
|
SERVER2=parallel-server2
|
|
|
|
# Make sure sort order is the same
|
|
export LANG=C
|
|
|
|
echo '### Test --transfer --return --cleanup'
|
|
|
|
rm -rf /tmp/parallel.file*
|
|
stdout ssh $SERVER1 rm -rf 'tmp/parallel.file*' '/tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 rm -rf 'tmp/parallel.file*' '/tmp/parallel.file*'
|
|
(seq 1 3;echo '>fire';seq 5 10; /bin/echo ' : & ) \n*.jpg'; echo '/./sub dir'; seq 13 20) >/tmp/test17
|
|
echo '# Create some weirdly files in /tmp'
|
|
mkdir -p /tmp/parallel.file
|
|
cat /tmp/test17 | parallel -k /bin/echo file{} '>'/tmp/parallel.file{}.file
|
|
cat /tmp/test17 | parallel -k /bin/echo /tmp/parallel.file{}.file >/tmp/test17abs
|
|
cat /tmp/test17 | parallel -k /bin/echo tmp/parallel.file{}.file >/tmp/test17rel
|
|
|
|
echo '### --transfer - abspath'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
cat /tmp/test17abs | parallel -k --transfer --sshlogin $SERVER1,parallel@$SERVER2 cat {}";"rm {}
|
|
# One of these should give the empty dir /tmp/parallel.file
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls '/tmp/parallel.file*'
|
|
# The other: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*'
|
|
|
|
echo '### --transfer - relpath'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
cd /
|
|
cat /tmp/test17rel | parallel -k --transfer --sshlogin $SERVER1,parallel@$SERVER2 cat {}";"rm {}
|
|
# Should give: No such file or directory
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*'
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*'
|
|
|
|
echo '### --transfer --cleanup - abspath'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
cat /tmp/test17abs | parallel -k --transfer --cleanup --sshlogin $SERVER1,parallel@$SERVER2 cat {}
|
|
echo good if no file
|
|
# Should give: No such file or directory
|
|
stdout ssh $SERVER1 ls '/tmp/parallel.file*'
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*'
|
|
|
|
echo '### --transfer --cleanup - relpath'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
cat /tmp/test17rel | parallel -k --transfer --cleanup --sshlogin $SERVER1,parallel@$SERVER2 cat {}
|
|
# Should give: No such file or directory
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --return - abspath'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
rm -rf /tmp/parallel.file*out
|
|
cat /tmp/test17abs | parallel -k --return {.}.out --sshlogin $SERVER1,parallel@$SERVER2 mkdir -p /tmp/parallel.file";"echo {} ">"{.}.out
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out
|
|
|
|
echo '### --return - relpath'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
rm -rf /tmp/parallel.file*out
|
|
cat /tmp/test17rel | parallel -k --return {.}.out --sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp/parallel.file ';'echo {} ">"{.}.out
|
|
ls tmp/parallel.file*out tmp/parallel.file/*out
|
|
|
|
echo '### --return - multiple files'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
rm -rf tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
cat /tmp/test17rel | parallel -k --return {.}.out --return {}.done \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp/parallel.file ';'echo {} ">"{.}.out';'echo {} ">"{}.done';'
|
|
ls tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
|
|
echo '### --return --cleanup - abspath'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
rm -rf /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
cat /tmp/test17abs | parallel -k --return {.}.out --return {}.done --cleanup \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p /tmp/parallel.file ';'echo {} ">"{.}.out';'echo {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls '/tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --return --cleanup - relpath'
|
|
rm -rf tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
cat /tmp/test17rel | parallel -k --return {.}.out --return {}.done --cleanup \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp/parallel.file ';'echo {} ">"{.}.out';'echo {} ">"{}.done';'
|
|
ls tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --return --cleanup - multiple returns'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
rm -rf tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
cat /tmp/test17rel | parallel -k --return {.}.out --return {}.done --cleanup \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp/parallel.file ';'echo {} ">"{.}.out';'echo {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --transfer --return --cleanup - abspath'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
rm -rf /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
cat /tmp/test17abs | parallel -k --transfer --return {.}.out --return {}.done --cleanup \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 cat {} ">"{.}.out';'cat {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls '/tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*' || echo OK
|
|
|
|
|
|
echo '### --transfer --return --cleanup - relpath'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
rm -rf tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
cat /tmp/test17rel | parallel -k --transfer --return {.}.out --return {}.done --cleanup \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp ';'cat {} ">"{.}.out';'cat {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --transfer --return --cleanup - multiple files'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
rm -rf tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
cat /tmp/test17rel | parallel -k --transfer --return {.}.out --return {}.done --cleanup \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp ';'cat {} ">"{.}.out';'cat {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --trc - abspath'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
rm -rf /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
cat /tmp/test17abs | parallel -k --trc {.}.out --trc {}.done \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp ';'cat {} ">"{.}.out';'cat {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls '/tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --trc - relpath'
|
|
stdout ssh $SERVER1 'rm -rf tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf tmp/parallel.file*'
|
|
rm -rf tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
cat /tmp/test17rel | parallel -k --trc {.}.out --trc {}.done \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp ';'cat {} ">"{.}.out';'cat {} ">"{}.done';'
|
|
ls tmp/parallel.file*out tmp/parallel.file/*out tmp/parallel.file*done tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls 'tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls 'tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --trc - multiple files'
|
|
stdout ssh $SERVER1 'rm -rf /tmp/parallel.file*'
|
|
stdout ssh parallel@$SERVER2 'rm -rf /tmp/parallel.file*'
|
|
rm -rf /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
cat /tmp/test17abs | parallel -k --trc {.}.out --trc {}.done \
|
|
--sshlogin $SERVER1,parallel@$SERVER2 mkdir -p tmp ';'cat {} ">"{.}.out';'cat {} ">"{}.done';'
|
|
ls /tmp/parallel.file*out /tmp/parallel.file/*out /tmp/parallel.file*done /tmp/parallel.file/*done
|
|
echo good if no file
|
|
stdout ssh $SERVER1 ls '/tmp/parallel.file*' || echo OK
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*' || echo OK
|
|
|
|
echo '### --transfer --cleanup - multiple argument files'
|
|
parallel -kv --transfer --cleanup -Sparallel@$SERVER2 cat {2} {1} :::: /tmp/test17rel <(sort -r /tmp/test17abs)
|
|
# Should give: No such file or directory
|
|
stdout ssh parallel@$SERVER2 ls '/tmp/parallel.file*' || echo OK
|
|
|