summaryrefslogtreecommitdiff
path: root/tests/btrfs/154
blob: f5dfce4bc39a0f0fa80c7798d2810808ad099eb0 (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
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2020 Synology.  All Rights Reserved.
#
# FS QA Test No. 154
#
# Test if btrfs rename handle dir item collision correctly
# Without patch fix, rename will fail with EOVERFLOW, and filesystem
# is forced readonly.
#
# This bug is going to be fixed by a patch for kernel titled
# "btrfs: correctly calculate item size used when item key collision happens"
#
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/filter

# real QA test starts here

_supported_fs btrfs
_require_scratch
_require_command $PYTHON2_PROG python2

rm -f $seqres.full

# Currently in btrfs the node/leaf size can not be smaller than the page
# size (but it can be greater than the page size). So use the largest
# supported node/leaf size (64Kb) so that the test can run on any platform
# that Linux supports.
_scratch_mkfs "--nodesize 65536" >>$seqres.full 2>&1
_scratch_mount

#
# In the following for loop, we'll create a leaf fully occupied by
# only one dir item with many forged collision names in it.
#
# leaf 22544384 items 1 free space 0 generation 6 owner FS_TREE
# leaf 22544384 flags 0x1(WRITTEN) backref revision 1
# fs uuid 9064ba52-3d2c-4840-8e26-35db08fa17d7
# chunk uuid 9ba39317-3159-46c9-a75a-965ab1e94267
#    item 0 key (256 DIR_ITEM 3737737011) itemoff 25 itemsize 65410
#    ...
#

$PYTHON2_PROG $here/src/btrfs_crc32c_forged_name.py -d $SCRATCH_MNT -c 310
echo "Silence is golden"

# success, all done
status=0; exit