mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-05 13:18:20 +03:00
tests: restore some test changes
Restore existing tests and separate new tests for new options later. Keep coverage for existing syntax Reverts bits from commits:a801b92b2c
.d71aaca07b
fa2a728a39
1e2420bca8
46abc28a48
0e3e611a13
This commit is contained in:
parent
3018cdcaa7
commit
f8034e14e6
@ -33,7 +33,7 @@ lvcreate -L3 -n cow $vg
|
|||||||
not lvconvert -s cow $vg/$lv1
|
not lvconvert -s cow $vg/$lv1
|
||||||
|
|
||||||
# Use cached LV with 'striped' cow volume
|
# Use cached LV with 'striped' cow volume
|
||||||
lvconvert -y -s $vg/$lv1 $vg/cow
|
lvconvert -y -s $vg/$lv1 cow
|
||||||
check lv_field $vg/cow segtype linear
|
check lv_field $vg/cow segtype linear
|
||||||
check lv_field $vg/$lv1 segtype cache
|
check lv_field $vg/$lv1 segtype cache
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ check lv_field $vg/$lv2 cache_settings "random_threshold=56,sequential_threshold
|
|||||||
# Check swap of cache pool metadata
|
# Check swap of cache pool metadata
|
||||||
lvconvert --yes --type cache-pool --poolmetadata $lv4 $vg/$lv3
|
lvconvert --yes --type cache-pool --poolmetadata $lv4 $vg/$lv3
|
||||||
UUID=$(get lv_field $vg/$lv5 uuid)
|
UUID=$(get lv_field $vg/$lv5 uuid)
|
||||||
lvconvert --yes --swapmetadata --poolmetadata $lv5 $vg/$lv3
|
lvconvert --yes --cachepool $vg/$lv3 --poolmetadata $lv5
|
||||||
check lv_field $vg/${lv3}_cmeta uuid "$UUID"
|
check lv_field $vg/${lv3}_cmeta uuid "$UUID"
|
||||||
|
|
||||||
|
|
||||||
@ -108,30 +108,32 @@ lvcreate -an -Zn -L 8 -n $lv4 $vg
|
|||||||
invalid lvconvert --type cache --poolmetadata $vg/$lv2 $vg/$lv1
|
invalid lvconvert --type cache --poolmetadata $vg/$lv2 $vg/$lv1
|
||||||
|
|
||||||
# Cannot mix with thins
|
# Cannot mix with thins
|
||||||
not lvconvert --type cache --poolmetadata $vg/$lv2 --thinpool $vg/$lv1
|
invalid lvconvert --type cache --poolmetadata $vg/$lv2 --thinpool $vg/$lv1
|
||||||
not lvconvert --type cache --thin --poolmetadata $vg/$lv2 $vg/$lv1
|
invalid lvconvert --type cache --thin --poolmetadata $vg/$lv2 $vg/$lv1
|
||||||
|
|
||||||
# Undefined cached volume
|
# Undefined cached volume
|
||||||
not lvconvert --type cache --cachepool $vg/$lv1
|
invalid lvconvert --type cache --cachepool $vg/$lv1
|
||||||
not lvconvert --cache --cachepool $vg/$lv1
|
invalid lvconvert --cache --cachepool $vg/$lv1
|
||||||
|
|
||||||
|
# FIXME: temporarily we return error code 5
|
||||||
|
INVALID=not
|
||||||
# Single vg is required
|
# Single vg is required
|
||||||
not lvconvert --type cache --cachepool $vg/$lv1 --poolmetadata $vg1/$lv2 $vg/$lv3
|
$INVALID lvconvert --type cache --cachepool $vg/$lv1 --poolmetadata $vg1/$lv2 $vg/$lv3
|
||||||
not lvconvert --type cache --cachepool $vg/$lv1 --poolmetadata $lv2 $vg1/$lv3
|
$INVALID lvconvert --type cache --cachepool $vg/$lv1 --poolmetadata $lv2 $vg1/$lv3
|
||||||
not lvconvert --type cache --cachepool $vg1/$lv1 --poolmetadata $vg2/$lv2 $vg/$lv3
|
$INVALID lvconvert --type cache --cachepool $vg1/$lv1 --poolmetadata $vg2/$lv2 $vg/$lv3
|
||||||
not lvconvert --type cache-pool --poolmetadata $vg2/$lv2 $vg1/$lv1
|
$INVALID lvconvert --type cache-pool --poolmetadata $vg2/$lv2 $vg1/$lv1
|
||||||
|
|
||||||
not lvconvert --cachepool $vg1/$lv1 --poolmetadata $vg2/$lv2
|
$INVALID lvconvert --cachepool $vg1/$lv1 --poolmetadata $vg2/$lv2
|
||||||
|
|
||||||
# Invalid syntax, vg is unknown
|
# Invalid syntax, vg is unknown
|
||||||
not lvconvert --yes --cachepool $lv3 --poolmetadata $lv4
|
$INVALID lvconvert --yes --cachepool $lv3 --poolmetadata $lv4
|
||||||
|
|
||||||
# Invalid chunk size is <32KiB >1GiB
|
# Invalid chunk size is <32KiB >1GiB
|
||||||
not lvconvert --type cache-pool --chunksize 16 --poolmetadata $lv2 $vg/$lv1
|
$INVALID lvconvert --type cache-pool --chunksize 16 --poolmetadata $lv2 $vg/$lv1
|
||||||
not lvconvert --type cache-pool --chunksize 2G --poolmetadata $lv2 $vg/$lv1
|
$INVALID lvconvert --type cache-pool --chunksize 2G --poolmetadata $lv2 $vg/$lv1
|
||||||
|
|
||||||
# Invalid chunk size is bigger then data size, needs to open VG
|
# Invalid chunk size is bigger then data size, needs to open VG
|
||||||
not lvconvert --yes --type cache-pool --chunksize 16M --poolmetadata $lv2 $vg/$lv1
|
fail lvconvert --yes --type cache-pool --chunksize 16M --poolmetadata $lv2 $vg/$lv1
|
||||||
|
|
||||||
lvremove -f $vg
|
lvremove -f $vg
|
||||||
|
|
||||||
@ -142,7 +144,7 @@ lvcreate --type cache-pool -an -v -L 2 -n cpool $vg
|
|||||||
lvcreate -H -L 4 -n corigin --cachepool $vg/cpool
|
lvcreate -H -L 4 -n corigin --cachepool $vg/cpool
|
||||||
|
|
||||||
# unsupported yet
|
# unsupported yet
|
||||||
not lvconvert --repair $vg/cpool 2>&1 | tee out
|
fail lvconvert --repair $vg/cpool 2>&1 | tee out
|
||||||
#grep "Cannot convert internal LV" out
|
#grep "Cannot convert internal LV" out
|
||||||
|
|
||||||
lvremove -f $vg
|
lvremove -f $vg
|
||||||
@ -154,13 +156,13 @@ lvcreate --type cache-pool -L10 $vg/$lv1
|
|||||||
lvcreate --cache -L20 $vg/$lv1
|
lvcreate --cache -L20 $vg/$lv1
|
||||||
lvcreate -L10 -n $lv2 $vg
|
lvcreate -L10 -n $lv2 $vg
|
||||||
|
|
||||||
not lvconvert --yes --type cache $vg/$lv2 --cachepool $vg/$lv1
|
fail lvconvert --yes --type cache $vg/$lv2 --cachepool $vg/$lv1
|
||||||
not lvconvert --yes --type cache $vg/$lv1 --cachepool $vg/$lv2
|
fail lvconvert --yes --type cache $vg/$lv1 --cachepool $vg/$lv2
|
||||||
not lvconvert --yes --type cache-pool $vg/$lv1
|
fail lvconvert --yes --type cache-pool $vg/$lv1
|
||||||
not lvconvert --yes --type mirror -m1 $vg/$lv1
|
fail lvconvert --yes --type mirror -m1 $vg/$lv1
|
||||||
not aux have_raid 1 0 0 || fail lvconvert --yes --type raid1 -m1 $vg/$lv1
|
not aux have_raid 1 0 0 || fail lvconvert --yes --type raid1 -m1 $vg/$lv1
|
||||||
not lvconvert --yes --type snapshot $vg/$lv1 $vg/$lv2
|
fail lvconvert --yes --type snapshot $vg/$lv1 $vg/$lv2
|
||||||
not lvconvert --yes --type snapshot $vg/$lv2 $vg/$lv1
|
fail lvconvert --yes --type snapshot $vg/$lv2 $vg/$lv1
|
||||||
not aux have_thin 1 0 0 || fail lvconvert --yes -T --thinpool $vg/$lv2 $vg/$lv1
|
not aux have_thin 1 0 0 || fail lvconvert --yes -T --thinpool $vg/$lv2 $vg/$lv1
|
||||||
|
|
||||||
lvremove -f $vg
|
lvremove -f $vg
|
||||||
|
@ -87,7 +87,7 @@ aux delay_dev "$dev2" 0 2000 ${offset}:1
|
|||||||
lvcreate -aey -l5 -Zn -Wn --type mirror --regionsize 16K -m2 -n $lv1 $vg "$dev1" "$dev2" "$dev4" "$dev3:$DEVRANGE"
|
lvcreate -aey -l5 -Zn -Wn --type mirror --regionsize 16K -m2 -n $lv1 $vg "$dev1" "$dev2" "$dev4" "$dev3:$DEVRANGE"
|
||||||
should not lvconvert -m-1 $vg/$lv1 "$dev1"
|
should not lvconvert -m-1 $vg/$lv1 "$dev1"
|
||||||
aux enable_dev "$dev2"
|
aux enable_dev "$dev2"
|
||||||
lvconvert --startpoll $vg/$lv1 || true # wait
|
should lvconvert $vg/$lv1 # wait
|
||||||
lvconvert -m2 $vg/$lv1 "$dev1" "$dev2" "$dev4" "$dev3:0" # If the above "should" failed...
|
lvconvert -m2 $vg/$lv1 "$dev1" "$dev2" "$dev4" "$dev3:0" # If the above "should" failed...
|
||||||
|
|
||||||
aux wait_for_sync $vg $lv1
|
aux wait_for_sync $vg $lv1
|
||||||
@ -113,7 +113,7 @@ LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+1 -b $vg/$lv1 "$dev4"
|
|||||||
# Next convert should fail b/c we can't have 2 at once
|
# Next convert should fail b/c we can't have 2 at once
|
||||||
should not lvconvert -m+1 $vg/$lv1 "$dev5"
|
should not lvconvert -m+1 $vg/$lv1 "$dev5"
|
||||||
aux enable_dev "$dev4"
|
aux enable_dev "$dev4"
|
||||||
lvconvert --startpoll $vg/$lv1 || true # wait
|
should lvconvert $vg/$lv1 # wait
|
||||||
lvconvert -m2 $vg/$lv1 # In case the above "should" actually failed
|
lvconvert -m2 $vg/$lv1 # In case the above "should" actually failed
|
||||||
|
|
||||||
check mirror $vg $lv1 "$dev3"
|
check mirror $vg $lv1 "$dev3"
|
||||||
@ -156,7 +156,7 @@ lvcreate -aey -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev3:$DEVRANGE
|
|||||||
lvchange -an $vg/$lv1
|
lvchange -an $vg/$lv1
|
||||||
lvconvert -m+1 $vg/$lv1 "$dev4"
|
lvconvert -m+1 $vg/$lv1 "$dev4"
|
||||||
lvchange -aey $vg/$lv1
|
lvchange -aey $vg/$lv1
|
||||||
lvconvert --startpoll $vg/$lv1 || true # wait
|
should lvconvert $vg/$lv1 # wait
|
||||||
check mirror $vg $lv1 "$dev3"
|
check mirror $vg $lv1 "$dev3"
|
||||||
check mirror_no_temporaries $vg $lv1
|
check mirror_no_temporaries $vg $lv1
|
||||||
lvremove -ff $vg
|
lvremove -ff $vg
|
||||||
@ -168,7 +168,7 @@ lvremove -ff $vg
|
|||||||
lvcreate -aey -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev3:$DEVRANGE"
|
lvcreate -aey -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev3:$DEVRANGE"
|
||||||
LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+1 -b $vg/$lv1 "$dev4"
|
LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+1 -b $vg/$lv1 "$dev4"
|
||||||
lvconvert -m-1 $vg/$lv1 "$dev4"
|
lvconvert -m-1 $vg/$lv1 "$dev4"
|
||||||
lvconvert --startpoll $vg/$lv1 || true # wait
|
should lvconvert $vg/$lv1 # wait
|
||||||
|
|
||||||
check mirror $vg $lv1 "$dev3"
|
check mirror $vg $lv1 "$dev3"
|
||||||
check mirror_no_temporaries $vg $lv1
|
check mirror_no_temporaries $vg $lv1
|
||||||
@ -179,7 +179,7 @@ lvremove -ff $vg
|
|||||||
lvcreate -aey -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev3:$DEVRANGE"
|
lvcreate -aey -l2 --type mirror -m1 -n $lv1 $vg "$dev1" "$dev2" "$dev3:$DEVRANGE"
|
||||||
LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+2 -b $vg/$lv1 "$dev4" "$dev5"
|
LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+2 -b $vg/$lv1 "$dev4" "$dev5"
|
||||||
lvconvert -m-1 $vg/$lv1 "$dev4"
|
lvconvert -m-1 $vg/$lv1 "$dev4"
|
||||||
lvconvert --startpoll $vg/$lv1 || true # wait
|
should lvconvert $vg/$lv1 # wait
|
||||||
|
|
||||||
check mirror $vg $lv1 "$dev3"
|
check mirror $vg $lv1 "$dev3"
|
||||||
check mirror_no_temporaries $vg $lv1
|
check mirror_no_temporaries $vg $lv1
|
||||||
@ -192,9 +192,9 @@ LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+1 -b $vg/$lv1 "$dev4"
|
|||||||
# FIXME: Extra wait here for mirror upconvert synchronization
|
# FIXME: Extra wait here for mirror upconvert synchronization
|
||||||
# otherwise we may fail her on parallel upconvert and downconvert
|
# otherwise we may fail her on parallel upconvert and downconvert
|
||||||
# lvconvert-mirror-updown.sh tests this errornous case separately
|
# lvconvert-mirror-updown.sh tests this errornous case separately
|
||||||
lvconvert --startpoll $vg/$lv1 || true
|
should lvconvert $vg/$lv1
|
||||||
lvconvert -m-1 $vg/$lv1 "$dev2"
|
lvconvert -m-1 $vg/$lv1 "$dev2"
|
||||||
lvconvert --startpoll $vg/$lv1 || true
|
should lvconvert $vg/$lv1
|
||||||
|
|
||||||
check mirror $vg $lv1 "$dev3"
|
check mirror $vg $lv1 "$dev3"
|
||||||
check mirror_no_temporaries $vg $lv1
|
check mirror_no_temporaries $vg $lv1
|
||||||
@ -207,9 +207,9 @@ LVM_TEST_TAG="kill_me_$PREFIX" lvconvert -m+1 -b $vg/$lv1 "$dev4"
|
|||||||
# FIXME: Extra wait here for mirror upconvert synchronization
|
# FIXME: Extra wait here for mirror upconvert synchronization
|
||||||
# otherwise we may fail her on parallel upconvert and downconvert
|
# otherwise we may fail her on parallel upconvert and downconvert
|
||||||
# lvconvert-mirror-updown.sh tests this errornous case separately
|
# lvconvert-mirror-updown.sh tests this errornous case separately
|
||||||
lvconvert --startpoll $vg/$lv1 || true
|
should lvconvert $vg/$lv1
|
||||||
lvconvert -m-1 $vg/$lv1 "$dev2"
|
lvconvert -m-1 $vg/$lv1 "$dev2"
|
||||||
lvconvert --startpoll $vg/$lv1 || true
|
should lvconvert $vg/$lv1
|
||||||
|
|
||||||
check mirror $vg $lv1 "$dev3"
|
check mirror $vg $lv1 "$dev3"
|
||||||
check mirror_no_temporaries $vg $lv1
|
check mirror_no_temporaries $vg $lv1
|
||||||
|
@ -45,7 +45,7 @@ lvchange -an $vg/$lv2 $vg/$lv1 $vg/pool $vg/repair
|
|||||||
|
|
||||||
# Manual repair steps:
|
# Manual repair steps:
|
||||||
# Test swapping - swap out thin-pool's metadata with our repair volume
|
# Test swapping - swap out thin-pool's metadata with our repair volume
|
||||||
lvconvert -y -f --swapmetadata --poolmetadata $vg/repair $vg/pool
|
lvconvert -y -f --poolmetadata $vg/repair --thinpool $vg/pool
|
||||||
|
|
||||||
lvchange -ay $vg/repair
|
lvchange -ay $vg/repair
|
||||||
|
|
||||||
@ -74,7 +74,7 @@ not "$LVM_TEST_THIN_DUMP_CMD" "$DM_DEV_DIR/$vg/repair" | tee dump
|
|||||||
lvchange -an $vg
|
lvchange -an $vg
|
||||||
|
|
||||||
# Swap repaired metadata back
|
# Swap repaired metadata back
|
||||||
lvconvert -y -f --swapmetadata --poolmetadata $vg/fixed $vg/pool
|
lvconvert -y -f --poolmetadata $vg/fixed --thinpool $vg/pool
|
||||||
|
|
||||||
# Check pool still preserves its original settings
|
# Check pool still preserves its original settings
|
||||||
check lv_field $vg/pool chunksize "128.00k"
|
check lv_field $vg/pool chunksize "128.00k"
|
||||||
@ -87,7 +87,7 @@ vgchange -ay $vg
|
|||||||
vgchange -an $vg
|
vgchange -an $vg
|
||||||
|
|
||||||
# Put back 'broken' metadata
|
# Put back 'broken' metadata
|
||||||
lvconvert -y -f --swapmetadata --poolmetadata $vg/repair $vg/pool
|
lvconvert -y -f --poolmetadata $vg/repair --thinpool $vg/pool
|
||||||
|
|
||||||
# Check --repair usage
|
# Check --repair usage
|
||||||
lvconvert -v --repair $vg/pool
|
lvconvert -v --repair $vg/pool
|
||||||
@ -98,7 +98,7 @@ lvchange -ay $vg/pool
|
|||||||
vgchange -an $vg
|
vgchange -an $vg
|
||||||
|
|
||||||
# Restore damaged metadata
|
# Restore damaged metadata
|
||||||
lvconvert -y -f --swapmetadata --poolmetadata $vg/pool_meta0 $vg/pool
|
lvconvert -y -f --poolmetadata $vg/pool_meta0 --thinpool $vg/pool
|
||||||
|
|
||||||
# Check lvremove -ff works even with damaged pool
|
# Check lvremove -ff works even with damaged pool
|
||||||
lvremove -ff $vg
|
lvremove -ff $vg
|
||||||
|
@ -29,9 +29,11 @@ aux wait_for_sync $vg $lv1
|
|||||||
aux wait_for_sync $vg $lv2
|
aux wait_for_sync $vg $lv2
|
||||||
lvchange -an $vg/$lv1
|
lvchange -an $vg/$lv1
|
||||||
|
|
||||||
|
# FIXME: temporarily we return error code 5
|
||||||
|
INVALID=not
|
||||||
# conversion fails for internal volumes
|
# conversion fails for internal volumes
|
||||||
not lvconvert --thinpool $vg/${lv1}_rimage_0
|
$INVALID lvconvert --thinpool $vg/${lv1}_rimage_0
|
||||||
not lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $vg/${lv2}_rimage_0
|
$INVALID lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $vg/${lv2}_rimage_0
|
||||||
|
|
||||||
lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
|
|
||||||
|
@ -57,14 +57,17 @@ lvchange -an $vg/$lv1
|
|||||||
|
|
||||||
# conversion fails for mirror segment type
|
# conversion fails for mirror segment type
|
||||||
fail lvconvert --thinpool $vg/$lv1
|
fail lvconvert --thinpool $vg/$lv1
|
||||||
|
|
||||||
|
# FIXME: temporarily we return error code 5
|
||||||
|
INVALID=not
|
||||||
# cannot use same LV
|
# cannot use same LV
|
||||||
not lvconvert --yes --thinpool $vg/$lv2 --poolmetadata $vg/$lv2
|
$INVALID lvconvert --yes --thinpool $vg/$lv2 --poolmetadata $vg/$lv2
|
||||||
|
|
||||||
prepare_lvs
|
prepare_lvs
|
||||||
|
|
||||||
# conversion fails for internal volumes
|
# conversion fails for internal volumes
|
||||||
# can't use --readahead with --poolmetadata
|
# can't use --readahead with --poolmetadata
|
||||||
not lvconvert --thinpool $vg/$lv1 --poolmetadata $vg/$lv2 --readahead 512
|
invalid lvconvert --thinpool $vg/$lv1 --poolmetadata $vg/$lv2 --readahead 512
|
||||||
lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
|
|
||||||
prepare_lvs
|
prepare_lvs
|
||||||
@ -81,9 +84,9 @@ grep "Pool zeroing and large" err
|
|||||||
UUID=$(get lv_field $vg/$lv2 uuid)
|
UUID=$(get lv_field $vg/$lv2 uuid)
|
||||||
# Fail is pool is active
|
# Fail is pool is active
|
||||||
# TODO maybe detect inactive pool and deactivate
|
# TODO maybe detect inactive pool and deactivate
|
||||||
fail lvconvert --swapmetadata --yes --poolmetadata $lv2 $vg/$lv1
|
fail lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $lv2
|
||||||
lvchange -an $vg
|
lvchange -an $vg
|
||||||
lvconvert --swapmetadata --yes --poolmetadata $lv2 $vg/$lv1
|
lvconvert --yes --thinpool $vg/$lv1 --poolmetadata $lv2
|
||||||
check lv_field $vg/${lv1}_tmeta uuid "$UUID"
|
check lv_field $vg/${lv1}_tmeta uuid "$UUID"
|
||||||
lvremove -f $vg
|
lvremove -f $vg
|
||||||
|
|
||||||
@ -96,20 +99,20 @@ lvcreate -L1M -n $lv3 $vg
|
|||||||
# chunk size is bigger then size of thin pool data
|
# chunk size is bigger then size of thin pool data
|
||||||
fail lvconvert --yes -c 1G --thinpool $vg/$lv3
|
fail lvconvert --yes -c 1G --thinpool $vg/$lv3
|
||||||
# stripes can't be used with poolmetadata
|
# stripes can't be used with poolmetadata
|
||||||
not lvconvert --stripes 2 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
invalid lvconvert --stripes 2 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
# too small metadata (<2M)
|
# too small metadata (<2M)
|
||||||
fail lvconvert --yes -c 64 --thinpool $vg/$lv1 --poolmetadata $vg/$lv3
|
fail lvconvert --yes -c 64 --thinpool $vg/$lv1 --poolmetadata $vg/$lv3
|
||||||
# too small chunk size fails
|
# too small chunk size fails
|
||||||
not lvconvert -c 4 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
$INVALID lvconvert -c 4 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
# too big chunk size fails
|
# too big chunk size fails
|
||||||
not lvconvert -c 2G --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
$INVALID lvconvert -c 2G --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
# negative chunk size fails
|
# negative chunk size fails
|
||||||
not lvconvert -c -256 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
$INVALID lvconvert -c -256 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
# non multiple of 64KiB fails
|
# non multiple of 64KiB fails
|
||||||
not lvconvert -c 88 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
$INVALID lvconvert -c 88 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2
|
||||||
|
|
||||||
# cannot use same LV for pool and convertion
|
# cannot use same LV for pool and convertion
|
||||||
not lvconvert --yes --thinpool $vg/$lv3 -T $vg/$lv3
|
$INVALID lvconvert --yes --thinpool $vg/$lv3 -T $vg/$lv3
|
||||||
|
|
||||||
# Warning about smaller then suggested
|
# Warning about smaller then suggested
|
||||||
lvconvert --yes -c 256 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2 2>&1 | tee err
|
lvconvert --yes -c 256 --thinpool $vg/$lv1 --poolmetadata $vg/$lv2 2>&1 | tee err
|
||||||
@ -129,7 +132,7 @@ if test "$TSIZE" = 64T; then
|
|||||||
lvcreate -L24T -n $lv1 $vg
|
lvcreate -L24T -n $lv1 $vg
|
||||||
# Warning about bigger then needed (24T data and 16G -> 128K chunk)
|
# Warning about bigger then needed (24T data and 16G -> 128K chunk)
|
||||||
lvconvert --yes -c 64 --thinpool $vg/$lv1 2>&1 | tee err
|
lvconvert --yes -c 64 --thinpool $vg/$lv1 2>&1 | tee err
|
||||||
grep "too small" err
|
grep "WARNING: Chunk size is too small" err
|
||||||
lvremove -f $vg
|
lvremove -f $vg
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -57,6 +57,7 @@ fail lvcreate -l 1 --cachepool pool8 $vg
|
|||||||
# no size specified
|
# no size specified
|
||||||
invalid lvcreate --cachepool pool $vg 2>&1 | tee err
|
invalid lvcreate --cachepool pool $vg 2>&1 | tee err
|
||||||
#grep "specify either size or extents" err
|
#grep "specify either size or extents" err
|
||||||
|
grep "Incorrect syntax" err
|
||||||
|
|
||||||
# Check nothing has been created yet
|
# Check nothing has been created yet
|
||||||
check vg_field $vg lv_count 0
|
check vg_field $vg lv_count 0
|
||||||
|
@ -38,7 +38,7 @@ lvchange -an $vg
|
|||||||
|
|
||||||
lvcreate -L2M -n $lv1 $vg
|
lvcreate -L2M -n $lv1 $vg
|
||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
lvconvert -y --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
|
|
||||||
# Cannot resize if set to 0%
|
# Cannot resize if set to 0%
|
||||||
not lvextend --use-policies --config 'activation{thin_pool_autoextend_percent = 0}' $vg/pool 2>&1 | tee err
|
not lvextend --use-policies --config 'activation{thin_pool_autoextend_percent = 0}' $vg/pool 2>&1 | tee err
|
||||||
|
@ -78,7 +78,7 @@ fake_metadata_ 400 2 >data
|
|||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
|
|
||||||
# Swap volume with restored fake metadata
|
# Swap volume with restored fake metadata
|
||||||
lvconvert -y --chunksize 64k --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --chunksize 64k --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
|
|
||||||
# Not alllowed when thin-pool metadata free space is <75% for 2M meta
|
# Not alllowed when thin-pool metadata free space is <75% for 2M meta
|
||||||
fail lvcreate -V20 $vg/pool
|
fail lvcreate -V20 $vg/pool
|
||||||
@ -91,7 +91,7 @@ lvchange -an $vg/pool
|
|||||||
fake_metadata_ 7400 2 >data
|
fake_metadata_ 7400 2 >data
|
||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv2"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv2"
|
||||||
# Swap volume with restored fake metadata
|
# Swap volume with restored fake metadata
|
||||||
lvconvert -y --chunksize 64k --swapmetadata --poolmetadata $vg/$lv2 $vg/pool
|
lvconvert -y --chunksize 64k --thinpool $vg/pool --poolmetadata $vg/$lv2
|
||||||
lvchange -ay $vg/pool
|
lvchange -ay $vg/pool
|
||||||
# Check generated metadata consume more then 88%
|
# Check generated metadata consume more then 88%
|
||||||
test "$(meta_percent_)" -gt "88"
|
test "$(meta_percent_)" -gt "88"
|
||||||
@ -138,7 +138,7 @@ lvchange -an $vg/thin $vg/thin2 $vg/pool
|
|||||||
# Transaction_id is lower by 1 and there are no messages -> ERROR
|
# Transaction_id is lower by 1 and there are no messages -> ERROR
|
||||||
fake_metadata_ 10 0 >data
|
fake_metadata_ 10 0 >data
|
||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
lvconvert -y --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
not vgchange -ay $vg 2>&1 | tee out
|
not vgchange -ay $vg 2>&1 | tee out
|
||||||
grep expected out
|
grep expected out
|
||||||
|
|
||||||
@ -147,7 +147,7 @@ check inactive $vg pool_tmeta
|
|||||||
# Transaction_id is higher by 1
|
# Transaction_id is higher by 1
|
||||||
fake_metadata_ 10 3 >data
|
fake_metadata_ 10 3 >data
|
||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
lvconvert -y --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
not vgchange -ay $vg 2>&1 | tee out
|
not vgchange -ay $vg 2>&1 | tee out
|
||||||
grep expected out
|
grep expected out
|
||||||
|
|
||||||
@ -158,7 +158,7 @@ fake_metadata_ 400 2 >data
|
|||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
|
|
||||||
# Swap volume with restored fake metadata
|
# Swap volume with restored fake metadata
|
||||||
lvconvert -y --chunksize 64k --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --chunksize 64k --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
|
|
||||||
vgchange -ay $vg
|
vgchange -ay $vg
|
||||||
|
|
||||||
@ -173,7 +173,7 @@ fake_metadata_ 350 2 >data
|
|||||||
lvchange -ay $vg/$lv1
|
lvchange -ay $vg/$lv1
|
||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
|
|
||||||
lvconvert -y --chunksize 64k --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --chunksize 64k --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
lvchange -ay $vg/pool $vg/$lv1
|
lvchange -ay $vg/pool $vg/$lv1
|
||||||
lvs -a $vg
|
lvs -a $vg
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ mkdir test_mnt
|
|||||||
|
|
||||||
setup_merge_ $vg1 $lv1
|
setup_merge_ $vg1 $lv1
|
||||||
mount "$(lvdev_ $vg1 $lv1)" test_mnt
|
mount "$(lvdev_ $vg1 $lv1)" test_mnt
|
||||||
lvconvert --mergesnapshot $vg1/$(snap_lv_name_ $lv1)
|
lvconvert --merge $vg1/$(snap_lv_name_ $lv1)
|
||||||
umount test_mnt
|
umount test_mnt
|
||||||
vgchange -an $vg1
|
vgchange -an $vg1
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ snap_and_merge() {
|
|||||||
SLEEP_PID=$(aux hold_device_open $vg $lv1 20)
|
SLEEP_PID=$(aux hold_device_open $vg $lv1 20)
|
||||||
|
|
||||||
# initiate background merge
|
# initiate background merge
|
||||||
lvconvert -b --mergesnapshot $vg/$lv2
|
lvconvert -b --merge $vg/$lv2
|
||||||
|
|
||||||
lvs -a -o+lv_merging,lv_merge_failed $vg
|
lvs -a -o+lv_merging,lv_merge_failed $vg
|
||||||
get lv_field $vg/$lv1 lv_attr | grep "Owi-ao"
|
get lv_field $vg/$lv1 lv_attr | grep "Owi-ao"
|
||||||
|
@ -51,15 +51,15 @@ mkdir test_mnt
|
|||||||
# test full merge of a single LV
|
# test full merge of a single LV
|
||||||
setup_merge_ $vg $lv1
|
setup_merge_ $vg $lv1
|
||||||
|
|
||||||
# make sure lvconvert --mergesnapshot requires explicit LV listing
|
# make sure lvconvert --merge requires explicit LV listing
|
||||||
not lvconvert --mergesnapshot
|
not lvconvert --merge
|
||||||
lvconvert --mergesnapshot $vg/$(snap_lv_name_ $lv1)
|
lvconvert --merge $vg/$(snap_lv_name_ $lv1)
|
||||||
lvremove -f $vg/$lv1
|
lvremove -f $vg/$lv1
|
||||||
|
|
||||||
|
|
||||||
# test that an actively merging snapshot may not be removed
|
# test that an actively merging snapshot may not be removed
|
||||||
setup_merge_ $vg $lv1
|
setup_merge_ $vg $lv1
|
||||||
lvconvert -i+100 --mergesnapshot --background $vg/$(snap_lv_name_ $lv1)
|
lvconvert -i+100 --merge --background $vg/$(snap_lv_name_ $lv1)
|
||||||
not lvremove -f $vg/$(snap_lv_name_ $lv1)
|
not lvremove -f $vg/$(snap_lv_name_ $lv1)
|
||||||
lvremove -f $vg/$lv1
|
lvremove -f $vg/$lv1
|
||||||
|
|
||||||
@ -67,7 +67,7 @@ lvremove -f $vg/$lv1
|
|||||||
# "onactivate merge" test
|
# "onactivate merge" test
|
||||||
setup_merge_ $vg $lv1
|
setup_merge_ $vg $lv1
|
||||||
mount "$(lvdev_ $vg $lv1)" test_mnt
|
mount "$(lvdev_ $vg $lv1)" test_mnt
|
||||||
lvconvert --mergesnapshot $vg/$(snap_lv_name_ $lv1)
|
lvconvert --merge $vg/$(snap_lv_name_ $lv1)
|
||||||
# -- refresh LV while FS is still mounted (merge must not start),
|
# -- refresh LV while FS is still mounted (merge must not start),
|
||||||
# verify 'snapshot-origin' target is still being used
|
# verify 'snapshot-origin' target is still being used
|
||||||
lvchange --refresh $vg/$lv1
|
lvchange --refresh $vg/$lv1
|
||||||
@ -88,7 +88,7 @@ lvremove -f $vg/$lv1
|
|||||||
# to make sure preload of origin's metadata is _not_ performed
|
# to make sure preload of origin's metadata is _not_ performed
|
||||||
setup_merge_ $vg $lv1
|
setup_merge_ $vg $lv1
|
||||||
mount "$(lvdev_ $vg $lv1)" test_mnt
|
mount "$(lvdev_ $vg $lv1)" test_mnt
|
||||||
lvconvert --mergesnapshot $vg/$(snap_lv_name_ $lv1)
|
lvconvert --merge $vg/$(snap_lv_name_ $lv1)
|
||||||
# -- refresh LV while FS is still mounted (merge must not start),
|
# -- refresh LV while FS is still mounted (merge must not start),
|
||||||
# verify 'snapshot-origin' target is still being used
|
# verify 'snapshot-origin' target is still being used
|
||||||
lvchange --refresh $vg/$lv1
|
lvchange --refresh $vg/$lv1
|
||||||
@ -99,7 +99,7 @@ lvremove -f $vg/$lv1
|
|||||||
|
|
||||||
# test multiple snapshot merge; tests copy out that is driven by merge
|
# test multiple snapshot merge; tests copy out that is driven by merge
|
||||||
setup_merge_ $vg $lv1 1
|
setup_merge_ $vg $lv1 1
|
||||||
lvconvert --mergesnapshot $vg/$(snap_lv_name_ $lv1)
|
lvconvert --merge $vg/$(snap_lv_name_ $lv1)
|
||||||
lvremove -f $vg/$lv1
|
lvremove -f $vg/$lv1
|
||||||
|
|
||||||
|
|
||||||
@ -108,7 +108,7 @@ setup_merge_ $vg $lv1
|
|||||||
setup_merge_ $vg $lv2
|
setup_merge_ $vg $lv2
|
||||||
lvchange --addtag this_is_a_test $vg/$(snap_lv_name_ $lv1)
|
lvchange --addtag this_is_a_test $vg/$(snap_lv_name_ $lv1)
|
||||||
lvchange --addtag this_is_a_test $vg/$(snap_lv_name_ $lv2)
|
lvchange --addtag this_is_a_test $vg/$(snap_lv_name_ $lv2)
|
||||||
lvconvert --mergesnapshot @this_is_a_test
|
lvconvert --merge @this_is_a_test
|
||||||
lvs $vg | tee out
|
lvs $vg | tee out
|
||||||
not grep $(snap_lv_name_ $lv1) out
|
not grep $(snap_lv_name_ $lv1) out
|
||||||
not grep $(snap_lv_name_ $lv2) out
|
not grep $(snap_lv_name_ $lv2) out
|
||||||
|
@ -71,7 +71,7 @@ aux prepare_thin_metadata 490 1 | tee data
|
|||||||
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
"$LVM_TEST_THIN_RESTORE_CMD" -i data -o "$DM_DEV_DIR/mapper/$vg-$lv1"
|
||||||
|
|
||||||
# Swap volume with restored fake metadata
|
# Swap volume with restored fake metadata
|
||||||
lvconvert -y --swapmetadata --poolmetadata $vg/$lv1 $vg/pool
|
lvconvert -y --thinpool $vg/pool --poolmetadata $vg/$lv1
|
||||||
|
|
||||||
lvchange -ay $vg
|
lvchange -ay $vg
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ touch mntsnap/test_snap
|
|||||||
|
|
||||||
lvs -o+tags,thin_id $vg
|
lvs -o+tags,thin_id $vg
|
||||||
|
|
||||||
lvconvert --mergethin $vg/snap
|
lvconvert --merge $vg/snap
|
||||||
|
|
||||||
umount mnt
|
umount mnt
|
||||||
|
|
||||||
@ -102,12 +102,12 @@ lvcreate -s -n snap $vg/$lv1
|
|||||||
lvcreate -s -L10 -n oldsnapof_${lv1} $vg/$lv1
|
lvcreate -s -L10 -n oldsnapof_${lv1} $vg/$lv1
|
||||||
not lvconvert --merge $vg/snap
|
not lvconvert --merge $vg/snap
|
||||||
$MKFS "$DM_DEV_DIR/$vg/oldsnapof_${lv1}"
|
$MKFS "$DM_DEV_DIR/$vg/oldsnapof_${lv1}"
|
||||||
lvconvert --mergesnapshot $vg/oldsnapof_${lv1}
|
lvconvert --merge $vg/oldsnapof_${lv1}
|
||||||
fsck -n "$DM_DEV_DIR/$vg/$lv1"
|
fsck -n "$DM_DEV_DIR/$vg/$lv1"
|
||||||
check lv_not_exists $vg oldsnapof_${lv1}
|
check lv_not_exists $vg oldsnapof_${lv1}
|
||||||
# Add old snapshot to thin snapshot
|
# Add old snapshot to thin snapshot
|
||||||
lvcreate -s -L10 -n oldsnapof_snap $vg/snap
|
lvcreate -s -L10 -n oldsnapof_snap $vg/snap
|
||||||
lvconvert --mergethin $vg/snap
|
lvconvert --merge $vg/snap
|
||||||
lvremove -f $vg/oldsnapof_snap
|
lvremove -f $vg/oldsnapof_snap
|
||||||
|
|
||||||
vgremove -ff $vg
|
vgremove -ff $vg
|
||||||
|
@ -34,7 +34,7 @@ mount "$DM_DEV_DIR/$vg/$lv1" mnt
|
|||||||
lvcreate -s -n snap $vg/$lv1
|
lvcreate -s -n snap $vg/$lv1
|
||||||
check lv_field $vg/snap thin_id "3"
|
check lv_field $vg/snap thin_id "3"
|
||||||
|
|
||||||
lvconvert --mergethin $vg/snap
|
lvconvert --merge $vg/snap
|
||||||
|
|
||||||
umount mnt
|
umount mnt
|
||||||
|
|
||||||
|
@ -23,6 +23,8 @@ lvcreate -l 1 -n lv1 $vg "$dev1"
|
|||||||
invalid vgextend
|
invalid vgextend
|
||||||
# --metadatacopies => use --pvmetadatacopies
|
# --metadatacopies => use --pvmetadatacopies
|
||||||
invalid vgextend --metadatacopies 3 $vg "$dev1" 2>&1 | tee out
|
invalid vgextend --metadatacopies 3 $vg "$dev1" 2>&1 | tee out
|
||||||
|
#grep -- "use --pvmetadatacopies" out
|
||||||
|
grep -- "unrecognized option '--metadatacopies'" out
|
||||||
|
|
||||||
# VG name should exist
|
# VG name should exist
|
||||||
fail vgextend --restoremissing $vg-invalid "$dev1"
|
fail vgextend --restoremissing $vg-invalid "$dev1"
|
||||||
|
Loading…
Reference in New Issue
Block a user