if [[ $(uname -m) = aarch64 ]]; then
# bug number: LU-11596
ALWAYS_EXCEPT+=" $GRANT_CHECK_LIST"
- # bug number: LU-11671 LU-11594 LU-11667 LU-11729
- ALWAYS_EXCEPT+=" 45 103a 317 810"
+ # bug number: LU-11671 LU-11594 LU-11667 LU-11729 LU-4398
+ ALWAYS_EXCEPT+=" 45 103a 317 810 817"
fi
# 5 12 (min)"
# make sure hard links were properly detected, and migration was
# performed only once for the entire link set; nonlinked files should
# also be migrated
- local actual=$(grep -c 'done migrate' <<< "$migrate_out")
+ local actual=$(grep -c 'done' <<< "$migrate_out")
local expected=$(($uniq_count + 1))
[ "$actual" -eq "$expected" ] ||
# Test 1: ensure file < 1 GB is always migrated with 1 stripe
echo -n "Setting initial stripe for 20MB test file..."
- $LFS setstripe -c 2 -i 0 "$dir/20mb" || error "cannot setstripe"
+ $LFS setstripe -c 2 -i 0 "$dir/20mb" ||
+ error "cannot setstripe 20MB file"
echo "done"
echo -n "Sizing 20MB test file..."
truncate "$dir/20mb" 20971520 || error "cannot create 20MB test file"
echo "done"
echo -n "Verifying small file autostripe count is 1..."
- $LFS_MIGRATE -y -A -C 1 "$dir/20mb" &> /dev/null ||
+ $LFS_MIGRATE -y -A -C 1 "$dir/20mb" ||
error "cannot migrate 20MB file"
local stripe_count=$($LFS getstripe -c "$dir/20mb") ||
error "cannot get stripe for $dir/20mb"
# sqrt(size_in_gb) + 1 OSTs but is larger than 1GB. The file must
# have at least an additional 1KB for each desired stripe for test 3
echo -n "Setting stripe for 1GB test file..."
- $LFS setstripe -c 1 -i 0 "$dir/1gb" || error "cannot setstripe"
+ $LFS setstripe -c 1 -i 0 "$dir/1gb" || error "cannot setstripe 1GB file"
echo "done"
echo -n "Sizing 1GB test file..."
# File size is 1GB + 3KB
- truncate "$dir/1gb" 1073744896 &> /dev/null ||
- error "cannot create 1GB test file"
- echo "done"
- echo -n "Migrating 1GB file..."
- $LFS_MIGRATE -y -A -C 1 "$dir/1gb" &> /dev/null ||
- error "cannot migrate file"
- echo "done"
- echo -n "Verifying autostripe count is sqrt(n) + 1..."
- stripe_count=$($LFS getstripe -c "$dir/1gb") ||
- error "cannot get stripe for $dir/1gb"
- [ $stripe_count -eq 2 ] ||
- error "unexpected stripe count $stripe_count (expected 2)"
+ truncate "$dir/1gb" 1073744896 || error "cannot create 1GB test file"
echo "done"
+ # need at least 512MB per OST for 1GB file to fit in 2 stripes
+ local avail=$($LCTL get_param -n llite.$FSNAME*.kbytesavail)
+ if (( avail > 524288 * OSTCOUNT )); then
+ echo -n "Migrating 1GB file..."
+ $LFS_MIGRATE -y -A -C 1 "$dir/1gb" ||
+ error "cannot migrate 1GB file"
+ echo "done"
+ echo -n "Verifying autostripe count is sqrt(n) + 1..."
+ stripe_count=$($LFS getstripe -c "$dir/1gb") ||
+ error "cannot getstripe for 1GB file"
+ [ $stripe_count -eq 2 ] ||
+ error "unexpected stripe count $stripe_count != 2"
+ echo "done"
+ fi
+
# Test 3: File is too large to fit within the available space on
# sqrt(n) + 1 OSTs. Simulate limited available space with -X
if [ $OSTCOUNT -ge 3 ]; then
# file size (1GB + 3KB) / OST count (3).
local kb_per_ost=349526
- echo -n "Migrating 1GB file..."
- $LFS_MIGRATE -y -A -C 1 -X $kb_per_ost "$dir/1gb" &>> \
- /dev/null || error "cannot migrate file"
+ echo -n "Migrating 1GB file with limit..."
+ $LFS_MIGRATE -y -A -C 1 -X $kb_per_ost "$dir/1gb" ||
+ error "cannot migrate 1GB file with limit"
echo "done"
stripe_count=$($LFS getstripe -c "$dir/1gb")
- echo -n "Verifying autostripe count with limited space..."
- [ "$stripe_count" -a $stripe_count -eq 3 ] ||
- error "unexpected stripe count $stripe_count (wanted 3)"
+ echo -n "Verifying 1GB autostripe count with limited space..."
+ [ "$stripe_count" -a $stripe_count -ge 3 ] ||
+ error "unexpected stripe count $stripe_count (min 3)"
echo "done"
fi
test_mkdir $dir
for i in d{0..9}; do
test_mkdir $dir/$i
+ touch $dir/$i/$tfile
done
- touch $dir/d{0..9}/$tfile
$LFS find $DIR/non_existent_dir $dir &&
error "$LFS find did not return an error"
# Make a directory unsearchable. This should NOT be the last entry in
# directory order. Arbitrarily pick the 6th entry
chmod 700 $($LFS find $dir -type d | sed '6!d')
+ $RUNAS $LFS find $DIR/non_existent $dir
local count=$($RUNAS $LFS find $DIR/non_existent $dir | wc -l)
# The user should be able to see 10 directories and 9 files
- [ $count == 19 ] || error "$LFS find did not continue after error"
+ (( count == 19 )) ||
+ error "$LFS find found $count != 19 entries after error"
}
run_test 56z "lfs find should continue after an error"
do_facet $SINGLEMDS lctl --device %$INACTIVE_OSC activate
echo $INACTIVE_OSC "is Activate"
- wait_osc_import_state mds ost$ostnum FULL
+ wait_osc_import_state mds ost$(( ostnum + 1 )) FULL
}
test_65k() { # bug11679
do_facet $SINGLEMDS lctl --device %$INACTIVE_OSC activate
echo $INACTIVE_OSC "is Activate"
- wait_osc_import_state mds ost$ostnum FULL
+ wait_osc_import_state mds ost$(( ostnum + 1 )) FULL
done
}
run_test 65k "validate manual striping works properly with deactivated OSCs"
}
run_test 276 "Race between mount and obd_statfs"
+test_277() {
+ $LCTL set_param ldlm.namespaces.*.lru_size=0
+ dd if=/dev/zero of=$DIR/$tfile bs=1M count=1
+ local cached_mb=$($LCTL get_param llite.*.max_cached_mb |
+ grep ^used_mb | awk '{print $2}')
+ [ $cached_mb -eq 1 ] || error "expected mb 1 got $cached_mb"
+ dd if=/dev/zero of=$DIR/$tfile bs=1M count=1 \
+ oflag=direct conv=notrunc
+ cached_mb=$($LCTL get_param llite.*.max_cached_mb |
+ grep ^used_mb | awk '{print $2}')
+ [ $cached_mb -eq 0 ] || error "expected mb 0 got $cached_mb"
+}
+run_test 277 "Direct IO shall drop page cache"
+
cleanup_test_300() {
trap 0
umask $SAVE_UMASK
test_317() {
[ $MDS1_VERSION -lt $(version_code 2.11.53) ] &&
skip "Need MDS version at least 2.11.53"
+ if [ "$ost1_FSTYPE" == "zfs" ]; then
+ skip "LU-10370: no implementation for ZFS"
+ fi
+
local trunc_sz
local grant_blk_size
- if [ "$(facet_fstype $facet)" == "zfs" ]; then
- skip "LU-10370: no implementation for ZFS" && return
- fi
-
- stack_trap "rm -f $DIR/$tfile" EXIT
grant_blk_size=$($LCTL get_param osc.$FSNAME*.import |
awk '/grant_block_size:/ { print $2; exit; }')
#
# blocks count.
#
dd if=/dev/zero of=$DIR/$tfile bs=5M count=1 conv=fsync ||
- error "Create file : $DIR/$tfile"
+ error "Create file $DIR/$tfile failed"
+ stack_trap "rm -f $DIR/$tfile" EXIT
for trunc_sz in 2097152 4097 4000 509 0; do
$TRUNCATE $DIR/$tfile $trunc_sz ||
}
run_test 816 "do not reset lru_resize on idle reconnect"
+cleanup_817() {
+ umount $tmpdir
+ exportfs -u localhost:$DIR/nfsexp
+ rm -rf $DIR/nfsexp
+}
+
+test_817() {
+ systemctl restart nfs-server.service || skip "failed to restart nfsd"
+
+ mkdir -p $DIR/nfsexp
+ exportfs -orw,no_root_squash localhost:$DIR/nfsexp ||
+ error "failed to export nfs"
+
+ tmpdir=$(mktemp -d /tmp/nfs-XXXXXX)
+ stack_trap cleanup_817 EXIT
+
+ mount -t nfs -orw localhost:$DIR/nfsexp $tmpdir ||
+ error "failed to mount nfs to $tmpdir"
+
+ cp /bin/true $tmpdir
+ $DIR/nfsexp/true || error "failed to execute 'true' command"
+}
+run_test 817 "nfsd won't cache write lock for exec file"
+
#
# tests that do cleanup/setup should be run at the end
#