File: 960

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 (124 lines) | stat: -rwxr-xr-x 3,277 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
#!/bin/sh
# PCP QA Test No. 960
# Exercise ds389 log parsing PMDA.
#
# Copyright (c) 2014 Red Hat.
#

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

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

[ -d $PCP_PMDAS_DIR/ds389log ] || _notrun "ds389log PMDA directory is not installed"

which logconv.pl >/dev/null 2>&1 || _notrun "No logconv.pl script installed"
$sudo ls /var/log/dirsrv/slapd-*/access 2>&1 >/dev/null || \
    _notrun "No ds389 directory log files accessible"
id dirsrv >/dev/null 2>&1 || _notrun "No dirsrv (default) account installed"

status=1	# failure is the default!

pmdads389log_remove()
{
    echo
    echo "=== remove ds389log agent ==="
    $sudo ./Remove >$tmp.out 2>&1
    _filter_pmda_remove <$tmp.out
}

pmdads389log_install()
{
    # start from known starting points
    cd $PCP_PMDAS_DIR/ds389log
    $sudo ./Remove >/dev/null 2>&1
    if ! _service pmcd stop; then _exit 1; fi

    cat <<EOF >$tmp.config
\$server = '$server';
\$bindpw = '$passwd';
EOF
    echo "pmdads389log config:" >> $seq_full
    cat $tmp.config >> $seq_full

    [ -f $PCP_PMDAS_DIR/ds389log/ds389log.conf ] && \
    $sudo cp $PCP_PMDAS_DIR/ds389log/ds389log.conf $tmp.backup
    $sudo cp $tmp.config $PCP_PMDAS_DIR/ds389log/ds389log.conf

    echo
    echo "=== ds389log agent installation ==="
    $sudo ./Install </dev/null >$tmp.out 2>&1
    # Check metrics have appeared ... W warnings, N metrics and V values
    # (expecting warnings from the not-supported-in-this-version metrics)
    _filter_pmda_install <$tmp.out \
    | sed \
        -e '/^Waiting for pmcd/s/\.\.\.[. ]*$/DOTS/' \
    | $PCP_AWK_PROG '
/Check ds389log metrics have appeared/ { if ($7 >= 0 && $7 <= 50) $7 = "N"
                                         if ($10 >= 10 && $10 <= 50) $10 = "X"
                                       }
                                       { print }'
    echo Install: >> $seq_full
    cat $tmp.out >> $seq_full
    echo Logfile: >> $seq_full
    cat $PCP_LOG_DIR/pmcd/ds389log.log >> $seq_full
}

pmdads389log_cleanup()
{
    if [ -f $tmp.access ]; then
        $sudo rm -fr /var/log/dirsrv
    fi
    if [ -f $tmp.backup ]; then
        $sudo cp $tmp.backup $PCP_PMDAS_DIR/ds389log/ds389log.conf
        $sudo rm $tmp.backup
    else
        $sudo rm -f $PCP_PMDAS_DIR/ds389log/ds389log.conf
    fi
    # note: _restore_auto_restart pmcd done in _cleanup_pmda()
    _cleanup_pmda ds389log
}

_prepare_pmda ds389log
trap "pmdads389log_cleanup; exit \$status" 0 1 2 3 15

_stop_auto_restart pmcd

_filter()
{
    # squash "not supported" warnings, turn values into VALUE
    LC_COLLATE=POSIX sort -n | \
    sed \
	-e 's/ 1 [0-9][0-9]*$/ 1 VALUE/g' \
    # end
}

# If there's a local ds390 install, use its access log.
# Else use the canned file included in the testsuite.
#
_prepare_ds389_log()
{
    if [ ! -d /var/log/dirsrv ]
    then
	touch $tmp.access
	dslog=/var/log/dirsrv/slapd-`hostname`
	$sudo mkdir -p "$dslog"
	$sudo cp $here/archives/ds390-access.gz "$dslog"
    fi
}

# real QA test starts here
_prepare_ds389_log
pmdads389log_install

echo
echo "=== extract metric values ==="
pmprobe -v ds389log 2>&1 | tee -a $seq_full | _filter

pmdads389log_remove
# success, all done
status=0
exit