pmrep: fix archive end time reporting
[pcp.git] / qa / 297
bloba919a9186510113152cc7035361246ddb0480451
1 #! /bin/sh
2 # PCP QA Test No. 297
3 # exercise pmproxy and client reconnect
5 # Copyright (c) 2005 Silicon Graphics, Inc. All Rights Reserved.
8 seq=`basename $0`
9 echo "QA output created by $seq"
11 # get standard environment, filters and checks
12 . ./common.product
13 . ./common.filter
14 . ./common.check
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
25 killpid=""
26 username=`id -u -n`
27 $sudo rm -rf $tmp.*
28 trap "_cleanup; rm -f $tmp.*; exit \$status" 0 1 2 3 15
30 _cleanup()
32 [ -n "$killpid" ] && $signal $killpid
33 $sudo $signal -a pmproxy >/dev/null 2>&1
34 $sudo $PCP_RC_DIR/pmproxy restart >/dev/null 2>&1
37 realname=`hostname`
38 chopname=`echo $realname | sed -e 's/\..*//'`
40 _filter()
42 sed \
43 -e '/^pmWhichContext/d' \
44 -e '/^pmUseContext/d' \
45 -e '/^pmNewZone/d' \
46 -e '/^pmUseZone/d' \
47 -e '/^__pmFdLookup/d' \
48 -e '/^__pmDecodeXtendError/d' \
49 -e '/^__pmAddIPC/d' \
50 -e '/^__pmSendCreds/d' \
51 -e '/^IPC table/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
57 s/localhost/MY_HOST/g
58 s/'$chopname'/MY_HOST/g
59 s/[0-9][0-9]*/N/g
60 }' \
61 -e '/^pmReconnectContext.* failed/d' \
62 -e '/^pmReconnectContext.* too soon/d' \
63 -e '/^pmNewContext/{
64 s/'$realname'/MY_HOST/g
65 s/'$chopname'/MY_HOST/g
66 }' \
67 -e '/^Context\[/{
68 s/'$realname'/MY_HOST/g
69 s/'$chopname'/MY_HOST/g
70 s/[0-9][0-9]*/N/g
71 }' \
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]/{
73 # pmdumptext
74 s//DATE/
75 s/ [0-9][0-9.]*/ N/g
76 }' \
77 | _filter_pmproxy | uniq
80 _filter_pmproxy()
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'
89 $sudo $PCP_RC_DIR/pmproxy stop >/dev/null 2>&1
90 $sudo $signal -a pmproxy >/dev/null 2>&1
92 export PMCD_RECONNECT_TIMEOUT=1
94 proxyargs="-Dcontext"
95 id pcp >/dev/null 2>&1 && proxyargs="$proxyargs -U $username"
97 $PCP_BINADM_DIR/pmproxy $proxyargs -l $tmp.log 2>&1 | _filter_pmproxy
99 export PMPROXY_HOST=localhost
101 # real QA test starts here
102 pmdumptext -Dcontext -t 0.5 sample.bin >$tmp.out 2>&1 &
103 killpid=$!
105 # don't need to confuse pmproxy or pmcd ...
107 unset PMPROXY_HOST
109 sleep 3
110 echo "killing pmproxy ..."
111 $signal -a pmproxy >/dev/null 2>&1
112 sleep 2
113 echo "1st pmproxy log" >$seq.full
114 cat $tmp.log >>$seq.full
116 echo "re-starting pmproxy ..."
117 $PCP_BINADM_DIR/pmproxy $proxyargs -l $tmp.log 2>&1 | _filter_pmproxy
119 sleep 4
120 echo "killing pmcd ..."
121 $sudo $PCP_RC_DIR/pcp stop >/dev/null 2>&1
122 sleep 2
123 echo >>$seq.full
124 echo "1st pmcd log" >>$seq.full
125 cat $PMCDLOG >>$seq.full
127 echo "re-starting pmcd ..."
128 $sudo $PCP_RC_DIR/pcp restart >/dev/null 2>&1
130 sleep 4
131 echo >>$seq.full
132 echo "2nd pmproxy log" >>$seq.full
133 cat $tmp.log >>$seq.full
134 echo >>$seq.full
135 echo "2nd pmcd log" >>$seq.full
136 cat $PMCDLOG >>$seq.full
138 echo >>$seq.full
139 echo "pmdumptext output" >>$seq.full
140 cat $tmp.out >>$seq.full
142 _filter <$tmp.out
144 # success, all done
145 exit