[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <176169819994.1433624.4365613323075287467.stgit@frogsfrogsfrogs>
Date: Tue, 28 Oct 2025 18:20:41 -0700
From: "Darrick J. Wong" <djwong@...nel.org>
To: djwong@...nel.org, zlang@...hat.com
Cc: neal@...pa.dev, fstests@...r.kernel.org, linux-ext4@...r.kernel.org,
 linux-fsdevel@...r.kernel.org, joannelkoong@...il.com, bernd@...ernd.com
Subject: [PATCH 01/33] misc: adapt tests to handle the fuse ext[234] drivers
From: Darrick J. Wong <djwong@...nel.org>
It would be useful to be able to run fstests against the userspace
ext[234] driver program fuse2fs.  A convention (at least on Debian)
seems to be to install fuse drivers as /sbin/mount.fuse.XXX so that
users can run "mount -t fuse.XXX" to start a fuse driver for a
disk-based filesystem type XXX.
Therefore, we'll adopt the practice of setting FSTYP=fuse.ext4 to
test ext4 with fuse2fs.  Change all the library code as needed to handle
this new type alongside all the existing ext[234] checks, which seems a
little cleaner than FSTYP=fuse FUSE_SUBTYPE=ext4, which also would
require even more treewide cleanups to work properly because most
fstests code switches on $FSTYP alone.
Signed-off-by: "Darrick J. Wong" <djwong@...nel.org>
---
 check             |   24 +++++++++++++++++-------
 common/casefold   |    4 ++++
 common/config     |   11 ++++++++---
 common/defrag     |    2 +-
 common/encrypt    |   16 ++++++++--------
 common/log        |   10 +++++-----
 common/populate   |   14 +++++++-------
 common/quota      |    9 +++++++++
 common/rc         |   50 +++++++++++++++++++++++++++++---------------------
 common/report     |    2 +-
 common/verity     |    8 ++++----
 tests/generic/020 |    2 +-
 tests/generic/067 |    2 +-
 tests/generic/441 |    2 +-
 tests/generic/496 |    2 +-
 tests/generic/621 |    2 +-
 tests/generic/740 |    2 +-
 tests/generic/746 |    4 ++--
 tests/generic/765 |    4 ++--
 19 files changed, 103 insertions(+), 67 deletions(-)
diff --git a/check b/check
index 9bb80a22440f97..81cd03f73ce155 100755
--- a/check
+++ b/check
@@ -140,12 +140,25 @@ get_sub_group_list()
 	echo $grpl
 }
 
+get_group_dirs()
+{
+	local fsgroup="$FSTYP"
+
+	case "$FSTYP" in
+	ext2|ext3|fuse.ext[234])
+		fsgroup=ext4
+		;;
+	esac
+
+	echo $SRC_GROUPS
+	echo $fsgroup
+}
+
 get_group_list()
 {
 	local grp=$1
 	local grpl=""
 	local sub=$(dirname $grp)
-	local fsgroup="$FSTYP"
 
 	if [ -n "$sub" -a "$sub" != "." -a -d "$SRC_DIR/$sub" ]; then
 		# group is given as <subdir>/<group> (e.g. xfs/quick)
@@ -154,10 +167,7 @@ get_group_list()
 		return
 	fi
 
-	if [ "$FSTYP" = ext2 -o "$FSTYP" = ext3 ]; then
-	    fsgroup=ext4
-	fi
-	for d in $SRC_GROUPS $fsgroup; do
+	for d in $(get_group_dirs); do
 		if ! test -d "$SRC_DIR/$d" ; then
 			continue
 		fi
@@ -171,7 +181,7 @@ get_group_list()
 get_all_tests()
 {
 	touch $tmp.list
-	for d in $SRC_GROUPS $FSTYP; do
+	for d in $(get_group_dirs); do
 		if ! test -d "$SRC_DIR/$d" ; then
 			continue
 		fi
@@ -387,7 +397,7 @@ if [ -n "$FUZZ_REWRITE_DURATION" ]; then
 fi
 
 if [ -n "$subdir_xfile" ]; then
-	for d in $SRC_GROUPS $FSTYP; do
+	for d in $(get_group_dirs); do
 		[ -f $SRC_DIR/$d/$subdir_xfile ] || continue
 		for f in `sed "s/#.*$//" $SRC_DIR/$d/$subdir_xfile`; do
 			exclude_tests+=($d/$f)
diff --git a/common/casefold b/common/casefold
index 2aae5e5e6c8925..fcdb4d210028ac 100644
--- a/common/casefold
+++ b/common/casefold
@@ -6,6 +6,10 @@
 _has_casefold_kernel_support()
 {
 	case $FSTYP in
+	fuse.ext[234])
+		# fuse2fs does not support casefolding
+		false
+		;;
 	ext4)
 		test -f '/sys/fs/ext4/features/casefold'
 		;;
diff --git a/common/config b/common/config
index 7fa97319d7d0ca..0cd2b33c4ade40 100644
--- a/common/config
+++ b/common/config
@@ -386,6 +386,11 @@ _common_mount_opts()
 	overlay)
 		echo $OVERLAY_MOUNT_OPTIONS
 		;;
