1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +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:
Zdenek Kabelac 2017-04-03 15:57:32 +02:00
parent 3018cdcaa7
commit f8034e14e6
16 changed files with 81 additions and 71 deletions

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -56,7 +56,8 @@ 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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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"

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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"