mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
99c495a308
Btrfs has always failed shared/218 because of the way we allocate extents on disk. The last part of 218 writes contiguously holey from the start of the file forward, which for btrfs means we get 16 extents but they are physically contigous. filefrag -v shows all 16 extents, but prints out that there is 1 extent, because they are physically contiguous. This isn't quite right and makes the test fail. So instead of using filefrag use xfs_io -c fiemap which will print the whole map and then get the count from there. With this patch btrfs now passes the test, I also verified that ext4 and xfs still pass this test. Thanks, Signed-off-by: Josef Bacik <jbacik@fusionio.com> Reviewed-by: Dave Chinner <dchinner@redhat.com> Signed-off-by: Ben Myers <bpm@sgi.com>
72 lines
1.8 KiB
Plaintext
72 lines
1.8 KiB
Plaintext
##/bin/bash
|
|
#
|
|
# Copyright (c) 2009 Eric Sandeen
|
|
# All Rights Reserved.
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License as
|
|
# published by the Free Software Foundation.
|
|
#
|
|
# This program is distributed in the hope that it would be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write the Free Software Foundation,
|
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
#
|
|
#
|
|
# Functions useful for defragmentation tests
|
|
#
|
|
|
|
_require_defrag()
|
|
{
|
|
case "$FSTYP" in
|
|
xfs)
|
|
DEFRAG_PROG="$XFS_FSR_PROG"
|
|
;;
|
|
ext4|ext4dev)
|
|
DEFRAG_PROG="$E4DEFRAG_PROG"
|
|
;;
|
|
btrfs)
|
|
DEFRAG_PROG="$BTRFS_UTIL_PROG filesystem defragment"
|
|
;;
|
|
*)
|
|
_notrun "defragmentation not supported for fstype \"$FSTYP\""
|
|
;;
|
|
esac
|
|
|
|
_require_command $DEFRAG_PROG
|
|
_require_xfs_io_fiemap
|
|
}
|
|
|
|
_extent_count()
|
|
{
|
|
$XFS_IO_PROG -c "fiemap" $1 | tail -n +2 | grep -v hole | wc -l
|
|
$XFS_IO_PROG -c "fiemap" $1 >> $seqres.full 2>&1
|
|
}
|
|
|
|
# Defrag file, check it, and remove it.
|
|
_defrag()
|
|
{
|
|
echo -n "Before: "
|
|
_extent_count $1
|
|
CSUM_BEFORE=`md5sum $1`
|
|
STAT_BEFORE=`stat -c "a: %x m: %y c: %z" $1`
|
|
$DEFRAG_PROG -v $1 >> $seqres.full 2>&1
|
|
_scratch_remount
|
|
STAT_AFTER=`stat -c "a: %x m: %y c: %z" $1`
|
|
CSUM_AFTER=`md5sum $1`
|
|
echo -n "After: "
|
|
_extent_count $1
|
|
if [ "$CSUM_BEFORE" != "$CSUM_AFTER" ]; then
|
|
_fail "file checksum changed post-defrag ($CSUM_BEFORE/$CSUM_AFTER)"
|
|
fi
|
|
if [ "$STAT_BEFORE" != "$STAT_AFTER" ]; then
|
|
_fail "file timestamps changed post-defrag:\n$STAT_BEFORE\n$STAT_AFTER"
|
|
fi
|
|
rm -f $1
|
|
}
|
|
|