blob: 5ab89f1b93f6176f7aac934da61f33390e202454 (
plain)
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
|
#!/bin/bash -x
#
# test_common.sh
#
# Common routines for tests
#
#
# Environment variables that affect tests:
# KEEP_TEMPDIR If set, the tempdir will not be deleted
# when the test is over.
#
# Clean up the temporary directory
cleanup() {
if [ -n ${TEMPDIR} ]; then
rm -rf "${TEMPDIR}"
fi
}
# Create a temporary directory where test files will be stored.
setup_tempdir() {
TEMPDIR=`mktemp -d`
if [ -z $KEEP_TEMPDIR ]; then
trap cleanup INT TERM EXIT
fi
}
# Standard initialization function for tests
init() {
setup_tempdir
cd `dirname $0`/..
}
# Exit with an error message.
die() {
echo $@
exit 1
}
# Test that flag is set (the element is found in the list)
is_set()
{
local flag=$1; shift
local flags="$@"
local i
for i in ${flags}; do
if [ "${flag}" = "${i}" ]; then
return 0
fi
done
return 1
}
# Stop an OSD started by vstart
stop_osd() {
osd_index=$1
pidfile="out/osd.$osd_index.pid"
if [ -e $pidfile ]; then
if kill `cat $pidfile` ; then
poll_cmd "eval test -e $pidfile ; echo \$?" "1" 1 30
[ $? -eq 1 ] && return 0
echo "ceph-osd process did not terminate correctly"
else
echo "kill `cat $pidfile` failed"
fi
else
echo "ceph-osd process $osd_index is not running"
fi
return 1
}
# Restart an OSD started by vstart
restart_osd() {
osd_index=$1
./ceph-osd -i $osd_index -c ceph.conf &
}
# Ask the user a yes/no question and get the response
yes_or_no_choice() {
while true; do
echo -n "${1} [y/n] "
read ans
case "${ans}" in
y|Y|yes|YES|Yes) return 0 ;;
n|N|no|NO|No) return 1 ;;
*) echo "Please type yes or no."
echo ;;
esac
done
}
# Block until the user says "continue" or "c"
continue_prompt() {
prompt=${1:-"to go on"}
while true; do
echo "Please type 'c' or 'continue' ${prompt}."
read ans
case "${ans}" in
c|continue) return 0 ;;
*) echo ;;
esac
done
}
# Write a bunch of objects to rados
write_objects() {
start_ver=$1
stop_ver=$2
num_objs=$3
obj_size=$4
pool=$5
[ -d "${TEMPDIR}" ] || die "must setup_tempdir"
for v in `seq $start_ver $stop_ver`; do
chr=`perl -e "print chr(48+$v)"`
head -c $obj_size /dev/zero | tr '\0' "$chr" > $TEMPDIR/ver$v
for i in `seq -w 1 $num_objs`; do
./rados -c ./ceph.conf -p $pool put obj$i $TEMPDIR/ver$v || die "radostool failed"
done
done
}
read_objects() {
ver=$1
num_objs=$2
obj_size=$3
[ -d "${TEMPDIR}" ] || die "must setup_tempdir"
chr=`perl -e "print chr(48+$ver)"`
head -c $obj_size /dev/zero | tr '\0' "$chr" > $TEMPDIR/exemplar
for i in `seq -w 1 $num_objs`; do
./rados -c ./ceph.conf -p $pool get obj$i $TEMPDIR/out$i || die "radostool failed"
cmp $TEMPDIR/out$i $TEMPDIR/exemplar || die "got back incorrect obj$i"
done
}
poll_cmd() {
command=$1
search_str=$2
polling_interval=$3
total_time=$4
t=0
while [ $t -lt $total_time ]; do
$command | grep "$search_str"
[ $? -eq 0 ] && return 1
sleep $polling_interval
t=$(($t+$polling_interval))
done
return 0
}
dump_osd_store() {
set +x
echo "dumping osd store..."
find ./dev/osd* -type f | grep obj | grep head$ | sort | while read file; do
echo $file
head -c 10 $file
echo
done
}
start_recovery() {
CEPH_NUM_OSD=$1
osd=0
while [ $osd -lt $CEPH_NUM_OSD ]; do
./ceph -c ./ceph.conf tell osd.$osd debug kick_recovery_wq 0
osd=$((osd+1))
done
}
init
|