 1b6b2bfae5
			
		
	
	1b6b2bfae5
	
	
	
		
			
			More leak fixes. * ps/leakfixes-part-4: (22 commits) builtin/diff: free symmetric diff members diff: free state populated via options builtin/log: fix leak when showing converted blob contents userdiff: fix leaking memory for configured diff drivers builtin/format-patch: fix various trivial memory leaks diff: fix leak when parsing invalid ignore regex option unpack-trees: clear index when not propagating it sequencer: release todo list on error paths merge-ort: unconditionally release attributes index builtin/fast-export: plug leaking tag names builtin/fast-export: fix leaking diff options builtin/fast-import: plug trivial memory leaks builtin/notes: fix leaking `struct notes_tree` when merging notes builtin/rebase: fix leaking `commit.gpgsign` value config: fix leaking comment character config submodule-config: fix leaking name entry when traversing submodules read-cache: fix leaking hashfile when writing index fails bulk-checkin: fix leaking state TODO object-name: fix leaking symlink paths in object context object-file: fix memory leak when reading corrupted headers ...
		
			
				
	
	
		
			357 lines
		
	
	
		
			9.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			357 lines
		
	
	
		
			9.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='remerge-diff handling'
 | |
| 
 | |
| TEST_PASSES_SANITIZE_LEAK=true
 | |
| . ./test-lib.sh
 | |
| 
 | |
| # This test is ort-specific
 | |
| if test "${GIT_TEST_MERGE_ALGORITHM}" != ort
 | |
| then
 | |
| 	skip_all="GIT_TEST_MERGE_ALGORITHM != ort"
 | |
| 	test_done
 | |
| fi
 | |
| 
 | |
| test_expect_success 'setup basic merges' '
 | |
| 	test_write_lines 1 2 3 4 5 6 7 8 9 >numbers &&
 | |
| 	git add numbers &&
 | |
| 	git commit -m base &&
 | |
| 
 | |
| 	git branch feature_a &&
 | |
| 	git branch feature_b &&
 | |
| 	git branch feature_c &&
 | |
| 
 | |
| 	git branch ab_resolution &&
 | |
| 	git branch bc_resolution &&
 | |
| 
 | |
| 	git checkout feature_a &&
 | |
| 	test_write_lines 1 2 three 4 5 6 7 eight 9 >numbers &&
 | |
| 	git commit -a -m change_a &&
 | |
| 
 | |
| 	git checkout feature_b &&
 | |
| 	test_write_lines 1 2 tres 4 5 6 7 8 9 >numbers &&
 | |
| 	git commit -a -m change_b &&
 | |
| 
 | |
| 	git checkout feature_c &&
 | |
| 	test_write_lines 1 2 3 4 5 6 7 8 9 10 >numbers &&
 | |
| 	git commit -a -m change_c &&
 | |
| 
 | |
| 	git checkout bc_resolution &&
 | |
| 	git merge --ff-only feature_b &&
 | |
| 	# no conflict
 | |
| 	git merge feature_c &&
 | |
| 
 | |
| 	git checkout ab_resolution &&
 | |
| 	git merge --ff-only feature_a &&
 | |
| 	# conflicts!
 | |
| 	test_must_fail git merge feature_b &&
 | |
| 	# Resolve conflict...and make another change elsewhere
 | |
| 	test_write_lines 1 2 drei 4 5 6 7 acht 9 >numbers &&
 | |
| 	git add numbers &&
 | |
| 	git merge --continue
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff on a clean merge' '
 | |
| 	git log -1 --oneline bc_resolution >expect &&
 | |
| 	git show --oneline --remerge-diff bc_resolution >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff on a clean merge with a filter' '
 | |
| 	git show --oneline --remerge-diff --diff-filter=U bc_resolution >actual &&
 | |
| 	test_must_be_empty actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff with both a resolved conflict and an unrelated change' '
 | |
| 	git log -1 --oneline ab_resolution >tmp &&
 | |
