~ubuntu-branches/ubuntu/utopic/coreutils/utopic-proposed

« back to all changes in this revision

Viewing changes to tests/tail-2/pid.sh

  • Committer: Package Import Robot
  • Author(s): Colin Watson
  • Date: 2012-11-28 03:03:42 UTC
  • mfrom: (8.3.4 sid)
  • Revision ID: package-import@ubuntu.com-20121128030342-21zanj8354gas5gr
Tags: 8.20-3ubuntu1
* Resynchronise with Debian.  Remaining changes:
  - Make 'uname -i -p' return the real processor/hardware, instead of
    unknown.
  - Build-depend on gettext:any instead of on gettext, so that apt-get can
    properly resolve build-dependencies on the tool when cross-building.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/bin/sh
 
2
# Test the --pid option of tail.
 
3
 
 
4
# Copyright (C) 2003-2012 Free Software Foundation, Inc.
 
5
 
 
6
# This program is free software: you can redistribute it and/or modify
 
7
# it under the terms of the GNU General Public License as published by
 
8
# the Free Software Foundation, either version 3 of the License, or
 
9
# (at your option) any later version.
 
10
 
 
11
# This program is distributed in the hope that it will be useful,
 
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
14
# GNU General Public License for more details.
 
15
 
 
16
# You should have received a copy of the GNU General Public License
 
17
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
18
 
 
19
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
 
20
print_ver_ tail
 
21
getlimits_
 
22
 
 
23
touch empty here || framework_failure_
 
24
 
 
25
 
 
26
for inotify in ---disable-inotify ''; do
 
27
  # Use tail itself to create a background process to monitor,
 
28
  # which will auto exit when "here" is removed.
 
29
  tail -f $inotify here &
 
30
  bg_pid=$!
 
31
 
 
32
  # Ensure that tail --pid=PID does not exit when PID is alive.
 
33
  timeout 1 tail -f -s.1 --pid=$bg_pid $inotify here
 
34
  test $? = 124 || fail=1
 
35
 
 
36
  # Cleanup background process
 
37
  kill $bg_pid
 
38
 
 
39
  # Ensure that tail --pid=PID exits with success status when PID is dead.
 
40
  # Use an unlikely-to-be-live PID
 
41
  timeout 10 tail -f -s.1 --pid=$PID_T_MAX $inotify empty
 
42
  ret=$?
 
43
  test $ret = 124 && skip_ "pid $PID_T_MAX present or tail too slow"
 
44
  test $ret = 0 || fail=1
 
45
 
 
46
  # Ensure tail doesn't wait for data when PID is dead
 
47
  timeout 10 tail -f -s10 --pid=$PID_T_MAX $inotify empty
 
48
  test $? = 124 && fail=1
 
49
done
 
50
 
 
51
Exit $fail