+	fuse.ext[234])
+		# fuse sets up secure defaults, so we must explicitly tell
+		# fuse2fs to use the more relaxed kernel access behaviors.
+		echo "-o kernel $EXT_MOUNT_OPTIONS"
+		;;
 	ext2|ext3|ext4)
 		# acls & xattrs aren't turned on by default on ext$FOO
 		echo "-o acl,user_xattr $EXT_MOUNT_OPTIONS"
@@ -472,7 +477,7 @@ _mkfs_opts()
 _fsck_opts()
 {
 	case $FSTYP in
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		export FSCK_OPTIONS="-nf"
 		;;
 	reiser*)
@@ -514,11 +519,11 @@ _source_specific_fs()
 
 		. ./common/btrfs
 		;;
-	ext4)
+	fuse.ext4|ext4)
 		[ "$MKFS_EXT4_PROG" = "" ] && _fatal "mkfs.ext4 not found"
 		. ./common/ext4
 		;;
-	ext2|ext3)
+	ext2|ext3|fuse.ext[23])
 		. ./common/ext4
 		;;
 	f2fs)
diff --git a/common/defrag b/common/defrag
index 055d0d0e9182c5..c054e62bde6f4d 100644
--- a/common/defrag
+++ b/common/defrag
@@ -12,7 +12,7 @@ _require_defrag()
         _require_xfs_io_command "falloc"
         DEFRAG_PROG="$XFS_FSR_PROG"
 	;;
-    ext4)
+    fuse.ext4|ext4)
 	testfile="$TEST_DIR/$$-test.defrag"
 	donorfile="$TEST_DIR/$$-donor.defrag"
 	bsize=`_get_block_size $TEST_DIR`
diff --git a/common/encrypt b/common/encrypt
index f2687631b214cf..4fa7b6853fd461 100644
--- a/common/encrypt
+++ b/common/encrypt
@@ -191,7 +191,7 @@ _require_hw_wrapped_key_support()
 _scratch_mkfs_encrypted()
 {
 	case $FSTYP in
-	ext4|f2fs)
+	fuse.ext4|ext4|f2fs)
 		_scratch_mkfs -O encrypt
 		;;
 	ubifs)
@@ -210,7 +210,7 @@ _scratch_mkfs_encrypted()
 _scratch_mkfs_sized_encrypted()
 {
 	case $FSTYP in
-	ext4|f2fs)
+	fuse.ext4|ext4|f2fs)
 		MKFS_OPTIONS="$MKFS_OPTIONS -O encrypt" _scratch_mkfs_sized $*
 		;;
 	*)
