/var/lib/pcp/testsuite/023 is in pcp-testsuite 4.0.1-1.
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 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 | #! /bin/sh
# PCP QA Test No. 023
# Test PMCD's PMDA timeout behaviour
#
# Copyright (c) 1995-2002 Silicon Graphics, Inc. All Rights Reserved.
# Copyright (c) 2016 Red Hat, Inc.
#
seq=`basename $0`
echo "QA output created by $seq"
# get standard filters
. ./common.product
. ./common.filter
. ./common.check
_get_libpcp_config
rm -f $seq.out
if [ "$ipv6" = "true" ]; then
ln $seq.out.2 $seq.out || exit 1
else
ln $seq.out.1 $seq.out || exit 1
fi
BINFMT=unknown-obj
which pmobjstyle >/dev/null 2>&1 && BINFMT=`pmobjstyle`
_filter_me()
{
sed \
-e "s/`hostname`/MY_HOSTNAME/g" \
-e "s/`hostname | sed -e 's/\..*//'`/MY_HOSTNAME/" \
-e "s/local:/MY_HOSTNAME/" \
-e "s/localhost\.localdomain/MY_HOSTNAME/" \
-e "s/localhost/MY_HOSTNAME/"
}
_filter_log()
{
sleep 3
_filter_pmcd_log <./pmcd.log \
| sed \
-e '/^DATA: from client/d' \
-e 's/Cannot open 000000660066: No such file or directory//' \
-e 's/^$//' \
-e '/^00[08]:/d' \
-e '/pmGetPDU/{
s/\[[0-9][0-9]*]/[PID]/
s/from=.*/from=PID/
}' \
-e '/_pmHaveMoreInput/{
s/\[[0-9][0-9]*]/[PID]/
s/0x[^ ]*\([^ ][^ ][^ ]\)/ADDR...\1/
}' \
-e '/Piggy-back/{
s/0x[^ ]*\([^ ][^ ][^ ]\)/ADDR...\1/
s/from=.*/from=PID/
}' \
-e '/pmXmitPDU/s/\[[0-9][0-9]*]/[PID]/' \
-e '/pmResult/s/ .* numpmid/ ... numpmid/' \
-e '/value /{
s/value [0-9][0-9]*/value INTEGER/
}' \
-e "s;$PCP_PMCDCONF_PATH;\$PCP_PMCDCONF_PATH;g" \
-e 's#/usr/pcp/lib/mips#mips#' \
-e 's#/usr/lib/pcp/mips#mips#' \
-e "s/$BINFMT/ISA/g" \
-e '/access violation from host/d' \
-e '/endclient client.* No permission/d' \
-e 's/ while attempting to read 12 bytes out of 12 in .*on fd/ on fd/' \
-e 's/fd=[0-9][0-9]*/fd=FD/g' \
-e "s;$here/src/;;" \
-e '/UNIX_DOMAIN_SOCKET/d' \
-e '/unix:/d' \
-e "/Warning:/s/PMCD_PORT=$port/PMCD_PORT=\$port/" \
| $PCP_AWK_PROG '
$3 ~ /^[0-9][0-9]*$/ { $3 = "A_PID"; }
/Host access list:/ { localHostPrinted = 0 }
$1 == "y" && $2 = "y" && $8 == "localhost" {
if (! localHostPrinted) {
localHostPrinted = 1
$5 = "IP-addr-in-hex"; $6 = "Host-mask"
}
else next
}
/pipe cmd=/ { $4 = "FD"; $5 = "FD" }
{ print }' \
| sed -e '/^pmcd 2 A_PID /s/ A_PID .*/ A_PID .../' \
| _filter_me \
| sed -e '/MY_HOSTNAME A_PID/{
s/^16 /N-OK /
s/^17 /N-OK /
s/^18 /N-OK /
s/^19 /N-OK /
s/^20 /N-OK /
}'
# last sed is because the number of open fds is platform-dependent
}
TMP_CONFIG=$tmp/conf.tmp
[ -z "$PCP_PMLOGGERCONTROL_PATH" ] && \
PCP_PMLOGGERCONTROL_PATH="$PCP_SYSCONF_DIR/pmlogger/control"
LOGCONTROL="$PCP_PMLOGGERCONTROL_PATH"
SAVE_LOGCONTROL=$tmp/control.save
signal=$PCP_BINADM_DIR/pmsignal
_needclean=true
rm -rf $tmp $tmp.*
mkdir $tmp
chmod ugo+rwx $tmp
cd $tmp
SAVE_LOGGER=`_get_config pmlogger`
[ -f $LOGCONTROL ] && $sudo mv $LOGCONTROL $SAVE_LOGCONTROL
cleanup()
{
echo >>$here/$seq.full
echo "pmcd.log at cleanup" >>$here/$seq.full
cat pmcd.log >>$here/$seq.full
cd $here
if $_needclean
then
_needclean=false
$sudo $signal -a -s TERM pmcd
_restore_config $PCP_PMCDCONF_PATH
echo "=== restored $PCP_PMCDCONF_PATH ===" >>$here/$seq.full
cat $PCP_PMCDCONF_PATH >>$here/$seq.full
[ -f $SAVE_LOGCONTROL ] && $sudo mv $SAVE_LOGCONTROL $LOGCONTROL
echo "=== restored $LOGCONTROL ===" >>$here/$seq.full
cat $LOGCONTROL >>$here/$seq.full
[ ! -z "$SAVE_LOGGER" ] && _change_config pmlogger $SAVE_LOGGER
echo "Restart and ping pmcd ..."
unset PMCD_PORT # don't worry about preserving just get rid of it
unset PMCD_SOCKET
_service pcp restart \
| tee -a $here/$seq.full \
| _filterall_pcp_start \
| sed \
-e '/Waiting for pmcd to terminate/d' \
-e '/Installing .* PMDA \.\.\./d'
_restore_auto_restart pmcd
_wait_for_pmcd
_wait_for_pmlogger
pmprobe pmcd.control.debug
sleepers=`ps $PCP_PS_ALL_FLAGS | grep '[d]umb_pmda' | $PCP_AWK_PROG '$3 == 1 { print $2 }'`
[ ! -z "$sleepers" ] && $sudo $signal -s TERM $sleepers
fi
rm -rf $tmp $tmp.*
}
trap "cleanup; exit \$status" 0 1 2 3 15
rm -f $here/$seq.full
echo "SAVE_LOGGER=$SAVE_LOGGER" >>$here/$seq.full
# real QA test starts here
# Get a domain number for the 'fake_kernel' pmda
FAKE_DOM=`pminfo -m hinv.ncpu | $PCP_AWK_PROG '{split ($3,d,"."); print d[1];}'`
# pick a tcp port that is not in use
#
port=`_get_port tcp 4340 4350`
if [ -z "$port" ]
then
echo "Arrgh ... no free TCP port in the range 4340 ... 4350"
exit 1
fi
_stop_auto_restart pmcd
_service pmlogger stop | tee -a $here/$seq.full | _filter_pcp_stop
_service pmcd stop | tee -a $here/$seq.full | _filter_pcp_stop
_service pmie stop >>$here/$seq.full
_change_config pmlogger off
# Create a fake namespace to force pminfo to query the fake agent
FAKE_NS=$tmp/$seq.fake_ns
echo 'root { hinv } ' > $FAKE_NS
echo 'hinv { ncpu 1:0:1 }' >> $FAKE_NS
# Make our own version of pmcd.conf with dummy agents that will time out.
# Copy the pmcd PMDA from the original pmcd.conf so that we can check pmcd's
# timeouts by storing into pmcd.control.timeout
# NOTE: none of the domains should clash with the pmcd PMDA (domain 2) or the
# sample agent (domain 254). These agents will be appended to the file.
#
cat <<EOF >$TMP_CONFIG
# Created by QA $seq
fake_irix 1 pipe binary $here/src/dumb_pmda -d 1 fake_irix
fake_proc 3 pipe binary $here/src/dumb_pmda -d 3 fake_proc
fake_cisco 5 pipe binary $here/src/dumb_pmda -d 5 fake_cisco
fake_six 6 pipe binary $here/src/dumb_pmda -d 6 fake_six
EOF
sed -n <$PCP_PMCDCONF_PATH >>$TMP_CONFIG \
-e '/^#/d' \
-e '/pmda_pmcd/s/[ ][ ]*/ /gp' \
-e '/pmdapmcd/s/[ ][ ]*/ /gp'
cat <<EOF >>$TMP_CONFIG
[access]
allow localhost : all;
disallow * : all;
EOF
_save_config $PCP_PMCDCONF_PATH
$sudo cp $TMP_CONFIG $PCP_PMCDCONF_PATH
# very odd inode update problem on kenj-pc with one variant of the Linux
# 2.6.11 kernel ... this should be 100% benign for everyone else
#
sync
echo '$PCP_PMCDCONF_PATH contains:' | sed -e "s;$PCP_VAR_DIR;\$PCP_VAR_DIR;"
echo '<BEGIN>'
sed <$PCP_PMCDCONF_PATH \
-e '/^pmcd 2 /s/2 .*/2 .../' \
-e "s;$here/src/;;"
echo '<END>'
# Note: start pmcd with -f so that its PID stays the same (no daemon)
#
PMCD_PORT=$port
PATH=$PATH:$here/src
PMCD_SOCKET=$tmp/pmcd.socket
export PMCD_PORT PATH PMCD_SOCKET
$PCP_PMCD_PROG -f -t 2 &
pmcd=$!
if [ -d $PCP_RUN_DIR ]
then
echo "$pmcd" >$tmp.tmp
$sudo cp $tmp.tmp $PCP_RUN_DIR/pmcd.pid
fi
# Sleep 3 sec for each fake pmda
sleep 15
_wait_for_pmcd
_filter_log
echo "pmcd.log after pmcd first started" >>$here/$seq.full
cat pmcd.log >>$here/$seq.full
# Get pmcd to stop the fake_kernel PMDA by asking for a metric from it.
# Sleep won't do anything, so it'll be timed out returning an IPC protocol
# failure. The next fetch for the domain will return a "No agent for
# domain..." error.
#
echo
echo "Restart dead agent test"
echo "Expect \"IPC protocol failure\" then \"No agent for domain...\":"
pminfo -n $FAKE_NS -d hinv.ncpu
pminfo -n $FAKE_NS -d hinv.ncpu
pminfo -f pmcd.agent.status
echo
# Check the functionality of pmcd.control.timeout. agenttimeout sets the pmcd
# agenttimeout for a specified domain to a given timeout, then fetches from
# the domain, expecting the agent to timeout and finally checks the timeout
# against the elapsed time for the fetch.
# Usage: agenttimeout domain timeout
#
echo
echo "pmcd.control.timeout tests"
$here/src/agenttimeout 5 3
$here/src/agenttimeout 6 8
#
# Be nice and set it back to 2 so that subsequent timeouts happen more quickly
#
pmstore pmcd.control.timeout 2
pminfo -f pmcd.agent.status
echo
# Get PMCD to restart any deceased agents. (The config file hasn't changed)
#
sleep 1
$signal -s HUP $pmcd
# Sleep 3 sec for each fake pmda in the config
sleep 15
_wait_for_pmcd
_filter_log
echo >>$here/$seq.full
echo "pmcd.log after pmcd SIGHUP" >>$here/$seq.full
cat pmcd.log >>$here/$seq.full
pminfo -f pmcd.agent.status
echo
# If agent not restarted then both messages will be "no agent for domain..."
#
echo "Expect \"IPC protocol failure\" then \"No PMCD agent...\":"
pminfo -n $FAKE_NS -d hinv.ncpu
pminfo -n $FAKE_NS -d hinv.ncpu
pminfo -f pmcd.agent.status
echo
status=0
|