 4cd6755656
			
		
	
	4cd6755656
	
	
	
		
			
			Use 'printf %d $(whatever|wc -l)' so that the shell removes the blanks for us. Signed-off-by: Johannes Sixt <j6t@kdbg.org> Acked-by: Thomas Rast <trast@student.ethz.ch> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			94 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description="Test whether cache-tree is properly updated
 | |
| 
 | |
| Tests whether various commands properly update and/or rewrite the
 | |
| cache-tree extension.
 | |
| "
 | |
|  . ./test-lib.sh
 | |
| 
 | |
| cmp_cache_tree () {
 | |
| 	test-dump-cache-tree >actual &&
 | |
| 	sed "s/$_x40/SHA/" <actual >filtered &&
 | |
| 	test_cmp "$1" filtered
 | |
| }
 | |
| 
 | |
| # We don't bother with actually checking the SHA1:
 | |
| # test-dump-cache-tree already verifies that all existing data is
 | |
| # correct.
 | |
| test_shallow_cache_tree () {
 | |
| 	printf "SHA  (%d entries, 0 subtrees)\n" $(git ls-files|wc -l) >expect &&
 | |
| 	cmp_cache_tree expect
 | |
| }
 | |
| 
 | |
| test_invalid_cache_tree () {
 | |
| 	echo "invalid                                   (0 subtrees)" >expect &&
 | |
| 	printf "SHA #(ref)  (%d entries, 0 subtrees)\n" $(git ls-files|wc -l) >>expect &&
 | |
| 	cmp_cache_tree expect
 | |
| }
 | |
| 
 | |
| test_no_cache_tree () {
 | |
| 	: >expect &&
 | |
| 	cmp_cache_tree expect
 | |
| }
 | |
| 
 | |
| test_expect_failure 'initial commit has cache-tree' '
 | |
| 	test_commit foo &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'read-tree HEAD establishes cache-tree' '
 | |
| 	git read-tree HEAD &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'git-add invalidates cache-tree' '
 | |
| 	test_when_finished "git reset --hard; git read-tree HEAD" &&
 | |
| 	echo "I changed this file" > foo &&
 | |
| 	git add foo &&
 | |
| 	test_invalid_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'update-index invalidates cache-tree' '
 | |
| 	test_when_finished "git reset --hard; git read-tree HEAD" &&
 | |
| 	echo "I changed this file" > foo &&
 | |
| 	git update-index --add foo &&
 | |
| 	test_invalid_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'write-tree establishes cache-tree' '
 | |
| 	test-scrap-cache-tree &&
 | |
| 	git write-tree &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'test-scrap-cache-tree works' '
 | |
| 	git read-tree HEAD &&
 | |
| 	test-scrap-cache-tree &&
 | |
| 	test_no_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'second commit has cache-tree' '
 | |
| 	test_commit bar &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'reset --hard gives cache-tree' '
 | |
| 	test-scrap-cache-tree &&
 | |
| 	git reset --hard &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_success 'reset --hard without index gives cache-tree' '
 | |
| 	rm -f .git/index &&
 | |
| 	git reset --hard &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_expect_failure 'checkout gives cache-tree' '
 | |
| 	git checkout HEAD^ &&
 | |
| 	test_shallow_cache_tree
 | |
| '
 | |
| 
 | |
| test_done
 |