On 2017/7/3 14:41, Amir Goldstein wrote: > On Mon, Jul 3, 2017 at 4:42 AM, zhangyi (F) <yi.zhang@xxxxxxxxxx> wrote: >> On 2017/6/30 22:28, Amir Goldstein wrote: >>> On Fri, Jun 30, 2017 at 6:20 AM, zhangyi (F) <yi.zhang@xxxxxxxxxx> wrote: >>>> In overlay/031, it only cover the test case of whiteouts in >>>> origined upper dir. This patch add two cases cover the other >>>> two situations: >>>> >>>> 1) Lower origined dir have whiteouts; >>>> 2) Both upper and lower origined dirs have whiteouts (although >>>> this case is pass now, still add this to cover all three kinds >>>> of situations). >>>> >>>> Signed-off-by: zhangyi (F) <yi.zhang@xxxxxxxxxx> >>> >>> Reviewed-by: Amir Goldstein <amir73il@xxxxxxxxx> >>> >>> Except one issue below. >>> >>>> --- >>>> tests/overlay/031 | 58 ++++++++++++++++++++++++++++++++++++++++++++----------- >>>> 1 file changed, 47 insertions(+), 11 deletions(-) >>>> >>>> diff --git a/tests/overlay/031 b/tests/overlay/031 >>>> index cb29ee5..b7bad3a 100755 >>>> --- a/tests/overlay/031 >>>> +++ b/tests/overlay/031 >>>> @@ -1,9 +1,10 @@ >>>> #! /bin/bash >>>> # FS QA Test 031 >>>> # >>>> -# The unmerged and impure upper directories may contain invalid >>>> -# whiteouts when we change lowerdir(e.g. clean up dir) and remount >>>> -# overlay. This may lead to whiteouts exposure and rmdir failure. >>>> +# The unmerged and origined directories may contain invalid >>>> +# whiteouts when we change underlaying dir (e.g. clean up lowerdir) >>>> +# and remount overlay. This may lead to whiteouts exposure and >>>> +# rmdir failure. >>>> # >>>> #----------------------------------------------------------------------- >>>> # Copyright (c) 2017 Huawei. All Rights Reserved. >>>> @@ -67,19 +68,21 @@ _require_scratch >>>> _scratch_mkfs >>>> >>>> # create test directorys and whiteout >>>> -lowerdir=$OVL_BASE_SCRATCH_MNT/lower >>>> +lowerdir1=$OVL_BASE_SCRATCH_MNT/lower1 >>>> +lowerdir2=$OVL_BASE_SCRATCH_MNT/lower2 >>>> upperdir=$OVL_BASE_SCRATCH_MNT/upper >>>> workdir=$OVL_BASE_SCRATCH_MNT/workdir >>>> -testfile=a >>>> -mkdir -p $lowerdir $upperdir $workdir >>>> +testfile1=a >>>> +testfile2=b >>>> +mkdir -p $lowerdir1 $lowerdir2 $upperdir $workdir >>>> >>>> -_create_whiteout $lowerdir $upperdir $workdir $testfile >>>> +_create_whiteout $lowerdir1 $upperdir $workdir $testfile1 >>>> >>>> # clean up the lower directory and mount overlay again, >>>> # whiteout will expose. >>>> -rm -rf $lowerdir/testdir >>>> +rm -rf $lowerdir1/testdir >>>> >>>> -_overlay_mount_dirs $lowerdir $upperdir $workdir $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT >>>> +_overlay_mount_dirs $lowerdir1 $upperdir $workdir $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT >>>> >>>> ls $SCRATCH_MNT/testdir >>>> >>>> @@ -90,15 +93,48 @@ rm -rf $SCRATCH_MNT/testdir 2>&1 | _filter_scratch >>>> # umount overlay again, create a new file with the same name and >>>> # mount overlay again. >>>> $UMOUNT_PROG $SCRATCH_MNT >>>> -touch $lowerdir/testdir >>>> +touch $lowerdir1/testdir >>>> >>>> -_overlay_mount_dirs $lowerdir $upperdir $workdir $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT >>>> +_overlay_mount_dirs $lowerdir1 $upperdir $workdir $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT >>>> >>>> # try to remove test dir from overlay dir, trigger ovl_remove_and_whiteout, >>>> # it will not clean up the dir and lead to residue. >>>> rm -rf $SCRATCH_MNT/testdir 2>&1 | _filter_scratch >>>> ls $workdir/work >>>> >>>> +$UMOUNT_PROG $SCRATCH_MNT >>>> + >>>> +# let lower dir have invalid whiteouts, repeat ls and rmdir test again. >>>> +rm -rf $lowerdir1/testdir >>>> +rm -rf $upperdir/testdir >>>> + >>>> +_create_whiteout $lowerdir2 $lowerdir1 $workdir $testfile1 >>>> + >>>> +rm -rf $lowerdir2/testdir >>>> + >>>> +_overlay_mount_dirs "$lowerdir1:$lowerdir2" $upperdir $workdir \ >>>> + $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT >>>> + >>>> +ls $SCRATCH_MNT/testdir >>>> +rm -rf $SCRATCH_MNT/testdir 2>&1 | _filter_scratch >>>> + >>>> +$UMOUNT_PROG $SCRATCH_MNT >>>> + >>>> +# let lower dir and upper dir both have invalid whiteouts, repeat ls and rmdir again. >>>> +rm -rf $lowerdir1/testdir >>>> +rm -rf $upperdir/testdir >>>> + >>>> +_create_whiteout $lowerdir1 $upperdir $workdir $testfile1 >>>> + >>>> +rm -rf $lowerdir1/testdir >>>> + >>>> +_create_whiteout $lowerdir2 $lowerdir1 $workdir $testfile2 >>>> + >>>> +_overlay_mount_dirs $lowerdir1 $upperdir $workdir $OVL_BASE_SCRATCH_MNT $SCRATCH_MNT >>>> + >>> >>> Forgot to rm -rf $lowerdir2/testdir ? >>> >> >> Lowerdir2 is no longer used for the final test, so I think there is no difference >> whether we removed lowerdir2/testdir or not.(I miss something?) >> > > Right. I tested with my overlayfs-devel branch and found a different issue > with the 'whiteouts in both upper and lower' test case. > When you run the test you see the warning: > overlayfs: failed to verify origin (lower1/testdir, ino=16777474, err=-116) > > This warning is generated by commit ("ovl: verify origin of merge dir lower") > and means that the test does not follow the lower dir at all. > > The solution is simple: > > rm -f $lowerdir1/testdir/$testfile1 instead of rm -rf $lowerdir1/testdir > to keep the original lower testdir dir intact, instead of recreating the > dir with the second _create_whiteout call. > Yes, indeed, will fix it, thanks a lot. Thanks, ZhangYi. -- To unsubscribe from this list: send the line "unsubscribe linux-unionfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html