summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXiaoxi Chen <xiaoxi.chen@intel.com>2015-12-08 07:58:05 +0100
committerXiaoxi Chen <xiaoxi.chen@intel.com>2015-12-08 08:20:32 +0100
commitf9a230aa528da550013f089b45b382168b1d3d5f (patch)
tree23590f0f0f620350f70b8c9f38a155f32e812464
parentosd/OSD.cc: shutdown after flapping certain times (diff)
downloadceph-f9a230aa528da550013f089b45b382168b1d3d5f.tar.xz
ceph-f9a230aa528da550013f089b45b382168b1d3d5f.zip
test/osd: add test case for shutdown_when_flapping
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>
-rw-r--r--src/test/CMakeLists.txt3
-rw-r--r--src/test/Makefile.am1
-rwxr-xr-xsrc/test/osd/osd-markdown.sh112
3 files changed, 116 insertions, 0 deletions
diff --git a/src/test/CMakeLists.txt b/src/test/CMakeLists.txt
index 82377732e4a..4cd4997709c 100644
--- a/src/test/CMakeLists.txt
+++ b/src/test/CMakeLists.txt
@@ -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)
diff --git a/src/test/Makefile.am b/src/test/Makefile.am
index 3d6353534d1..b3470f42ebe 100644
--- a/src/test/Makefile.am
+++ b/src/test/Makefile.am
@@ -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
index 00000000000..4dfa78d7225
--- /dev/null
+++ b/src/test/osd/osd-markdown.sh
@@ -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: