 8facec08fe
			
		
	
	8facec08fe
	
	
	
		
			
			In Git for Windows, the MSYS2 POSIX emulation layer used by the Bash converts command-line arguments that looks like they refer to a POSIX path containing a file list (i.e. @<absolute-path>) into a Windows path equivalent when calling non-MSYS2 executables, such as git.exe. Let's just skip the test that uses the parameter `@/at-test` that confuses the MSYS2 runtime. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			103 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='test various @{X} syntax combinations together'
 | |
| . ./test-lib.sh
 | |
| 
 | |
| check() {
 | |
| 	test_expect_${4:-success} "$1 = $3" "
 | |
| 		echo '$3' >expect &&
 | |
| 		if test '$2' = 'commit'
 | |
| 		then
 | |
| 			git log -1 --format=%s '$1' >actual
 | |
| 		elif test '$2' = 'ref'
 | |
| 		then
 | |
| 			git rev-parse --symbolic-full-name '$1' >actual
 | |
| 		else
 | |
| 			git cat-file -p '$1' >actual
 | |
| 		fi &&
 | |
| 		test_cmp expect actual
 | |
| 	"
 | |
| }
 | |
| 
 | |
| nonsense() {
 | |
| 	test_expect_${2:-success} "$1 is nonsensical" "
 | |
| 		test_must_fail git rev-parse --verify '$1'
 | |
| 	"
 | |
| }
 | |
| 
 | |
| fail() {
 | |
| 	"$@" failure
 | |
| }
 | |
| 
 | |
| test_expect_success 'setup' '
 | |
| 	test_commit master-one &&
 | |
| 	test_commit master-two &&
 | |
| 	git checkout -b upstream-branch &&
 | |
| 	test_commit upstream-one &&
 | |
| 	test_commit upstream-two &&
 | |
| 	if test_have_prereq !MINGW
 | |
| 	then
 | |
| 		git checkout -b @/at-test
 | |
| 	fi &&
 | |
| 	git checkout -b @@/at-test &&
 | |
| 	git checkout -b @at-test &&
 | |
| 	git checkout -b old-branch &&
 | |
| 	test_commit old-one &&
 | |
| 	test_commit old-two &&
 | |
| 	git checkout -b new-branch &&
 | |
| 	test_commit new-one &&
 | |
| 	test_commit new-two &&
 | |
| 	git branch -u master old-branch &&
 | |
| 	git branch -u upstream-branch new-branch
 | |
| '
 | |
| 
 | |
| check HEAD ref refs/heads/new-branch
 | |
| check "@{1}" commit new-one
 | |
| check "HEAD@{1}" commit new-one
 | |
| check "@{now}" commit new-two
 | |
| check "HEAD@{now}" commit new-two
 | |
| check "@{-1}" ref refs/heads/old-branch
 | |
| check "@{-1}@{0}" commit old-two
 | |
| check "@{-1}@{1}" commit old-one
 | |
| check "@{u}" ref refs/heads/upstream-branch
 | |
| check "HEAD@{u}" ref refs/heads/upstream-branch
 | |
| check "@{u}@{1}" commit upstream-one
 | |
| check "@{-1}@{u}" ref refs/heads/master
 | |
| check "@{-1}@{u}@{1}" commit master-one
 | |
| check "@" commit new-two
 | |
| check "@@{u}" ref refs/heads/upstream-branch
 | |
| check "@@/at-test" ref refs/heads/@@/at-test
 | |
| test_have_prereq MINGW ||
 | |
| check "@/at-test" ref refs/heads/@/at-test
 | |
| check "@at-test" ref refs/heads/@at-test
 | |
| nonsense "@{u}@{-1}"
 | |
| nonsense "@{0}@{0}"
 | |
| nonsense "@{1}@{u}"
 | |
| nonsense "HEAD@{-1}"
 | |
| nonsense "@{-1}@{-1}"
 | |
| 
 | |
| # @{N} versus HEAD@{N}
 | |
| 
 | |
| check "HEAD@{3}" commit old-two
 | |
| nonsense "@{3}"
 | |
| 
 | |
| test_expect_success 'switch to old-branch' '
 | |
| 	git checkout old-branch
 | |
| '
 | |
| 
 | |
| check HEAD ref refs/heads/old-branch
 | |
| check "HEAD@{1}" commit new-two
 | |
| check "@{1}" commit old-one
 | |
| 
 | |
| test_expect_success 'create path with @' '
 | |
| 	echo content >normal &&
 | |
| 	echo content >fun@ny &&
 | |
| 	git add normal fun@ny &&
 | |
| 	git commit -m "funny path"
 | |
| '
 | |
| 
 | |
| check "@:normal" blob content
 | |
| check "@:fun@ny" blob content
 | |
| 
 | |
| test_done
 |