| 	cat <<-EOF >>tmp &&
 | |
| 	diff --git a/numbers b/numbers
 | |
| 	remerge CONFLICT (content): Merge conflict in numbers
 | |
| 	index a1fb731..6875544 100644
 | |
| 	--- a/numbers
 | |
| 	+++ b/numbers
 | |
| 	@@ -1,13 +1,9 @@
 | |
| 	 1
 | |
| 	 2
 | |
| 	-<<<<<<< b0ed5cb (change_a)
 | |
| 	-three
 | |
| 	-=======
 | |
| 	-tres
 | |
| 	->>>>>>> 6cd3f82 (change_b)
 | |
| 	+drei
 | |
| 	 4
 | |
| 	 5
 | |
| 	 6
 | |
| 	 7
 | |
| 	-eight
 | |
| 	+acht
 | |
| 	 9
 | |
| 	EOF
 | |
| 	# Hashes above are sha1; rip them out so test works with sha256
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 
 | |
| 	git show --oneline --remerge-diff ab_resolution >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'pickaxe still includes additional headers for relevant changes' '
 | |
| 	# reuses "expect" from the previous testcase
 | |
| 
 | |
| 	git log --oneline --remerge-diff -Sacht ab_resolution >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'can filter out additional headers with pickaxe' '
 | |
| 	git show --remerge-diff --submodule=log --find-object=HEAD ab_resolution >actual &&
 | |
| 	test_must_be_empty actual &&
 | |
| 
 | |
| 	git show --remerge-diff -S"not present" --all >actual &&
 | |
| 	test_must_be_empty actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff also works for git-diff-tree' '
 | |
| 	# With a clean merge
 | |
| 	git diff-tree -r -p --remerge-diff --no-commit-id bc_resolution >actual &&
 | |
| 	test_must_be_empty actual &&
 | |
| 
 | |
| 	# With both a resolved conflict and an unrelated change
 | |
| 	cat <<-EOF >tmp &&
 | |
| 	diff --git a/numbers b/numbers
 | |
| 	remerge CONFLICT (content): Merge conflict in numbers
 | |
| 	index a1fb731..6875544 100644
 | |
| 	--- a/numbers
 | |
| 	+++ b/numbers
 | |
| 	@@ -1,13 +1,9 @@
 | |
| 	 1
 | |
| 	 2
 | |
| 	-<<<<<<< b0ed5cb (change_a)
 | |
| 	-three
 | |
| 	-=======
 | |
| 	-tres
 | |
| 	->>>>>>> 6cd3f82 (change_b)
 | |
| 	+drei
 | |
| 	 4
 | |
| 	 5
 | |
| 	 6
 | |
| 	 7
 | |
| 	-eight
 | |
| 	+acht
 | |
| 	 9
 | |
| 	EOF
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 	git diff-tree -r -p --remerge-diff --no-commit-id ab_resolution >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'setup non-content conflicts' '
 | |
| 	git switch --orphan base &&
 | |
| 
 | |
| 	test_write_lines 1 2 3 4 5 6 7 8 9 >numbers &&
 | |
| 	test_write_lines a b c d e f g h i >letters &&
 | |
| 	test_write_lines in the way >content &&
 | |
| 	git add numbers letters content &&
 | |
| 	git commit -m base &&
 | |
| 
 | |
| 	git branch side1 &&
 | |
| 	git branch side2 &&
 | |
| 
 | |
| 	git checkout side1 &&
 | |
| 	test_write_lines 1 2 three 4 5 6 7 8 9 >numbers &&
 | |
| 	git mv letters letters_side1 &&
 | |
| 	git mv content file_or_directory &&
 | |
| 	git add numbers &&
 | |
| 	git commit -m side1 &&
 | |
| 
 | |
| 	git checkout side2 &&
 | |
| 	git rm numbers &&
 | |
| 	git mv letters letters_side2 &&
 | |
| 	mkdir file_or_directory &&
 | |
| 	echo hello >file_or_directory/world &&
 | |
