From be94410446d381ab0512d347421a921c7966a10e Mon Sep 17 00:00:00 2001 From: Zdenek Kabelac Date: Sat, 24 Oct 2020 00:29:45 +0200 Subject: [PATCH] tests: fsadm test continue after fs repair Test case where filesystem has been corrected via fsck. In such case fsck returns '1' as success and should be handled in a same way as '0' since fs is correct. --- test/shell/fsadm.sh | 27 ++++++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/test/shell/fsadm.sh b/test/shell/fsadm.sh index 8141da42c..3e7f9083c 100644 --- a/test/shell/fsadm.sh +++ b/test/shell/fsadm.sh @@ -61,7 +61,8 @@ cleanup_mounted_and_teardown() fscheck_ext3() { - fsck.ext3 -p -F -f "$dev_vg_lv" + # fsck with result code '1' is success + fsck.ext3 -p -F -f "$dev_vg_lv" || test "$?" -eq 1 } fscheck_xfs() @@ -113,6 +114,30 @@ if check_missing ext2; then fscheck_ext3 lvresize -f -L20M $vg_lv + + if which debugfs ; then + mkfs.ext2 -b4096 -j "$dev_vg_lv" + mount "$dev_vg_lv" "$mount_dir" + touch "$mount_dir/file" + umount "$mount_dir" + # generate a 'repariable' corruption + # so fsck returns code 1 (fs repaired) + debugfs -R "clri file" -w "$dev_vg_lv" + + fsadm -v -f check "$dev_vg_lv" + + # corrupting again + mount "$dev_vg_lv" "$mount_dir" + touch "$mount_dir/file" + umount "$mount_dir" + debugfs -R "clri file" -w "$dev_vg_lv" + + mount "$dev_vg_lv" "$mount_dir" + fsadm -v -y --lvresize resize $vg_lv 10M + lvresize -L+10M -y -r -n $vg_lv + umount "$mount_dir" 2>/dev/null || true + fscheck_ext3 + fi fi if check_missing ext3; then