mirror of
https://github.com/fish-shell/fish-shell.git
synced 2024-12-01 06:53:39 +08:00
1e858eae35
This demonstrates that we only write control sequences when interactive.
56 lines
984 B
Fish
56 lines
984 B
Fish
# RUN: %fish %s
|
|
|
|
# Ensure that job IDs are sequential.
|
|
|
|
status job-control full
|
|
|
|
set -g tokill
|
|
|
|
function func100
|
|
sleep 100 &
|
|
set -g tokill $tokill $last_pid
|
|
end
|
|
func100
|
|
|
|
# The redirection ensures this becomes a real job.
|
|
begin
|
|
sleep 200 &
|
|
set -g tokill $tokill $last_pid
|
|
end </dev/null
|
|
|
|
|
|
sleep 300 &
|
|
set -g tokill $tokill $last_pid
|
|
|
|
jobs
|
|
|
|
#CHECK: Job Group{{.*}}
|
|
#CHECK: 3{{.*\t}}sleep 300 &
|
|
#CHECK: 2{{.*\t}}sleep 200 &
|
|
#CHECK: 1{{.*\t}}sleep 100 &
|
|
|
|
# Kill job 2; the next job should have job ID 4 because 3 is still in use (#6053).
|
|
|
|
status job-control interactive
|
|
command kill -9 $tokill[2]
|
|
# Wait for the job to die - the signal needs to be delivered.
|
|
wait $tokill[2] 2>/dev/null
|
|
set -e tokill[2]
|
|
status job-control full
|
|
sleep 400 &
|
|
set -g tokill $tokill $last_pid
|
|
|
|
jobs
|
|
|
|
#CHECK: Job Group{{.*}}
|
|
#CHECK: 4{{.*\t}}sleep 400 &
|
|
#CHECK: 3{{.*\t}}sleep 300 &
|
|
#CHECK: 1{{.*\t}}sleep 100 &
|
|
|
|
|
|
status job-control interactive
|
|
|
|
for pid in $tokill
|
|
command kill -9 $pid
|
|
end
|