File: 699

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 (105 lines) | stat: -rwxr-xr-x 2,131 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
#!/bin/sh
# PCP QA Test No. 699
# pmlogrewrite clobbers existing output file?
#
# Copyright (c) 2018 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.*
}

_filter()
{
    sed -n \
	-e "s@$tmp@TMP@g" \
	-e "s@,v[2|3]@@g" \
	-e '/Error/p ' \
	-e '/already exists/p' \
    # end
}

_filter_pminfo()
{
    sed \
	-e "s@$tmp@TMP@g" \
    # end
}

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

for suff in 0 1 2 index meta
do
    cp tmparch/mv-foo.$suff $tmp.in.$suff
    cp tmparch/mv-foo.$suff $tmp.out.$suff
done

echo 'metric sample.seconds { type -> 64 }' >$tmp.config

# real QA test starts here

echo "=== output archive exists, case ===" | tee -a $seq_full

echo "--- check archives before ---"
pmlogcheck $tmp.in
pminfo -d sample.seconds -a $tmp.in
pmlogcheck $tmp.out
pminfo -d sample.seconds -a $tmp.out

echo "--- pmlogrewrite, expect failure ---"
pmlogrewrite -Dlog -c $tmp.config $tmp.in $tmp.out 2>$tmp.err
cat $tmp.err | tee -a $seq_full | _filter

echo "--- check archives after ---"
pmlogcheck $tmp.in
pminfo -d sample.seconds -a $tmp.in
pmlogcheck $tmp.out 2>&1 \
| sed -e "s@$tmp@TMP@g"
pminfo -d sample.seconds -a $tmp.out

for suff in meta index 0 1 2
do
    echo | tee -a $seq_full
    echo "=== removed output archive .$suff file ===" | tee -a $seq_full
    rm -f $tmp.out.$suff

    echo "--- pmlogrewrite, expect failure ---"
    pmlogrewrite -Dlog -c $tmp.config $tmp.in $tmp.out 2>$tmp.err
    cat $tmp.err | tee -a $seq_full | _filter

    echo "--- check archives after ---"
    pminfo -d sample.seconds -a $tmp.in
    pminfo -d sample.seconds -a $tmp.out 2>&1 | _filter_pminfo

    for x in meta index 0 1 2
    do
	if [ -f $tmp.out.$x ]
	then
	    if cmp $tmp.in.$x $tmp.out.$x >/dev/null 2>&1
	    then
		echo "TMP.out.$x: no change"
	    else
		echo "TMP.out.$x: different"
	    fi
	else
	    echo "TMP.out.$x: absent"
	fi
    done

done


# success, all done
status=0
exit