Whamcloud - gitweb
LU-12704 tests: component end must be multiple of stripesize
[fs/lustre-release.git] / lustre / tests / racer / file_create.sh
index e615365..f5fd90f 100755 (executable)
@@ -1,18 +1,49 @@
 #!/bin/bash
-
+trap 'kill $(jobs -p)' EXIT
+RACER_ENABLE_PFL=${RACER_ENABLE_PFL:-true}
+RACER_ENABLE_DOM=${RACER_ENABLE_DOM:-true}
+RACER_ENABLE_FLR=${RACER_ENABLE_FLR:-true}
 DIR=$1
 MAX=$2
 MAX_MB=${RACER_MAX_MB:-8}
 
-OSTCOUNT=${OSTCOUNT:-$(lfs df $DIR 2> /dev/null | grep -c OST)}
+layout=(raid0 raid0)
+
+# check if it supports PFL layout
+$RACER_ENABLE_PFL && layout+=(pfl pfl pfl)
+
+# check if it supports DoM
+$RACER_ENABLE_DOM && layout+=(dom dom dom)
+
+# check if it supports FLR
+$RACER_ENABLE_FLR && layout+=(flr flr flr)
+
+echo "layout: ${layout[*]}"
 
-while /bin/true ; do 
+while /bin/true; do
        file=$((RANDOM % MAX))
        # $RANDOM is between 0 and 32767, and we want $blockcount in 64kB units
        blockcount=$((RANDOM * MAX_MB / 32 / 64))
        stripecount=$((RANDOM % (OSTCOUNT + 1)))
-       [ $OSTCOUNT -gt 0 ] &&
-               lfs setstripe -c $stripecount $DIR/$file 2> /dev/null
-       dd if=/dev/zero of=$DIR/$file bs=64k count=$blockcount 2> /dev/null
+
+       [ $stripecount -gt 0 ] && {
+               stripesize=$(((RANDOM % 16 + 1) * 64))K
+               comp_end=$((${stripesize%K} * (RANDOM % 8 + 1)))K
+               pattern=${layout[$RANDOM % ${#layout[*]}]}
+
+               case $pattern in
+               dom) opt="setstripe -E $stripesize -L mdt -E eof -c $stripecount -S 1M" ;;
+               pfl) opt="setstripe -E $comp_end -S $stripesize -E eof -c $stripecount -S 2M" ;;
+               flr) opt="mirror create -N2 -E $comp_end -S $stripesize -E eof -c $stripecount -S 2M" ;;
+               raid0) opt="setstripe -S $stripesize -c $stripecount" ;;
+               esac
+
+               $LFS $opt $DIR/$file 2> /dev/null || true
+       }
+
+       # offset between 0 and 16MB (256 64k chunks), with 1/2 at offset 0
+       seek=$((RANDOM / 64)); [ $seek -gt 256 ] && seek=0
+       dd if=/dev/zero of=$DIR/$file bs=64k count=$blockcount \
+               seek=$seek 2> /dev/null || true
 done