@@ -225,7 +225,7 @@ _scratch_mkfs_sized_encrypted()
 _scratch_mkfs_stable_inodes_encrypted()
 {
 	case $FSTYP in
-	ext4)
+	fuse.ext4|ext4)
 		if ! _scratch_mkfs -O encrypt -O stable_inodes; then
 			_notrun "-O stable_inodes is not supported"
 		fi
@@ -330,7 +330,7 @@ _num_to_hex()
 _get_fs_keyprefix()
 {
 	case $FSTYP in
-	ext4|f2fs)
+	fuse.ext4|ext4|f2fs)
 		echo $FSTYP
 		;;
 	*)
@@ -557,7 +557,7 @@ _get_encryption_nonce()
 	local inode=$2
 
 	case $FSTYP in
-	ext4)
+	fuse.ext4|ext4)
 		# Use debugfs to dump the special xattr named "c", which is the
 		# file's fscrypt_context.  This produces a line like:
 		#
@@ -605,7 +605,7 @@ _require_get_encryption_nonce_support()
 {
 	echo "Checking for _get_encryption_nonce() support for $FSTYP" >> $seqres.full
 	case $FSTYP in
-	ext4)
+	fuse.ext4|ext4)
 		_require_command "$DEBUGFS_PROG" debugfs
 		;;
 	f2fs)
@@ -631,7 +631,7 @@ _get_ciphertext_filename()
 	local dir_inode=$3
 
 	case $FSTYP in
-	ext4)
+	fuse.ext4|ext4)
 		# Extract the filename from the debugfs output line like:
 		#
 		#  131075  100644 (1)      0      0       0 22-Apr-2019 16:54 \xa2\x85\xb0z\x13\xe9\x09\x86R\xed\xdc\xce\xad\x14d\x19
@@ -685,7 +685,7 @@ _require_get_ciphertext_filename_support()
 {
 	echo "Checking for _get_ciphertext_filename() support for $FSTYP" >> $seqres.full
 	case $FSTYP in
-	ext4)
+	fuse.ext4|ext4)
 		# Verify that the "ls -l -r" debugfs command is supported and
 		# that it hex-encodes non-ASCII characters, rather than using an
 		# ambiguous escaping method.  This requires e2fsprogs v1.45.1 or
diff --git a/common/log b/common/log
index ab7bc9f8733e28..b846d7087c0de5 100644
--- a/common/log
+++ b/common/log
@@ -228,7 +228,7 @@ _scratch_dump_log()
 	f2fs)
 		$DUMP_F2FS_PROG $SCRATCH_DEV
 		;;
-	ext4)
+	fuse.ext[34]|ext[34])
 		$DEBUGFS_PROG -R "logdump -a" $SCRATCH_DEV
 		;;
 	*)
@@ -245,7 +245,7 @@ _test_dump_log()
 	f2fs)
 		$DUMP_F2FS_PROG $TEST_DEV
 		;;
-	ext4)
+	fuse.ext[34]|ext[34])
 		$DEBUGFS_PROG -R "logdump -a" $TEST_DEV
 		;;
 	*)
@@ -262,7 +262,7 @@ _print_logstate()
     f2fs)
         dirty=$(_scratch_f2fs_logstate)
         ;;
-    ext4)
+    fuse.ext[34]|ext[34])
         dirty=$(_scratch_ext4_logstate)
         ;;
     *)
@@ -531,7 +531,7 @@ _require_logstate()
             _notrun "This test requires dump.f2fs utility."
         fi
         ;;
-    ext4)
+    fuse.ext[34]|ext[34])
 	if [ -z "$DUMPE2FS_PROG" ]; then
 		_notrun "This test requires dumpe2fs utility."
 	fi
@@ -599,7 +599,7 @@ _get_log_configs()
     f2fs)
         _f2fs_log_config
         ;;
-    ext4)
+    fuse.ext[34]|ext[34])
         _ext4_log_config
         ;;
     *)
