blob: 02aef1af99c93b87db53b52bce4d73a08b3db54d (
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
|
#! /bin/sh
# PCP QA Test No. 541
# another variant on ...
# #535080 - dynamic indoms for pmie, uses sample.dynamic.*
# this time, the problem is when the intial instance domain contains
# one instance, the pmie expression tree uses the 1:1 operator instead
# of the n:1 operator
#
# Copyright (c) 1995-2002 Silicon Graphics, Inc. All Rights Reserved.
#
seq=`basename $0`
echo "QA output created by $seq"
# get standard environment, filters and checks
. ./common.product
. ./common.filter
. ./common.check
signal=$PCP_BINADM_DIR/pmsignal
status=1 # failure is the default!
control=$PCP_PMDAS_DIR/sample/dynamic.indom
_cleanup()
{
[ -f $control.$seq ] && $sudo mv $control.$seq $control
rm -f $tmp.*
}
$sudo rm -f $control.$seq
trap "_cleanup; exit \$status" 0 1 2 3 15
# real QA test starts here
[ -f $control ] && $sudo mv $control $control.$seq
$sudo $PCP_RC_DIR/pcp restart | _filter_pcp_start
_wait_for_pmcd
_wait_for_pmlogger
# prime the sample PMDA to refresh the dynamic indom
#
pminfo -f sample.dynamic >/dev/null 2>&1
for op in some_inst all_inst
do
echo
echo "=== operator $op ==="
# just one instance
#
cat >$tmp.indom <<End-of-File
0 zero
End-of-File
$sudo rm -f $control
$sudo cp $tmp.indom $control
pmprobe -I sample.dynamic.counter
cat <<End-of-File | pmie -t 250msec >$tmp.out 2>&1 &
$op ( sample.dynamic.counter > 0 ) -> shell "echo counter:" " %i:?";
End-of-File
pid=$!
sleep 3
# replace one instance by two others
#
cat >$tmp.indom <<End-of-File
1 one
2 two
End-of-File
$sudo rm -f $control
$sudo cp $tmp.indom $control
pmprobe -I sample.dynamic.counter
sleep 2
$signal -s TERM $pid
wait
uniq $tmp.out
done
# success, all done
status=0
exit
|