]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
test/osd: add test case for shutdown_when_flapping 6708/head
authorXiaoxi Chen <xiaoxi.chen@intel.com>
Tue, 8 Dec 2015 06:58:05 +0000 (14:58 +0800)
committerXiaoxi Chen <xiaoxi.chen@intel.com>
Tue, 8 Dec 2015 07:20:32 +0000 (15:20 +0800)
TEST_markdown_exceed_maxdown_count :
  down N+1 times within period, should be UP in first N times but DOWN in last time.
TEST_markdown_boot :
  down exactly N times within period, should be UP for all N times.
TEST_markdown_boot_exceed_time :
  down N+1 times but exceed the period, should be UP after the test.

Signed-off-by: Xiaoxi Chen <xiaoxi.chen@intel.com>
src/test/CMakeLists.txt
src/test/Makefile.am
src/test/osd/osd-markdown.sh [new file with mode: 0755]

index 82377732e4a7834a6fa8df13c7a8b82567cd34bb..4cd4997709ca2549061fb641d1f4b75f050a561d 100644 (file)
@@ -346,6 +346,9 @@ add_dependencies(check osd_pool_create)
 add_test(NAME osd_copy_from COMMAND bash ${CMAKE_SOURCE_DIR}/src/test/osd/osd-copy-from.sh)
 add_dependencies(check osd_copy_from)
 
+add_test(NAME osd_mark_down COMMAND bash ${CMAKE_SOURCE_DIR}/src/test/osd/osd-markdown.sh)
+add_dependencies(check osd-markdown)
+
 add_test(NAME mon_handle_forward COMMAND bash ${CMAKE_SOURCE_DIR}/src/test/mon/mon-handle-forward.sh)
 add_dependencies(check mon_handle_forward)
 
index 3d6353534d14c5db1827d42a3257e88cd9f6ce13..b3470f42ebe3b376ebf6d09489328f2433ab1ca7 100644 (file)
@@ -84,6 +84,7 @@ check_SCRIPTS += \
        test/osd/osd-bench.sh \
        test/osd/osd-reactivate.sh \
        test/osd/osd-copy-from.sh \
+       test/osd/osd-markdown.sh \
        test/mon/mon-handle-forward.sh \
        test/libradosstriper/rados-striper.sh \
        test/test_objectstore_memstore.sh
diff --git a/src/test/osd/osd-markdown.sh b/src/test/osd/osd-markdown.sh
new file mode 100755 (executable)
index 0000000..4dfa78d
--- /dev/null
@@ -0,0 +1,112 @@
+#!/bin/bash
+#
+# Copyright (C) 2015 Intel <contact@intel.com.com>
+# Copyright (C) 2014, 2015 Red Hat <contact@redhat.com>
+#
+# Author: Xiaoxi Chen <xiaoxi.chen@intel.com>
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Library Public License as published by
+# the Free Software Foundation; either version 2, or (at your option)
+# any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU Library Public License for more details.
+#
+
+source ../qa/workunits/ceph-helpers.sh
+
+function run() {
+    local dir=$1
+    shift
+
+    export CEPH_MON="127.0.0.1:7108" # git grep '\<7108\>' : there must be only one
+    export CEPH_ARGS
+    CEPH_ARGS+="--fsid=$(uuidgen) --auth-supported=none "
+    CEPH_ARGS+="--mon-host=$CEPH_MON "
+
+    local funcs=${@:-$(set | sed -n -e 's/^\(TEST_[0-9a-z_]*\) .*/\1/p')}
+    for func in $funcs ; do
+        setup $dir || return 1
+        $func $dir || return 1
+        teardown $dir || return 1
+    done
+}
+
+function markdown_N_impl() {
+  markdown_times=$1
+  total_time=$2
+  interval=$(($total_time / markdown_times))
+  sleep 10
+  for i in `seq 1 $markdown_times`
+  do
+    # check the OSD is UP
+    ./ceph osd tree
+    ./ceph osd tree | grep osd.0 |grep up || return 1
+    # mark the OSD down.
+    ./ceph osd down 0
+    sleep $interval
+  done
+}
+
+
+function TEST_markdown_exceed_maxdown_count() {
+    local dir=$1
+
+    run_mon $dir a || return 1
+    run_osd $dir 0 || return 1
+    run_osd $dir 1 || return 1
+    run_osd $dir 2 || return 1
+    local count=5
+    local period=40
+    ceph tell osd.0 injectargs '--osd_max_markdown_count '$count'' || return 1
+    ceph tell osd.0 injectargs '--osd_max_markdown_period '$period'' || return 1
+
+    markdown_N_impl $(($count+1)) $period
+    # down N+1 times ,the osd.0 shoud die
+    ./ceph osd tree | grep down | grep osd.0 || return 1
+}
+
+function TEST_markdown_boot() {
+    local dir=$1
+
+    run_mon $dir a || return 1
+    run_osd $dir 0 || return 1
+    run_osd $dir 1 || return 1
+    run_osd $dir 2 || return 1
+
+    local count=5
+    local period=40
+    ceph tell osd.0 injectargs '--osd_max_markdown_count '$count'' || return 1
+    ceph tell osd.0 injectargs '--osd_max_markdown_period '$period'' || return 1
+
+    markdown_N_impl $count $period
+    #down N times, osd.0 should be up
+    ./ceph osd tree | grep up | grep osd.0 || return 1
+}
+
+function TEST_markdown_boot_exceed_time() {
+    local dir=$1
+
+    run_mon $dir a || return 1
+    run_osd $dir 0 || return 1
+    run_osd $dir 1 || return 1
+    run_osd $dir 2 || return 1
+
+    local count=5
+    local period=40
+    ceph tell osd.0 injectargs '--osd_max_markdown_count '$count'' || return 1
+    ceph tell osd.0 injectargs '--osd_max_markdown_period '$period'' || return 1
+
+    #actually we will down 6 times in 60s, so the 5th down will be in 50s > period
+    markdown_N_impl $(($count+1)) $(($period + 20))
+    ./ceph osd tree | grep up | grep osd.0 || return 1
+}
+
+main osd-markdown "$@"
+
+# Local Variables:
+# compile-command: "cd ../.. ; make -j4 && test/osd/osd-bench.sh"
+# End: