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
|
#!/bin/sh
# PCP QA Test No. 1098
# Exercise a couple of python PMDA module features.
#
# Copyright (c) 2017 Red Hat.
#
seq=`basename $0`
echo "QA output created by $seq"
. ./common.python
$python -c "from pcp import pmda" >/dev/null 2>&1
[ $? -eq 0 ] || _notrun "python pcp pmda module not installed"
domain=242
loaded=2
_cleanup()
{
cd $here
if $need_restore
then
need_restore=false
$sudo rm -rf $PCP_ETC_DIR/pcp/labels/*
_restore_config $PCP_ETC_DIR/pcp/labels
_sighup_pmcd
fi
if pmprobe -I pmcd.agent.status | grep '"test_python"' >/dev/null
then
$sudo rm $PCP_VAR_DIR/config/pmda/$domain.$loaded
cd $here/pmdas/test_python
$sudo ./Remove >>$seq_full 2>&1
$sudo rm -f domain.h.python
cd $here
fi
$sudo rm -rf $tmp $tmp.*
}
status=1 # failure is the default!
userid=`id -u`
groupid=`id -g`
hostname=`hostname`
machineid=`_machine_id`
domainname=`_domain_name`
trap "_cleanup; exit \$status" 0 1 2 3 15
need_restore=true
_filter_labels()
{
sed \
-e "s/.domainname.:.${domainname}./\"domainname\":\"DOMAIN\"/g" \
-e "s/.machineid.:.${machineid}./\"machineid\":\"MACHINE\"/g" \
-e "s/.hostname.:.${hostname}./\"hostname\":\"HOSTNAME\"/g" \
-e "s/.groupid.:$groupid/\"groupid\":GID/g" \
-e "s/.userid.:$userid/\"userid\":UID/g" \
#end
}
# real QA test starts here
_save_config $PCP_ETC_DIR/pcp/labels
$sudo rm -rf $PCP_ETC_DIR/pcp/labels/*
_sighup_pmcd || _exit 1
cd pmdas/test_python
cat > $tmp.conf <<EOF
2 0 2147483647
5 1503630694 five
9 1503630694 nine
EOF
$sudo cp $tmp.conf $PCP_VAR_DIR/config/pmda/$domain.$loaded
$sudo ./Install </dev/null \
| _filter_pmda_install \
| tee -a $seq_full \
| sed -e '/^Waiting for pmcd/s/\.\.\.[. ]*$/DOTS/' >$tmp.tmp
pminfo -f test_python >>$seq_full 2>&1
if grep 'warnings,' <$tmp.tmp >/dev/null
then
echo "Arrgh: warnings for some metrics!"
echo "pminfo --fetch output:" && pminfo -f test_python
echo "PMDA log file:" && cat "$PCP_LOG_DIR/pmcd/test_python.log"
fi
$PCP_AWK_PROG <$tmp.tmp '
/Check test_python metrics have appeared/ { if ($(NF-1) >= 0 && $(NF-1) <= 9) $(NF-1) = "N" }
{ print }'
cd $here
# start from a known place
pmstore test_python.some_value 0 \
| sed -e 's/old value=./old value=N/g'
# need a few invocations to tickle the bug
for i in 1 2 3 4 5 6 7 8; do
echo "=== Round $i ===" | tee -a $seq_full
pmprobe \
test_python.other_indom.some_value \
test_python.some_value \
test_python.some_indom.some_value
done
# exercise indom cache re-loading from backing store
echo && echo "=== Bonus Round ===" | tee -a $seq_full
pmstore test_python.loaded_indom.some_value 0 >>$seq_full
pminfo -f test_python.loaded_indom.some_value | $here/src/sortinst
# exercise intrinsic and extrinsic label interfaces
echo && echo "=== Round Two ===" | tee -a $seq_full
pminfo -l test_python.some_value | _filter_labels
# success, all done
status=0
exit
|