blob: 7e5538494230d62930d3c6aac1c5b23a24470e64 [file] [log] [blame]
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0+
# Copyright (c) 2019, Oracle and/or its affiliates. All Rights Reserved.
#
# FS QA Test No. 506
#
# Basic tests of the xfs_spaceman health command.
seq=`basename $0`
seqres=$RESULT_DIR/$seq
echo "QA output created by $seq"
here=`pwd`
tmp=/tmp/$$
status=1 # failure is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15
_cleanup()
{
cd /
rm -f $tmp.*
}
# get standard environment, filters and checks
. ./common/rc
. ./common/fuzzy
. ./common/filter
# real QA test starts here
_supported_fs xfs
_require_scratch_nocheck
_require_scrub
_require_xfs_spaceman_command "health"
rm -f $seqres.full
_scratch_mkfs > $seqres.full 2>&1
_scratch_mount
_scratch_cycle_mount # make sure we haven't run quotacheck on this mount
# Haven't checked anything, it should tell us to run scrub
$XFS_SPACEMAN_PROG -c "health" $SCRATCH_MNT
# Run scrub to collect health info.
_scratch_scrub -n >> $seqres.full
query() {
$XFS_SPACEMAN_PROG -c "$@" $SCRATCH_MNT | tee -a $seqres.full
}
query_health() {
query "$@" | grep -q ": ok$"
}
query_sick() {
query "$@" | grep -q ": unhealthy$"
}
# Let's see if we get at least one healthy rating for each health reporting
# group.
query_health "health -f" || \
echo "Didn't see a single healthy fs metadata?"
query_health "health -a 0" || \
echo "Didn't see a single healthy ag metadata?"
query_health "health $SCRATCH_MNT" || \
echo "Didn't see a single healthy file metadata?"
# Unmount, corrupt filesystem
_scratch_unmount
_scratch_xfs_db -x -c 'sb 1' -c 'fuzz -d magicnum random' >> $seqres.full
# Now let's see what the AG report says
_scratch_mount
_scratch_scrub -n >> $seqres.full 2>&1
query_sick "health -a 1" || \
echo "Didn't see the expected unhealthy metadata?"
# success, all done
status=0
exit