85 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| OUT=$test_name.log
 | |
| EXP=$test_dir/expect
 | |
| E2FSCK=../e2fsck/e2fsck
 | |
| 
 | |
| NAMELEN=255
 | |
| DIRENT_SZ=8
 | |
| BLOCKSZ=1024
 | |
| INODESZ=128
 | |
| CSUM_SZ=8
 | |
| CSUM_TAIL_SZ=12
 | |
| DIRENT_PER_LEAF=$(((BLOCKSZ - CSUM_TAIL_SZ) / (NAMELEN + DIRENT_SZ)))
 | |
| HEADER=32
 | |
| INDEX_SZ=8
 | |
| INDEX_L1=$(((BLOCKSZ - HEADER - CSUM_SZ) / INDEX_SZ))
 | |
| INDEX_L2=$(((BLOCKSZ - DIRENT_SZ - CSUM_SZ) / INDEX_SZ))
 | |
| DIRBLK=$((3 + INDEX_L1 * INDEX_L2))
 | |
| ENTRIES=$((DIRBLK * DIRENT_PER_LEAF))
 | |
| # directory leaf blocks - get twice as much because the leaves won't be full
 | |
| # and there are also other filesystem blocks.
 | |
| FSIZE=$((DIRBLK * 2))
 | |
| 
 | |
| $MKE2FS -b 1024 -O extents,64bit,large_dir,uninit_bg,metadata_csum -N 50 \
 | |
| 	-I $INODESZ -F $TMPFILE $FSIZE > $OUT.new 2>&1
 | |
| RC=$?
 | |
| if [ $RC -eq 0 ]; then
 | |
| {
 | |
| 	# First some initial fs setup to create indexed dir
 | |
| 	echo "mkdir /foo"
 | |
| 	echo "cd /foo"
 | |
| 	touch $TMPFILE.tmp
 | |
| 	echo "write $TMPFILE.tmp foofile"
 | |
| 	i=0
 | |
| 	while test $i -lt $DIRENT_PER_LEAF ; do
 | |
| 		printf "ln foofile f%0254u\n" $i
 | |
| 		i=$((i + 1));
 | |
| 	done
 | |
| 	echo "expand ./"
 | |
| 	printf "ln foofile f%0254u\n" $i
 | |
| } | $DEBUGFS -w $TMPFILE > /dev/null 2>> $OUT.new
 | |
| 	RC=$?
 | |
| 	# e2fsck should optimize the dir to become indexed
 | |
| 	$E2FSCK -yfD $TMPFILE >> $OUT.new 2>&1
 | |
| 	status=$?
 | |
| 	echo Exit status is $status >> $OUT.new
 | |
| fi
 | |
| 
 | |
| if [ $RC -eq 0 ]; then
 | |
| {
 | |
| 	START=$SECONDS
 | |
| 	i=$(($DIRENT_PER_LEAF+1))
 | |
| 	last=$i
 | |
| 	echo "cd /foo"
 | |
| 	while test $i -lt $ENTRIES ; do
 | |
| 	    ELAPSED=$((SECONDS - START))
 | |
| 	    if test $((i % 5000)) -eq 0 -a $ELAPSED -gt 10; then
 | |
| 		RATE=$(((i - last) / ELAPSED))
 | |
| 		echo "$test_name: $i/$ENTRIES links, ${ELAPSED}s @ $RATE/s" >&2
 | |
| 		START=$SECONDS
 | |
| 		last=$i
 | |
| 	    fi
 | |
| 	    printf "ln foofile f%0254u\n" $i
 | |
| 	    i=$((i + 1))
 | |
| 	done
 | |
| } | $DEBUGFS -w $TMPFILE > /dev/null 2>> $OUT.new
 | |
| 	RC=$?
 | |
| fi
 | |
| 
 | |
| if [ $RC -eq 0 ]; then
 | |
| 	$E2FSCK -yfD $TMPFILE >> $OUT.new 2>&1
 | |
| 	status=$?
 | |
| 	echo Exit status is $status >> $OUT.new
 | |
| 	sed -f $cmd_dir/filter.sed -e "s;$TMPFILE;test.img;" $OUT.new > $OUT
 | |
| 	rm -f $OUT.new
 | |
| 
 | |
| 	cmp -s $OUT $EXP
 | |
| 	RC=$?
 | |
| fi
 | |
| if [ $RC -eq 0 ]; then
 | |
| 	echo "$test_name: $test_description: ok"
 | |
| 	touch $test_name.ok
 | |
| else
 | |
| 	echo "$test_name: $test_description: failed"
 | |
| 	diff -u $EXP $OUT > $test_name.failed
 | |
| fi
 |