diff --git a/common/populate b/common/populate
index 1c0dd03e4ac787..6ca4a68b129806 100644
--- a/common/populate
+++ b/common/populate
@@ -21,7 +21,7 @@ _require_populate_commands() {
 		_require_command "$WIPEFS_PROG" "wipefs"
 		_require_scratch_xfs_mdrestore
 		;;
-	ext*)
+	fuse.ext[234]|ext[234])
 		_require_command "$DUMPE2FS_PROG" "dumpe2fs"
 		_require_command "$E2IMAGE_PROG" "e2image"
 		;;
@@ -61,7 +61,7 @@ __populate_fail() {
 
 		_scratch_xfs_metadump "$metadump" "${mdargs[@]}"
 		;;
-	ext4)
+	fuse.ext[234]|ext[234])
 		_scratch_unmount
 		_ext4_metadump "${SCRATCH_DEV}" "$metadump"
 		;;
@@ -978,7 +978,7 @@ _scratch_populate() {
 		_scratch_xfs_populate
 		_scratch_xfs_populate_check
 		;;
-	"ext2"|"ext3"|"ext4")
+	fuse.ext[234]|ext[234])
 		_scratch_ext4_populate
 		_scratch_ext4_populate_check
 		;;
@@ -1072,7 +1072,7 @@ _scratch_populate_cache_tag() {
 	fi
 
 	case "${FSTYP}" in
-	"ext4")
+	fuse.ext[234]|ext[234])
 		extra_descr="LOGDEV_SIZE ${logdev_sz}"
 		;;
 	"xfs")
@@ -1095,7 +1095,7 @@ _scratch_populate_restore_cached() {
 		_scratch_xfs_mdrestore "${metadump}"
 		return $?
 		;;
-	"ext2"|"ext3"|"ext4")
+	fuse.ext[234]|ext[234])
 		local logdev=none
 		[ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_LOGDEV" ] && \
 			logdev=$SCRATCH_LOGDEV
@@ -1130,7 +1130,7 @@ _scratch_populate_save_metadump()
 				"$rtdev" compress "${mdargs[@]}"
 		res=$?
 		;;
-	"ext2"|"ext3"|"ext4")
+	fuse.ext[234]|ext[234])
 		_ext4_metadump "${SCRATCH_DEV}" "${metadump_file}" compress
 		res=$?
 		;;
@@ -1168,7 +1168,7 @@ _scratch_populate_cached() {
 		_scratch_xfs_populate $@
 		_scratch_xfs_populate_check
 		;;
-	"ext2"|"ext3"|"ext4")
+	fuse.ext[234]|ext[234])
 		_scratch_ext4_populate $@
 		_scratch_ext4_populate_check
 		;;
diff --git a/common/quota b/common/quota
index a51386b1dd249b..e22a8b5d2f0d3c 100644
--- a/common/quota
+++ b/common/quota
@@ -12,6 +12,9 @@ _require_quota()
     [ -n "$QUOTA_PROG" ] || _notrun "Quota user tools not installed"
 
     case $FSTYP in
+    fuse.ext[234])
+	    _notrun "quota not supported on fuse.ext[234]"
+	    ;;
     ext2|ext3|ext4|f2fs)
 	if [ ! -d /proc/sys/fs/quota ]; then
 	    _notrun "Installed kernel does not support quotas"
@@ -163,6 +166,9 @@ _require_getnextquota()
 _scratch_enable_pquota()
 {
 	case $FSTYP in
+	fuse.ext[234])
+		_notrun "fuse.ext[234] doesn't support project quota"
+		;;
 	ext2|ext3|ext4)
 		tune2fs -O quota,project $SCRATCH_DEV >>$seqres.full 2>&1
 		_try_scratch_mount >/dev/null 2>&1 \
@@ -335,6 +341,9 @@ _check_quota_usage()
 
 	VFS_QUOTA=0
 	case $FSTYP in
+	fuse.ext[234])
+		echo "fuse.ext[234] doesn't support quota"
+		;;
 	ext2|ext3|ext4|f2fs|gfs2|bcachefs)
 		VFS_QUOTA=1
 		quotaon -f -u -g $SCRATCH_MNT 2>/dev/null