| 	git add file_or_directory/world &&
 | |
| 	git commit -m side2 &&
 | |
| 
 | |
| 	git checkout -b resolution side1 &&
 | |
| 	test_must_fail git merge side2 &&
 | |
| 	test_write_lines 1 2 three 4 5 6 7 8 9 >numbers &&
 | |
| 	git add numbers &&
 | |
| 	git add letters_side1 &&
 | |
| 	git rm letters &&
 | |
| 	git rm letters_side2 &&
 | |
| 	git add file_or_directory~HEAD &&
 | |
| 	git mv file_or_directory~HEAD wanted_content &&
 | |
| 	git commit -m resolved
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff with non-content conflicts' '
 | |
| 	git log -1 --oneline resolution >tmp &&
 | |
| 	cat <<-EOF >>tmp &&
 | |
| 	diff --git a/file_or_directory~HASH (side1) b/wanted_content
 | |
| 	similarity index 100%
 | |
| 	rename from file_or_directory~HASH (side1)
 | |
| 	rename to wanted_content
 | |
| 	remerge CONFLICT (file/directory): directory in the way of file_or_directory from HASH (side1); moving it to file_or_directory~HASH (side1) instead.
 | |
| 	diff --git a/letters b/letters
 | |
| 	remerge CONFLICT (rename/rename): letters renamed to letters_side1 in HASH (side1) and to letters_side2 in HASH (side2).
 | |
| 	diff --git a/letters_side2 b/letters_side2
 | |
| 	deleted file mode 100644
 | |
| 	index b236ae5..0000000
 | |
| 	--- a/letters_side2
 | |
| 	+++ /dev/null
 | |
| 	@@ -1,9 +0,0 @@
 | |
| 	-a
 | |
| 	-b
 | |
| 	-c
 | |
| 	-d
 | |
| 	-e
 | |
| 	-f
 | |
| 	-g
 | |
| 	-h
 | |
| 	-i
 | |
| 	diff --git a/numbers b/numbers
 | |
| 	remerge CONFLICT (modify/delete): numbers deleted in HASH (side2) and modified in HASH (side1).  Version HASH (side1) of numbers left in tree.
 | |
| 	EOF
 | |
| 	# We still have some sha1 hashes above; rip them out so test works
 | |
| 	# with sha256
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 
 | |
| 	git show --oneline --remerge-diff resolution >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff w/ diff-filter=U: all conflict headers, no diff content' '
 | |
| 	git log -1 --oneline resolution >tmp &&
 | |
| 	cat <<-EOF >>tmp &&
 | |
| 	diff --git a/file_or_directory~HASH (side1) b/file_or_directory~HASH (side1)
 | |
| 	remerge CONFLICT (file/directory): directory in the way of file_or_directory from HASH (side1); moving it to file_or_directory~HASH (side1) instead.
 | |
| 	diff --git a/letters b/letters
 | |
| 	remerge CONFLICT (rename/rename): letters renamed to letters_side1 in HASH (side1) and to letters_side2 in HASH (side2).
 | |
| 	diff --git a/numbers b/numbers
 | |
| 	remerge CONFLICT (modify/delete): numbers deleted in HASH (side2) and modified in HASH (side1).  Version HASH (side1) of numbers left in tree.
 | |
| 	EOF
 | |
| 	# We still have some sha1 hashes above; rip them out so test works
 | |
| 	# with sha256
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 
 | |
| 	git show --oneline --remerge-diff --diff-filter=U resolution >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'submodule formatting ignores additional headers' '
 | |
| 	# Reuses "expect" from last testcase
 | |
| 
 | |
| 	git show --oneline --remerge-diff --diff-filter=U --submodule=log >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff w/ diff-filter=R: relevant file + conflict header' '
 | |
| 	git log -1 --oneline resolution >tmp &&
 | |
| 	cat <<-EOF >>tmp &&
 | |
| 	diff --git a/file_or_directory~HASH (side1) b/wanted_content
 | |
