summaryrefslogtreecommitdiffstats
path: root/src/ceph/qa/workunits/rados/test_rados_timeouts.sh
blob: bb35d727e6dfc640ea33b83e1d47bc7c396dd20e (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
#!/bin/bash -x

delay_mon() {
    MSGTYPE=$1
    shift
    $@ --rados-mon-op-timeout 1 --ms-inject-delay-type mon --ms-inject-delay-max 10000000 --ms-inject-delay-probability 1 --ms-inject-delay-msg-type $MSGTYPE
    if [ $? -eq 0 ]; then
        exit 1
    fi
}

delay_osd() {
    MSGTYPE=$1
    shift
    $@ --rados-osd-op-timeout 1 --ms-inject-delay-type osd --ms-inject-delay-max 10000000 --ms-inject-delay-probability 1 --ms-inject-delay-msg-type $MSGTYPE
    if [ $? -eq 0 ]; then
        exit 2
    fi
}

# pool ops
delay_mon omap rados lspools
delay_mon poolopreply rados mkpool test
delay_mon poolopreply rados mksnap -p test snap
delay_mon poolopreply rados rmpool test test --yes-i-really-really-mean-it

# other mon ops
delay_mon getpoolstats rados df
delay_mon mon_command ceph df
delay_mon omap ceph osd dump
delay_mon omap ceph -s

# osd ops
delay_osd osd_op_reply rados -p data put ls /bin/ls
delay_osd osd_op_reply rados -p data get ls - >/dev/null
delay_osd osd_op_reply rados -p data ls
delay_osd command_reply ceph tell osd.0 bench 1 1

# rbd commands, using more kinds of osd ops
rbd create -s 1 test
delay_osd osd_op_reply rbd watch test
delay_osd osd_op_reply rbd info test
delay_osd osd_op_reply rbd snap create test@snap
delay_osd osd_op_reply rbd import /bin/ls ls
rbd rm test

echo OK