File: 110

package info (click to toggle)
pcp 7.1.0-1
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 252,748 kB
  • sloc: ansic: 1,483,656; sh: 182,366; xml: 160,462; cpp: 83,813; python: 24,980; perl: 18,327; yacc: 6,877; lex: 2,864; makefile: 2,738; awk: 165; fortran: 60; java: 52
file content (260 lines) | stat: -rwxr-xr-x 5,214 bytes parent folder | download
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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
#! /bin/sh
# PCP QA Test No. 110
# check out simple PMDA
#
# 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

signal=$PCP_BINADM_DIR/pmsignal
status=1

ROOT_LOG_PATH=`echo $PCP_PMCDLOG_PATH | sed -e 's/pmcd.log/root.log/'`
PMDA_LOG_PATH=`echo $PCP_PMCDLOG_PATH | sed -e 's/pmcd.log/simple.log/'`

_cleanup()
{
	[ -f $home/$iam/$iam.conf.$seq ] && _restore_config $home/$iam/$iam.conf
	if diff $PCP_PMCDCONF_PATH.$seq $PCP_PMCDCONF_PATH > /dev/null 2>&1
	then
	    _restore_config $PCP_PMCDCONF_PATH
	else

# do a default install which ensures the pmns and any views are installed

	    $sudo ./Install < /dev/null > /dev/null 2>&1

# PMDA may have been installed differently to default. As everything is
# installed we can use the old pmcd.conf file to restore state.

	    if diff $PCP_PMCDCONF_PATH.$seq $PCP_PMCDCONF_PATH > /dev/null 2>&1
	    then
	    	_restore_config $PCP_PMCDCONF_PATH
	    else
	    	_restore_config $PCP_PMCDCONF_PATH
		$sudo $signal -a -s HUP pmcd
	    fi
	fi

	_service pmlogger start >>$seq_full
	_wait_for_pmlogger

	$sudo rm -f $tmp.*
	exit $status
}

trap "_cleanup" 0 1 2 3 15

_failed()
{
    echo
    echo "... failed! ... here is the Install log ..."
    cat $tmp.out
    echo
    echo "... and the tail of the pmcd log ..."
    tail -20 $PCP_PMCDLOG_PATH
    echo
    echo "... and the root PMDA log ..."
    cat $ROOT_LOG_PATH
    echo
    echo "...and the PMDA log ..."
    cat $PMDA_LOG_PATH
}

_filter()
{
    _filter_pmda_install | \
    sed \
	-e 's/ or perl//' \
	-e 's/ or python//' \
	-e "s;$tmp;TMP;" \
	-e "s/$port1/PORT1/" \
	-e "s/$port2/PORT2/"
}

_full()
{
    echo "--- pmcd.conf ---" >>$seq_full
    cat $PCP_PMCDCONF_PATH >>$seq_full
    echo "--- pmcd.log ---" >>$seq_full
    cat $PCP_PMCDLOG_PATH >>$seq_full
    echo "--- root.log ---" >>$seq_full
    if [ -f $ROOT_LOG_PATH ]
    then
	cat $ROOT_LOG_PATH >>$seq_full
    else
	echo "$ROOT_LOG_PATH: file not found" >>$seq_full
    fi
    echo "--- simple.log ---" >>$seq_full
    if [ -f $PMDA_LOG_PATH ]
    then
	cat $PMDA_LOG_PATH >>$seq_full
    else
	echo "$PMDA_LOG_PATH: file not found" >>$seq_full
    fi
    echo >>$seq_full
}


# pmlogger may get confused by pmcd reconfig ... safest to stop it
# first, and restart it in cleanup()
#
if ! _service pmlogger stop >>$seq_full; then _exit 1; fi

# real QA test starts here
home=$PCP_PMDAS_DIR
iam=simple
if [ ! -d $home/$iam ]
then
    echo "Where is $home/$iam?"
    exit 1