| 	similarity index 100%
 | |
| 	rename from file_or_directory~HASH (side1)
 | |
| 	rename to wanted_content
 | |
| 	remerge CONFLICT (file/directory): directory in the way of file_or_directory from HASH (side1); moving it to file_or_directory~HASH (side1) instead.
 | |
| 	EOF
 | |
| 	# We still have some sha1 hashes above; rip them out so test works
 | |
| 	# with sha256
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 
 | |
| 	git show --oneline --remerge-diff --diff-filter=R resolution >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff w/ pathspec: limits to relevant file including conflict header' '
 | |
| 	git log -1 --oneline resolution >tmp &&
 | |
| 	cat <<-EOF >>tmp &&
 | |
| 	diff --git a/letters b/letters
 | |
| 	remerge CONFLICT (rename/rename): letters renamed to letters_side1 in HASH (side1) and to letters_side2 in HASH (side2).
 | |
| 	diff --git a/letters_side2 b/letters_side2
 | |
| 	deleted file mode 100644
 | |
| 	index b236ae5..0000000
 | |
| 	--- a/letters_side2
 | |
| 	+++ /dev/null
 | |
| 	@@ -1,9 +0,0 @@
 | |
| 	-a
 | |
| 	-b
 | |
| 	-c
 | |
| 	-d
 | |
| 	-e
 | |
| 	-f
 | |
| 	-g
 | |
| 	-h
 | |
| 	-i
 | |
| 	EOF
 | |
| 	# We still have some sha1 hashes above; rip them out so test works
 | |
| 	# with sha256
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 
 | |
| 	git show --oneline --remerge-diff resolution -- "letters*" >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'setup non-content conflicts' '
 | |
| 	git switch --orphan newbase &&
 | |
| 
 | |
| 	test_write_lines 1 2 3 4 5 6 7 8 9 >numbers &&
 | |
| 	git add numbers &&
 | |
| 	git commit -m base &&
 | |
| 
 | |
| 	git branch newside1 &&
 | |
| 	git branch newside2 &&
 | |
| 
 | |
| 	git checkout newside1 &&
 | |
| 	test_write_lines 1 2 three 4 5 6 7 8 9 >numbers &&
 | |
| 	git add numbers &&
 | |
| 	git commit -m side1 &&
 | |
| 
 | |
| 	git checkout newside2 &&
 | |
| 	test_write_lines 1 2 drei 4 5 6 7 8 9 >numbers &&
 | |
| 	git add numbers &&
 | |
| 	git commit -m side2 &&
 | |
| 
 | |
| 	git checkout -b newresolution newside1 &&
 | |
| 	test_must_fail git merge newside2 &&
 | |
| 	git checkout --theirs numbers &&
 | |
| 	git add -u numbers &&
 | |
| 	git commit -m resolved
 | |
| '
 | |
| 
 | |
| test_expect_success 'remerge-diff turns off history simplification' '
 | |
| 	git log -1 --oneline newresolution >tmp &&
 | |
| 	cat <<-EOF >>tmp &&
 | |
| 	diff --git a/numbers b/numbers
 | |
| 	remerge CONFLICT (content): Merge conflict in numbers
 | |
| 	index 070e9e7..5335e78 100644
 | |
| 	--- a/numbers
 | |
| 	+++ b/numbers
 | |
| 	@@ -1,10 +1,6 @@
 | |
| 	 1
 | |
| 	 2
 | |
| 	-<<<<<<< 96f1e45 (side1)
 | |
| 	-three
 | |
| 	-=======
 | |
| 	 drei
 | |
| 	->>>>>>> 4fd522f (side2)
 | |
| 	 4
 | |
| 	 5
 | |
| 	 6
 | |
| 	EOF
 | |
| 	# We still have some sha1 hashes above; rip them out so test works
 | |
| 	# with sha256
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
 | |
| 
 | |
| 	git show --oneline --remerge-diff newresolution -- numbers >tmp &&
 | |
| 	sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_done
 |