 b99bfc7a6c
			
		
	
	b99bfc7a6c
	
	
	
		
			
			Adjust the test so that it computes variables for object IDs instead of using hard-coded hashes. Convert some single-line heredocs into inline uses of echo now that they can be expressed succinctly. Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			139 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='Test git notes prune'
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success 'setup: create a few commits with notes' '
 | |
| 
 | |
| 	: > file1 &&
 | |
| 	git add file1 &&
 | |
| 	test_tick &&
 | |
| 	git commit -m 1st &&
 | |
| 	git notes add -m "Note #1" &&
 | |
| 	first=$(git rev-parse HEAD) &&
 | |
| 	: > file2 &&
 | |
| 	git add file2 &&
 | |
| 	test_tick &&
 | |
| 	git commit -m 2nd &&
 | |
| 	git notes add -m "Note #2" &&
 | |
| 	second=$(git rev-parse HEAD) &&
 | |
| 	: > file3 &&
 | |
| 	git add file3 &&
 | |
| 	test_tick &&
 | |
| 	git commit -m 3rd &&
 | |
| 	third=$(git rev-parse HEAD) &&
 | |
| 	COMMIT_FILE=$(echo $third | sed "s!^..!.git/objects/&/!") &&
 | |
| 	test -f $COMMIT_FILE &&
 | |
| 	test-tool chmtime =+0 $COMMIT_FILE &&
 | |
| 	git notes add -m "Note #3"
 | |
| '
 | |
| 
 | |
| cat > expect <<END_OF_LOG
 | |
| commit $third
 | |
| Author: A U Thor <author@example.com>
 | |
| Date:   Thu Apr 7 15:15:13 2005 -0700
 | |
| 
 | |
|     3rd
 | |
| 
 | |
| Notes:
 | |
|     Note #3
 | |
| 
 | |
| commit $second
 | |
| Author: A U Thor <author@example.com>
 | |
| Date:   Thu Apr 7 15:14:13 2005 -0700
 | |
| 
 | |
|     2nd
 | |
| 
 | |
| Notes:
 | |
|     Note #2
 | |
| 
 | |
| commit $first
 | |
| Author: A U Thor <author@example.com>
 | |
| Date:   Thu Apr 7 15:13:13 2005 -0700
 | |
| 
 | |
|     1st
 | |
| 
 | |
| Notes:
 | |
|     Note #1
 | |
| END_OF_LOG
 | |
| 
 | |
| test_expect_success 'verify commits and notes' '
 | |
| 
 | |
| 	git log > actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remove some commits' '
 | |
| 
 | |
| 	git reset --hard HEAD~1 &&
 | |
| 	git reflog expire --expire=now HEAD &&
 | |
| 	git gc --prune=now
 | |
| '
 | |
| 
 | |
| test_expect_success 'verify that commits are gone' '
 | |
| 
 | |
| 	test_must_fail git cat-file -p $third &&
 | |
| 	git cat-file -p $second &&
 | |
| 	git cat-file -p $first
 | |
| '
 | |
| 
 | |
| test_expect_success 'verify that notes are still present' '
 | |
| 
 | |
| 	git notes show $third &&
 | |
| 	git notes show $second &&
 | |
| 	git notes show $first
 | |
| '
 | |
| 
 | |
| test_expect_success 'prune -n does not remove notes' '
 | |
| 
 | |
| 	git notes list > expect &&
 | |
| 	git notes prune -n &&
 | |
| 	git notes list > actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| 
 | |
| test_expect_success 'prune -n lists prunable notes' '
 | |
| 
 | |
| 	echo $third >expect &&
 | |
| 	git notes prune -n > actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| 
 | |
| test_expect_success 'prune notes' '
 | |
| 
 | |
| 	git notes prune
 | |
| '
 | |
| 
 | |
| test_expect_success 'verify that notes are gone' '
 | |
| 
 | |
| 	test_must_fail git notes show $third &&
 | |
| 	git notes show $second &&
 | |
| 	git notes show $first
 | |
| '
 | |
| 
 | |
| test_expect_success 'remove some commits' '
 | |
| 
 | |
| 	git reset --hard HEAD~1 &&
 | |
| 	git reflog expire --expire=now HEAD &&
 | |
| 	git gc --prune=now
 | |
| '
 | |
| 
 | |
| test_expect_success 'prune -v notes' '
 | |
| 
 | |
| 	echo $second >expect &&
 | |
| 	git notes prune -v > actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'verify that notes are gone' '
 | |
| 
 | |
| 	test_must_fail git notes show $third &&
 | |
| 	test_must_fail git notes show $second &&
 | |
| 	git notes show $first
 | |
| '
 | |
| 
 | |
| test_done
 |