pmrep: fix archive end time reporting
[pcp.git] / qa / 455
blob525671fa34523179b0ee734a4913d9ab87c32ecf
1 #! /bin/sh
2 # PCP QA Test No. 455
3 # Sanity checks for rsyslog pmda
5 # Copyright (c) 2011 Aconex. All Rights Reserved.
8 seq=`basename $0`
9 echo "QA output created by $seq"
11 # get standard filters
12 . ./common.product
13 . ./common.check
14 . ./common.filter
16 [ -d $PCP_PMDAS_DIR/rsyslog ] || _notrun "rsyslog PMDA directory is not installed"
17 grep rsyslog.elasticsearch.submits $PCP_PMDAS_DIR/rsyslog/pmdarsyslog.pl >/dev/null
18 [ $? -eq 0 ] || _notrun "Newer version of rsyslog PMDA needed"
20 perl -e "use PCP::PMDA" >/dev/null 2>&1
21 test $? -eq 0 || _notrun "PCP::PMDA perl module is not installed"
23 install_on_cleanup=false
24 pminfo rsyslog >/dev/null 2>&1 && install_on_cleanup=true
26 status=1
27 done_clean=false
29 _cleanup()
31 if $done_clean
32 then
34 else
35 if [ -f $tmp.pmcd.conf ]
36 then
37 $sudo cp $tmp.pmcd.conf $PCP_PMCDCONF_PATH
38 rm -f $tmp.pmcd.conf
40 rm -f $tmp.*
41 $sudo $PCP_RC_DIR/pcp restart | _filter_pcp_start
42 _wait_for_pmcd
43 _wait_for_pmlogger
44 if $install_on_cleanup
45 then
46 ( cd $PCP_PMDAS_DIR/rsyslog; $sudo ./Install </dev/null >/dev/null 2>&1 )
47 else
48 ( cd $PCP_PMDAS_DIR/rsyslog; $sudo ./Remove >/dev/null 2>&1 )
50 done_clean=true
52 exit $status
55 _filter()
57 # number of warnings depends on rsyslog config
58 sed \
59 -e '/Creating rsyslog statistics file/d' \
60 -e 's/ [0-9]* warnings/ some warnings/g'
63 _val_filter()
65 $PCP_AWK_PROG '
66 /^rsyslog\.interval/ { fix = 1 }
67 fix == 1 && /value [0-9][0-9]*/ { $2 = "NUMBER" }
68 { print }
69 NF == 0 { fix = 0 }'
72 trap "_cleanup" 0 1 2 3 15
74 # real QA test starts here
75 iam=rsyslog
76 cd $PCP_PMDAS_DIR/$iam
78 # copy the pmcd config file to restore state later.
79 cp $PCP_PMCDCONF_PATH $tmp.pmcd.conf
81 # start from a known starting point
82 $sudo ./Remove >/dev/null 2>&1
83 $sudo rm -f pmns domain.h
85 echo
86 echo "=== $iam agent installation ==="
87 $sudo rm -f $PCP_LOG_DIR/rsyslog/stats
88 $sudo ./Install </dev/null >$tmp.out 2>&1
89 _filter_pmda_install <$tmp.out \
90 | _filter
92 echo
93 echo "=== validate values ==="
94 rm -f $tmp.stats
95 echo "\
96 2011-05-11T08:18:02.420771+10:00 host rsyslogd-pstats: imuxsock: submitted=85 ratelimit.discarded=0 ratelimit.numratelimiters=24
97 2011-05-11T08:18:02.420797+10:00 host rsyslogd-pstats: main Q: size=1181 enqueued=1181 full=0 maxqsize=1181
98 2011-05-11T08:18:07.423713+10:00 host rsyslogd-pstats: imuxsock: submitted=85 ratelimit.discarded=0 ratelimit.numratelimiters=24
99 2011-05-11T08:18:07.423752+10:00 host rsyslogd-pstats: main Q: size=1 enqueued=1183 full=0 maxqsize=1182" > $tmp.stats
101 for i in 1 2 3 4 5
103 [ -p $PCP_LOG_DIR/rsyslog/stats ] && break
104 sleep 1
105 done
107 if [ ! -p $PCP_LOG_DIR/rsyslog/stats ]
108 then
109 echo "Arrgh failed to see named pipe $PCP_LOG_DIR/rsyslog/stats after 5 seconds"
110 ls -l $PCP_LOG_DIR/rsyslog
111 exit
114 $sudo sh -c "cat $tmp.stats >> $PCP_LOG_DIR/rsyslog/stats"
115 sleep 2 # give some time for pmdarsyslog to be told
116 $sudo sh -c "cat $tmp.stats >> $PCP_LOG_DIR/rsyslog/stats"
117 sleep 2 # give more time for pmdarsyslog to be told
118 pminfo rsyslog \
119 | LC_COLLATE=POSIX sort \
120 | while read metric
122 pminfo -f $metric
123 done \
124 | _val_filter
126 echo
127 echo "=== remove $iam agent ==="
128 $sudo ./Remove >$tmp.out 2>&1
129 _filter_pmda_remove <$tmp.out
131 status=0
132 exit