 e4e68081bb
			
		
	
	e4e68081bb
	
	
	
		
			
			* maint-2.29: Git 2.29.3 Git 2.28.1 Git 2.27.1 Git 2.26.3 Git 2.25.5 Git 2.24.4 Git 2.23.4 Git 2.22.5 Git 2.21.4 Git 2.20.5 Git 2.19.6 Git 2.18.5 Git 2.17.6 unpack_trees(): start with a fresh lstat cache run-command: invalidate lstat cache after a command finished checkout: fix bug that makes checkout follow symlinks in leading path
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='basic checkout-index tests
 | |
| '
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success 'checkout-index --gobbledegook' '
 | |
| 	test_expect_code 129 git checkout-index --gobbledegook 2>err &&
 | |
| 	test_i18ngrep "[Uu]sage" err
 | |
| '
 | |
| 
 | |
| test_expect_success 'checkout-index -h in broken repository' '
 | |
| 	mkdir broken &&
 | |
| 	(
 | |
| 		cd broken &&
 | |
| 		git init &&
 | |
| 		>.git/index &&
 | |
| 		test_expect_code 129 git checkout-index -h >usage 2>&1
 | |
| 	) &&
 | |
| 	test_i18ngrep "[Uu]sage" broken/usage
 | |
| '
 | |
| 
 | |
| test_expect_success 'checkout-index reports errors (cmdline)' '
 | |
| 	test_must_fail git checkout-index -- does-not-exist 2>stderr &&
 | |
| 	test_i18ngrep not.in.the.cache stderr
 | |
| '
 | |
| 
 | |
| test_expect_success 'checkout-index reports errors (stdin)' '
 | |
| 	echo does-not-exist |
 | |
| 	test_must_fail git checkout-index --stdin 2>stderr &&
 | |
| 	test_i18ngrep not.in.the.cache stderr
 | |
| '
 | |
| for mode in 'case' 'utf-8'
 | |
| do
 | |
| 	case "$mode" in
 | |
| 	case)	dir='A' symlink='a' mode_prereq='CASE_INSENSITIVE_FS' ;;
 | |
| 	utf-8)
 | |
| 		dir=$(printf "\141\314\210") symlink=$(printf "\303\244")
 | |
| 		mode_prereq='UTF8_NFD_TO_NFC' ;;
 | |
| 	esac
 | |
| 
 | |
| 	test_expect_success SYMLINKS,$mode_prereq \
 | |
| 	"checkout-index with $mode-collision don't write to the wrong place" '
 | |
| 		git init $mode-collision &&
 | |
| 		(
 | |
| 			cd $mode-collision &&
 | |
| 			mkdir target-dir &&
 | |
| 
 | |
| 			empty_obj_hex=$(git hash-object -w --stdin </dev/null) &&
 | |
| 			symlink_hex=$(printf "%s" "$PWD/target-dir" | git hash-object -w --stdin) &&
 | |
| 
 | |
| 			cat >objs <<-EOF &&
 | |
| 			100644 blob ${empty_obj_hex}	${dir}/x
 | |
| 			100644 blob ${empty_obj_hex}	${dir}/y
 | |
| 			100644 blob ${empty_obj_hex}	${dir}/z
 | |
| 			120000 blob ${symlink_hex}	${symlink}
 | |
| 			EOF
 | |
| 
 | |
| 			git update-index --index-info <objs &&
 | |
| 
 | |
| 			# Note: the order is important here to exercise the
 | |
| 			# case where the file at ${dir} has its type changed by
 | |
| 			# the time Git tries to check out ${dir}/z.
 | |
| 			#
 | |
| 			# Also, we use core.precomposeUnicode=false because we
 | |
| 			# want Git to treat the UTF-8 paths transparently on
 | |
| 			# Mac OS, matching what is in the index.
 | |
| 			#
 | |
| 			git -c core.precomposeUnicode=false checkout-index -f \
 | |
| 				${dir}/x ${dir}/y ${symlink} ${dir}/z &&
 | |
| 
 | |
| 			# Should not create ${dir}/z at ${symlink}/z
 | |
| 			test_path_is_missing target-dir/z
 | |
| 
 | |
| 		)
 | |
| 	'
 | |
| done
 | |
| 
 | |
| test_done
 |