diff --git a/common/rc b/common/rc
index 01b6f1d50c856f..3fe6f53758c05b 100644
--- a/common/rc
+++ b/common/rc
@@ -372,7 +372,7 @@ _scratch_options()
     "xfs")
 	_scratch_xfs_options "$@"
 	;;
-    ext2|ext3|ext4)
+    ext2|ext3|fuse.ext[234]|ext4)
 	_scratch_ext4_options "$@"
 	;;
     esac
@@ -430,7 +430,7 @@ _supports_filetype()
 	xfs)
 		_xfs_has_feature $dir ftype
 		;;
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		local dev=`$DF_PROG $dir | tail -1 | $AWK_PROG '{print $1}'`
 		tune2fs -l $dev | grep -q filetype
 		;;
@@ -845,7 +845,7 @@ _metadump_dev() {
 	btrfs)
 		_btrfs_metadump $device $dumpfile
 		;;
-	ext*)
+	ext*|fuse.ext*)
 		_ext4_metadump $device $dumpfile $compressopt
 		;;
 	xfs)
@@ -897,7 +897,7 @@ _test_mkfs()
     btrfs)
         $MKFS_BTRFS_PROG $MKFS_OPTIONS $* $TEST_DEV > /dev/null
 	;;
-    ext2|ext3|ext4)
+    ext2|ext3|fuse.ext[234]|ext4)
 	$MKFS_PROG -t $FSTYP -- -F $MKFS_OPTIONS $* $TEST_DEV
 	;;
     f2fs)
@@ -946,7 +946,7 @@ _try_mkfs_dev()
     btrfs)
         $MKFS_BTRFS_PROG $MKFS_OPTIONS $*
 	;;
-    ext2|ext3|ext4)
+    ext2|ext3|fuse.ext[234]|ext4)
 	$MKFS_PROG -t $FSTYP -- -F $MKFS_OPTIONS $*
 	;;
     f2fs)
@@ -1021,7 +1021,7 @@ _scratch_mkfs()
 		$UBIUPDATEVOL_PROG ${SCRATCH_DEV} -t
 		return 0
 		;;
-	ext4)
+	ext4|fuse.ext4)
 		_scratch_mkfs_ext4 $*
 		return $?
 		;;
@@ -1037,7 +1037,7 @@ _scratch_mkfs()
 		mkfs_cmd="$MKFS_BTRFS_PROG"
 		mkfs_filter="cat"
 		;;
-	ext3)
+	ext3|fuse.ext3)
 		mkfs_cmd="$MKFS_PROG -t $FSTYP -- -F"
 		mkfs_filter="grep -v -e ^Warning: -e \"^mke2fs \""
 
@@ -1046,7 +1046,7 @@ _scratch_mkfs()
 		$mkfs_cmd -O journal_dev $MKFS_OPTIONS $SCRATCH_LOGDEV && \
 		mkfs_cmd="$mkfs_cmd -J device=$SCRATCH_LOGDEV"
 		;;
-	ext2)
+	ext2|fuse.ext2)
 		mkfs_cmd="$MKFS_PROG -t $FSTYP -- -F"
 		mkfs_filter="grep -v -e ^Warning: -e \"^mke2fs \""
 		;;
@@ -1287,7 +1287,7 @@ _try_scratch_mkfs_sized()
 	btrfs)
 		def_blksz=`echo $MKFS_OPTIONS | sed -rn 's/.*-s ?+([0-9]+).*/\1/p'`
 		;;
-	ext2|ext3|ext4|reiser4|ocfs2)
+	ext2|ext3|fuse.ext[234]|ext4|reiser4|ocfs2)
 		def_blksz=`echo $MKFS_OPTIONS | sed -rn 's/.*-b ?+([0-9]+).*/\1/p'`
 		;;
 	udf)
