Whamcloud - gitweb
LU-12473 llapi: fix pool_list by path
[fs/lustre-release.git] / lustre / tests / sanity.sh
index e21d948..e15d104 100644 (file)
@@ -41,8 +41,8 @@ init_logging
 ALWAYS_EXCEPT="$SANITY_EXCEPT "
 # bug number for skipped test: LU-9693 LU-6493 LU-9693
 ALWAYS_EXCEPT+="               42a     42b     42c "
-# bug number:    LU-8411 LU-9096 LU-9054
-ALWAYS_EXCEPT+=" 407     253     312 "
+# bug number:    LU-8411 LU-9054
+ALWAYS_EXCEPT+=" 407     312 "
 
 if $SHARED_KEY; then
        # bug number:    LU-9795 LU-9795 LU-9795 LU-9795
@@ -1742,12 +1742,6 @@ test_27m() {
 }
 run_test 27m "create file while OST0 was full"
 
-sleep_maxage() {
-       local delay=$(do_facet $SINGLEMDS lctl get_param -n lov.*.qos_maxage |
-                     awk '{ print $1 * 2; exit; }')
-       sleep $delay
-}
-
 # OSCs keep a NOSPC flag that will be reset after ~5s (qos_maxage)
 # if the OST isn't full anymore.
 reset_enospc() {
@@ -1777,12 +1771,12 @@ exhaust_precreations() {
        # on the mdt's osc
        local mdtosc_proc1=$(get_mdtosc_proc_path $mfacet $OST)
        local last_id=$(do_facet $mfacet lctl get_param -n \
-                       osc.$mdtosc_proc1.prealloc_last_id)
+                       osp.$mdtosc_proc1.prealloc_last_id)
        local next_id=$(do_facet $mfacet lctl get_param -n \
-                       osc.$mdtosc_proc1.prealloc_next_id)
+                       osp.$mdtosc_proc1.prealloc_next_id)
 
        local mdtosc_proc2=$(get_mdtosc_proc_path $mfacet)
-       do_facet $mfacet lctl get_param osc.$mdtosc_proc2.prealloc*
+       do_facet $mfacet lctl get_param osp.$mdtosc_proc2.prealloc*
 
        test_mkdir -p $DIR/$tdir/${OST}
        $LFS setstripe -i $OSTIDX -c 1 $DIR/$tdir/${OST}
@@ -1790,7 +1784,7 @@ exhaust_precreations() {
        do_facet $ofacet lctl set_param fail_val=$FAILIDX fail_loc=0x215
        echo "Creating to objid $last_id on ost $OST..."
        createmany -o $DIR/$tdir/${OST}/f $next_id $((last_id - next_id + 2))
-       do_facet $mfacet lctl get_param osc.$mdtosc_proc2.prealloc*
+       do_facet $mfacet lctl get_param osp.$mdtosc_proc2.prealloc*
        do_facet $ofacet lctl set_param fail_loc=$FAILLOC
        sleep_maxage
 }
@@ -2033,9 +2027,9 @@ test_27y() {
 
        local mdtosc=$(get_mdtosc_proc_path $SINGLEMDS $FSNAME-OST0000)
        local last_id=$(do_facet $SINGLEMDS lctl get_param -n \
-               osc.$mdtosc.prealloc_last_id)
+               osp.$mdtosc.prealloc_last_id)
        local next_id=$(do_facet $SINGLEMDS lctl get_param -n \
-               osc.$mdtosc.prealloc_next_id)
+               osp.$mdtosc.prealloc_next_id)
        local fcount=$((last_id - next_id))
        [[ $fcount -eq 0 ]] && skip "not enough space on OST0"
        [[ $fcount -gt $OSTCOUNT ]] && fcount=$OSTCOUNT
