 c8556c6213
			
		
	
	c8556c6213
	
	
	
		
			
			When parse_pathspec() is called with no paths, the behavior could be either return no paths, or return one path that is cwd. Some commands do the former, some the latter. parse_pathspec() itself does not make either the default and requires the caller to specify either flag if it may run into this situation. I've grep'd through all parse_pathspec() call sites. Some pass neither, but those are guaranteed never pass empty path to parse_pathspec(). There are two call sites that may pass empty path and are fixed with this patch. [jc: added a test from Antoine's bug report] Reported-by: Antoine Pelisse <apelisse@gmail.com> Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='magic pathspec tests using git-log'
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success 'setup' '
 | |
| 	test_commit initial &&
 | |
| 	test_tick &&
 | |
| 	git commit --allow-empty -m empty &&
 | |
| 	mkdir sub
 | |
| '
 | |
| 
 | |
| test_expect_success '"git log :/" should not be ambiguous' '
 | |
| 	git log :/
 | |
| '
 | |
| 
 | |
| test_expect_success '"git log :/a" should be ambiguous (applied both rev and worktree)' '
 | |
| 	: >a &&
 | |
| 	test_must_fail git log :/a 2>error &&
 | |
| 	grep ambiguous error
 | |
| '
 | |
| 
 | |
| test_expect_success '"git log :/a -- " should not be ambiguous' '
 | |
| 	git log :/a --
 | |
| '
 | |
| 
 | |
| test_expect_success '"git log -- :/a" should not be ambiguous' '
 | |
| 	git log -- :/a
 | |
| '
 | |
| 
 | |
| test_expect_success '"git log :" should be ambiguous' '
 | |
| 	test_must_fail git log : 2>error &&
 | |
| 	grep ambiguous error
 | |
| '
 | |
| 
 | |
| test_expect_success 'git log -- :' '
 | |
| 	git log -- :
 | |
| '
 | |
| 
 | |
| test_expect_success 'git log HEAD -- :/' '
 | |
| 	cat >expected <<-EOF &&
 | |
| 	24b24cf initial
 | |
| 	EOF
 | |
| 	(cd sub && git log --oneline HEAD -- :/ >../actual) &&
 | |
| 	test_cmp expected actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'command line pathspec parsing for "git log"' '
 | |
| 	git reset --hard &&
 | |
| 	>a &&
 | |
| 	git add a &&
 | |
| 	git commit -m "add an empty a" --allow-empty &&
 | |
| 	echo 1 >a &&
 | |
| 	git commit -a -m "update a to 1" &&
 | |
| 	git checkout HEAD^ &&
 | |
| 	echo 2 >a &&
 | |
| 	git commit -a -m "update a to 2" &&
 | |
| 	test_must_fail git merge master &&
 | |
| 	git add a &&
 | |
| 	git log --merge -- a
 | |
| '
 | |
| 
 | |
| test_done
 |