summaryrefslogtreecommitdiff
path: root/qa/297
diff options
context:
space:
mode:
Diffstat (limited to 'qa/297')
-rwxr-xr-xqa/297145
1 files changed, 145 insertions, 0 deletions
diff --git a/qa/297 b/qa/297
new file mode 100755
index 0000000..a919a91
--- /dev/null
+++ b/qa/297
@@ -0,0 +1,145 @@
+#! /bin/sh
+# PCP QA Test No. 297
+# exercise pmproxy and client reconnect
+#
+# Copyright (c) 2005 Silicon Graphics, Inc. All Rights Reserved.
+#
+
+seq=`basename $0`
+echo "QA output created by $seq"
+
+# get standard environment, filters and checks
+. ./common.product
+. ./common.filter
+. ./common.check
+
+which pmdumptext >/dev/null 2>&1 || \
+ _notrun "No pmdumptext binary installed"
+which pmproxy >/dev/null 2>&1 || \
+ _notrun "No pmproxy binary installed"
+
+PMCDLOG=$PCP_LOG_DIR/pmcd/pmcd.log
+
+status=0 # success is the default!
+signal=$PCP_BINADM_DIR/pmsignal
+killpid=""
+username=`id -u -n`
+$sudo rm -rf $tmp.*
+trap "_cleanup; rm -f $tmp.*; exit \$status" 0 1 2 3 15
+
+_cleanup()
+{
+ [ -n "$killpid" ] && $signal $killpid
+ $sudo $signal -a pmproxy >/dev/null 2>&1
+ $sudo $PCP_RC_DIR/pmproxy restart >/dev/null 2>&1
+}
+
+realname=`hostname`
+chopname=`echo $realname | sed -e 's/\..*//'`
+
+_filter()
+{
+ sed \
+ -e '/^pmWhichContext/d' \
+ -e '/^pmUseContext/d' \
+ -e '/^pmNewZone/d' \
+ -e '/^pmUseZone/d' \
+ -e '/^__pmFdLookup/d' \
+ -e '/^__pmDecodeXtendError/d' \
+ -e '/^__pmAddIPC/d' \
+ -e '/^__pmSendCreds/d' \
+ -e '/^IPC table/d' \
+ -e '/^__pmConnectPMCD.* failed/d' \
+ -e '/^__pmConnect(fd=[0-9][0-9]*(nsprFd=/d' \
+ -e '/^__pmConnectPMCD/{
+s/'$realname'/MY_HOST/g
+s/localhost\.localdomain/MY_HOST/g
+s/localhost/MY_HOST/g
+s/'$chopname'/MY_HOST/g
+s/[0-9][0-9]*/N/g
+}' \
+ -e '/^pmReconnectContext.* failed/d' \
+ -e '/^pmReconnectContext.* too soon/d' \
+ -e '/^pmNewContext/{
+s/'$realname'/MY_HOST/g
+s/'$chopname'/MY_HOST/g
+}' \
+ -e '/^Context\[/{
+s/'$realname'/MY_HOST/g
+s/'$chopname'/MY_HOST/g
+s/[0-9][0-9]*/N/g
+}' \
+ -e '/^[A-Z][a-z][a-z] [A-Z][a-z][a-z] *[0-9][0-9]* [0-9][0-9]:[0-9][0-9]:[0-9][0-9]/{
+# pmdumptext
+s//DATE/
+s/ [0-9][0-9.]*/ N/g
+}' \
+ | _filter_pmproxy | uniq
+}
+
+_filter_pmproxy()
+{
+ sed -e '/^__pmSetSocketIPC: fd=/d' \
+ -e '/^__pmSetDataIPC: fd=/d' \
+ -e '/^__pmDataIPC: fd=/d' \
+ -e '/^IPC table fd/d' \
+ -e '/^__pmSetVersionIPC: fd=/d'
+}
+
+$sudo $PCP_RC_DIR/pmproxy stop >/dev/null 2>&1
+$sudo $signal -a pmproxy >/dev/null 2>&1
+
+export PMCD_RECONNECT_TIMEOUT=1
+
+proxyargs="-Dcontext"
+id pcp >/dev/null 2>&1 && proxyargs="$proxyargs -U $username"
+
+$PCP_BINADM_DIR/pmproxy $proxyargs -l $tmp.log 2>&1 | _filter_pmproxy
+
+export PMPROXY_HOST=localhost
+
+# real QA test starts here
+pmdumptext -Dcontext -t 0.5 sample.bin >$tmp.out 2>&1 &
+killpid=$!
+
+# don't need to confuse pmproxy or pmcd ...
+#
+unset PMPROXY_HOST
+
+sleep 3
+echo "killing pmproxy ..."
+$signal -a pmproxy >/dev/null 2>&1
+sleep 2
+echo "1st pmproxy log" >$seq.full
+cat $tmp.log >>$seq.full
+
+echo "re-starting pmproxy ..."
+$PCP_BINADM_DIR/pmproxy $proxyargs -l $tmp.log 2>&1 | _filter_pmproxy
+
+sleep 4
+echo "killing pmcd ..."
+$sudo $PCP_RC_DIR/pcp stop >/dev/null 2>&1
+sleep 2
+echo >>$seq.full
+echo "1st pmcd log" >>$seq.full
+cat $PMCDLOG >>$seq.full
+
+echo "re-starting pmcd ..."
+$sudo $PCP_RC_DIR/pcp restart >/dev/null 2>&1
+
+sleep 4
+echo >>$seq.full
+echo "2nd pmproxy log" >>$seq.full
+cat $tmp.log >>$seq.full
+echo >>$seq.full
+echo "2nd pmcd log" >>$seq.full
+cat $PMCDLOG >>$seq.full
+
+echo >>$seq.full
+echo "pmdumptext output" >>$seq.full
+cat $tmp.out >>$seq.full
+
+_filter <$tmp.out
+
+# success, all done
+exit