/var/lib/pcp/testsuite/103 is in pcp-testsuite 3.8.12ubuntu1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
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 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | #! /bin/sh
# PCP QA Test No. 103
# exercise the logging state compatibility matrix for pmlc ...
# initial: some instances for a metric
# request: some overlapping instances for the same metric
#
# 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
. ./common.check
trap "$sudo rm -f $tmp $tmp.*; exit" 0 1 2 3 15
_filter_pmlc()
{
sed \
-e '/connect /{
s/connect [0-9][0-9]*/connect PID/
s/@.*/@HOSTNAME/
}' \
-e '/Connected /{
s/port [0-9][0-9]*/port PORT/
s/ at .*/ at HOSTNAME/
}' \
-e 's/ nl / /' \
-e "/timed out/d" \
-e 's/Version [0-9].*/Version VERSION/' \
| $PCP_AWK_PROG '
/pmlc commands/ { skip = 1; print "[command summary deleted ...]" }
/metric-name/ { skip = 0; next }
skip == 1 { next }
{ print }'
}
_filter_logger()
{
_filter_pmlogger_log \
| sed \
-e '/AF event queue/d'
}
_filter_dump()
{
_filter_pmdumplog \
| sed \
-e '/^$/d' \
-e '/pmResult/s/ .* numpmid/ ... numpmid/' \
-e '/inst /{
s/inst \[[0-9][0-9]* or "dks..."]/inst [DISK]/
s;inst \[[0-9][0-9]* or "/dev/[^"]*"];inst [DISK];
s;inst \[[0-9][0-9]* or ".*/dbs/.*\.dbf"];inst [FILE];
}' \
-e '/value /{
s/value [0-9][0-9]*\.[0-9][0-9]*e.[0-9][0-9]*/value NUMBER/
s/value [0-9][0-9]*\.[0-9][0-9]*/value NUMBER/
s/value [0-9][0-9]*e.[0-9][0-9]*/value NUMBER/
s/value [0-9][0-9]*/value NUMBER/
s/value \[.*]/value AGGREGATE/
s/value ".*"/value STRING/
}' \
-e "/pmcd\.pmlogger\./s/$logger_pid/LOGGER_PID/g" \
-e '/pmcd\.pmlogger\.port/s/value .*/value PORT/' \
-e '/pmcd\.pmlogger\.host/s/value ".*/value "HOST"/' \
-e '/pmcd\.pmlogger\.archive/s/value ".*/value "PATH"/'
}
_do_cmds()
{
for ctl in mandatory advisory
do
for state in "on once" maybe off
do
[ "$ctl $state" = "advisory maybe" ] && continue
for req_ctl in mandatory advisory
do
for req_state in "on once" maybe off
do
[ "$req_ctl $req_state" = "advisory maybe" ] && continue
( echo "# setup"; \
echo "log mandatory maybe sample.bin "'[ "bin-100", "bin-200", "bin-300", "bin-400", "bin-500" ]'; \
echo "# $ctl $state -> $req_ctl $req_state"; \
echo "log $ctl $state sample.bin "'[ "bin-100", "bin-200", "bin-300"]'; \
) | pmlc -ie $1
pmsleep 0.5
( echo "log $req_ctl $req_state sample.bin "'[ "bin-200", "bin-400" ]'; \
echo "query sample.bin"; \
) | pmlc -ie $1
pmsleep 0.5
# need sleeps to allow pmlogger to get a look in and
# to allow the pmlogger socket to be closed so the
# next pmlc invocation can get connected
done
done
done
done
}
x=3
# real QA test starts here
$sudo rm -f $tmp.0 $tmp.meta $tmp.index
# start pmlogger with the expected number of samples plus a few more
# to detect extra log output
#
_start_up_pmlogger -t 0.5sec -L -s 30 -c /dev/null -l $tmp.log $tmp >$tmp.err 2>&1
logger_pid=$pid
pmsleep 1.5
_do_cmds $logger_pid >$tmp.out 2>&1
# this chews up any remaining samples quickly so pmlogger terminates
#
echo "log mandatory on 25 msec sample.long.one" \
| pmlc -ie $logger_pid >>$tmp.out 2>&1
_filter_pmlc <$tmp.out
# wait for pmlogger to terminate
#
_wait_pmlogger_end $logger_pid
cat $tmp.err $tmp.log | _filter_logger
echo
if [ -s $tmp.0 ]
then
echo "Uniq filtered entries from pmdumplog ..."
pmdumplog $tmp \
| _filter_dump \
| sed -e 's/TIMESTAMP//' -e 's/^ *//' \
| LC_COLLATE=POSIX sort -u
pmdumplog $tmp >$seq.full 2>&1
else
echo "Archive log is empty"
fi
exit
|