| #!/bin/sh | 
 |  | 
 | test_description='check that read-tree rejects confusing paths' | 
 | . ./test-lib.sh | 
 |  | 
 | test_expect_success 'create base tree' ' | 
 | 	echo content >file && | 
 | 	git add file && | 
 | 	git commit -m base && | 
 | 	blob=$(git rev-parse HEAD:file) && | 
 | 	tree=$(git rev-parse HEAD^{tree}) | 
 | ' | 
 |  | 
 | test_expect_success 'enable core.protectHFS for rejection tests' ' | 
 | 	git config core.protectHFS true | 
 | ' | 
 |  | 
 | test_expect_success 'enable core.protectNTFS for rejection tests' ' | 
 | 	git config core.protectNTFS true | 
 | ' | 
 |  | 
 | while read path pretty; do | 
 | 	: ${pretty:=$path} | 
 | 	case "$path" in | 
 | 	*SPACE) | 
 | 		path="${path%SPACE} " | 
 | 		;; | 
 | 	esac | 
 | 	test_expect_success "reject $pretty at end of path" ' | 
 | 		printf "100644 blob %s\t%s" "$blob" "$path" >tree && | 
 | 		bogus=$(git mktree <tree) && | 
 | 		test_must_fail git read-tree $bogus | 
 | 	' | 
 |  | 
 | 	test_expect_success "reject $pretty as subtree" ' | 
 | 		printf "040000 tree %s\t%s" "$tree" "$path" >tree && | 
 | 		bogus=$(git mktree <tree) && | 
 | 		test_must_fail git read-tree $bogus | 
 | 	' | 
 | done <<-EOF | 
 | . | 
 | .. | 
 | .git | 
 | .GIT | 
 | ${u200c}.Git {u200c}.Git | 
 | .gI${u200c}T .gI{u200c}T | 
 | .GiT${u200c} .GiT{u200c} | 
 | git~1 | 
 | .git.SPACE .git.{space} | 
 | .\\\\.GIT\\\\foobar backslashes | 
 | .git\\\\foobar backslashes2 | 
 | EOF | 
 |  | 
 | test_expect_success 'utf-8 paths allowed with core.protectHFS off' ' | 
 | 	test_when_finished "git read-tree HEAD" && | 
 | 	test_config core.protectHFS false && | 
 | 	printf "100644 blob %s\t%s" "$blob" ".gi${u200c}t" >tree && | 
 | 	ok=$(git mktree <tree) && | 
 | 	git read-tree $ok | 
 | ' | 
 |  | 
 | test_done |