@@ -1356,7 +1356,7 @@ _try_scratch_mkfs_sized()
 				-b size=$blocksize "$@"
 		fi
 		;;
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		# Can't use _scratch_mkfs_ext4 here because the block count has
 		# to come after the device path.
 		if [ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_LOGDEV" ]; then
@@ -1457,7 +1457,7 @@ _scratch_mkfs_geom()
 		MKFS_OPTIONS+=" -d su=$sunit_bytes,sw=$swidth_mult"
 	fi
 	;;
-    ext4)
+    fuse.ext4|ext4)
 	MKFS_OPTIONS+=" -b $blocksize -E stride=$sunit_blocks,stripe_width=$swidth_blocks"
 	;;
     *)
@@ -1494,7 +1494,7 @@ _scratch_mkfs_blocksized()
 	xfs)
 		_try_scratch_mkfs_xfs $MKFS_OPTIONS -b size=$blocksize
 		;;
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		_scratch_mkfs_ext4 $MKFS_OPTIONS -b $blocksize
 		;;
 	gfs2)
@@ -2174,10 +2174,10 @@ _require_scratch_size_nocheck()
 _require_scratch_16T_support()
 {
 	case $FSTYP in
-	ext2|ext3|f2fs)
+	ext2|ext3|f2fs|fuse.ext[23])
 		_notrun "$FSTYP doesn't support >16T filesystem"
 		;;
-	ext4)
+	fuse.ext4|ext4)
 		_scratch_mkfs >> $seqres.full 2>&1
 		_scratch_mount
 		local blocksize=$(_get_block_size $SCRATCH_MNT)
@@ -2773,10 +2773,10 @@ _filesystem_timestamp_range()
 	s64min=$((1<<63))
 
 	case $fstyp in
-	ext2)
+	ext2|fuse.ext2)
 		echo "$s32min $s32max"
 		;;
-	ext3|ext4)
+	fuse.ext[34]|ext3|ext4)
 		if [ $(dumpe2fs -h $device 2>/dev/null | grep "Inode size:" | cut -d: -f2) -gt 128 ]; then
 			printf "%d %d\n" $s32min 0x37fffffff
 		else
@@ -3386,7 +3386,7 @@ _fstyp_has_non_default_seek_data_hole()
 	fi
 
 	case "$fstyp" in
-	btrfs|ext4|xfs|cifs|f2fs|gfs2|ocfs2|tmpfs)
+	btrfs|ext4|fuse.ext4|xfs|cifs|f2fs|gfs2|ocfs2|tmpfs)
 		return 0
 		;;
 	nfs*)
@@ -3405,6 +3405,10 @@ _fstyp_has_non_default_seek_data_hole()
 			return 1
 		fi
 		;;
+	fuse.ext[23])
+		# fuse2fs doesn't implement SEEK_DATA/SEEK_HOLE yet
+		return 1
+		;;
 	*)
 		# by default fstyp has default SEEK_HOLE behavior;
 		# if your fs has non-default behavior, add it to whitelist above!
@@ -3588,7 +3592,7 @@ _check_generic_filesystem()
 
     if [ $ok -eq 0 ] && [ -n "$DUMP_CORRUPT_FS" ]; then
         case "$FSTYP" in
-        ext*)
+        ext*|fuse.ext*)
             local flatdev="$(basename "$device")"
             _ext4_metadump "$device" "$seqres.$flatdev.check.qcow2" compress
             ;;
@@ -4305,6 +4309,10 @@ _has_metadata_journaling()
 	fi
 
 	case "$FSTYP" in
+	fuse.ext[234])
+		echo "fuse4fs does not support metadata journaling on $FSTYP"
+		return 1
+		;;
 	ext2|vfat|msdos|udf|exfat|tmpfs)
 		echo "$FSTYP does not support metadata journaling"
 		return 1
@@ -5535,7 +5543,7 @@ _label_get_max()
 	f2fs)
 		echo 255
 		;;
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		echo 16
 		;;
 	*)