fi
cd $home/$iam
unset ROOT MAKEFLAGS

# copy the pmcd config file to restore state later.
_save_config $PCP_PMCDCONF_PATH
# ditto for simple pmda config
[ -f $home/$iam/$iam.conf ] && _save_config $home/$iam/$iam.conf

if $sudo $PCP_MAKE_PROG clobber >$tmp.out 2>&1
then
    :
else
    cat $tmp.out
    echo "Arrgh, make clobber failed"
    exit
fi

# start from a known starting point
$sudo ./Remove >/dev/null 2>&1

echo
echo "=== pipe daemon agent ==="
echo "=== pipe daemon agent ===" >>$seq_full
$sudo ./Remove >$tmp.out 2>&1
$sudo rm -f $PMDA_LOG_PATH
echo 'daemon
pipe' | $sudo ./Install -e >>$tmp.out 2>&1
_full

_filter <$tmp.out

if pminfo -v simple
then
    :
else
    _failed
fi

# give the PMDA + socket a chance to be setup before pminfo check
PCPQA_CHECK_DELAY=3; export PCPQA_CHECK_DELAY

echo
echo "=== Unix socket daemon agent ==="
echo "=== Unix socket daemon agent ===" >>$seq_full
$sudo ./Remove >$tmp.out 2>&1
echo 'daemon
socket
Unix
'"$tmp.fifo-1" | $sudo ./Install -e >>$tmp.out 2>&1
echo "+++ fifo-1 PMDA log +++" >>$seq_full
if [ -f $PMDA_LOG_PATH ]
then
    cat $PMDA_LOG_PATH >>$seq_full
else
    echo "$PMDA_LOG_PATH: file not found" >>$seq_full
fi
ls -ld "$tmp.fifo-1" `dirname "$tmp.fifo-1"` >>$seq_full
$sudo rm -f $PMDA_LOG_PATH
echo 'daemon
socket
Unix
'"$tmp.fifo-2" | $sudo ./Install -e >>$tmp.out 2>&1
echo "+++ fifo-2 PMDA log +++" >>$seq_full
if [ -f $PMDA_LOG_PATH ]
then
    cat $PMDA_LOG_PATH >>$seq_full
else
    echo "$PMDA_LOG_PATH: file not found" >>$seq_full
fi
ls -ld "$tmp.fifo-2" `dirname "$tmp.fifo-2"` >>$seq_full
_full

_filter <$tmp.out

if pminfo -v simple
then
    :
else
    _failed
fi

echo
echo "=== Internet socket daemon agent ==="
echo "=== Internet socket daemon agent ===" >>$seq_full
$sudo ./Remove >$tmp.out 2>&1

# pick a tcp port that is not in use
#
port1=`_get_port tcp 5650 5699`
if [ -z "$port1" ]
then
    echo "Arrgh ... no free TCP port in the range 5650 ... 5699"
    exit 1
fi

echo 'daemon
socket
Internet
'$port1 | $sudo ./Install -e >>$tmp.out 2>&1

# use next port this time
port2=`expr $port1 + 1`

$sudo rm -f $PMDA_LOG_PATH
echo 'daemon
socket
Internet
'$port2 | $sudo ./Install -e >>$tmp.out 2>&1
_full

_filter <$tmp.out

if pminfo -v simple
then
    :
else
    _failed
fi

echo
echo "=== dso agent ==="
echo "=== dso agent ===" >>$seq_full
$sudo ./Remove >$tmp.out 2>&1
echo dso | $sudo ./Install -e >>$tmp.out 2>&1
$sudo rm -f $PMDA_LOG_PATH
echo dso | $sudo ./Install -e >>$tmp.out 2>&1
_full

_filter <$tmp.out

if pminfo -v simple
then
    :
else
    _failed
fi

$sudo ./Remove >$tmp.out 2>&1
_filter <$tmp.out

status=0
exit