]> git.proxmox.com Git - ceph.git/blame - ceph/qa/workunits/rbd/rbd-nbd.sh
import ceph nautilus 14.2.2
[ceph.git] / ceph / qa / workunits / rbd / rbd-nbd.sh
CommitLineData
11fdf7f2
TL
1#!/usr/bin/env bash
2set -ex
7c673cae 3
c07f9fc5 4. $(dirname $0)/../../standalone/ceph-helpers.sh
7c673cae
FG
5
6POOL=rbd
11fdf7f2 7NS=ns
7c673cae
FG
8IMAGE=testrbdnbd$$
9SIZE=64
10DATA=
11DEV=
12
13_sudo()
14{
15 local cmd
16
17 if [ `id -u` -eq 0 ]
18 then
19 "$@"
20 return $?
21 fi
22
23 # Look for the command in the user path. If it fails run it as is,
24 # supposing it is in sudo path.
25 cmd=`which $1 2>/dev/null` || cmd=$1
26 shift
27 sudo -nE "${cmd}" "$@"
28}
29
30setup()
31{
11fdf7f2
TL
32 local ns x
33
7c673cae
FG
34 if [ -e CMakeCache.txt ]; then
35 # running under cmake build dir
36
37 CEPH_SRC=$(readlink -f $(dirname $0)/../../../src)
38 CEPH_ROOT=${PWD}
39 CEPH_BIN=${CEPH_ROOT}/bin
40
41 export LD_LIBRARY_PATH=${CEPH_ROOT}/lib:${LD_LIBRARY_PATH}
42 export PYTHONPATH=${PYTHONPATH}:${CEPH_SRC}/pybind
43 for x in ${CEPH_ROOT}/lib/cython_modules/lib* ; do
44 PYTHONPATH="${PYTHONPATH}:${x}"
45 done
46 PATH=${CEPH_BIN}:${PATH}
47 fi
48
49 _sudo echo test sudo
50
51 trap cleanup INT TERM EXIT
52 TEMPDIR=`mktemp -d`
53 DATA=${TEMPDIR}/data
54 dd if=/dev/urandom of=${DATA} bs=1M count=${SIZE}
11fdf7f2
TL
55
56 rbd namespace create ${POOL}/${NS}
57
58 for ns in '' ${NS}; do
59 rbd --dest-pool ${POOL} --dest-namespace "${ns}" --no-progress import \
60 ${DATA} ${IMAGE}
61 done
7c673cae
FG
62}
63
64function cleanup()
65{
11fdf7f2
TL
66 local ns s
67
7c673cae 68 set +e
11fdf7f2 69 rm -Rf ${TEMPDIR}
7c673cae
FG
70 if [ -n "${DEV}" ]
71 then
72 _sudo rbd-nbd unmap ${DEV}
73 fi
11fdf7f2
TL
74
75 for ns in '' ${NS}; do
76 if rbd -p ${POOL} --namespace "${ns}" status ${IMAGE} 2>/dev/null; then
77 for s in 0.5 1 2 4 8 16 32; do
78 sleep $s
79 rbd -p ${POOL} --namespace "${ns}" status ${IMAGE} |
80 grep 'Watchers: none' && break
81 done
82 rbd -p ${POOL} --namespace "${ns}" snap purge ${IMAGE}
83 rbd -p ${POOL} --namespace "${ns}" remove ${IMAGE}
84 fi
85 done
86 rbd namespace remove ${POOL}/${NS}
7c673cae
FG
87}
88
89function expect_false()
90{
91 if "$@"; then return 1; else return 0; fi
92}
93
11fdf7f2
TL
94function get_pid()
95{
96 local ns=$1
97
98 PID=$(rbd-nbd --format xml list-mapped | $XMLSTARLET sel -t -v \
99 "//devices/device[pool='${POOL}'][namespace='${ns}'][image='${IMAGE}'][device='${DEV}']/id")
100 test -n "${PID}"
101 ps -p ${PID} -o cmd | grep rbd-nbd
102}
103
81eedcae
TL
104unmap_device()
105{
106 local unmap_dev=$1
107 local list_dev=$2
108 _sudo rbd-nbd unmap ${unmap_dev}
109
110 for s in 0.5 1 2 4 8 16 32; do
111 sleep ${s}
112 rbd-nbd list-mapped | expect_false grep "${list_dev} $" && return 0
113 done
114 return 1
115}
116
7c673cae
FG
117#
118# main
119#
120
121setup
122
123# exit status test
124expect_false rbd-nbd
125expect_false rbd-nbd INVALIDCMD
126if [ `id -u` -ne 0 ]
127then
128 expect_false rbd-nbd map ${IMAGE}
129fi
130expect_false _sudo rbd-nbd map INVALIDIMAGE
131expect_false _sudo rbd-nbd --device INVALIDDEV map ${IMAGE}
132
11fdf7f2
TL
133# list format test
134expect_false rbd-nbd --format INVALID list-mapped
135rbd-nbd --format json --pretty-format list-mapped
136rbd-nbd --format xml list-mapped
137
7c673cae
FG
138# map test using the first unused device
139DEV=`_sudo rbd-nbd map ${POOL}/${IMAGE}`
11fdf7f2 140get_pid
7c673cae
FG
141# map test specifying the device
142expect_false _sudo rbd-nbd --device ${DEV} map ${POOL}/${IMAGE}
143dev1=${DEV}
81eedcae 144unmap_device ${DEV} ${DEV}
7c673cae
FG
145DEV=
146# XXX: race possible when the device is reused by other process
147DEV=`_sudo rbd-nbd --device ${dev1} map ${POOL}/${IMAGE}`
148[ "${DEV}" = "${dev1}" ]
31f18b77 149rbd-nbd list-mapped | grep "${IMAGE}"
11fdf7f2 150get_pid
7c673cae
FG
151
152# read test
153[ "`dd if=${DATA} bs=1M | md5sum`" = "`_sudo dd if=${DEV} bs=1M | md5sum`" ]
154
155# write test
156dd if=/dev/urandom of=${DATA} bs=1M count=${SIZE}
157_sudo dd if=${DATA} of=${DEV} bs=1M oflag=direct
158[ "`dd if=${DATA} bs=1M | md5sum`" = "`rbd -p ${POOL} --no-progress export ${IMAGE} - | md5sum`" ]
159
160# trim test
161provisioned=`rbd -p ${POOL} --format xml du ${IMAGE} |
162 $XMLSTARLET sel -t -m "//stats/images/image/provisioned_size" -v .`
163used=`rbd -p ${POOL} --format xml du ${IMAGE} |
164 $XMLSTARLET sel -t -m "//stats/images/image/used_size" -v .`
165[ "${used}" -eq "${provisioned}" ]
166_sudo mkfs.ext4 -E discard ${DEV} # better idea?
167sync
168provisioned=`rbd -p ${POOL} --format xml du ${IMAGE} |
169 $XMLSTARLET sel -t -m "//stats/images/image/provisioned_size" -v .`
170used=`rbd -p ${POOL} --format xml du ${IMAGE} |
171 $XMLSTARLET sel -t -m "//stats/images/image/used_size" -v .`
172[ "${used}" -lt "${provisioned}" ]
173
174# resize test
175devname=$(basename ${DEV})
176blocks=$(awk -v dev=${devname} '$4 == dev {print $3}' /proc/partitions)
177test -n "${blocks}"
178rbd resize ${POOL}/${IMAGE} --size $((SIZE * 2))M
179rbd info ${POOL}/${IMAGE}
180blocks2=$(awk -v dev=${devname} '$4 == dev {print $3}' /proc/partitions)
181test -n "${blocks2}"
182test ${blocks2} -eq $((blocks * 2))
183rbd resize ${POOL}/${IMAGE} --allow-shrink --size ${SIZE}M
184blocks2=$(awk -v dev=${devname} '$4 == dev {print $3}' /proc/partitions)
185test -n "${blocks2}"
186test ${blocks2} -eq ${blocks}
187
188# read-only option test
189_sudo rbd-nbd unmap ${DEV}
190DEV=`_sudo rbd-nbd map --read-only ${POOL}/${IMAGE}`
31f18b77
FG
191PID=$(rbd-nbd list-mapped | awk -v pool=${POOL} -v img=${IMAGE} -v dev=${DEV} \
192 '$2 == pool && $3 == img && $5 == dev {print $1}')
193test -n "${PID}"
194ps -p ${PID} -o cmd | grep rbd-nbd
195
7c673cae
FG
196_sudo dd if=${DEV} of=/dev/null bs=1M
197expect_false _sudo dd if=${DATA} of=${DEV} bs=1M oflag=direct
198_sudo rbd-nbd unmap ${DEV}
199
200# exclusive option test
201DEV=`_sudo rbd-nbd map --exclusive ${POOL}/${IMAGE}`
11fdf7f2 202get_pid
31f18b77 203
7c673cae
FG
204_sudo dd if=${DATA} of=${DEV} bs=1M oflag=direct
205expect_false timeout 10 \
206 rbd bench ${IMAGE} --io-type write --io-size=1024 --io-total=1024
207_sudo rbd-nbd unmap ${DEV}
11fdf7f2
TL
208DEV=
209rbd bench ${IMAGE} --io-type write --io-size=1024 --io-total=1024
210
211# unmap by image name test
212DEV=`_sudo rbd-nbd map ${POOL}/${IMAGE}`
213get_pid
214_sudo rbd-nbd unmap "${IMAGE}"
215rbd-nbd list-mapped | expect_false grep "${DEV} $"
216DEV=
217ps -p ${PID} -o cmd | expect_false grep rbd-nbd
218
219# map/unmap snap test
220rbd snap create ${POOL}/${IMAGE}@snap
221DEV=`_sudo rbd-nbd map ${POOL}/${IMAGE}@snap`
222get_pid
81eedcae 223unmap_device "${IMAGE}@snap" ${DEV}
11fdf7f2
TL
224DEV=
225ps -p ${PID} -o cmd | expect_false grep rbd-nbd
226
227# map/unmap namespace test
228rbd snap create ${POOL}/${NS}/${IMAGE}@snap
229DEV=`_sudo rbd-nbd map ${POOL}/${NS}/${IMAGE}@snap`
230get_pid ${NS}
81eedcae 231unmap_device "${POOL}/${NS}/${IMAGE}@snap" ${DEV}
11fdf7f2
TL
232DEV=
233ps -p ${PID} -o cmd | expect_false grep rbd-nbd
31f18b77
FG
234
235# auto unmap test
236DEV=`_sudo rbd-nbd map ${POOL}/${IMAGE}`
11fdf7f2 237get_pid
31f18b77
FG
238_sudo kill ${PID}
239for i in `seq 10`; do
240 rbd-nbd list-mapped | expect_false grep "^${PID} *${POOL} *${IMAGE}" && break
241 sleep 1
242done
243rbd-nbd list-mapped | expect_false grep "^${PID} *${POOL} *${IMAGE}"
244
7c673cae 245echo OK