91 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
#!/bin/sh
 | 
						|
#
 | 
						|
# Copyright (c) 2006 Junio C Hamano
 | 
						|
#
 | 
						|
 | 
						|
test_description='git update-index --again test.
 | 
						|
'
 | 
						|
 | 
						|
. ./test-lib.sh
 | 
						|
 | 
						|
test_expect_success 'update-index --add' '
 | 
						|
	echo hello world >file1 &&
 | 
						|
	echo goodbye people >file2 &&
 | 
						|
	git update-index --add file1 file2 &&
 | 
						|
	git ls-files -s >current &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	100644 $(git hash-object file1) 0	file1
 | 
						|
	100644 $(git hash-object file2) 0	file2
 | 
						|
	EOF
 | 
						|
	cmp current expected
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'update-index --again' '
 | 
						|
	rm -f file1 &&
 | 
						|
	echo hello everybody >file2 &&
 | 
						|
	if git update-index --again
 | 
						|
	then
 | 
						|
		echo should have refused to remove file1
 | 
						|
		exit 1
 | 
						|
	else
 | 
						|
		echo happy - failed as expected
 | 
						|
	fi &&
 | 
						|
	git ls-files -s >current &&
 | 
						|
	cmp current expected
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'update-index --remove --again' '
 | 
						|
	git update-index --remove --again &&
 | 
						|
	git ls-files -s >current &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	100644 $(git hash-object file2) 0	file2
 | 
						|
	EOF
 | 
						|
	cmp current expected
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'first commit' 'git commit -m initial'
 | 
						|
 | 
						|
test_expect_success 'update-index again' '
 | 
						|
	mkdir -p dir1 &&
 | 
						|
	echo hello world >dir1/file3 &&
 | 
						|
	echo goodbye people >file2 &&
 | 
						|
	git update-index --add file2 dir1/file3 &&
 | 
						|
	echo hello everybody >file2 &&
 | 
						|
	echo happy >dir1/file3 &&
 | 
						|
	git update-index --again &&
 | 
						|
	git ls-files -s >current &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	100644 $(git hash-object dir1/file3) 0	dir1/file3
 | 
						|
	100644 $(git hash-object file2) 0	file2
 | 
						|
	EOF
 | 
						|
	cmp current expected
 | 
						|
'
 | 
						|
 | 
						|
file2=$(git hash-object file2)
 | 
						|
test_expect_success 'update-index --update from subdir' '
 | 
						|
	echo not so happy >file2 &&
 | 
						|
	(cd dir1 &&
 | 
						|
	cat ../file2 >file3 &&
 | 
						|
	git update-index --again
 | 
						|
	) &&
 | 
						|
	git ls-files -s >current &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	100644 $(git hash-object dir1/file3) 0	dir1/file3
 | 
						|
	100644 $file2 0	file2
 | 
						|
	EOF
 | 
						|
	test_cmp expected current
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'update-index --update with pathspec' '
 | 
						|
	echo very happy >file2 &&
 | 
						|
	cat file2 >dir1/file3 &&
 | 
						|
	git update-index --again dir1/ &&
 | 
						|
	git ls-files -s >current &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	100644 $(git hash-object dir1/file3) 0	dir1/file3
 | 
						|
	100644 $file2 0	file2
 | 
						|
	EOF
 | 
						|
	cmp current expected
 | 
						|
'
 | 
						|
 | 
						|
test_done
 |