summaryrefslogtreecommitdiff
path: root/tests/generic/479
blob: ad20aaeecb76f6be4810bad928be8275cec120bc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (C) 2018 SUSE Linux Products GmbH. All Rights Reserved.
#
# FSQA Test No. 479
#
# Test that when a fsync journal/log exists, if we rename a special file (fifo,
# symbolic link or device), create a hard link for it with its old name and then
# commit the journal/log, if a power loss happens the filesystem will not fail
# to replay the journal/log when it is mounted the next time.
#
seq=`basename $0`
seqres=$RESULT_DIR/$seq
echo "QA output created by $seq"
tmp=/tmp/$$
status=1	# failure is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15

_cleanup()
{
	_cleanup_flakey
	cd /
	rm -f $tmp.*
}

# get standard environment, filters and checks
. ./common/rc
. ./common/filter
. ./common/dmflakey

# real QA test starts here
_supported_fs generic
_supported_os Linux
_require_scratch
_require_dm_target flakey

rm -f $seqres.full

run_test()
{
	local file_type=$1

	_scratch_mkfs >>$seqres.full 2>&1
	_require_metadata_journaling $SCRATCH_DEV
	_init_flakey
	_mount_flakey

	mkdir $SCRATCH_MNT/testdir
	case $file_type in
	symlink)
		ln -s xxx $SCRATCH_MNT/testdir/foo
		;;
	fifo)
		mkfifo $SCRATCH_MNT/testdir/foo
		;;
	dev)
		mknod $SCRATCH_MNT/testdir/foo c 0 0
		;;
	*)
		_fail "Invalid file type argument: $file_type"
	esac
	# Make sure everything done so far is durably persisted.
	sync

	# Create a file and fsync it just to create a journal/log. This file
	# must be in the same directory as our special file "foo".
	touch $SCRATCH_MNT/testdir/f1
	$XFS_IO_PROG -c "fsync" $SCRATCH_MNT/testdir/f1

	# Rename our special file and then create link that has its old name.
	mv $SCRATCH_MNT/testdir/foo $SCRATCH_MNT/testdir/bar
	ln $SCRATCH_MNT/testdir/bar $SCRATCH_MNT/testdir/foo

	# Create a second file and fsync it. This is just to durably persist the
	# fsync journal/log which is typically modified by the previous rename
	# and link operations. This file does not need to be placed in the same
	# directory as our special file.
	touch $SCRATCH_MNT/f2
	$XFS_IO_PROG -c "fsync" $SCRATCH_MNT/f2

	# Simulate a power failure and mount the filesystem to check that
	# replaying the fsync log/journal succeeds, that is the mount operation
	# does not fail.
	_flakey_drop_and_remount
	_unmount_flakey
	_cleanup_flakey
}

run_test symlink
run_test fifo
run_test dev

echo "Silence is golden"
status=0
exit