File: 1097

package info (click to toggle)
pcp 7.0.5-1
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 252,916 kB
  • sloc: ansic: 1,478,844; sh: 177,285; xml: 160,462; cpp: 83,809; python: 24,349; perl: 18,303; yacc: 6,877; lex: 2,864; makefile: 2,694; awk: 165; fortran: 60; java: 52
file content (118 lines) | stat: -rwxr-xr-x 2,575 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
#!/bin/sh
# PCP QA Test No. 1097
# Checkout new pmlogconf -a flag to be used to cull missing
# templates when operating on a "Auto-generated" config file
# from pmlogger_check
#
# Copyright (c) 2017 Ken McDonell.  All Rights Reserved.
#

seq=`basename $0`
echo "QA output created by $seq"

# get standard environment, filters and checks
. ./common.product
. ./common.filter
. ./common.check

_cleanup()
{
    cd $here
    $sudo rm -rf $tmp $tmp.*
}

status=1	# failure is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15

_filter()
{
    sed \
	-e "s@$PCP_BINADM_DIR@PCP_BINADM_DIR@g" \
	-e "s@$PCP_VAR_DIR@PCP_VAR_DIR@g" \
    # end
}

_report_tags()
{
    file=$1

    [ -f "$file" ] || echo "File $file is not regular?"
    miatags="mia/kermit mia/gonzo mia/fozzie mia/red mia/green mia/blue"
    reallymiatags="reallymia/terry reallymia/cathy reallymia/emma"
    for tag in $miatags $reallymiatags
    do
	echo checking tag $tag | tee -a $seq_full
	pmlogconf -q -g $tag $file 2>> $seq_full
    done
}

rm -f $tmp.tmp
pmlogconf -q $tmp.tmp >>$seq_full </dev/null 2>&1

$PCP_AWK_PROG <$tmp.tmp '
BEGIN					{ state = 0 }
state == 2 && /DO NOT UPDATE/		{ state = 3 }
					{ outf = "'$tmp'." state; print >outf }
state == 0 && /\+ groupdir /		{ state = 1 }
state == 1 && NR > 100 && /^#----/	{ state = 2 }'
cat $tmp.0 >$tmp.base
cat <<'End-of-File' >>$tmp.base
#
#+ mia/kermit:y:default:
log mandatory on default {
    mia.kermit
}
#---- 1
#+ mia/gonzo:x::
#---- 2
#+ mia/fozzie:n::
#---- 3
End-of-File
cat $tmp.1 >>$tmp.base
cat <<'End-of-File' >>$tmp.base
#+ mia/red:x::
#---- 4
#+ mia/green:y:once:
log advisory on once {
    mia.green
}
#---- 5
#+ mia/blue:n::
#---- 6
End-of-File
cat $tmp.2 >>$tmp.base
cat <<'End-of-File' >>$tmp.base
#+ reallymia/terry:x::
#---- 7
#+ reallymia/cathy:n::
#---- 8
#+ reallymia/emma:y:1 hour:
log mandatory on 1 hour {
    reallymia.emma
}
#---- 9
End-of-File
cat $tmp.3 >>$tmp.base

# real QA test starts here
echo "default behaviour ... "
cp $tmp.base $tmp.in
pmlogconf -r -q $tmp.in </dev/null 2>$tmp.err >>$seq_full
_filter <$tmp.err
# expect no differences, but groups are now sorted (so cant use diff)
# instead use the --group option to pmlogconf to verify group exists.
# diff $tmp.base $tmp.in
_report_tags $tmp.in

echo
echo "new behaviour with -c ..."
cp $tmp.base $tmp.in
pmlogconf -r -c -q $tmp.in </dev/null 2>$tmp.err >>$seq_full
_filter <$tmp.err
echo "expect mia and reallymia templates to be gone"
#diff $tmp.base $tmp.in | sed -e '/^[0-9]/s/[0-9][0-9]*/N/g'
_report_tags $tmp.in

# success, all done
status=0
exit