File: 1453

package info (click to toggle)
pcp 7.1.0-1
  • links: PTS
  • area: main
  • in suites: forky
  • 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 (125 lines) | stat: -rwxr-xr-x 3,006 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
#!/bin/sh
# PCP QA Test No. 1453
# pmie_check creates pmie.log.YYYYMMDD with wrong ownership
# - if it is root this is a bug, should be pcp
#
# related to https://bugzilla.redhat.com/show_bug.cgi?id=1832262
# (the Jun 2023 discussion at the end of the bug, not the
# earlier discussion circo 2020)
#
# Copyright (c) 2023 Ken McDonell.  All Rights Reserved.
#

if [ $# -eq 0 ]
then
    seq=`basename $0`
    echo "QA output created by $seq"
else
    # use $seq from caller, unless not set
    [ -n "$seq" ] || seq=`basename $0`
    echo "QA output created by `basename $0` $*"
fi

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

[ -d $PCP_LOG_DIR/pmie/`hostname` ] || _notrun "$PCP_LOG_DIR/pmie/`hostname` dir not found"

# same datestamp as pmie_check
#
today=`pmdate %Y%m%d`


pmie_was_running=false
[ -f $PCP_RUN_DIR/pmie.pid ] && pmie_was_running=true

_cleanup()
{
    [ -f pmie.log.$seq ] && $sudo mv pmie.log.$seq pmie.log
    [ -f pmie.log.$today.$seq ] && $sudo mv pmie.log.$today.$seq pmie.log.$today
    cd $here
    $sudo rm -rf $tmp $tmp.*

    if $pmie_was_running
    then
	_service pmie start >>$seq_full 2>&1
    else
	_service pmie stop >>$seq_full 2>&1
	$sudo $PCP_BINADM_DIR/pmsignal -a -s TERM pmie >>$seq_full 2>&1
	_wait_pmie_end
    fi
}

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

_filter()
{
    sed \
	-e 's/<something>/<else>/' \
    # end
}

if $pmie_was_running
then
    if ! _service pmie stop >>$seq_full 2>&1; then _exit 1; fi
fi

cd $PCP_LOG_DIR/pmie/`hostname`

# setup for the test ...
# - need a pmie.log in place (move any existing one aside)
# - must not have a today's pmie.log.YYYYMMDD (move any existing one
#   aside)
#
[ -f pmie.log ] && $sudo mv pmie.log pmie.log.$seq
[ -f pmie.log.$today ] && $sudo mv pmie.log.$today pmie.log.$today.$seq
cat <<End-of-File >$tmp.log
Log for pmie on bozo.localdomain started Sat Jun 10 07:39:02 2023

pmie: PID = 3140736, via local: [primary]

babble from QA $seq
End-of-File
$sudo cp $tmp.log pmie.log
$sudo chown $PCP_USER:$PCP_GROUP pmie.log

# real QA test starts here
echo "--- before ---" >>$seq_full
ls -li >>$seq_full

if ! _service pmie start 2>&1; then _exit 1; fi \
| tee -a $seq_full \
| _filter_pmie_start

echo "--- after ---" >>$seq_full
ls -li >>$seq_full

if [ -f pmie.log.$today ]
then
    echo "pmie.log.TODAY created"
    owner=`ls -l pmie.log.$today | $PCP_AWK_PROG 'NR == 1 {print $3}'`
    if [ "$owner" = "$PCP_USER" ]
    then
	echo "pmie.log.TODAY owner is PCP_USER"
    else
	echo "Botch: pmie.log.TODAY owner is $owner not $PCP_USER"
	ls -l pmie.log.$today
    fi
    group=`ls -l pmie.log.$today | $PCP_AWK_PROG 'NR == 1 {print $4}'`
    if [ "$group" = "$PCP_GROUP" ]
    then
	echo "pmie.log.TODAY group is PCP_GROUP"
    else
	echo "Botch: pmie.log.TODAY group is $group not $PCP_GROUP"
	ls -l pmie.log.$today
    fi
else
    echo "Botch: pmie.log.TODAY not created"
    ls -l
fi

# success, all done
exit