198 lines
6.3 KiB
Diff
198 lines
6.3 KiB
Diff
|
From 0a4d6d9d1d8ef4e3fe141c757dd5aad4b48b316c Mon Sep 17 00:00:00 2001
|
||
|
From: Leo Yan <leo.yan@linaro.org>
|
||
|
Date: Thu, 3 Jun 2021 17:59:24 +0800
|
||
|
Subject: [PATCH 28/33] tests: multi-hosts: Test lease timeout with LV
|
||
|
exclusive mode
|
||
|
|
||
|
This patch is to test timeout handling after activate LV with exclusive
|
||
|
mode. It contains two scripts for host A and host B separately.
|
||
|
|
||
|
The script on host A firstly creates VGs and LVs based on the passed
|
||
|
back devices, every back device is for a dedicated VG and a LV is
|
||
|
created as well in the VG. Afterwards, all LVs are activated by host A,
|
||
|
so host A acquires the lease for these LVs. Then the test is designed
|
||
|
to fail on host A.
|
||
|
|
||
|
After the host A fails, host B starts to run the paired testing script,
|
||
|
it firstly fails to activate the LVs since the locks are leased by
|
||
|
host A; after lease expiration (after 70s), host B can achieve the lease
|
||
|
for LVs and it can operate LVs and VGs.
|
||
|
|
||
|
On the host A:
|
||
|
make check_lvmlockd_idm \
|
||
|
LVM_TEST_BACKING_DEVICE=/dev/sdj3,/dev/sdk3,/dev/sdl3 \
|
||
|
LVM_TEST_MULTI_HOST=1 T=multi_hosts_lv_ex_timeout_hosta.sh
|
||
|
|
||
|
On the host B:
|
||
|
make check_lvmlockd_idm \
|
||
|
LVM_TEST_BACKING_DEVICE=/dev/sdj3,/dev/sdk3,/dev/sdl3 \
|
||
|
LVM_TEST_MULTI_HOST=1 T=multi_hosts_lv_ex_timeout_hostb.sh
|
||
|
|
||
|
Signed-off-by: Leo Yan <leo.yan@linaro.org>
|
||
|
Signed-off-by: Heming Zhao <heming.zhao@suse.com>
|
||
|
---
|
||
|
test/shell/multi_hosts_lv_ex_timeout_hosta.sh | 87 +++++++++++++++++++++++++++
|
||
|
test/shell/multi_hosts_lv_ex_timeout_hostb.sh | 56 +++++++++++++++++
|
||
|
2 files changed, 143 insertions(+)
|
||
|
create mode 100644 test/shell/multi_hosts_lv_ex_timeout_hosta.sh
|
||
|
create mode 100644 test/shell/multi_hosts_lv_ex_timeout_hostb.sh
|
||
|
|
||
|
diff --git a/test/shell/multi_hosts_lv_ex_timeout_hosta.sh b/test/shell/multi_hosts_lv_ex_timeout_hosta.sh
|
||
|
new file mode 100644
|
||
|
index 000000000000..c8be91ee35f4
|
||
|
--- /dev/null
|
||
|
+++ b/test/shell/multi_hosts_lv_ex_timeout_hosta.sh
|
||
|
@@ -0,0 +1,87 @@
|
||
|
+#!/usr/bin/env bash
|
||
|
+
|
||
|
+# Copyright (C) 2021 Seagate, Inc. All rights reserved.
|
||
|
+#
|
||
|
+# This copyrighted material is made available to anyone wishing to use,
|
||
|
+# modify, copy, or redistribute it subject to the terms and conditions
|
||
|
+# of the GNU General Public License v2.
|
||
|
+#
|
||
|
+# You should have received a copy of the GNU General Public License
|
||
|
+# along with this program; if not, write to the Free Software Foundation,
|
||
|
+# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||
|
+
|
||
|
+# This testing script is for multi-hosts testing.
|
||
|
+#
|
||
|
+# On the host A:
|
||
|
+# make check_lvmlockd_idm \
|
||
|
+# LVM_TEST_BACKING_DEVICE=/dev/sdj3,/dev/sdk3,/dev/sdl3 \
|
||
|
+# LVM_TEST_MULTI_HOST=1 T=multi_hosts_lv_ex_timeout_hosta.sh
|
||
|
+# On the host B:
|
||
|
+# make check_lvmlockd_idm \
|
||
|
+# LVM_TEST_BACKING_DEVICE=/dev/sdj3,/dev/sdk3,/dev/sdl3 \
|
||
|
+# LVM_TEST_MULTI_HOST=1 T=multi_hosts_lv_ex_timeout_hostb.sh
|
||
|
+
|
||
|
+SKIP_WITH_LVMPOLLD=1
|
||
|
+
|
||
|
+. lib/inittest
|
||
|
+
|
||
|
+[ -z "$LVM_TEST_MULTI_HOST" ] && skip;
|
||
|
+
|
||
|
+IFS=',' read -r -a BLKDEVS <<< "$LVM_TEST_BACKING_DEVICE"
|
||
|
+
|
||
|
+for d in "${BLKDEVS[@]}"; do
|
||
|
+ aux extend_filter_LVMTEST "a|$d|"
|
||
|
+done
|
||
|
+
|
||
|
+aux lvmconf "devices/allow_changes_with_duplicate_pvs = 1"
|
||
|
+
|
||
|
+for d in "${BLKDEVS[@]}"; do
|
||
|
+ dd if=/dev/zero of="$d" bs=32k count=1
|
||
|
+ wipefs -a "$d" 2>/dev/null || true
|
||
|
+
|
||
|
+ sg_dev=`sg_map26 ${d}`
|
||
|
+ if [ -n "$LVM_TEST_LOCK_TYPE_IDM" ]; then
|
||
|
+ echo "Cleanup IDM context for drive ${d} ($sg_dev)"
|
||
|
+ sg_raw -v -r 512 -o /tmp/idm_tmp_data.bin $sg_dev \
|
||
|
+ 88 00 01 00 00 00 00 20 FF 01 00 00 00 01 00 00
|
||
|
+ sg_raw -v -s 512 -i /tmp/idm_tmp_data.bin $sg_dev \
|
||
|
+ 8E 00 FF 00 00 00 00 00 00 00 00 00 00 01 00 00
|
||
|
+ rm /tmp/idm_tmp_data.bin
|
||
|
+ fi
|
||
|
+done
|
||
|
+
|
||
|
+for i in $(seq 1 ${#BLKDEVS[@]}); do
|
||
|
+ vgcreate $SHARED TESTVG$i ${BLKDEVS[$(( i - 1 ))]}
|
||
|
+ lvcreate -a n --zero n -l 1 -n foo TESTVG$i
|
||
|
+ lvchange -a ey TESTVG$i/foo
|
||
|
+done
|
||
|
+
|
||
|
+for d in "${BLKDEVS[@]}"; do
|
||
|
+ drive_wwn=`udevadm info $d | awk -F= '/E: ID_WWN=/ {print $2}'`
|
||
|
+ for dev in /dev/*; do
|
||
|
+ if [ -b "$dev" ] && [[ ! "$dev" =~ [0-9] ]]; then
|
||
|
+ wwn=`udevadm info "${dev}" | awk -F= '/E: ID_WWN=/ {print $2}'`
|
||
|
+ if [ "$wwn" = "$drive_wwn" ]; then
|
||
|
+ base_name="$(basename -- ${dev})"
|
||
|
+ drive_list+=("$base_name")
|
||
|
+ host_list+=(`readlink /sys/block/$base_name | awk -F'/' '{print $6}'`)
|
||
|
+ fi
|
||
|
+ fi
|
||
|
+ done
|
||
|
+done
|
||
|
+
|
||
|
+for d in "${drive_list[@]}"; do
|
||
|
+ [ -f /sys/block/$d/device/delete ] && echo 1 > /sys/block/$d/device/delete
|
||
|
+done
|
||
|
+
|
||
|
+sleep 100
|
||
|
+
|
||
|
+for i in $(seq 1 ${#BLKDEVS[@]}); do
|
||
|
+ check grep_lvmlockd_dump "S lvm_TESTVG$i kill_vg"
|
||
|
+ lvmlockctl --drop TESTVG$i
|
||
|
+done
|
||
|
+
|
||
|
+# Rescan drives so can probe the deleted drives and join back them
|
||
|
+for h in "${host_list[@]}"; do
|
||
|
+ [ -f /sys/class/scsi_host/${h}/scan ] && echo "- - -" > /sys/class/scsi_host/${h}/scan
|
||
|
+done
|
||
|
diff --git a/test/shell/multi_hosts_lv_ex_timeout_hostb.sh b/test/shell/multi_hosts_lv_ex_timeout_hostb.sh
|
||
|
new file mode 100644
|
||
|
index 000000000000..f0273fa44758
|
||
|
--- /dev/null
|
||
|
+++ b/test/shell/multi_hosts_lv_ex_timeout_hostb.sh
|
||
|
@@ -0,0 +1,56 @@
|
||
|
+#!/usr/bin/env bash
|
||
|
+
|
||
|
+# Copyright (C) 2021 Seagate, Inc. All rights reserved.
|
||
|
+#
|
||
|
+# This copyrighted material is made available to anyone wishing to use,
|
||
|
+# modify, copy, or redistribute it subject to the terms and conditions
|
||
|
+# of the GNU General Public License v2.
|
||
|
+#
|
||
|
+# You should have received a copy of the GNU General Public License
|
||
|
+# along with this program; if not, write to the Free Software Foundation,
|
||
|
+# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||
|
+
|
||
|
+# This testing script is for multi-hosts testing.
|
||
|
+#
|
||
|
+# On the host A:
|
||
|
+# make check_lvmlockd_idm \
|
||
|
+# LVM_TEST_BACKING_DEVICE=/dev/sdj3,/dev/sdk3,/dev/sdl3 \
|
||
|
+# LVM_TEST_MULTI_HOST=1 T=multi_hosts_lv_ex_timeout_hosta.sh
|
||
|
+# On the host B:
|
||
|
+# make check_lvmlockd_idm \
|
||
|
+# LVM_TEST_BACKING_DEVICE=/dev/sdj3,/dev/sdk3,/dev/sdl3 \
|
||
|
+# LVM_TEST_MULTI_HOST=1 T=multi_hosts_lv_ex_timeout_hostb.sh
|
||
|
+
|
||
|
+SKIP_WITH_LVMPOLLD=1
|
||
|
+
|
||
|
+. lib/inittest
|
||
|
+
|
||
|
+[ -z "$LVM_TEST_MULTI_HOST" ] && skip;
|
||
|
+
|
||
|
+IFS=',' read -r -a BLKDEVS <<< "$LVM_TEST_BACKING_DEVICE"
|
||
|
+
|
||
|
+for d in "${BLKDEVS[@]}"; do
|
||
|
+ aux extend_filter_LVMTEST "a|$d|"
|
||
|
+done
|
||
|
+
|
||
|
+aux lvmconf "devices/allow_changes_with_duplicate_pvs = 1"
|
||
|
+
|
||
|
+vgchange --lock-start
|
||
|
+
|
||
|
+vgdisplay
|
||
|
+
|
||
|
+for i in $(seq 1 ${#BLKDEVS[@]}); do
|
||
|
+ not lvchange -a ey TESTVG$i/foo
|
||
|
+done
|
||
|
+
|
||
|
+# Sleep for 70 seconds so the previous lease is expired
|
||
|
+sleep 70
|
||
|
+
|
||
|
+for i in $(seq 1 ${#BLKDEVS[@]}); do
|
||
|
+ lvchange -a ey TESTVG$i/foo
|
||
|
+ lvchange -a n TESTVG$i/foo
|
||
|
+done
|
||
|
+
|
||
|
+for i in $(seq 1 ${#BLKDEVS[@]}); do
|
||
|
+ vgremove -f TESTVG$i
|
||
|
+done
|
||
|
--
|
||
|
1.8.3.1
|
||
|
|