 acd2a45b83
			
		
	
	acd2a45b83
	
	
	
		
			
			This makes git-push refuse pushing into a non-bare repository to update the current branch by default. To help people who are used to be able to do this (and later "reset --hard" it in some other way), an error message is issued when this refusal is triggered, instructing how to resurrect the old behaviour. Hosting sites that do not give the users direct access to customize their repositories (e.g. repo.or.cz, gitorious, github etc.) may further want to explicitly set the configuration variable to "refuse" for their customers' repositories. Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			44 lines
		
	
	
		
			656 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			656 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='forced push to replace commit we do not have'
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success setup '
 | |
| 
 | |
| 	>file1 && git add file1 && test_tick &&
 | |
| 	git commit -m Initial &&
 | |
| 	git config receive.denyCurrentBranch warn &&
 | |
| 
 | |
| 	mkdir another && (
 | |
| 		cd another &&
 | |
| 		git init &&
 | |
| 		git fetch --update-head-ok .. master:master
 | |
| 	) &&
 | |
| 
 | |
| 	>file2 && git add file2 && test_tick &&
 | |
| 	git commit -m Second
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success 'non forced push should die not segfault' '
 | |
| 
 | |
| 	(
 | |
| 		cd another &&
 | |
| 		git push .. master:master
 | |
| 		test $? = 1
 | |
| 	)
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success 'forced push should succeed' '
 | |
| 
 | |
| 	(
 | |
| 		cd another &&
 | |
| 		git push .. +master:master
 | |
| 	)
 | |
| 
 | |
| '
 | |
| 
 | |
| test_done
 |