 4f4b18497a
			
		
	
	4f4b18497a
	
	
	
		
			
			Broken &&-chains in the test scripts have been corrected.
* es/test-chain-lint:
  t6000-t9999: detect and signal failure within loop
  t5000-t5999: detect and signal failure within loop
  t4000-t4999: detect and signal failure within loop
  t0000-t3999: detect and signal failure within loop
  tests: simplify by dropping unnecessary `for` loops
  tests: apply modern idiom for exiting loop upon failure
  tests: apply modern idiom for signaling test failure
  tests: fix broken &&-chains in `{...}` groups
  tests: fix broken &&-chains in `$(...)` command substitutions
  tests: fix broken &&-chains in compound statements
  tests: use test_write_lines() to generate line-oriented output
  tests: simplify construction of large blocks of text
  t9107: use shell parameter expansion to avoid breaking &&-chain
  t6300: make `%(raw:size) --shell` test more robust
  t5516: drop unnecessary subshell and command invocation
  t4202: clarify intent by creating expected content less cleverly
  t1020: avoid aborting entire test script when one test fails
  t1010: fix unnoticed failure on Windows
  t/lib-pager: use sane_unset() to avoid breaking &&-chain
		
	
		
			
				
	
	
		
			150 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='more git add -u'
 | |
| 
 | |
| TEST_PASSES_SANITIZE_LEAK=true
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success setup '
 | |
| 	>xyzzy &&
 | |
| 	_empty=$(git hash-object --stdin <xyzzy) &&
 | |
| 	>yomin &&
 | |
| 	>caskly &&
 | |
| 	if test_have_prereq SYMLINKS; then
 | |
| 		ln -s frotz nitfol &&
 | |
| 		T_letter=T
 | |
| 	else
 | |
| 		printf %s frotz > nitfol &&
 | |
| 		T_letter=M
 | |
| 	fi &&
 | |
| 	mkdir rezrov &&
 | |
| 	>rezrov/bozbar &&
 | |
| 	git add caskly xyzzy yomin nitfol rezrov/bozbar &&
 | |
| 
 | |
| 	test_tick &&
 | |
| 	git commit -m initial
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success modify '
 | |
| 	rm -f xyzzy yomin nitfol caskly &&
 | |
| 	# caskly disappears (not a submodule)
 | |
| 	mkdir caskly &&
 | |
| 	# nitfol changes from symlink to regular
 | |
| 	>nitfol &&
 | |
| 	# rezrov/bozbar disappears
 | |
| 	rm -fr rezrov &&
 | |
| 	if test_have_prereq SYMLINKS; then
 | |
| 		ln -s xyzzy rezrov
 | |
| 	else
 | |
| 		printf %s xyzzy > rezrov
 | |
| 	fi &&
 | |
| 	# xyzzy disappears (not a submodule)
 | |
| 	mkdir xyzzy &&
 | |
| 	echo gnusto >xyzzy/bozbar &&
 | |
| 	# yomin gets replaced with a submodule
 | |
| 	mkdir yomin &&
 | |
| 	>yomin/yomin &&
 | |
| 	(
 | |
| 		cd yomin &&
 | |
| 		git init &&
 | |
| 		git add yomin &&
 | |
| 		git commit -m "sub initial"
 | |
| 	) &&
 | |
| 	yomin=$(GIT_DIR=yomin/.git git rev-parse HEAD) &&
 | |
| 	# yonk is added and then turned into a submodule
 | |
| 	# this should appear as T in diff-files and as A in diff-index
 | |
| 	>yonk &&
 | |
| 	git add yonk &&
 | |
| 	rm -f yonk &&
 | |
| 	mkdir yonk &&
 | |
| 	>yonk/yonk &&
 | |
| 	(
 | |
| 		cd yonk &&
 | |
| 		git init &&
 | |
| 		git add yonk &&
 | |
| 		git commit -m "sub initial"
 | |
| 	) &&
 | |
| 	yonk=$(GIT_DIR=yonk/.git git rev-parse HEAD) &&
 | |
| 	# zifmia is added and then removed
 | |
| 	# this should appear in diff-files but not in diff-index.
 | |
| 	>zifmia &&
 | |
| 	git add zifmia &&
 | |
| 	rm -f zifmia &&
 | |
| 	mkdir zifmia &&
 | |
| 	{
 | |
| 		git ls-tree -r HEAD |
 | |
| 		sed -e "s/^/:/" -e "
 | |
| 			/	caskly/{
 | |
| 				s/	caskly/ $ZERO_OID D&/
 | |
| 				s/blob/000000/
 | |
| 			}
 | |
| 			/	nitfol/{
 | |
| 				s/	nitfol/ $ZERO_OID $T_letter&/
 | |
| 				s/blob/100644/
 | |
| 			}
 | |
| 			/	rezrov.bozbar/{
 | |
| 				s/	rezrov.bozbar/ $ZERO_OID D&/
 | |
| 				s/blob/000000/
 | |
| 			}
 | |
| 			/	xyzzy/{
 | |
| 				s/	xyzzy/ $ZERO_OID D&/
 | |
| 				s/blob/000000/
 | |
| 			}
 | |
| 			/	yomin/{
 | |
| 			    s/	yomin/ $ZERO_OID T&/
 | |
| 				s/blob/160000/
 | |
| 			}
 | |
| 		"
 | |
| 	} >expect &&
 | |
| 	{
 | |
| 		cat expect &&
 | |
| 		echo ":100644 160000 $_empty $ZERO_OID T	yonk" &&
 | |
| 		echo ":100644 000000 $_empty $ZERO_OID D	zifmia"
 | |
| 	} >expect-files &&
 | |
| 	{
 | |
| 		cat expect &&
 | |
| 		echo ":000000 160000 $ZERO_OID $ZERO_OID A	yonk"
 | |
| 	} >expect-index &&
 | |
| 	{
 | |
| 		echo "100644 $_empty 0	nitfol" &&
 | |
| 		echo "160000 $yomin 0	yomin" &&
 | |
| 		echo "160000 $yonk 0	yonk"
 | |
| 	} >expect-final
 | |
| '
 | |
| 
 | |
| test_expect_success diff-files '
 | |
| 	git diff-files --raw >actual &&
 | |
| 	test_cmp expect-files actual
 | |
| '
 | |
| 
 | |
| test_expect_success diff-index '
 | |
| 	git diff-index --raw HEAD -- >actual &&
 | |
| 	test_cmp expect-index actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'add -u' '
 | |
| 	rm -f ".git/saved-index" &&
 | |
| 	cp -p ".git/index" ".git/saved-index" &&
 | |
| 	git add -u &&
 | |
| 	git ls-files -s >actual &&
 | |
| 	test_cmp expect-final actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'commit -a' '
 | |
| 	if test -f ".git/saved-index"
 | |
| 	then
 | |
| 		rm -f ".git/index" &&
 | |
| 		mv ".git/saved-index" ".git/index"
 | |
| 	fi &&
 | |
| 	git commit -m "second" -a &&
 | |
| 	git ls-files -s >actual &&
 | |
| 	test_cmp expect-final actual &&
 | |
| 	rm -f .git/index &&
 | |
| 	git read-tree HEAD &&
 | |
| 	git ls-files -s >actual &&
 | |
| 	test_cmp expect-final actual
 | |
| '
 | |
| 
 | |
| test_done
 |