@@ -5779,7 +5787,7 @@ _require_od_endian_flag()
 # fs labels, and extended attribute names) as raw byte sequences.
 _require_names_are_bytes() {
         case "$FSTYP" in
-        ext2|ext3|ext4|f2fs|xfs|btrfs)
+        ext2|ext3|fuse.ext[234]|ext4|f2fs|xfs|btrfs)
 		# do nothing
 	        ;;
 	*)
@@ -5957,7 +5965,7 @@ _require_duplicate_fsid()
 	"btrfs")
 		_require_btrfs_fs_feature temp_fsid
 		;;
-	"ext4")
+	fuse.ext[234]|"ext4")
 		;;
 	*)
 		_notrun "$FSTYP does not support duplicate fsid"
diff --git a/common/report b/common/report
index a41a58f790b784..33978321f56a90 100644
--- a/common/report
+++ b/common/report
@@ -77,7 +77,7 @@ __generate_report_vars() {
 
 	# Add per-filesystem variables to the report variable list
 	test "$FSTYP" = "xfs" && __generate_xfs_report_vars
-	[[ "$FSTYP" == ext[0-9]* ]] && __generate_ext4_report_vars
+	[[ "$FSTYP" =~ ext[0-9]* ]] && __generate_ext4_report_vars
 
 	# Optional environmental variables
 	for varname in "${REPORT_ENV_LIST_OPT[@]}"; do
diff --git a/common/verity b/common/verity
index 11e839d2e7dfcf..9a15642190ded9 100644
--- a/common/verity
+++ b/common/verity
@@ -198,7 +198,7 @@ _require_fsverity_corruption()
 _scratch_mkfs_verity()
 {
 	case $FSTYP in
-	ext4|f2fs)
+	fuse.ext4|ext4|f2fs)
 		_scratch_mkfs -O verity
 		;;
 	btrfs)
@@ -216,7 +216,7 @@ _scratch_mkfs_verity()
 _scratch_mkfs_encrypted_verity()
 {
 	case $FSTYP in
-	ext4)
+	fuse.ext4|ext4)
 		_scratch_mkfs -O encrypt,verity
 		;;
 	f2fs)
@@ -386,7 +386,7 @@ _fsv_scratch_corrupt_merkle_tree()
 	local offset=$2
 
 	case $FSTYP in
-	ext4|f2fs)
+	fuse.ext4|ext4|f2fs)
 		# ext4 and f2fs store the Merkle tree after the file contents
 		# itself, starting at the next 65536-byte aligned boundary.
 		(( offset += ($(_get_filesize $file) + 65535) & ~65535 ))
@@ -417,7 +417,7 @@ _fsv_scratch_corrupt_merkle_tree()
 _require_fsverity_max_file_size_limit()
 {
 	case $FSTYP in
-	btrfs|ext4|f2fs)
+	btrfs|fuse.ext4|ext4|f2fs)
 		;;
 	*)
 		_notrun "$FSTYP does not store verity data past EOF; no special file size limit"
diff --git a/tests/generic/020 b/tests/generic/020
index 8b77d5ca750105..b98216b1f21b52 100755
--- a/tests/generic/020
+++ b/tests/generic/020
@@ -59,7 +59,7 @@ _attr_get_max()
 	xfs|udf|pvfs2|9p|ceph|fuse|nfs|ceph-fuse)
 		max_attrs=1000
 		;;
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		# For 4k blocksizes, most of the attributes have an attr_name of
 		# "attribute_NN" which is 12, and "value_NN" which is 8.
 		# But for larger block sizes, we start having extended
diff --git a/tests/generic/067 b/tests/generic/067
index 99d10ee0be0a0f..f8a59758668d5d 100755
--- a/tests/generic/067
+++ b/tests/generic/067
@@ -56,7 +56,7 @@ mount_free_loopdev()
 mount_wrong_fstype()
 {
 	local fs=ext4
-	if [ "$FSTYP" == "ext4" ]; then
+	if [[ "$FSTYP" =~ ext4 ]]; then
 		fs=xfs
 	fi
 	echo "# mount with wrong fs type" >>$seqres.full
diff --git a/tests/generic/441 b/tests/generic/441
index 6b48fc9ed5fbb3..063ca3f8daa258 100755
--- a/tests/generic/441
+++ b/tests/generic/441
@@ -33,7 +33,7 @@ case $FSTYP in
 	btrfs)
 		_notrun "btrfs has a specialized test for this"
 		;;