@@ -2478,6 +2472,8 @@ test_27D() {
        [ $MDS1_VERSION -lt $(version_code 2.9.55) ] ||
                [ $CLIENT_VERSION -lt $(version_code 2.9.55) ] &&
                        skip27D+=" -s 30,31"
+       [ $(lustre_version_code $SINGLEMDS) -lt $(version_code $SEL_VER) ] &&
+               skip27D+="-s 32"
        [[ ! $($LCTL get_param mdc.*.import) =~ connect_flags.*overstriping ||
          $OSTCOUNT -ge $(($LOV_MAX_STRIPE_COUNT / 2)) ]] &&
                skip27D+=" -s 32,33"
@@ -2814,6 +2810,24 @@ test_27K() {
 }
 run_test 27K "basic ops on dir with foreign LMV"
 
+test_27L() {
+       remote_mds_nodsh && skip "remote MDS with nodsh"
+
+       local POOL=${POOL:-$TESTNAME}
+
+       if ! combined_mgs_mds ; then
+               mount_mgs_client
+               trap umount_mgs_client EXIT
+       fi
+
+       pool_add $POOL || error "pool_add failed"
+
+       lfs pool_list $MOUNT | grep -Fx "${FSNAME}.${POOL}" ||
+                error "pool_list does not contain ${FSNAME}.${POOL}:" \
+                      "$(lfs pool_list $MOUNT | grep -F "${POOL}")"
+}
+run_test 27L "lfs pool_list gives correct pool name"
+
 # createtest also checks that device nodes are created and
 # then visible correctly (#2091)
 test_28() { # bug 2091
@@ -5099,7 +5113,7 @@ test_53() {
        local mdtosc=$(get_mdtosc_proc_path $SINGLEMDS)
        local value
        for value in $(do_facet $SINGLEMDS \
-                      $LCTL get_param osc.$mdtosc.prealloc_last_id) ; do
+                      $LCTL get_param osp.$mdtosc.prealloc_last_id) ; do
                param=$(echo ${value[0]} | cut -d "=" -f1)
                ostname=$(echo $param | cut -d "." -f2 | cut -d - -f 1-2)
 
@@ -6936,9 +6950,9 @@ test_60g() {
 run_test 60g "transaction abort won't cause MDT hung"
 
 test_60h() {
-       [ $MDS1_VERSION -le $(version_code 2.12.52) ] ||
+       [ $MDS1_VERSION -le $(version_code 2.12.52) ] &&
                skip "Need MDS version at least 2.12.52"
-       [ $MDSCOUNT -le 2 ] || skip "Need >= 2 MDTs"
+       [ $MDSCOUNT -lt 2 ] && skip "Need at least 2 MDTs"
 
        local f
 
@@ -9589,7 +9603,7 @@ test_116a() { # was previously test_116()
        remote_mds_nodsh && skip "remote MDS with nodsh"
 
        echo -n "Free space priority "
-       do_facet $SINGLEMDS lctl get_param -n lo*.*-mdtlov.qos_prio_free |
+       do_facet $SINGLEMDS lctl get_param -n lo[vd].*-mdtlov.qos_prio_free |
                head -n1
        declare -a AVAIL
        free_min_max
@@ -9710,17 +9724,17 @@ test_116b() { # LU-2093
 
 #define OBD_FAIL_MDS_OSC_CREATE_FAIL     0x147
        local old_rr=$(do_facet $SINGLEMDS lctl get_param -n \
-                      lo*.$FSNAME-MDT0000-mdtlov.qos_threshold_rr | head -1)
+                      lo[vd].$FSNAME-MDT0000-mdtlov.qos_threshold_rr | head -1)
        [ -z "$old_rr" ] && skip "no QOS"
        do_facet $SINGLEMDS lctl set_param \
-               lo*.$FSNAME-MDT0000-mdtlov.qos_threshold_rr=0
+               lo[vd].$FSNAME-MDT0000-mdtlov.qos_threshold_rr=0
        mkdir -p $DIR/$tdir
        do_facet $SINGLEMDS lctl set_param fail_loc=0x147
        createmany -o $DIR/$tdir/f- 20 || error "can't create"
        do_facet $SINGLEMDS lctl set_param fail_loc=0
        rm -rf $DIR/$tdir
        do_facet $SINGLEMDS lctl set_param \
-               lo*.$FSNAME-MDT0000-mdtlov.qos_threshold_rr=$old_rr
+               lo[vd].$FSNAME-MDT0000-mdtlov.qos_threshold_rr=$old_rr
 }
 run_test 116b "QoS shouldn't LBUG if not enough OSTs found on the 2nd pass"
 
@@ -15183,9 +15197,9 @@ test_220() { #LU-325
        # on the mdt's osc
        local mdtosc_proc1=$(get_mdtosc_proc_path $SINGLEMDS $OST)
        local last_id=$(do_facet $SINGLEMDS lctl get_param -n \
-                       osc.$mdtosc_proc1.prealloc_last_id)
+                       osp.$mdtosc_proc1.prealloc_last_id)
        local next_id=$(do_facet $SINGLEMDS lctl get_param -n \
-                       osc.$mdtosc_proc1.prealloc_next_id)
+                       osp.$mdtosc_proc1.prealloc_next_id)
 
        $LFS df -i
 
@@ -15211,9 +15225,9 @@ test_220() { #LU-325
        createmany -o $DIR/$tdir/f $MDSOBJS || return 3
 
        local last_id2=$(do_facet mds${MDSIDX} lctl get_param -n \
-                       osc.$mdtosc_proc1.prealloc_last_id)
+                       osp.$mdtosc_proc1.prealloc_last_id)
        local next_id2=$(do_facet mds${MDSIDX} lctl get_param -n \
-                       osc.$mdtosc_proc1.prealloc_next_id)
+                       osp.$mdtosc_proc1.prealloc_next_id)
 
        echo "after creation, last_id=$last_id2, next_id=$next_id2"
        $LFS df -i
@@ -16874,33 +16888,6 @@ test_252() {
 }
 run_test 252 "check lr_reader tool"
 
-test_253_fill_ost() {
-       local size_mb #how many MB should we write to pass watermark
-       local lwm=$3  #low watermark
-       local free_10mb #10% of free space
-
-       free_kb=$($LFS df $MOUNT | grep $1 | awk '{ print $4 }')
-       size_mb=$((free_kb / 1024 - lwm))
-       free_10mb=$((free_kb / 10240))
-       #If 10% of free space cross low watermark use it
-       if (( free_10mb > size_mb )); then
-               size_mb=$free_10mb
-       else
-               #At least we need to store 1.1 of difference between
-               #free space and low watermark
-               size_mb=$((size_mb + size_mb / 10))
-       fi
-       if (( lwm <= $((free_kb / 1024)) )) || [ ! -f $DIR/$tdir/1 ]; then
-               dd if=/dev/zero of=$DIR/$tdir/1 bs=1M count=$size_mb \
-                        oflag=append conv=notrunc
-       fi
-
-       sleep_maxage
-
-       free_kb=$($LFS df $MOUNT | grep $1 | awk '{ print $4 }')
-       echo "OST still has $((free_kb / 1024)) mbytes free"
-}
-
 test_253() {
        [ $PARALLEL == "yes" ] && skip "skip parallel run"
        remote_mds_nodsh && skip "remote MDS with nodsh"
@@ -16908,9 +16895,8 @@ test_253() {
 
        local ostidx=0
        local rc=0
+       local ost_name=$(ostname_from_index $ostidx)
 
-       local ost_name=$($LFS osts |
-               sed -n 's/^'$ostidx': \(.*\)_UUID .*/\1/p')
        # on the mdt's osc
        local mdtosc_proc1=$(get_mdtosc_proc_path $SINGLEMDS $ost_name)
        do_facet $SINGLEMDS $LCTL get_param -n \
@@ -16922,60 +16908,45 @@ test_253() {
        wait_delete_completed
        mkdir $DIR/$tdir
 
-       local last_wm_h=$(do_facet $SINGLEMDS $LCTL get_param -n \
-                       osp.$mdtosc_proc1.reserved_mb_high)
-       local last_wm_l=$(do_facet $SINGLEMDS $LCTL get_param -n \
-                       osp.$mdtosc_proc1.reserved_mb_low)
-       echo "prev high watermark $last_wm_h, prev low watermark $last_wm_l"
-
        if ! combined_mgs_mds ; then
                mount_mgs_client
        fi
-       create_pool $FSNAME.$TESTNAME || error "Pool creation failed"
-       do_facet mgs $LCTL pool_add $FSNAME.$TESTNAME $ost_name ||
-               error "Adding $ost_name to pool failed"
-
-       # Wait for client to see a OST at pool
-       wait_update $HOSTNAME "$LCTL get_param -n
-               lov.$FSNAME-*.pools.$TESTNAME | sort -u |
-               grep $ost_name" "$ost_name""_UUID" $((TIMEOUT/2)) ||
-               error "Client can not see the pool"
+       pool_add $TESTNAME || error "Pool creation failed"
+       pool_add_targets $TESTNAME 0 || error "Pool add targets failed"
+
        $LFS setstripe $DIR/$tdir -i $ostidx -c 1 -p $FSNAME.$TESTNAME ||
                error "Setstripe failed"
 
-       dd if=/dev/zero of=$DIR/$tdir/0 bs=1M count=10
-       local blocks=$($LFS df $MOUNT | grep $ost_name | awk '{ print $4 }')
-       echo "OST still has $((blocks/1024)) mbytes free"
-
-       local new_lwm=$((blocks/1024-10))
-       do_facet $SINGLEMDS $LCTL set_param \
-                       osp.$mdtosc_proc1.reserved_mb_high=$((new_lwm+5))
-       do_facet $SINGLEMDS $LCTL set_param \
-                       osp.$mdtosc_proc1.reserved_mb_low=$new_lwm
-
-       test_253_fill_ost $ost_name $mdtosc_proc1 $new_lwm
+       dd if=/dev/zero of=$DIR/$tdir/$tfile.0 bs=1M count=10
 
-       #First enospc could execute orphan deletion so repeat.
-       test_253_fill_ost $ost_name $mdtosc_proc1 $new_lwm
+       local wms=$(ost_watermarks_set_enospc $tfile $ostidx |
+                   grep "watermarks")
+       stack_trap "ost_watermarks_clear_enospc $tfile $ostidx $wms" EXIT
 
        local oa_status=$(do_facet $SINGLEMDS $LCTL get_param -n \
                        osp.$mdtosc_proc1.prealloc_status)
        echo "prealloc_status $oa_status"
 
-       dd if=/dev/zero of=$DIR/$tdir/2 bs=1M count=1 &&
+       dd if=/dev/zero of=$DIR/$tdir/$tfile.1 bs=1M count=1 &&
                error "File creation should fail"
+
        #object allocation was stopped, but we still able to append files
-       dd if=/dev/zero of=$DIR/$tdir/1 bs=1M seek=6 count=5 oflag=append ||
-               error "Append failed"
-       rm -f $DIR/$tdir/1 $DIR/$tdir/0 $DIR/$tdir/r*
+       dd if=/dev/zero of=$DIR/$tdir/$tfile.0 bs=1M seek=6 count=5 \
+               oflag=append || error "Append failed"
+
+       rm -f $DIR/$tdir/$tfile.0
+
+       # For this test, we want to delete the files we created to go out of
+       # space but leave the watermark, so we remain nearly out of space
+       ost_watermarks_enospc_delete_files $tfile $ostidx
 
        wait_delete_completed
 
        sleep_maxage
 
        for i in $(seq 10 12); do
-               dd if=/dev/zero of=$DIR/$tdir/$i bs=1M count=1 2>/dev/null ||
-                       error "File creation failed after rm";
+               dd if=/dev/zero of=$DIR/$tdir/$tfile.$i bs=1M count=1 \
+                       2>/dev/null || error "File creation failed after rm"
        done
 
        oa_status=$(do_facet $SINGLEMDS $LCTL get_param -n \
@@ -16985,16 +16956,6 @@ test_253() {
        if (( oa_status != 0 )); then
                error "Object allocation still disable after rm"
        fi
-       do_facet $SINGLEMDS $LCTL set_param \
-                       osp.$mdtosc_proc1.reserved_mb_high=$last_wm_h
-       do_facet $SINGLEMDS $LCTL set_param \
-                       osp.$mdtosc_proc1.reserved_mb_low=$last_wm_l
-
-
-       do_facet mgs $LCTL pool_remove $FSNAME.$TESTNAME $ost_name ||
-               error "Remove $ost_name from pool failed"
-       do_facet mgs $LCTL pool_destroy $FSNAME.$TESTNAME ||
-               error "Pool destroy fialed"
 
        if ! combined_mgs_mds ; then
                umount_mgs_client
@@ -19378,6 +19339,51 @@ test_317() {
 }
 run_test 317 "Verify blocks get correctly update after truncate"
 
+test_318() {
+       local old_max_active=$($LCTL get_param -n \
+                           llite.*.max_read_ahead_async_active 2>/dev/null)
+
+       $LCTL set_param llite.*.max_read_ahead_async_active=256
+       local max_active=$($LCTL get_param -n \
+                          llite.*.max_read_ahead_async_active 2>/dev/null)
+       [ $max_active -ne 256 ] && error "expected 256 but got $max_active"
+
+       # currently reset to 0 is unsupported, leave it 512 for now.
+       $LCTL set_param llite.*.max_read_ahead_async_active=0 &&
+               error "set max_read_ahead_async_active should fail"
+
+       $LCTL set_param llite.*.max_read_ahead_async_active=512
+       max_active=$($LCTL get_param -n \
+                    llite.*.max_read_ahead_async_active 2>/dev/null)
+       [ $max_active -eq 512 ] || error "expected 512 but got $max_active"
+
+       # restore @max_active
+       [ $old_max_active -ne 0 ] && $LCTL set_param \
+               llite.*.max_read_ahead_async_active=$old_max_active
+
+       local old_threshold=$($LCTL get_param -n \
+               llite.*.read_ahead_async_file_threshold_mb 2>/dev/null)
+       local max_per_file_mb=$($LCTL get_param -n \
+               llite.*.max_read_ahead_per_file_mb 2>/dev/null)
+
+       local invalid=$(($max_per_file_mb + 1))
+       $LCTL set_param \
+               llite.*.read_ahead_async_file_threshold_mb=$invalid\
+                       && error "set $invalid should fail"
+
+       local valid=$(($invalid - 1))
+       $LCTL set_param \
+               llite.*.read_ahead_async_file_threshold_mb=$valid ||
+                       error "set $valid should succeed"
+       local threshold=$($LCTL get_param -n \
+               llite.*.read_ahead_async_file_threshold_mb 2>/dev/null)
+       [ $threshold -eq $valid ] || error \
+               "expect threshold $valid got $threshold"
+       $LCTL set_param \
+               llite.*.read_ahead_async_file_threshold_mb=$old_threshold
+}
+run_test 318 "Verify async readahead tunables"
+
 test_319() {
        [ $MDSCOUNT -lt 2 ] && skip "needs >= 2 MDTs" && return 0
 
@@ -20094,6 +20100,12 @@ test_413b() {
        done
        [ $((max - min)) -gt $MDSCOUNT ] ||
                error "subdirs shouldn't be evenly distributed"
+
+       which getfattr > /dev/null 2>&1 || skip_env "no getfattr command"
+
+       $LFS setdirstripe -D -d $DIR/$tdir || error "setdirstripe -d failed"
+       getfattr -n trusted.dmv $DIR/$tdir && error "default dir layout exists"
+       true
 }
 run_test 413b "mkdir with balanced space usage"
 
@@ -20313,14 +20325,17 @@ test_420()
        umask 0000
        mkdir -m03777 $dir/testdir
        ls -dn $dir/testdir
-       local dirperms=$(ls -dn $dir/testdir | awk '{print $1}')
+       # Need to remove trailing '.' when SELinux is enabled
+       local dirperms=$(ls -dn $dir/testdir |
+                        awk '{ sub(/\.$/, "", $1); print $1}')
        [ $dirperms == "drwxrwsrwt" ] ||
                error "incorrect perms on $dir/testdir"
 
-       $PDSH ${uname}@localhost "PATH=$LUSTRE/tests:\$PATH; \
+       su - $uname -c "PATH=$LUSTRE/tests:\$PATH; \
                openfile -f O_RDONLY:O_CREAT -m 02755 $dir/testdir/testfile"
        ls -n $dir/testdir/testfile
-       local fileperms=$(ls -n $dir/testdir/testfile | awk '{print $1}')
+       local fileperms=$(ls -n $dir/testdir/testfile |
+                         awk '{ sub(/\.$/, "", $1); print $1}')
        [ $fileperms == "-rwxr-xr-x" ] ||
                error "incorrect perms on $dir/testdir/testfile"
 
@@ -21281,6 +21296,34 @@ test_814()
 }
 run_test 814 "sparse cp works as expected (LU-12361)"
 
+test_815()
+{
+       writeme -b 100 $DIR/$tfile || error "write 100 bytes failed"
+       writeme -b 0 $DIR/$tfile || error "write 0 byte failed"
+}
+run_test 815 "zero byte tiny write doesn't hang (LU-12382)"
+
+test_816() {
+       $LFS setstripe -c 1 -i 0 $DIR/$tfile
+       # ensure ost1 is connected
+       stat $DIR/$tfile >/dev/null || error "can't stat"
+       wait_osc_import_state client ost1 FULL
+       # no locks, no reqs to let the connection idle
+       cancel_lru_locks osc
+       lru_resize_disable osc
+       local before
+       local now
+       before=$($LCTL get_param -n \
+                ldlm.namespaces.$FSNAME-OST0000-osc-[^M]*.lru_size)
+
+       wait_osc_import_state client ost1 IDLE
+       dd if=/dev/null of=$DIR/$tfile bs=1k count=1 conv=sync
+       now=$($LCTL get_param -n \
+             ldlm.namespaces.$FSNAME-OST0000-osc-[^M]*.lru_size)
+       [ $before == $now ] || error "lru_size changed $before != $now"
+}
+run_test 816 "do not reset lru_resize on idle reconnect"
+
 #
 # tests that do cleanup/setup should be run at the end
 #