git: 5691cbec520b - main - stress2: Added one more unionfs test
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sun, 16 Jan 2022 06:34:11 UTC
The branch main has been updated by pho: URL: https://cgit.FreeBSD.org/src/commit/?id=5691cbec520bf9283771a4b2be09a60a01af5f2b commit 5691cbec520bf9283771a4b2be09a60a01af5f2b Author: Peter Holm <pho@FreeBSD.org> AuthorDate: 2022-01-16 06:33:45 +0000 Commit: Peter Holm <pho@FreeBSD.org> CommitDate: 2022-01-16 06:33:45 +0000 stress2: Added one more unionfs test --- tools/test/stress2/misc/unionfs9.sh | 99 +++++++++++++++++++++++++++++++++++++ 1 file changed, 99 insertions(+) diff --git a/tools/test/stress2/misc/unionfs9.sh b/tools/test/stress2/misc/unionfs9.sh new file mode 100755 index 000000000000..80ab45e38f88 --- /dev/null +++ b/tools/test/stress2/misc/unionfs9.sh @@ -0,0 +1,99 @@ +#!/bin/sh + +# +# SPDX-License-Identifier: BSD-2-Clause-FreeBSD +# +# Copyright (c) 2022 Peter Holm <pho@FreeBSD.org> +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# 1. Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# 2. Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in the +# documentation and/or other materials provided with the distribution. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE +# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS +# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY +# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF +# SUCH DAMAGE. +# + +# Parallel mount and umount test + +# umount(1) stuck in "mount drain" seen: +# https://people.freebsd.org/~pho/stress/log/log0205.txt + +# https://people.freebsd.org/~pho/stress/log/log0226.txt + +[ `id -u ` -ne 0 ] && echo "Must be root!" && exit 1 +. ../default.cfg + +mounts=3 # Number of parallel scripts +CONT=/tmp/unionfs9.continue + +set -e +mdconfig -a -t swap -s 256m -u $mdstart +newfs $newfs_flags -n md$mdstart > /dev/null +mount /dev/md$mdstart $mntpoint + +for i in `jot $mounts $((mdstart + 2))`; do + mdconfig -a -t swap -s 512m -u $((mdstart + i)) + newfs $newfs_flags -n md$((mdstart + i)) > /dev/null + mkdir -p ${mntpoint}$i + mount /dev/md$((mdstart + i)) ${mntpoint}$i +done +set +e +echo Pre: +mount | grep mnt + +(cd $mntpoint; jot 500 | xargs touch) +(cd ../testcases/swap; ./swap -t 5m -i 20 > /dev/null) & + +# Start the parallel tests +touch $CONT +for i in `jot $mounts $((mdstart + 2))`; do + while [ -f $CONT ]; do + find ${mntpoint}$i -type f -maxdepth 2 -ls > \ + /dev/null 2>&1 + done & + # The test: Parallel mount and unmounts + start=`date +%s` + ( + while [ $((`date +%s` - start)) -lt 300 ]; do + mount_unionfs $mntpoint ${mntpoint}$i > \ + /dev/null 2>&1 + opt=$([ `jot -r 1 0 1` -eq 0 ] && echo "-f") + while mount | grep -q ${mntpoint}$i; do + umount $opt ${mntpoint}$i > \ + /dev/null 2>&1 + done + done + rm -f $CONT + ) & +done +while [ -f $CONT ] ; do sleep 1; done +while pgrep -q swap; do pkill swap; done +wait +echo Post: +mount | grep mnt + +for i in `jot $mounts $((mdstart + 2))`; do + umount ${mntpoint}$i > /dev/null 2>&1 + mdconfig -d -u $((mdstart + i)) + rmdir ${mntpoint}$i +done +while mount | grep $mntpoint | grep -q /dev/md; do + umount $mntpoint || sleep 1 + [ $((n += 1)) -gt 300 ] && { echo FAIL; exit 1; } +done +mdconfig -d -u $mdstart +exit 0