-	ext3|ext4|xfs|bcachefs)
+	ext3|fuse.ext[234]|ext4|xfs|bcachefs)
 		# Do the more thorough test if we have a logdev
 		_has_logdev && sflag=''
 		;;
diff --git a/tests/generic/496 b/tests/generic/496
index 344a4f5b08b4d4..0e76f55dd03b69 100755
--- a/tests/generic/496
+++ b/tests/generic/496
@@ -52,7 +52,7 @@ $XFS_IO_PROG -f -c "falloc 0 $len" $swapfile >> $seqres.full
 
 # ext4/xfs should not fail for swapon on fallocated files
 case $FSTYP in
-ext4|xfs)
+fuse.ext[234]|ext4|xfs)
 	"$here/src/swapon" $swapfile >> $seqres.full 2>&1 || \
 		_fail "swapon failed on fallocated file"
 	;;
diff --git a/tests/generic/621 b/tests/generic/621
index e5f92894c8eb4b..2d3fa4be0f9044 100755
--- a/tests/generic/621
+++ b/tests/generic/621
@@ -144,7 +144,7 @@ done
 # directories); otherwise e2fsck doesn't check for duplicate filenames.
 echo -e "\n# Checking for duplicate filenames via fsck"
 _scratch_unmount
-if [ "$FSTYP" = ext4 ]; then
+if [[ "$FSTYP" =~ ext4 ]]; then
 	if ! e2fsck -f -y -D $SCRATCH_DEV &>> $seqres.full; then
 		_log_err "filesystem on $SCRATCH_DEV is inconsistent"
 	fi
diff --git a/tests/generic/740 b/tests/generic/740
index ce55200f7bc34c..83a16052a8a252 100755
--- a/tests/generic/740
+++ b/tests/generic/740
@@ -36,7 +36,7 @@ do
 	postargs=""	# for any special post-device options
 
 	case "$fs"  in
-	ext2|ext3|ext4)
+	ext2|ext3|fuse.ext[234]|ext4)
 		preargs="-F"
 		;;
 	cramfs)
diff --git a/tests/generic/746 b/tests/generic/746
index 6f02b1cc354782..aa9282c66ebe06 100755
--- a/tests/generic/746
+++ b/tests/generic/746
@@ -26,7 +26,7 @@ btrfs)
 	_require_fs_space $TEST_DIR 3145728
 	fssize=3000
 	;;
-ext4)
+fuse.ext[234]|ext4)
 	_require_dumpe2fs
 	;;
 xfs)
@@ -65,7 +65,7 @@ get_holes()
 get_free_sectors()
 {
 	case $FSTYP in
-	ext4)
+	fuse.ext[234]|ext4)
 	_unmount $loop_mnt
 	$DUMPE2FS_PROG $loop_dev  2>&1 | grep " Free blocks" | cut -d ":" -f2- | \
 		tr ',' '\n' | $SED_PROG 's/^ //' | \
diff --git a/tests/generic/765 b/tests/generic/765
index 8c4e0bd02e4e65..a714f8db33a873 100755
--- a/tests/generic/765
+++ b/tests/generic/765
@@ -28,7 +28,7 @@ get_supported_bsize()
             fi
         done
         ;;
-    "ext4")
+    fuse.ext[234]|"ext4")
         min_bsize=1024
         max_bsize=$(_get_page_size)
         ;;
@@ -50,7 +50,7 @@ get_mkfs_opts()
     "xfs")
         mkfs_opts="-b size=$bsize"
         ;;
-    "ext4")
+    fuse.ext[234]|"ext4")
         mkfs_opts="-b $bsize"
         ;;
     *)
Powered by blists - more mailing lists
 
