File: time-max-rss.sh

package info (click to toggle)
time 1.9-0.4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,900 kB
  • sloc: ansic: 10,793; sh: 5,505; makefile: 63
file content (64 lines) | stat: -rwxr-xr-x 2,047 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/bin/sh

# Test MAX-RSS (Resident size) reporting

# Copyright (C) 2017-2018 Free Software Foundation, Inc.
#
# This file is part of GNU Time.
#
# GNU Time is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# GNU Time is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with GNU time.  If not, see <http://www.gnu.org/licenses/>.

# Written by Assaf Gordon
. "${test_dir=.}/init.sh"

fail=

# The auxiliary program should be built and runnable
time-aux || framework_failure_ "time-aux is missing/not runnable"

# Get the baseline number of MAX-RSS kilobytes
# use by the program when not allocating any extra memory
env time -o mem-baseline -f "%M" time-aux \
  || framework_failure_ "failed to run time/time-aux (baseline max-rss)"

# Allocate 5MB of RAM
env time -o mem-5MB -f "%M" time-aux -m 5M \
  || framework_failure_ "failed to run time/time-aux (5M max-rss)"

# Calculate the difference
b=$(cat mem-baseline) || framework_failure_ "failed to read mem-baseline"
c=$(cat mem-5MB) || framework_failure_ "failed to read mem-5MB"
d=$(( c - b ))

# On some systems (e.g. OpenSolaris) getrusage(2) returns zero in ru_maxrss.
# Detect and skip the test if this is the case.
test "$b" -eq "0" && test "$c" -eq 0 \
  && skip_ "getrusage(2) returns zero in ru_maxrss"

# There could be alot of variation between each invocation,
# accept a reasonable range
if test "$d" -ge 5000 && test "$d" -le 6000 ; then
    : # acceptable values: 5000-6000 KB
else
    cat<<EOF>&2
time(1) failed to detect 5MB allcoation.
  mem-baseline(kb): $b
  mem-5MB(kb):      $c
  delta(kb):        $d
EOF
    fail=1
fi


exit $fail