blob: 432076370e154ca35bce474e4a2407ebd1ab6205 (
plain)
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
|
#! /bin/sh
# PCP QA Test No. 427
# bogus pmda entries in pmcd.conf
# #564017
#
# Copyright (c) 1995-2002 Silicon Graphics, Inc. All Rights Reserved.
#
seq=`basename $0`
echo "QA output created by $seq"
# get standard filters
. ./common.product
. ./common.filter
. ./common.check
if [ -z "$PCP_PMCDCONF_PATH" ] ; then
echo eek; exit 1;
fi
if [ -z "$PCP_PMCDLOG_PATH" ] ; then
echo yuk; exit 1;
fi
status=1 # failure is the default!
needclean=true
[ -z "$PCP_PMLOGGERCONTROL_PATH" ] && \
PCP_PMLOGGERCONTROL_PATH="$PCP_SYSCONF_DIR/pmlogger/control"
trap "_cleanup" 0 1 2 3 15
_cleanup()
{
if $needclean
then
if [ -s $tmp.pmcd.conf ]
then
$sudo cp $tmp.pmcd.conf $PCP_PMCDCONF_PATH
fi
[ -f $tmp.control ] && \
$sudo cp $tmp.control $PCP_PMLOGGERCONTROL_PATH
needclean=false
$sudo $PCP_RC_DIR/pcp restart | _filter_pcp_start
_wait_for_pmcd
# make sure bogus has gone away
echo
echo "Anything below here may indicate that bogus has not gone away:"
grep bogus $PCP_PMCDCONF_PATH
pminfo -f pmcd.agent | grep bogus
fi
$sudo rm -f $tmp.*
exit $status
}
# real QA test starts here
# disable all pmloggers ...
$sudo cp $PCP_PMLOGGERCONTROL_PATH $tmp.control
cat <<End-of-File >$tmp.tmp
# dummy file created by qa/$seq on `date`
# the goal here is to have a controlled primary logger that does
# not make requests to pmcd!
\$version=1.1
LOCALHOSTNAME y n $PCP_LOG_DIR/pmlogger/LOCALHOSTNAME -c /dev/null
End-of-File
$sudo cp $tmp.tmp $PCP_PMLOGGERCONTROL_PATH
# backup $PCP_PMCDCONF_PATH
$sudo cp $PCP_PMCDCONF_PATH $tmp.pmcd.conf
# add bogus entry
$PCP_AWK_PROG < $PCP_PMCDCONF_PATH > $tmp.pmcd.new -v seq="$seq" -v path="$tmp.bogus.pmda" '
function printline()
{
printf("# Added by QA test %s\n", seq);
printf("bogus 169 pipe binary %s\n", path);
}
BEGIN { flag = 0 }
$1 == "[access]" { printline(); print; flag = 1; next }
{ print }
END { if (flag == 0) printline(); }'
# copy the new config
$sudo cp $tmp.pmcd.new $PCP_PMCDCONF_PATH
# restart pmcd
$sudo $PCP_RC_DIR/pcp restart | _filter_pcp_start
_wait_for_pmcd
# check that pmcd reported the agent as an error
echo
echo "errors for bogus in $PCP_PMCDLOG_PATH:" \
| sed -e"s|$PCP_PMCDLOG_PATH|/var/adm/pcplog/pmcd.log|"
egrep "^pmcd:" $PCP_PMCDLOG_PATH \
| grep bogus \
| sed -e "s#$tmp\.##"
# check that the pmcd.agent.status metric is correct
echo
echo "pmcd agent metrics for bogus:"
pminfo -f pmcd.agent.type | egrep '^pmcd|bogus'
pminfo -f pmcd.agent.status | egrep '^pmcd|bogus'
echo
# success, all done
status=0
exit
|