3 # exercise pmproxy and client reconnect
5 # Copyright (c) 2005 Silicon Graphics, Inc. All Rights Reserved.
9 echo "QA output created by $seq"
11 # get standard environment, filters and checks
16 which pmdumptext
>/dev
/null
2>&1 || \
17 _notrun
"No pmdumptext binary installed"
18 which pmproxy
>/dev
/null
2>&1 || \
19 _notrun
"No pmproxy binary installed"
21 PMCDLOG
=$PCP_LOG_DIR/pmcd
/pmcd.log
23 status
=0 # success is the default!
24 signal
=$PCP_BINADM_DIR/pmsignal
28 trap "_cleanup; rm -f $tmp.*; exit \$status" 0 1 2 3 15
32 [ -n "$killpid" ] && $signal $killpid
33 $sudo $signal -a pmproxy
>/dev
/null
2>&1
34 _service pmproxy restart
>/dev
/null
2>&1
38 chopname
=`echo $realname | sed -e 's/\..*//'`
43 -e '/^pmWhichContext/d' \
44 -e '/^pmUseContext/d' \
47 -e '/^__pmFdLookup/d' \
48 -e '/^__pmDecodeXtendError/d' \
50 -e '/^__pmSendCreds/d' \
52 -e '/^__pmConnectPMCD.* failed/d' \
53 -e '/^__pmConnect(fd=[0-9][0-9]*(nsprFd=/d' \
54 -e '/^__pmConnectPMCD/{
55 s/'$realname'/MY_HOST/g
56 s/localhost\.localdomain/MY_HOST/g
58 s/'$chopname'/MY_HOST/g
61 -e '/^pmReconnectContext.* failed/d' \
62 -e '/^pmReconnectContext.* too soon/d' \
64 s/'$realname'/MY_HOST/g
65 s/'$chopname'/MY_HOST/g
68 s/'$realname'/MY_HOST/g
69 s/'$chopname'/MY_HOST/g
72 -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]/{
77 | _filter_pmproxy |
uniq
82 sed -e '/^__pmSetSocketIPC: fd=/d' \
83 -e '/^__pmSetDataIPC: fd=/d' \
84 -e '/^__pmDataIPC: fd=/d' \
85 -e '/^IPC table fd/d' \
86 -e '/^__pmSetVersionIPC: fd=/d' \
87 -e '/^__pmSetFeaturesIPC: fd=/d' \
88 -e 's/localhost/MY_HOST/g'
91 _service pmproxy stop
>/dev
/null
2>&1
92 $sudo $signal -a pmproxy
>/dev
/null
2>&1
94 export PMCD_RECONNECT_TIMEOUT
=1
97 id pcp
>/dev
/null
2>&1 && proxyargs
="$proxyargs -U $username"
99 $PCP_BINADM_DIR/pmproxy
$proxyargs -l $tmp.log
2>&1 | _filter_pmproxy
101 export PMPROXY_HOST
=localhost
103 # real QA test starts here
104 pmdumptext
-Dcontext -t 0.5 sample.bin
>$tmp.out
2>&1 &
107 # don't need to confuse pmproxy or pmcd ...
112 echo "killing pmproxy ..."
113 $signal -a pmproxy
>/dev
/null
2>&1
115 echo "1st pmproxy log" >$seq.full
116 cat $tmp.log
>>$seq.full
118 echo "re-starting pmproxy ..."
119 $PCP_BINADM_DIR/pmproxy
$proxyargs -l $tmp.log
2>&1 | _filter_pmproxy
122 echo "killing pmcd ..."
123 _service pcp stop
>/dev
/null
2>&1
126 echo "1st pmcd log" >>$seq.full
127 cat $PMCDLOG >>$seq.full
129 echo "re-starting pmcd ..."
130 _service pcp restart
>/dev
/null
2>&1
135 echo "2nd pmproxy log" >>$seq.full
136 cat $tmp.log
>>$seq.full
138 echo "2nd pmcd log" >>$seq.full
139 cat $PMCDLOG >>$seq.full
142 echo "pmdumptext output" >>$seq.full
143 cat $tmp.out
>>$seq.full