summaryrefslogtreecommitdiff
path: root/qa/053
blob: 3a272c032a6201eb68a0cebccbd1bb35853055df (plain)
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
65
66
67
68
69
70
71
72
73
74
75
76
#! /bin/sh
# PCP QA Test No. 053
# Verify the good stuff happens with pmclient
#
# Copyright (c) 1995-2002 Silicon Graphics, Inc.  All Rights Reserved.
#

seq=`basename $0`
echo "QA output created by $seq"

# get standard filters
. ./common.product
. ./common.filter

_filter()
{

    $PCP_AWK_PROG '
/^Archive: /		{ print "... title ..."; next }
/^[0-9. 	]*$/	{ print "... " NF " numbers ..."; next }
			{ print }'
}

trap "rm -f $tmp $tmp.*; exit" 0 1 2 3 15

# real QA test starts here
cat >$tmp.config <<End-of-File
log mandatory on once {
    hinv.ncpu
}
log mandatory on 5 secs {
    kernel.all.load [ "1 minute", "15 minute" ]
    kernel.percpu.cpu.user
    kernel.percpu.cpu.sys
    mem.freemem
    disk.all.total
}
End-of-File
pmlogger -c $tmp.config -l $tmp.log -s 4 $tmp
_filter_pmlogger_log <$tmp.log

ncpu=`pmprobe -v hinv.ncpu 2>&1 \
| $PCP_AWK_PROG '
NF == 3 && $2 == 1	{ print $3; exit }
			{ print "0"; exit }'`

#
# output is sensitive to SP/MP ... so do the one that is real, and fake
# the other

if [ "$ncpu" -eq 1 ]
then
    pmclient -a $tmp | _filter
    echo "..."
    # fake MP output
    cat <<End-of-File
pmclient: pmFetch: End of PCP archive log
... title ...
  CPU  Busy    Busy  Free Mem   Disk     Load Average
 Util   CPU    Util  (Mbytes)   IOPS    1 Min  15 Min
... 7 numbers ...
... 7 numbers ...
End-of-File
else
    # fake SP output
    cat <<End-of-File
pmclient: pmFetch: End of PCP archive log
... title ...
  CPU  Free Mem   Disk     Load Average
 Util  (Mbytes)   IOPS    1 Min  15 Min
... 5 numbers ...
... 5 numbers ...
End-of-File
    echo "..."
    pmclient -a $tmp | _filter
fi