72 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			72 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
| #!/bin/sh
 | |
| #
 | |
| # Copyright (c) 2005 Junio C Hamano
 | |
| #
 | |
| 
 | |
| test_description='More rename detection tests.
 | |
| 
 | |
| The rename detection logic should be able to detect pure rename or
 | |
| copy of symbolic links, but should not produce rename/copy followed
 | |
| by an edit for them.
 | |
| '
 | |
| 
 | |
| TEST_PASSES_SANITIZE_LEAK=true
 | |
| . ./test-lib.sh
 | |
| . "$TEST_DIRECTORY"/lib-diff.sh
 | |
| 
 | |
| test_expect_success SYMLINKS 'prepare reference tree' '
 | |
| 	echo xyzzy | tr -d '\\\\'012 >yomin &&
 | |
| 	ln -s xyzzy frotz &&
 | |
| 	git update-index --add frotz yomin &&
 | |
| 	tree=$(git write-tree) &&
 | |
| 	echo $tree
 | |
| '
 | |
| 
 | |
| test_expect_success SYMLINKS 'prepare work tree' '
 | |
| 	mv frotz rezrov &&
 | |
| 	rm -f yomin &&
 | |
| 	ln -s xyzzy nitfol &&
 | |
| 	ln -s xzzzy bozbar &&
 | |
| 	git update-index --add --remove frotz rezrov nitfol bozbar yomin
 | |
| '
 | |
| 
 | |
| # tree has frotz pointing at xyzzy, and yomin that contains xyzzy to
 | |
| # confuse things.  work tree has rezrov (xyzzy) nitfol (xyzzy) and
 | |
| # bozbar (xzzzy).
 | |
| # rezrov and nitfol are rename/copy of frotz and bozbar should be
 | |
| # a new creation.
 | |
| 
 | |
| test_expect_success SYMLINKS 'setup diff output' '
 | |
| 	GIT_DIFF_OPTS=--unified=0 git diff-index -C -p $tree >current &&
 | |
| 	cat >expected <<\EOF
 | |
| diff --git a/bozbar b/bozbar
 | |
| new file mode 120000
 | |
| --- /dev/null
 | |
| +++ b/bozbar
 | |
| @@ -0,0 +1 @@
 | |
| +xzzzy
 | |
| \ No newline at end of file
 | |
| diff --git a/frotz b/nitfol
 | |
| similarity index 100%
 | |
| copy from frotz
 | |
| copy to nitfol
 | |
| diff --git a/frotz b/rezrov
 | |
| similarity index 100%
 | |
| rename from frotz
 | |
| rename to rezrov
 | |
| diff --git a/yomin b/yomin
 | |
| deleted file mode 100644
 | |
| --- a/yomin
 | |
| +++ /dev/null
 | |
| @@ -1 +0,0 @@
 | |
| -xyzzy
 | |
| \ No newline at end of file
 | |
| EOF
 | |
| '
 | |
| 
 | |
| test_expect_success SYMLINKS 'validate diff output' '
 | |
| 	compare_diff_patch current expected
 | |
| '
 | |
| 
 | |
| test_done
 |