File: pfile_corruption.sh

package info (click to toggle)
cssc 1.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 11,368 kB
  • sloc: cpp: 39,446; ansic: 17,403; sh: 11,328; python: 3,923; makefile: 1,929; perl: 342; awk: 15; sed: 15
file content (119 lines) | stat: -rw-r--r-- 4,062 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
#! /bin/sh

# pfile_corruption.sh: Tests relating to p-file corruption

# Import common functions & definitions.
. ../common/test-common
. ../common/real-thing

# Local functions
# Manually create a valid p-file
makep() {
    printf "$1" >| "${p}"
}

check_pfile() {
    options=""
while case "$1" in
	  -*) options="$options $1"; true;;
	  *) false;;
      esac
do
    shift
done

    label="$1"
    pbody="$2"
    sact_retcode="$3"
    expected_stdout_egrep_pattern="$4"
    expected_stderr_egrep_pattern="$5"
    shift 5
    if ! $TESTING_CSSC; then
	# Other implementations have different error messages.
	expected_stderr_egrep_pattern=IGNORE
    fi
    makep "$pbody"
    docommand --stderr_regex --stdout_regex $options "$label" "${vg_sact} $s" $sact_retcode "$expected_stdout_egrep_pattern" "$expected_stderr_egrep_pattern"
}

g=foo
s=s.$g
p=p.$g

remove $s $p $g

echo >| $g

# Create an s-file with a revision 1.1.
docommand setup1 "${vg_admin} -i${g} ${s}" 0 "" IGNORE
# Remove the writable g-file so that get -e won't barf.
remove $g

# Use get to create a valid p-file
docommand setup2 "${vg_get} -e ${s}" 0 IGNORE IGNORE

# Verify that everything seems to work.  Ignore stdout since it will
# contain the date/time at which we ran command setup2, which we can't
# predict.
docommand S1 "${vg_sact} $s" 0 IGNORE ""

# This is the basic success case (without using check_pfile)
docommand S2 "makep '1.1 1.2 james 16/02/28 10:59:47\n'" 0 IGNORE IGNORE
docommand S3 "${vg_sact} $s" 0 '1.1 1.2 james 16/02/28 10:59:47\n' IGNORE

# At this point we know that sact doesn't barf on a valid p-file and
# we can make a valid p-file and use sact to display it.

# This just verifies that check_pfile actually can succeed (with no
# stderr message)
check_pfile  --nostderr_regex S4 '1.1 1.2 james 16/02/28 10:59:47\n' 0 IGNORE ""

# Verify that it's OK for the date in the pfile to be in the past.
# We later rely on this fact in test S9.
check_pfile --nostdout_regex S4a '1.1 1.2 james 15/02/28 10:59:47\n' 0 '1.1 1.2 james 15/02/28 10:59:47\n' IGNORE

# Verify that we detect a missing terminating newline
check_pfile S5 '1.1 1.2 james 16/02/28 10:59:47' 1 IGNORE IGNORE

# Verify that we detect an invalid initial or next SID
check_pfile S6 'x.y 1.2 james 16/02/28 10:59:47\n' 1 IGNORE "SID"
check_pfile S7 '1.1 x.y james 16/02/28 10:59:47\n' 1 IGNORE "SID"

# The username is basically free-format, just make sure it's not missing.
check_pfile S8 '1.1 1.2 16/02/28 10:59:47\n' 1 IGNORE "Expected 5-7 args"

# Invalid date (there are not that many days in February 2015)
check_pfile S9 '1.1 1.2 james 15/02/29 10:59:47\n' 1 IGNORE "Invalid date"

# Valid time, 24 clock
check_pfile --nostdout_regex --nostderr_regex S10 '1.1 1.2 james 16/02/28 23:59:47\n' 0 \
	    '1.1 1.2 james 16/02/28 23:59:47\n' ""

# Invalid times
check_pfile S11 '1.1 1.2 james 16/02/28 25:59:47\n' 1 IGNORE "Invalid date/time"
check_pfile S12 '1.1 1.2 james 16/02/28 23:69:47\n' 1 IGNORE "Invalid date/time"
check_pfile S13 '1.1 1.2 james 16/02/28 23:49:67\n' 1 IGNORE "Invalid date/time"

# Make sure we allow a leap second.
check_pfile  --nostdout_regex --nostderr_regex S14 '1.1 1.2 james 16/02/28 23:59:60\n' 0 \
	     '1.1 1.2 james 16/02/28 23:59:60\n' ""

# Included and excluded deltas
# This test shows that the included/excluded deltas are not printed by sact.
# This follows the current implementation of CSSC, I did not yet cross check
# by running this test against Unix.
check_pfile  --nostdout_regex --nostderr_regex S15 \
	     '1.3 1.4 james 16/02/28 11:55:42 -i1.1-1.2 -x1.3\n' 0 \
	     '1.3 1.4 james 16/02/28 11:55:42\n' ""
# Just included deltas
check_pfile   --nostdout_regex  --nostderr_regex S16 '1.3 1.4 james 16/02/28 11:55:42 -i1.1-1.2\n' 0 IGNORE ""
# Just excluded deltas
check_pfile  --nostderr_regex S17 '1.3 1.4 james 16/02/28 11:55:42 -x1.1-1.2\n' 0 IGNORE ""
# Included and excluded deltas, but in the other order
check_pfile  --nostderr_regex S18 '1.3 1.4 james 16/02/28 11:55:42 -x1.1-1.2 -i1.3\n' 0 IGNORE ""


exit 0

# Cleanup
remove $s $p $g