Re: [PATCH v2 2/4] overlay: prepare for new lowerdir+,datadir+ tests

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Dec 04, 2023 at 08:58:57PM +0200, Amir Goldstein wrote:
> In preparation to forking tests for new lowerdir+,datadir+ mount options,
> prepare a helper to test kernel support and pass datadirs into mount
> helpers in overlay/079 test.
> 
> Signed-off-by: Amir Goldstein <amir73il@xxxxxxxxx>
> ---
>  common/overlay    | 15 +++++++++++++++
>  tests/overlay/079 | 36 +++++++++++++++++++++---------------
>  2 files changed, 36 insertions(+), 15 deletions(-)
> 
> diff --git a/common/overlay b/common/overlay
> index 8f275228..ea1eb7b1 100644
> --- a/common/overlay
> +++ b/common/overlay
> @@ -247,6 +247,21 @@ _require_scratch_overlay_lowerdata_layers()
>  	_scratch_unmount
>  }
>  
> +# Check kernel support for lowerdir+=<lowerdir>,datadir+=<lowerdatadir> format
> +_require_scratch_overlay_lowerdir_add_layers()
> +{
> +	local lowerdir="$OVL_BASE_SCRATCH_MNT/$OVL_UPPER"
> +	local datadir="$OVL_BASE_SCRATCH_MNT/$OVL_LOWER"
> +
> +	_scratch_mkfs > /dev/null 2>&1
> +	$MOUNT_PROG -t overlay $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT \
> +		-o"lowerdir+=$lowerdir,datadir+=$datadir" \
> +		-o"redirect_dir=follow,metacopy=on" > /dev/null 2>&1 || \
> +	        _notrun "overlay lowerdir+,datadir+ not supported on ${SCRATCH_DEV}"

Hi Amir,

I found overlay cases don't use helpers in common/overlay recently, always
use raw $MOUNT_PROG directly (not only in this patchset). Although overlay
supports new mount format, can we improve the mount helpers in common/overlay
to support that? It would be to good to use common helpers to do common
operation.

Anyway, that can be changed in another patch, if it takes too much time or
you don't want to do it at here. What do you think?

Thanks,
Zorro

> +
> +	_scratch_unmount
> +}
> +
>  # Helper function to check underlying dirs of overlay filesystem
>  _overlay_fsck_dirs()
>  {
> diff --git a/tests/overlay/079 b/tests/overlay/079
> index 77f94598..078ee816 100755
> --- a/tests/overlay/079
> +++ b/tests/overlay/079
> @@ -139,16 +139,21 @@ check_file_size_contents()
>  
>  mount_overlay()
>  {
> -	local _lowerdir=$1
> +	local _lowerdir=$1 _datadir2=$2 _datadir=$3
>  
> -	_overlay_scratch_mount_dirs "$_lowerdir" $upperdir $workdir -o redirect_dir=on,index=on,metacopy=on
> +	$MOUNT_PROG -t overlay $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT \
> +		-o"lowerdir=$_lowerdir::$_datadir2::$_datadir" \
> +		-o"upperdir=$upperdir,workdir=$workdir" \
> +		-o redirect_dir=on,metacopy=on
>  }
>  
>  mount_ro_overlay()
>  {
> -	local _lowerdir=$1
> +	local _lowerdir=$1 _datadir2=$2 _datadir=$3
>  
> -	_overlay_scratch_mount_dirs "$_lowerdir" "-" "-" -o ro,redirect_dir=follow,metacopy=on
> +	$MOUNT_PROG -t overlay $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT \
> +		-o"lowerdir=$_lowerdir::$_datadir2::$_datadir" \
> +		-o redirect_dir=follow,metacopy=on
>  }
>  
>  umount_overlay()
> @@ -160,14 +165,14 @@ test_no_access()
>  {
>  	local _target=$1
>  
> -	mount_ro_overlay "$lowerdir::$datadir2::$datadir"
> +	mount_ro_overlay "$lowerdir" "$datadir2" "$datadir"
>  
>  	stat $SCRATCH_MNT/$_target >> $seqres.full 2>&1 || \
>  		echo "No access to lowerdata layer $_target"
>  
>  	echo "Unmount and Mount rw"
>  	umount_overlay
> -	mount_overlay "$lowerdir::$datadir2::$datadir"
> +	mount_overlay "$lowerdir" "$datadir2" "$datadir"
>  	stat $SCRATCH_MNT/$_target >> $seqres.full 2>&1 || \
>  		echo "No access to lowerdata layer $_target"
>  	umount_overlay
> @@ -175,11 +180,12 @@ test_no_access()
>  
>  test_common()
>  {
> -	local _lowerdirs=$1 _target=$2 _size=$3 _blocks=$4 _data="$5"
> -	local _redirect=$6
> +	local _lowerdir=$1 _datadir2=$2 _datadir=$3
> +	local _target=$4 _size=$5 _blocks=$6 _data="$7"
> +	local _redirect=$8
>  
>  	echo "Mount ro"
> -	mount_ro_overlay $_lowerdirs
> +	mount_ro_overlay $_lowerdir $_datadir2 $_datadir
>  
>  	# Check redirect xattr to lowerdata
>  	[ -n "$_redirect" ] && check_redirect $lowerdir/$_target "$_redirect"
> @@ -191,7 +197,7 @@ test_common()
>  	# Do a mount cycle and check size and contents again.
>  	echo "Unmount and Mount rw"
>  	umount_overlay
> -	mount_overlay $_lowerdirs
> +	mount_overlay $_lowerdir $_datadir2 $_datadir
>  	echo "check properties of metadata copied up file $_target"
>  	check_file_size_contents $SCRATCH_MNT/$_target $_size "$_data"
>  	check_file_blocks $SCRATCH_MNT/$_target $_blocks
> @@ -203,7 +209,7 @@ test_common()
>  	check_file_size_contents $upperdir/$_target $_size ""
>  
>  	# Trigger data copy up and check absence of metacopy xattr.
> -	mount_overlay $_lowerdirs
> +	mount_overlay $_lowerdir $_datadir2 $_datadir
>  	$XFS_IO_PROG -c "falloc 0 1" $SCRATCH_MNT/$_target >> $seqres.full
>  	echo "check properties of data copied up file $_target"
>  	check_file_size_contents $SCRATCH_MNT/$_target $_size "$_data"
> @@ -216,7 +222,7 @@ test_lazy()
>  {
>  	local _target=$1
>  
> -	mount_overlay "$lowerdir::$datadir2::$datadir"
> +	mount_overlay "$lowerdir" "$datadir2" "$datadir"
>  
>  	# Metadata should be valid
>  	check_file_size $SCRATCH_MNT/$_target $datasize
> @@ -305,12 +311,12 @@ test_no_access "$sharedname"
>  
>  echo -e "\n== Check follow to lowerdata layer with absolute redirect =="
>  prepare_midlayer "/subdir/$dataname"
> -test_common "$lowerdir::$datadir2::$datadir" "$dataname" $datasize $datablocks \
> +test_common "$lowerdir" "$datadir2" "$datadir" "$dataname" $datasize $datablocks \
>  		"$datacontent" "/subdir/$dataname"
> -test_common "$lowerdir::$datadir2::$datadir" "$dataname2" $datasize $datablocks \
> +test_common "$lowerdir" "$datadir2" "$datadir" "$dataname2" $datasize $datablocks \
>  		"$datacontent2" "/subdir/$dataname.2"
>  # Shared file should be picked from upper datadir
> -test_common "$lowerdir::$datadir2::$datadir" "$sharedname" $datasize $datablocks \
> +test_common "$lowerdir" "$datadir2" "$datadir" "$sharedname" $datasize $datablocks \
>  		"$datacontent2" "/subdir/$dataname.shared"
>  
>  echo -e "\n== Check lazy follow to lowerdata layer =="
> -- 
> 2.34.1
> 





[Index of Archives]     [Linux Filesystems Devel]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux