2017-07-10 10:40:09 +02:00
#!/usr/bin/env bash
2017-07-02 21:38:32 +02:00
# Copyright (C) 2017 Red Hat, 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 v.2.
#
# 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, MA2110-1301 USA
2017-06-15 11:06:08 -05:00
#######################################################################
# This series of tests is meant to validate the correctness of
# 'dmsetup status' for RAID LVs - especially during various sync action
# transitions, like: recover, resync, check, repair, idle, reshape, etc
#######################################################################
2018-05-31 16:18:53 -05:00
2017-06-15 11:06:08 -05:00
SKIP_WITH_LVMPOLLD = 1
. lib/inittest
# check for version 1.9.0
# - it is the point at which linear->raid1 uses "recover"
2017-10-30 21:58:38 -05:00
# check for version 1.13.0 instead
# - it is the point at which a finishing "recover" doesn't print all 'a's
aux have_raid 1 13 0 || skip
2017-06-15 11:06:08 -05:00
aux prepare_pvs 9
2017-07-06 19:41:25 +02:00
get_devs
2018-05-31 16:18:53 -05:00
vgcreate $SHARED -s 2m " $vg " " ${ DEVICES [@] } "
2017-06-15 11:06:08 -05:00
###########################################
# Upconverted RAID1 should never have all 'a's in status output
###########################################
2021-03-24 12:08:40 +01:00
aux delay_dev " $dev2 " 0 20
2017-07-10 10:40:09 +02:00
lvcreate -aey -l 2 -n $lv1 $vg " $dev1 "
lvconvert --type raid1 -y -m 1 $vg /$lv1 " $dev2 "
2021-03-24 12:08:40 +01:00
for i in { 100..0} ; do
check in_sync $vg $lv1 && break
a = ( $( dmsetup status $vg -$lv1 ) ) || die " Unable to get status of $vg / $lv1 "
2017-10-30 21:58:38 -05:00
b = ( $( echo " ${ a [6] } " | sed s:/:' ' :) )
if [ " ${ b [0] } " -ne " ${ b [1] } " ] ; then
# First, 'check in_sync' should only need to check the ratio
# If we are here, it is probably doing more than that.
# If not in-sync, then we should only ever see "Aa"
2021-03-24 12:08:40 +01:00
# Ignore until raid starts to report consistent data
[ " ${ b [0] } " = "0" ] || [ " ${ a [5] } " = = "Aa" ]
2017-10-30 21:58:38 -05:00
else
[ " ${ a [5] } " != "aa" ]
should [ " ${ a [5] } " = = "AA" ] # RHBZ 1507719
fi
2021-03-24 12:08:40 +01:00
sleep .1
2017-06-15 11:06:08 -05:00
done
2017-07-10 10:40:09 +02:00
aux enable_dev " $dev2 "
2017-06-15 11:06:08 -05:00
lvremove -ff $vg
2021-03-24 12:08:40 +01:00
test " $i " -gt 0 || die " Unable to get in sync $vg / $lv1 "
2017-06-15 11:06:08 -05:00
2017-06-16 10:11:58 -05:00
###########################################
# Upconverted RAID1 should not be at 100% right after upconvert
###########################################
2017-07-10 10:40:09 +02:00
aux delay_dev " $dev2 " 0 50
lvcreate -aey -l 2 -n $lv1 $vg " $dev1 "
lvconvert --type raid1 -y -m 1 $vg /$lv1 " $dev2 "
2017-06-16 10:11:58 -05:00
a = ( $( dmsetup status $vg -$lv1 ) ) || die " Unable to get status of $vg / $lv1 "
2017-07-10 10:40:09 +02:00
b = ( $( echo " ${ a [6] } " | sed s:/:' ' :) )
2017-10-30 21:58:38 -05:00
should [ " ${ b [0] } " -ne " ${ b [1] } " ] # RHBZ 1507729
2017-07-10 10:40:09 +02:00
aux enable_dev " $dev2 "
2017-06-16 10:11:58 -05:00
lvremove -ff $vg
###########################################
# Catch anything suspicious with linear -> RAID1 upconvert
###########################################
2021-03-24 12:08:40 +01:00
aux delay_dev " $dev2 " 0 20
2017-07-10 10:40:09 +02:00
lvcreate -aey -l 2 -n $lv1 $vg " $dev1 "
lvconvert --type raid1 -y -m 1 $vg /$lv1 " $dev2 "
2021-03-24 12:08:40 +01:00
for i in { 100..0} ; do
a = ( $( dmsetup status $vg -$lv1 ) ) || die " Unable to get status of $vg / $lv1 "
2017-07-10 10:40:09 +02:00
b = ( $( echo " ${ a [6] } " | sed s:/:' ' :) )
2021-03-24 12:08:40 +01:00
if [ " ${ b [0] } " -eq "0" ] ; then
: # Ignore until raid starts to report consistent data
elif [ " ${ b [0] } " -ne " ${ b [1] } " ] ; then
2017-06-16 10:11:58 -05:00
# If the sync operation ("recover" in this case) is not
# finished, then it better be as follows:
2017-07-10 10:40:09 +02:00
[ " ${ a [5] } " = "Aa" ]
2017-11-02 08:53:48 -05:00
# Might be transitioning from "idle" to "recover".
# Kernel could check mddev->recovery for the intent to
# begin a "recover" and report that... probably would be
# better. RHBZ 1507719
should [ " ${ a [7] } " = "recover" ]
2017-06-16 10:11:58 -05:00
else
# Tough to tell the INVALID case,
# Before starting sync thread: "Aa X/X recover"
# from the valid case,
# Just finished sync thread: "Aa X/X recover"
2017-10-30 21:58:38 -05:00
should [ " ${ a [5] } " = "AA" ] # RHBZ 1507719
should [ " ${ a [7] } " = "idle" ] # RHBZ 1507719
2017-06-16 10:11:58 -05:00
break
fi
2021-03-24 12:08:40 +01:00
sleep .1
2017-06-16 10:11:58 -05:00
done
2017-07-10 10:40:09 +02:00
aux enable_dev " $dev2 "
2017-06-16 10:11:58 -05:00
lvremove -ff $vg
###########################################
# Catch anything suspicious with RAID1 2-way -> 3-way upconvert
###########################################
2021-03-24 12:08:40 +01:00
aux delay_dev " $dev3 " 0 20
2017-07-10 10:40:09 +02:00
lvcreate --type raid1 -m 1 -aey -l 2 -n $lv1 $vg " $dev1 " " $dev2 "
2017-10-30 21:58:38 -05:00
aux wait_for_sync $vg $lv1
2017-07-10 10:40:09 +02:00
lvconvert -y -m +1 $vg /$lv1 " $dev3 "
2021-03-24 12:08:40 +01:00
for i in { 100..0} ; do
a = ( $( dmsetup status $vg -$lv1 ) ) || die " Unable to get status of $vg / $lv1 "
2017-07-10 10:40:09 +02:00
b = ( $( echo " ${ a [6] } " | sed s:/:' ' :) )
2021-03-24 12:08:40 +01:00
if [ " ${ b [0] } " -eq "0" ] ; then
: # Ignore until raid starts to report consistent data
elif [ " ${ b [0] } " -ne " ${ b [1] } " ] ; then
2017-06-16 10:11:58 -05:00
# If the sync operation ("recover" in this case) is not
# finished, then it better be as follows:
2017-07-10 10:40:09 +02:00
[ " ${ a [5] } " = "AAa" ]
[ " ${ a [7] } " = "recover" ]
2017-06-16 10:11:58 -05:00
else
# Tough to tell the INVALID case,
2017-10-24 14:06:44 -05:00
# Before starting sync thread: "AAa X/X recover"
2017-06-16 10:11:58 -05:00
# from the valid case,
2017-10-24 14:06:44 -05:00
# Just finished sync thread: "AAa X/X recover"
2017-10-30 21:58:38 -05:00
should [ " ${ a [5] } " = "AAA" ] # RHBZ 1507719
should [ " ${ a [7] } " = "idle" ] # RHBZ 1507719
2017-06-16 10:11:58 -05:00
break
fi
2021-03-24 12:08:40 +01:00
sleep .1
2017-06-16 10:11:58 -05:00
done
2017-07-10 10:40:09 +02:00
aux enable_dev " $dev3 "
2017-06-16 10:11:58 -05:00
lvremove -ff $vg
2021-03-24 12:08:40 +01:00
test " $i " -gt 0 || die " Unable to get in sync $vg / $lv1 "
2017-06-16 10:11:58 -05:00
###########################################
# Catch anything suspicious with RAID1 initial resync
###########################################
2021-03-24 12:08:40 +01:00
aux delay_dev " $dev2 " 0 20
2017-07-10 10:40:09 +02:00
lvcreate --type raid1 -m 1 -aey -l 2 -n $lv1 $vg " $dev1 " " $dev2 "
2021-03-24 12:08:40 +01:00
for i in { 100..0} ; do
a = ( $( dmsetup status $vg -$lv1 ) ) || die " Unable to get status of $vg / $lv1 "
2017-07-10 10:40:09 +02:00
b = ( $( echo " ${ a [6] } " | sed s:/:' ' :) )
2021-03-24 12:08:40 +01:00
if [ " ${ b [0] } " -eq "0" ] ; then
: # Ignore until raid starts to report consistent data
elif [ " ${ b [0] } " -ne " ${ b [1] } " ] ; then
2017-06-16 10:11:58 -05:00
# If the sync operation ("resync" in this case) is not
# finished, then it better be as follows:
2017-07-10 10:40:09 +02:00
[ " ${ a [5] } " = "aa" ]
2017-10-30 21:58:38 -05:00
# Should be in "resync", but it is possible things are only
# just getting going - in which case, it could be "idle"
# with 0% sync ratio
[ " ${ a [7] } " = "resync" ] || \
[ [ " ${ a [7] } " = "idle" && " ${ b [0] } " -eq "0" ] ]
2017-06-16 10:11:58 -05:00
else
2017-10-30 21:58:38 -05:00
should [ " ${ a [5] } " = "AA" ] # RHBZ 1507719
should [ " ${ a [7] } " = "idle" ] # RHBZ 1507719
2017-06-16 10:11:58 -05:00
break
fi
2021-03-24 12:08:40 +01:00
sleep .1
2017-06-16 10:11:58 -05:00
done
2017-07-10 10:40:09 +02:00
aux enable_dev " $dev2 "
2017-06-16 10:11:58 -05:00
lvremove -ff $vg
2021-03-24 12:08:40 +01:00
test " $i " -gt 0 || die " Unable to get in sync $vg / $lv1 "
2017-06-16 10:11:58 -05:00
2017-06-15 11:06:08 -05:00
vgremove -ff $vg