| #! /bin/bash |
| # SPDX-License-Identifier: GPL-2.0 |
| # Copyright (c) 2018 Huawei. All Rights Reserved. |
| # |
| # FS QA Test 508 |
| # |
| # This testcase is trying to test recovery flow of generic filesystem, it needs |
| # creation time support on specified filesystem. |
| # With below steps, once the file is created, creation time attribute should be |
| # valid on the file, after we fsync that file, it expects creation time can be |
| # recovered after sudden power-cuts. |
| # 1. touch testfile; |
| # 1.1 sync (optional) |
| # 2. xfs_io -f testfile -c "fsync"; |
| # 3. godown; |
| # 4. umount; |
| # 5. mount; |
| # 6. check creation time |
| # |
| . ./common/preamble |
| _begin_fstest shutdown auto quick metadata |
| |
| # Import common functions. |
| . ./common/filter |
| |
| |
| _require_test_lsattr |
| _require_statx |
| _require_xfs_io_command "statx" "-v" |
| |
| _require_scratch |
| _require_scratch_shutdown |
| _require_scratch_btime |
| |
| _scratch_mkfs >/dev/null 2>&1 |
| _require_metadata_journaling $SCRATCH_DEV |
| |
| testfile=$SCRATCH_MNT/testfile |
| |
| do_check() |
| { |
| _scratch_mount |
| |
| touch $testfile |
| |
| if [ "$1" == "sync" ]; then |
| _scratch_sync |
| fi |
| |
| before=`$XFS_IO_PROG -f $testfile -c "statx -v" | grep btime` |
| |
| $XFS_IO_PROG -f $testfile -c "fsync" | _filter_xfs_io |
| |
| _scratch_shutdown | tee -a $seqres.full |
| _scratch_cycle_mount |
| |
| after=`$XFS_IO_PROG -f $testfile -c "statx -v" | grep btime` |
| |
| # check inode's creation time |
| if [ "$before" != "$after" ]; then |
| echo "Before: $before" |
| echo "After : $after" |
| fi |
| echo "Before: $before" >> $seqres.full |
| echo "After : $after" >> $seqres.full |
| |
| rm -f $testfile |
| _scratch_unmount |
| } |
| |
| echo "Silence is golden" |
| |
| do_check |
| do_check sync |
| |
| status=0 |
| exit |