]> git.proxmox.com Git - ceph.git/blame - ceph/qa/workunits/rbd/rbd-nbd.sh
bump version to 18.2.2-pve1
[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
522d829b 7ANOTHER_POOL=new_default_pool$$
11fdf7f2 8NS=ns
7c673cae
FG
9IMAGE=testrbdnbd$$
10SIZE=64
11DATA=
12DEV=
13
14_sudo()
15{
16 local cmd
17
18 if [ `id -u` -eq 0 ]
19 then
20 "$@"
21 return $?
22 fi
23
24 # Look for the command in the user path. If it fails run it as is,
25 # supposing it is in sudo path.
26 cmd=`which $1 2>/dev/null` || cmd=$1
27 shift
28 sudo -nE "${cmd}" "$@"
29}
30
31setup()
32{
11fdf7f2
TL
33 local ns x
34
7c673cae
FG
35 if [ -e CMakeCache.txt ]; then
36 # running under cmake build dir
37
38 CEPH_SRC=$(readlink -f $(dirname $0)/../../../src)
39 CEPH_ROOT=${PWD}
40 CEPH_BIN=${CEPH_ROOT}/bin
41
42 export LD_LIBRARY_PATH=${CEPH_ROOT}/lib:${LD_LIBRARY_PATH}
9f95a23c 43 export PYTHONPATH=${PYTHONPATH}:${CEPH_SRC}/pybind:${CEPH_ROOT}/lib/cython_modules/lib.3
7c673cae
FG
44 PATH=${CEPH_BIN}:${PATH}
45 fi
46
47 _sudo echo test sudo
48
49 trap cleanup INT TERM EXIT
50 TEMPDIR=`mktemp -d`
51 DATA=${TEMPDIR}/data
52 dd if=/dev/urandom of=${DATA} bs=1M count=${SIZE}
11fdf7f2
TL
53
54 rbd namespace create ${POOL}/${NS}
55
56 for ns in '' ${NS}; do
57 rbd --dest-pool ${POOL} --dest-namespace "${ns}" --no-progress import \
58 ${DATA} ${IMAGE}
59 done
522d829b
TL
60
61 # create another pool
62 ceph osd pool create ${ANOTHER_POOL} 8
63 rbd pool init ${ANOTHER_POOL}
7c673cae
FG
64}
65
66function cleanup()
67{
11fdf7f2
TL
68 local ns s
69
7c673cae 70 set +e
f67539c2
TL
71
72 mount | fgrep ${TEMPDIR}/mnt && _sudo umount -f ${TEMPDIR}/mnt
73
11fdf7f2 74 rm -Rf ${TEMPDIR}
7c673cae
FG
75 if [ -n "${DEV}" ]
76 then
522d829b 77 _sudo rbd device --device-type nbd unmap ${DEV}
7c673cae 78 fi
11fdf7f2
TL
79
80 for ns in '' ${NS}; do
81 if rbd -p ${POOL} --namespace "${ns}" status ${IMAGE} 2>/dev/null; then
82 for s in 0.5 1 2 4 8 16 32; do
83 sleep $s
84 rbd -p ${POOL} --namespace "${ns}" status ${IMAGE} |
85 grep 'Watchers: none' && break
86 done
87 rbd -p ${POOL} --namespace "${ns}" snap purge ${IMAGE}
88 rbd -p ${POOL} --namespace "${ns}" remove ${IMAGE}
89 fi
90 done
91 rbd namespace remove ${POOL}/${NS}
522d829b
TL
92
93 # cleanup/reset default pool
94 rbd config global rm global rbd_default_pool
95 ceph osd pool delete ${ANOTHER_POOL} ${ANOTHER_POOL} --yes-i-really-really-mean-it
7c673cae
FG
96}
97
98function expect_false()
99{
100 if "$@"; then return 1; else return 0; fi
101}
102
11fdf7f2
TL
103function get_pid()
104{
522d829b
TL
105 local pool=$1
106 local ns=$2
11fdf7f2 107
522d829b
TL
108 PID=$(rbd device --device-type nbd --format xml list | $XMLSTARLET sel -t -v \
109 "//devices/device[pool='${pool}'][namespace='${ns}'][image='${IMAGE}'][device='${DEV}']/id")
f67539c2 110 test -n "${PID}" || return 1
f91f0fd5 111 ps -p ${PID} -C rbd-nbd
11fdf7f2
TL
112}
113
81eedcae
TL
114unmap_device()
115{
39ae355f 116 local args=$1
f91f0fd5 117 local pid=$2
f67539c2 118
39ae355f 119 _sudo rbd device --device-type nbd unmap ${args}
522d829b 120 rbd device --device-type nbd list | expect_false grep "^${pid}\\b" || return 1
f67539c2 121 ps -C rbd-nbd | expect_false grep "^ *${pid}\\b" || return 1
81eedcae 122
f67539c2
TL
123 # workaround possible race between unmap and following map
124 sleep 0.5
81eedcae
TL
125}
126
7c673cae
FG
127#
128# main
129#
130
131setup
132
133# exit status test
134expect_false rbd-nbd
135expect_false rbd-nbd INVALIDCMD
136if [ `id -u` -ne 0 ]
137then
522d829b 138 expect_false rbd device --device-type nbd map ${IMAGE}
7c673cae 139fi
522d829b 140expect_false _sudo rbd device --device-type nbd map INVALIDIMAGE
7c673cae
FG
141expect_false _sudo rbd-nbd --device INVALIDDEV map ${IMAGE}
142
11fdf7f2 143# list format test
522d829b
TL
144expect_false rbd device --device-type nbd --format INVALID list
145rbd device --device-type nbd --format json --pretty-format list
146rbd device --device-type nbd --format xml list
11fdf7f2 147
7c673cae 148# map test using the first unused device
522d829b
TL
149DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
150get_pid ${POOL}
7c673cae
FG
151# map test specifying the device
152expect_false _sudo rbd-nbd --device ${DEV} map ${POOL}/${IMAGE}
153dev1=${DEV}
f91f0fd5 154unmap_device ${DEV} ${PID}
7c673cae
FG
155DEV=
156# XXX: race possible when the device is reused by other process
157DEV=`_sudo rbd-nbd --device ${dev1} map ${POOL}/${IMAGE}`
158[ "${DEV}" = "${dev1}" ]
522d829b
TL
159rbd device --device-type nbd list | grep "${IMAGE}"
160get_pid ${POOL}
7c673cae
FG
161
162# read test
163[ "`dd if=${DATA} bs=1M | md5sum`" = "`_sudo dd if=${DEV} bs=1M | md5sum`" ]
164
165# write test
166dd if=/dev/urandom of=${DATA} bs=1M count=${SIZE}
167_sudo dd if=${DATA} of=${DEV} bs=1M oflag=direct
168[ "`dd if=${DATA} bs=1M | md5sum`" = "`rbd -p ${POOL} --no-progress export ${IMAGE} - | md5sum`" ]
20effc67
TL
169unmap_device ${DEV} ${PID}
170
171# notrim test
172DEV=`_sudo rbd device --device-type nbd --options notrim map ${POOL}/${IMAGE}`
173get_pid ${POOL}
174provisioned=`rbd -p ${POOL} --format xml du ${IMAGE} |
175 $XMLSTARLET sel -t -m "//stats/images/image/provisioned_size" -v .`
176used=`rbd -p ${POOL} --format xml du ${IMAGE} |
177 $XMLSTARLET sel -t -m "//stats/images/image/used_size" -v .`
178[ "${used}" -eq "${provisioned}" ]
179# should fail discard as at time of mapping notrim was used
180expect_false _sudo blkdiscard ${DEV}
181sync
182provisioned=`rbd -p ${POOL} --format xml du ${IMAGE} |
183 $XMLSTARLET sel -t -m "//stats/images/image/provisioned_size" -v .`
184used=`rbd -p ${POOL} --format xml du ${IMAGE} |
185 $XMLSTARLET sel -t -m "//stats/images/image/used_size" -v .`
186[ "${used}" -eq "${provisioned}" ]
187unmap_device ${DEV} ${PID}
7c673cae
FG
188
189# trim test
20effc67
TL
190DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
191get_pid ${POOL}
7c673cae
FG
192provisioned=`rbd -p ${POOL} --format xml du ${IMAGE} |
193 $XMLSTARLET sel -t -m "//stats/images/image/provisioned_size" -v .`
194used=`rbd -p ${POOL} --format xml du ${IMAGE} |
195 $XMLSTARLET sel -t -m "//stats/images/image/used_size" -v .`
196[ "${used}" -eq "${provisioned}" ]
20effc67
TL
197# should honor discard as at time of mapping trim was considered by default
198_sudo blkdiscard ${DEV}
7c673cae
FG
199sync
200provisioned=`rbd -p ${POOL} --format xml du ${IMAGE} |
201 $XMLSTARLET sel -t -m "//stats/images/image/provisioned_size" -v .`
202used=`rbd -p ${POOL} --format xml du ${IMAGE} |
203 $XMLSTARLET sel -t -m "//stats/images/image/used_size" -v .`
204[ "${used}" -lt "${provisioned}" ]
205
206# resize test
207devname=$(basename ${DEV})
208blocks=$(awk -v dev=${devname} '$4 == dev {print $3}' /proc/partitions)
209test -n "${blocks}"
210rbd resize ${POOL}/${IMAGE} --size $((SIZE * 2))M
211rbd info ${POOL}/${IMAGE}
212blocks2=$(awk -v dev=${devname} '$4 == dev {print $3}' /proc/partitions)
213test -n "${blocks2}"
214test ${blocks2} -eq $((blocks * 2))
215rbd resize ${POOL}/${IMAGE} --allow-shrink --size ${SIZE}M
216blocks2=$(awk -v dev=${devname} '$4 == dev {print $3}' /proc/partitions)
217test -n "${blocks2}"
218test ${blocks2} -eq ${blocks}
219
220# read-only option test
f91f0fd5 221unmap_device ${DEV} ${PID}
522d829b
TL
222DEV=`_sudo rbd --device-type nbd map --read-only ${POOL}/${IMAGE}`
223PID=$(rbd device --device-type nbd list | awk -v pool=${POOL} -v img=${IMAGE} -v dev=${DEV} \
31f18b77
FG
224 '$2 == pool && $3 == img && $5 == dev {print $1}')
225test -n "${PID}"
f91f0fd5 226ps -p ${PID} -C rbd-nbd
31f18b77 227
7c673cae
FG
228_sudo dd if=${DEV} of=/dev/null bs=1M
229expect_false _sudo dd if=${DATA} of=${DEV} bs=1M oflag=direct
f91f0fd5 230unmap_device ${DEV} ${PID}
7c673cae
FG
231
232# exclusive option test
522d829b
TL
233DEV=`_sudo rbd --device-type nbd map --exclusive ${POOL}/${IMAGE}`
234get_pid ${POOL}
31f18b77 235
7c673cae
FG
236_sudo dd if=${DATA} of=${DEV} bs=1M oflag=direct
237expect_false timeout 10 \
238 rbd bench ${IMAGE} --io-type write --io-size=1024 --io-total=1024
f91f0fd5 239unmap_device ${DEV} ${PID}
11fdf7f2
TL
240DEV=
241rbd bench ${IMAGE} --io-type write --io-size=1024 --io-total=1024
242
243# unmap by image name test
522d829b
TL
244DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
245get_pid ${POOL}
f91f0fd5 246unmap_device ${IMAGE} ${PID}
11fdf7f2 247DEV=
11fdf7f2
TL
248
249# map/unmap snap test
250rbd snap create ${POOL}/${IMAGE}@snap
522d829b
TL
251DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}@snap`
252get_pid ${POOL}
f91f0fd5 253unmap_device "${IMAGE}@snap" ${PID}
11fdf7f2 254DEV=
11fdf7f2 255
39ae355f
TL
256# map/unmap snap test with --snap-id
257SNAPID=`rbd snap ls ${POOL}/${IMAGE} | awk '$2 == "snap" {print $1}'`
258DEV=`_sudo rbd device --device-type nbd map --snap-id ${SNAPID} ${POOL}/${IMAGE}`
259get_pid ${POOL}
260unmap_device "--snap-id ${SNAPID} ${IMAGE}" ${PID}
261DEV=
262
11fdf7f2
TL
263# map/unmap namespace test
264rbd snap create ${POOL}/${NS}/${IMAGE}@snap
522d829b
TL
265DEV=`_sudo rbd device --device-type nbd map ${POOL}/${NS}/${IMAGE}@snap`
266get_pid ${POOL} ${NS}
f91f0fd5 267unmap_device "${POOL}/${NS}/${IMAGE}@snap" ${PID}
11fdf7f2 268DEV=
f91f0fd5 269
39ae355f
TL
270# map/unmap namespace test with --snap-id
271SNAPID=`rbd snap ls ${POOL}/${NS}/${IMAGE} | awk '$2 == "snap" {print $1}'`
272DEV=`_sudo rbd device --device-type nbd map --snap-id ${SNAPID} ${POOL}/${NS}/${IMAGE}`
273get_pid ${POOL} ${NS}
274unmap_device "--snap-id ${SNAPID} ${POOL}/${NS}/${IMAGE}" ${PID}
275DEV=
276
277# map/unmap namespace using options test
278DEV=`_sudo rbd device --device-type nbd map --pool ${POOL} --namespace ${NS} --image ${IMAGE}`
279get_pid ${POOL} ${NS}
280unmap_device "--pool ${POOL} --namespace ${NS} --image ${IMAGE}" ${PID}
281DEV=`_sudo rbd device --device-type nbd map --pool ${POOL} --namespace ${NS} --image ${IMAGE} --snap snap`
282get_pid ${POOL} ${NS}
283unmap_device "--pool ${POOL} --namespace ${NS} --image ${IMAGE} --snap snap" ${PID}
284DEV=
285
f91f0fd5 286# unmap by image name test 2
522d829b
TL
287DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
288get_pid ${POOL}
f91f0fd5 289pid=$PID
522d829b
TL
290DEV=`_sudo rbd device --device-type nbd map ${POOL}/${NS}/${IMAGE}`
291get_pid ${POOL} ${NS}
f91f0fd5
TL
292unmap_device ${POOL}/${NS}/${IMAGE} ${PID}
293DEV=
294unmap_device ${POOL}/${IMAGE} ${pid}
31f18b77 295
522d829b
TL
296# map/unmap test with just image name and expect image to come from default pool
297if [ "${POOL}" = "rbd" ];then
298 DEV=`_sudo rbd device --device-type nbd map ${IMAGE}`
299 get_pid ${POOL}
300 unmap_device ${IMAGE} ${PID}
301 DEV=
302fi
303
304# map/unmap test with just image name after changing default pool
305rbd config global set global rbd_default_pool ${ANOTHER_POOL}
306rbd create --size 10M ${IMAGE}
307DEV=`_sudo rbd device --device-type nbd map ${IMAGE}`
308get_pid ${ANOTHER_POOL}
309unmap_device ${IMAGE} ${PID}
310DEV=
311
312# reset
313rbd config global rm global rbd_default_pool
314
31f18b77 315# auto unmap test
522d829b
TL
316DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
317get_pid ${POOL}
31f18b77
FG
318_sudo kill ${PID}
319for i in `seq 10`; do
522d829b 320 rbd device --device-type nbd list | expect_false grep "^${PID} *${POOL} *${IMAGE}" && break
31f18b77
FG
321 sleep 1
322done
522d829b 323rbd device --device-type nbd list | expect_false grep "^${PID} *${POOL} *${IMAGE}"
31f18b77 324
f67539c2
TL
325# quiesce test
326QUIESCE_HOOK=${TEMPDIR}/quiesce.sh
522d829b
TL
327DEV=`_sudo rbd device --device-type nbd map --quiesce --quiesce-hook ${QUIESCE_HOOK} ${POOL}/${IMAGE}`
328get_pid ${POOL}
f67539c2
TL
329
330# test it fails if the hook does not exists
331test ! -e ${QUIESCE_HOOK}
332expect_false rbd snap create ${POOL}/${IMAGE}@quiesce1
333_sudo dd if=${DATA} of=${DEV} bs=1M count=1 oflag=direct
334
335# test the hook is executed
336touch ${QUIESCE_HOOK}
337chmod +x ${QUIESCE_HOOK}
338cat > ${QUIESCE_HOOK} <<EOF
339#/bin/sh
340echo "test the hook is executed" >&2
341echo \$1 > ${TEMPDIR}/\$2
342EOF
343rbd snap create ${POOL}/${IMAGE}@quiesce1
344_sudo dd if=${DATA} of=${DEV} bs=1M count=1 oflag=direct
345test "$(cat ${TEMPDIR}/quiesce)" = ${DEV}
346test "$(cat ${TEMPDIR}/unquiesce)" = ${DEV}
347
348# test snap create fails if the hook fails
349touch ${QUIESCE_HOOK}
350chmod +x ${QUIESCE_HOOK}
351cat > ${QUIESCE_HOOK} <<EOF
352#/bin/sh
353echo "test snap create fails if the hook fails" >&2
354exit 22
355EOF
356expect_false rbd snap create ${POOL}/${IMAGE}@quiesce2
357_sudo dd if=${DATA} of=${DEV} bs=1M count=1 oflag=direct
358
359# test the hook is slow
360cat > ${QUIESCE_HOOK} <<EOF
361#/bin/sh
362echo "test the hook is slow" >&2
363sleep 7
364EOF
365rbd snap create ${POOL}/${IMAGE}@quiesce2
366_sudo dd if=${DATA} of=${DEV} bs=1M count=1 oflag=direct
367
368# test rbd-nbd_quiesce hook that comes with distribution
369unmap_device ${DEV} ${PID}
370LOG_FILE=${TEMPDIR}/rbd-nbd.log
371if [ -n "${CEPH_SRC}" ]; then
372 QUIESCE_HOOK=${CEPH_SRC}/tools/rbd_nbd/rbd-nbd_quiesce
522d829b 373 DEV=`_sudo rbd device --device-type nbd map --quiesce --quiesce-hook ${QUIESCE_HOOK} \
f67539c2
TL
374 ${POOL}/${IMAGE} --log-file=${LOG_FILE}`
375else
522d829b 376 DEV=`_sudo rbd device --device-type nbd map --quiesce ${POOL}/${IMAGE} --log-file=${LOG_FILE}`
f67539c2 377fi
522d829b 378get_pid ${POOL}
f67539c2
TL
379_sudo mkfs ${DEV}
380mkdir ${TEMPDIR}/mnt
381_sudo mount ${DEV} ${TEMPDIR}/mnt
382rbd snap create ${POOL}/${IMAGE}@quiesce3
383_sudo dd if=${DATA} of=${TEMPDIR}/mnt/test bs=1M count=1 oflag=direct
384_sudo umount ${TEMPDIR}/mnt
385unmap_device ${DEV} ${PID}
386DEV=
387cat ${LOG_FILE}
388expect_false grep 'quiesce failed' ${LOG_FILE}
389
390# test detach/attach
20effc67
TL
391OUT=`_sudo rbd device --device-type nbd --options try-netlink,show-cookie map ${POOL}/${IMAGE}`
392read DEV COOKIE <<< "${OUT}"
522d829b 393get_pid ${POOL}
f67539c2 394_sudo mount ${DEV} ${TEMPDIR}/mnt
20effc67 395_sudo rbd device detach ${POOL}/${IMAGE} --device-type nbd
522d829b 396expect_false get_pid ${POOL}
20effc67
TL
397expect_false _sudo rbd device attach --device ${DEV} ${POOL}/${IMAGE} --device-type nbd
398if [ -n "${COOKIE}" ]; then
399 _sudo rbd device attach --device ${DEV} --cookie ${COOKIE} ${POOL}/${IMAGE} --device-type nbd
400else
401 _sudo rbd device attach --device ${DEV} ${POOL}/${IMAGE} --device-type nbd --force
402fi
522d829b 403get_pid ${POOL}
20effc67 404_sudo rbd device detach ${DEV} --device-type nbd
522d829b 405expect_false get_pid ${POOL}
20effc67
TL
406if [ -n "${COOKIE}" ]; then
407 _sudo rbd device attach --device ${DEV} --cookie ${COOKIE} ${POOL}/${IMAGE} --device-type nbd
408else
409 _sudo rbd device attach --device ${DEV} ${POOL}/${IMAGE} --device-type nbd --force
410fi
522d829b 411get_pid ${POOL}
f67539c2
TL
412ls ${TEMPDIR}/mnt/
413dd if=${TEMPDIR}/mnt/test of=/dev/null bs=1M count=1
414_sudo dd if=${DATA} of=${TEMPDIR}/mnt/test1 bs=1M count=1 oflag=direct
415_sudo umount ${TEMPDIR}/mnt
416unmap_device ${DEV} ${PID}
20effc67
TL
417# if kernel supports cookies
418if [ -n "${COOKIE}" ]; then
419 OUT=`_sudo rbd device --device-type nbd --show-cookie --cookie "abc de" --options try-netlink map ${POOL}/${IMAGE}`
420 read DEV ANOTHER_COOKIE <<< "${OUT}"
421 get_pid ${POOL}
422 test "${ANOTHER_COOKIE}" = "abc de"
423 unmap_device ${DEV} ${PID}
424fi
39ae355f
TL
425DEV=
426
427# test detach/attach with --snap-id
428SNAPID=`rbd snap ls ${POOL}/${IMAGE} | awk '$2 == "snap" {print $1}'`
429OUT=`_sudo rbd device --device-type nbd --options try-netlink,show-cookie map --snap-id ${SNAPID} ${POOL}/${IMAGE}`
430read DEV COOKIE <<< "${OUT}"
431get_pid ${POOL}
432_sudo rbd device detach ${POOL}/${IMAGE} --snap-id ${SNAPID} --device-type nbd
433expect_false get_pid ${POOL}
434expect_false _sudo rbd device attach --device ${DEV} --snap-id ${SNAPID} ${POOL}/${IMAGE} --device-type nbd
435if [ -n "${COOKIE}" ]; then
436 _sudo rbd device attach --device ${DEV} --cookie ${COOKIE} --snap-id ${SNAPID} ${POOL}/${IMAGE} --device-type nbd
437else
438 _sudo rbd device attach --device ${DEV} --snap-id ${SNAPID} ${POOL}/${IMAGE} --device-type nbd --force
439fi
440get_pid ${POOL}
441_sudo rbd device detach ${DEV} --device-type nbd
442expect_false get_pid ${POOL}
443DEV=
444
445# test discard granularity with journaling
446rbd config image set ${POOL}/${IMAGE} rbd_discard_granularity_bytes 4096
447rbd feature enable ${POOL}/${IMAGE} journaling
448DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
449get_pid ${POOL}
450# since a discard will now be pruned to only whole blocks (0..4095, 4096..8191)
451# let us test all the cases around those alignments. 512 is the smallest
452# possible block blkdiscard allows us to use. Thus the test checks
453# 512 before, on the alignment, 512 after.
454_sudo blkdiscard --offset 0 --length $((4096-512)) ${DEV}
455_sudo blkdiscard --offset 0 --length 4096 ${DEV}
456_sudo blkdiscard --offset 0 --length $((4096+512)) ${DEV}
457_sudo blkdiscard --offset 512 --length $((8192-1024)) ${DEV}
458_sudo blkdiscard --offset 512 --length $((8192-512)) ${DEV}
459_sudo blkdiscard --offset 512 --length 8192 ${DEV}
460# wait for commit log to be empty, 10 seconds should be well enough
461tries=0
462queue_length=`rbd journal inspect --pool ${POOL} --image ${IMAGE} | awk '/entries inspected/ {print $1}'`
463while [ ${tries} -lt 10 ] && [ ${queue_length} -gt 0 ]; do
464 rbd journal inspect --pool ${POOL} --image ${IMAGE} --verbose
465 sleep 1
466 queue_length=`rbd journal inspect --pool ${POOL} --image ${IMAGE} | awk '/entries inspected/ {print $1}'`
467 tries=$((tries+1))
468done
469[ ${queue_length} -eq 0 ]
470unmap_device ${DEV} ${PID}
471DEV=
472rbd feature disable ${POOL}/${IMAGE} journaling
473rbd config image rm ${POOL}/${IMAGE} rbd_discard_granularity_bytes
474
aee94f69
TL
475# test that disabling a feature so that the op is proxied to rbd-nbd
476# (arranged here by blkdiscard before "rbd feature disable") doesn't hang
477DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
478get_pid ${POOL}
479rbd feature enable ${POOL}/${IMAGE} journaling
480_sudo blkdiscard --offset 0 --length 4096 ${DEV}
481rbd feature disable ${POOL}/${IMAGE} journaling
482unmap_device ${DEV} ${PID}
483DEV=
484
39ae355f
TL
485# test that rbd_op_threads setting takes effect
486EXPECTED=`ceph-conf --show-config-value librados_thread_count`
487DEV=`_sudo rbd device --device-type nbd map ${POOL}/${IMAGE}`
488get_pid ${POOL}
489ACTUAL=`ps -p ${PID} -T | grep -c io_context_pool`
490[ ${ACTUAL} -eq ${EXPECTED} ]
491unmap_device ${DEV} ${PID}
492EXPECTED=$((EXPECTED * 3 + 1))
493DEV=`_sudo rbd device --device-type nbd --rbd-op-threads ${EXPECTED} map ${POOL}/${IMAGE}`
494get_pid ${POOL}
495ACTUAL=`ps -p ${PID} -T | grep -c io_context_pool`
496[ ${ACTUAL} -eq ${EXPECTED} ]
497unmap_device ${DEV} ${PID}
498DEV=
f67539c2 499
7c673cae 500echo OK