mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
tests: avoid hiding results in local
There is a difference between: local a=$(shell) and local a a=$(shell) The first return exit code from shells' local command.
This commit is contained in:
parent
d1dcbe0853
commit
b22ab4dab0
@ -75,7 +75,8 @@ fscheck_reiserfs()
|
|||||||
|
|
||||||
check_missing()
|
check_missing()
|
||||||
{
|
{
|
||||||
eval local t=$\check_$1
|
local t
|
||||||
|
eval t=$\check_$1
|
||||||
test -z "$t" && return 0
|
test -z "$t" && return 0
|
||||||
test "$t" = skip && return 1
|
test "$t" = skip && return 1
|
||||||
echo "WARNING: fsadm test skipped $1 tests, $t tool is missing."
|
echo "WARNING: fsadm test skipped $1 tests, $t tool is missing."
|
||||||
|
@ -29,9 +29,13 @@ aux prepare_vg 6
|
|||||||
run_writemostly_check() {
|
run_writemostly_check() {
|
||||||
local vg=$1
|
local vg=$1
|
||||||
local lv=${2}${THIN_POSTFIX}
|
local lv=${2}${THIN_POSTFIX}
|
||||||
local segtype=$(get lv_field $vg/$lv segtype -a)
|
local segtype=
|
||||||
local d0=$(get lv_devices $vg/${lv}_rimage_0)
|
local d0
|
||||||
local d1=$(get lv_devices $vg/${lv}_rimage_1)
|
local d1
|
||||||
|
|
||||||
|
segtype=$(get lv_field $vg/$lv segtype -a)
|
||||||
|
d0=$(get lv_devices $vg/${lv}_rimage_0)
|
||||||
|
d1=$(get lv_devices $vg/${lv}_rimage_1)
|
||||||
|
|
||||||
printf "#\n#\n#\n# %s/%s (%s): run_writemostly_check\n#\n#\n#\n" \
|
printf "#\n#\n#\n# %s/%s (%s): run_writemostly_check\n#\n#\n#\n" \
|
||||||
$vg $lv $segtype
|
$vg $lv $segtype
|
||||||
|
@ -43,7 +43,7 @@ test_lvconvert() {
|
|||||||
local finish_count=$3
|
local finish_count=$3
|
||||||
local finish_count_p1=$(($finish_count + 1))
|
local finish_count_p1=$(($finish_count + 1))
|
||||||
local finish_log_type=$4
|
local finish_log_type=$4
|
||||||
local dev_array=("$dev1" "$dev2" "$dev3" "$dev4" "$dev5")
|
local dev_array=( "$dev1" "$dev2" "$dev3" "$dev4" "$dev5" )
|
||||||
local start_log_count
|
local start_log_count
|
||||||
local finish_log_count
|
local finish_log_count
|
||||||
local max_log_count
|
local max_log_count
|
||||||
|
@ -18,7 +18,8 @@ init_lv_() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
test_blkid_() {
|
test_blkid_() {
|
||||||
local type=$(blkid -s TYPE -o value -c /dev/null "$DM_DEV_DIR/$vg/$lv1")
|
local type
|
||||||
|
type=$(blkid -s TYPE -o value -c /dev/null "$DM_DEV_DIR/$vg/$lv1")
|
||||||
test "$type" = "swap"
|
test "$type" = "swap"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,7 +22,9 @@ lv_devices_() {
|
|||||||
local lv=$1
|
local lv=$1
|
||||||
shift
|
shift
|
||||||
local devices=$@
|
local devices=$@
|
||||||
local devs=$(get lv_field $lv devices -a | sed 's/([0-9]*)//g; s/ //g; s/,/ /g')
|
local devs
|
||||||
|
|
||||||
|
devs=$(get lv_devices "$lv")
|
||||||
|
|
||||||
for d in $devs; do
|
for d in $devs; do
|
||||||
(echo "$devices" | grep $d) || return 1
|
(echo "$devices" | grep $d) || return 1
|
||||||
|
@ -75,9 +75,10 @@ rest_pvs_()
|
|||||||
local num=$2
|
local num=$2
|
||||||
local rem=
|
local rem=
|
||||||
local n
|
local n
|
||||||
|
local dev
|
||||||
|
|
||||||
for n in $(seq 1 $(($index - 1))) $(seq $(($index + 1)) $num); do
|
for n in $(seq 1 $(($index - 1))) $(seq $(($index + 1)) $num); do
|
||||||
eval local dev=$\dev$n
|
eval dev=$\dev$n
|
||||||
rem="$rem $dev"
|
rem="$rem $dev"
|
||||||
done
|
done
|
||||||
|
|
||||||
@ -223,6 +224,7 @@ done
|
|||||||
test_3way_mirror_plus_1_fail_3_()
|
test_3way_mirror_plus_1_fail_3_()
|
||||||
{
|
{
|
||||||
local index=$1
|
local index=$1
|
||||||
|
local dev
|
||||||
|
|
||||||
lvcreate -an -Zn -l2 --type mirror -m2 -n $lv1 $vg "$dev1" "$dev2" "$dev3" "$dev5":$BLOCKS
|
lvcreate -an -Zn -l2 --type mirror -m2 -n $lv1 $vg "$dev1" "$dev2" "$dev3" "$dev5":$BLOCKS
|
||||||
lvconvert -m+1 $vg/$lv1 "$dev4"
|
lvconvert -m+1 $vg/$lv1 "$dev4"
|
||||||
@ -232,9 +234,9 @@ test_3way_mirror_plus_1_fail_3_()
|
|||||||
aux disable_dev $(rest_pvs_ $index 4)
|
aux disable_dev $(rest_pvs_ $index 4)
|
||||||
vgreduce --removemissing --force $vg
|
vgreduce --removemissing --force $vg
|
||||||
lvs -a -o+devices $vg
|
lvs -a -o+devices $vg
|
||||||
eval local dev=\$dev$n
|
eval dev=\$dev$n
|
||||||
check linear $vg $lv1
|
check linear $vg $lv1
|
||||||
check lv_on $vg $lv1 "$dev"
|
check lv_on $vg $lv1 "$dev"
|
||||||
}
|
}
|
||||||
|
|
||||||
for n in $(seq 1 4); do
|
for n in $(seq 1 4); do
|
||||||
@ -278,6 +280,7 @@ done
|
|||||||
test_2way_mirror_plus_2_fail_3_()
|
test_2way_mirror_plus_2_fail_3_()
|
||||||
{
|
{
|
||||||
local index=$1
|
local index=$1
|
||||||
|
local dev
|
||||||
|
|
||||||
lvcreate -an -Zn -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev5":$BLOCKS
|
lvcreate -an -Zn -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev5":$BLOCKS
|
||||||
lvconvert -m+2 $vg/$lv1 "$dev3" "$dev4"
|
lvconvert -m+2 $vg/$lv1 "$dev3" "$dev4"
|
||||||
@ -286,7 +289,7 @@ test_2way_mirror_plus_2_fail_3_()
|
|||||||
aux disable_dev $(rest_pvs_ $index 4)
|
aux disable_dev $(rest_pvs_ $index 4)
|
||||||
vgreduce --removemissing --force $vg
|
vgreduce --removemissing --force $vg
|
||||||
lvs -a -o+devices $vg
|
lvs -a -o+devices $vg
|
||||||
eval local dev=\$dev$n
|
eval dev=\$dev$n
|
||||||
mimages_are_on_ $lv1 "$dev" || lv_is_on_ $lv1 "$dev"
|
mimages_are_on_ $lv1 "$dev" || lv_is_on_ $lv1 "$dev"
|
||||||
not mirrorlog_is_on_ $lv1 "$dev5"
|
not mirrorlog_is_on_ $lv1 "$dev5"
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,9 @@ setup_merge_() {
|
|||||||
local VG_NAME=$1
|
local VG_NAME=$1
|
||||||
local LV_NAME=$2
|
local LV_NAME=$2
|
||||||
local NUM_EXTRA_SNAPS=${3:-0}
|
local NUM_EXTRA_SNAPS=${3:-0}
|
||||||
local BASE_SNAP_LV_NAME=$(snap_lv_name_ $LV_NAME)
|
local BASE_SNAP_LV_NAME
|
||||||
|
|
||||||
|
BASE_SNAP_LV_NAME=$(snap_lv_name_ $LV_NAME)
|
||||||
|
|
||||||
lvcreate -aey -n $LV_NAME -l 50%FREE $VG_NAME
|
lvcreate -aey -n $LV_NAME -l 50%FREE $VG_NAME
|
||||||
lvcreate -s -n $BASE_SNAP_LV_NAME -l 20%FREE ${VG_NAME}/${LV_NAME}
|
lvcreate -s -n $BASE_SNAP_LV_NAME -l 20%FREE ${VG_NAME}/${LV_NAME}
|
||||||
|
@ -14,23 +14,17 @@
|
|||||||
which mkfs.ext3 || skip
|
which mkfs.ext3 || skip
|
||||||
|
|
||||||
check_logical_block_size() {
|
check_logical_block_size() {
|
||||||
local DEV_=$(cat SCSI_DEBUG_DEV)
|
|
||||||
# Verify logical_block_size - requires Linux >= 2.6.31
|
# Verify logical_block_size - requires Linux >= 2.6.31
|
||||||
SYSFS_LOGICAL_BLOCK_SIZE=$(echo /sys/block/$(basename $DEV_)/queue/logical_block_size)
|
SYSFS_LOGICAL_BLOCK_SIZE="/sys/block/$(basename $(< SCSI_DEBUG_DEV))/queue/logical_block_size"
|
||||||
if [ -f "$SYSFS_LOGICAL_BLOCK_SIZE" ] ; then
|
test -f "$SYSFS_LOGICAL_BLOCK_SIZE" || return 0
|
||||||
ACTUAL_LOGICAL_BLOCK_SIZE=$(cat $SYSFS_LOGICAL_BLOCK_SIZE)
|
test "$(< $SYSFS_LOGICAL_BLOCK_SIZE)" -eq "$1" # ACTUAL_LOGICAL_BLOCK_SIZE
|
||||||
test $ACTUAL_LOGICAL_BLOCK_SIZE = $1
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
check_optimal_io_size() {
|
check_optimal_io_size() {
|
||||||
local DEV_=$(cat SCSI_DEBUG_DEV)
|
|
||||||
# Verify optimal_io_size
|
# Verify optimal_io_size
|
||||||
SYSFS_OPTIMAL_IO_SIZE=$(echo /sys/block/$(basename $DEV_)/queue/optimal_io_size)
|
SYSFS_OPTIMAL_IO_SIZE="/sys/block/$(basename $(< SCSI_DEBUG_DEV))/queue/optimal_io_size"
|
||||||
if [ -f "$SYSFS_OPTIMAL_IO_SIZE" ] ; then
|
test -f "$SYSFS_OPTIMAL_IO_SIZE" || return 0
|
||||||
ACTUAL_OPTIMAL_IO_SIZE=$(cat $SYSFS_OPTIMAL_IO_SIZE)
|
test "$(< $SYSFS_OPTIMAL_IO_SIZE)" -eq "$1" # ACTUAL_OPTIMAL_IO_SIZE
|
||||||
test $ACTUAL_OPTIMAL_IO_SIZE = $1
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
lvdev_() {
|
lvdev_() {
|
||||||
@ -64,7 +58,7 @@ DEV_SIZE=$(($NUM_DEVS*$PER_DEV_SIZE))
|
|||||||
# Test that kernel supports topology
|
# Test that kernel supports topology
|
||||||
aux prepare_scsi_debug_dev $DEV_SIZE || skip
|
aux prepare_scsi_debug_dev $DEV_SIZE || skip
|
||||||
|
|
||||||
if [ ! -e /sys/block/$(basename $(cat SCSI_DEBUG_DEV))/alignment_offset ] ; then
|
if [ ! -e /sys/block/$(basename $(< SCSI_DEBUG_DEV))/alignment_offset ] ; then
|
||||||
aux cleanup_scsi_debug_dev
|
aux cleanup_scsi_debug_dev
|
||||||
skip
|
skip
|
||||||
fi
|
fi
|
||||||
@ -79,7 +73,9 @@ aux prepare_scsi_debug_dev $DEV_SIZE \
|
|||||||
check_logical_block_size $LOGICAL_BLOCK_SIZE
|
check_logical_block_size $LOGICAL_BLOCK_SIZE
|
||||||
|
|
||||||
aux prepare_pvs $NUM_DEVS $PER_DEV_SIZE
|
aux prepare_pvs $NUM_DEVS $PER_DEV_SIZE
|
||||||
vgcreate $vg $(cat DEVICES)
|
get_devs
|
||||||
|
|
||||||
|
vgcreate $vg "${DEVICES[@]}"
|
||||||
test_snapshot_mount
|
test_snapshot_mount
|
||||||
vgremove $vg
|
vgremove $vg
|
||||||
|
|
||||||
@ -94,7 +90,7 @@ aux prepare_scsi_debug_dev $DEV_SIZE \
|
|||||||
check_logical_block_size $LOGICAL_BLOCK_SIZE
|
check_logical_block_size $LOGICAL_BLOCK_SIZE
|
||||||
|
|
||||||
aux prepare_pvs $NUM_DEVS $PER_DEV_SIZE
|
aux prepare_pvs $NUM_DEVS $PER_DEV_SIZE
|
||||||
vgcreate $vg $(cat DEVICES)
|
vgcreate $vg "${DEVICES[@]}"
|
||||||
test_snapshot_mount
|
test_snapshot_mount
|
||||||
vgremove $vg
|
vgremove $vg
|
||||||
|
|
||||||
@ -109,7 +105,7 @@ aux prepare_scsi_debug_dev $DEV_SIZE \
|
|||||||
check_logical_block_size $LOGICAL_BLOCK_SIZE
|
check_logical_block_size $LOGICAL_BLOCK_SIZE
|
||||||
|
|
||||||
aux prepare_pvs $NUM_DEVS $PER_DEV_SIZE
|
aux prepare_pvs $NUM_DEVS $PER_DEV_SIZE
|
||||||
vgcreate $vg $(cat DEVICES)
|
vgcreate $vg "${DEVICES[@]}"
|
||||||
test_snapshot_mount
|
test_snapshot_mount
|
||||||
vgremove $vg
|
vgremove $vg
|
||||||
|
|
||||||
@ -126,6 +122,6 @@ check_logical_block_size $LOGICAL_BLOCK_SIZE
|
|||||||
check_optimal_io_size 786432
|
check_optimal_io_size 786432
|
||||||
|
|
||||||
aux prepare_pvs 1 $PER_DEV_SIZE
|
aux prepare_pvs 1 $PER_DEV_SIZE
|
||||||
check pv_field $(cat DEVICES) pe_start 768.00k
|
check pv_field "${DEVICES[@]}" pe_start 768.00k
|
||||||
|
|
||||||
aux cleanup_scsi_debug_dev
|
aux cleanup_scsi_debug_dev
|
||||||
|
Loading…
Reference in New Issue
Block a user