 fc1ddf42af
			
		
	
	fc1ddf42af
	
	
	
		
			
			Now that the default value for TEST_PASSES_SANITIZE_LEAK is `true` there is no longer a need to have that variable declared in all of our tests. Drop it. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			178 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='"git merge" top-level frontend'
 | |
| 
 | |
| GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
 | |
| export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| t3033_reset () {
 | |
| 	git checkout -B main two &&
 | |
| 	git branch -f left three &&
 | |
| 	git branch -f right four
 | |
| }
 | |
| 
 | |
| test_expect_success setup '
 | |
| 	test_commit one &&
 | |
| 	git branch left &&
 | |
| 	git branch right &&
 | |
| 	test_commit two &&
 | |
| 	git checkout left &&
 | |
| 	test_commit three &&
 | |
| 	git checkout right &&
 | |
| 	test_commit four &&
 | |
| 	git checkout --orphan newroot &&
 | |
| 	test_commit five &&
 | |
| 	git checkout main
 | |
| '
 | |
| 
 | |
| # Local branches
 | |
| 
 | |
| test_expect_success 'merge an octopus into void' '
 | |
| 	t3033_reset &&
 | |
| 	git checkout --orphan test &&
 | |
| 	git rm -fr . &&
 | |
| 	test_must_fail git merge left right &&
 | |
| 	test_must_fail git rev-parse --verify HEAD &&
 | |
| 	git diff --quiet &&
 | |
| 	test_must_fail git rev-parse HEAD
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge an octopus, fast-forward (ff)' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard one &&
 | |
| 	git merge left right &&
 | |
| 	# one is ancestor of three (left) and four (right)
 | |
| 	test_must_fail git rev-parse --verify HEAD^3 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 | sort >actual &&
 | |
| 	git rev-parse three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge octopus, non-fast-forward (ff)' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard one &&
 | |
| 	git merge --no-ff left right &&
 | |
| 	# one is ancestor of three (left) and four (right)
 | |
| 	test_must_fail git rev-parse --verify HEAD^4 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 HEAD^3 | sort >actual &&
 | |
| 	git rev-parse one three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge octopus, fast-forward (does not ff)' '
 | |
| 	t3033_reset &&
 | |
| 	git merge left right &&
 | |
| 	# two (main) is not an ancestor of three (left) and four (right)
 | |
| 	test_must_fail git rev-parse --verify HEAD^4 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 HEAD^3 | sort >actual &&
 | |
| 	git rev-parse two three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge octopus, non-fast-forward' '
 | |
| 	t3033_reset &&
 | |
| 	git merge --no-ff left right &&
 | |
| 	test_must_fail git rev-parse --verify HEAD^4 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 HEAD^3 | sort >actual &&
 | |
| 	git rev-parse two three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| # The same set with FETCH_HEAD
 | |
| 
 | |
| test_expect_success 'merge FETCH_HEAD octopus into void' '
 | |
| 	t3033_reset &&
 | |
| 	git checkout --orphan test &&
 | |
| 	git rm -fr . &&
 | |
| 	git fetch . left right &&
 | |
| 	test_must_fail git merge FETCH_HEAD &&
 | |
| 	test_must_fail git rev-parse --verify HEAD &&
 | |
| 	git diff --quiet &&
 | |
| 	test_must_fail git rev-parse HEAD
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge FETCH_HEAD octopus fast-forward (ff)' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard one &&
 | |
| 	git fetch . left right &&
 | |
| 	git merge FETCH_HEAD &&
 | |
| 	# one is ancestor of three (left) and four (right)
 | |
| 	test_must_fail git rev-parse --verify HEAD^3 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 | sort >actual &&
 | |
| 	git rev-parse three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge FETCH_HEAD octopus non-fast-forward (ff)' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard one &&
 | |
| 	git fetch . left right &&
 | |
| 	git merge --no-ff FETCH_HEAD &&
 | |
| 	# one is ancestor of three (left) and four (right)
 | |
| 	test_must_fail git rev-parse --verify HEAD^4 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 HEAD^3 | sort >actual &&
 | |
| 	git rev-parse one three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge FETCH_HEAD octopus fast-forward (does not ff)' '
 | |
| 	t3033_reset &&
 | |
| 	git fetch . left right &&
 | |
| 	git merge FETCH_HEAD &&
 | |
| 	# two (main) is not an ancestor of three (left) and four (right)
 | |
| 	test_must_fail git rev-parse --verify HEAD^4 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 HEAD^3 | sort >actual &&
 | |
| 	git rev-parse two three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'merge FETCH_HEAD octopus non-fast-forward' '
 | |
| 	t3033_reset &&
 | |
| 	git fetch . left right &&
 | |
| 	git merge --no-ff FETCH_HEAD &&
 | |
| 	test_must_fail git rev-parse --verify HEAD^4 &&
 | |
| 	git rev-parse HEAD^1 HEAD^2 HEAD^3 | sort >actual &&
 | |
| 	git rev-parse two three four | sort >expect &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| # two-project merge
 | |
| test_expect_success 'refuse two-project merge by default' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard four &&
 | |
| 	test_must_fail git merge five
 | |
| '
 | |
| 
 | |
| test_expect_success 'refuse two-project merge by default, quit before --autostash happens' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard four &&
 | |
| 	echo change >>one.t &&
 | |
| 	git diff >expect &&
 | |
| 	test_must_fail git merge --autostash five 2>err &&
 | |
| 	test_grep ! "stash" err &&
 | |
| 	git diff >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'two-project merge with --allow-unrelated-histories' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard four &&
 | |
| 	git merge --allow-unrelated-histories five &&
 | |
| 	git diff --exit-code five
 | |
| '
 | |
| 
 | |
| test_expect_success 'two-project merge with --allow-unrelated-histories with --autostash' '
 | |
| 	t3033_reset &&
 | |
| 	git reset --hard four &&
 | |
| 	echo change >>one.t &&
 | |
| 	git diff one.t >expect &&
 | |
| 	git merge --allow-unrelated-histories --autostash five 2>err &&
 | |
| 	test_grep "Applied autostash." err &&
 | |
| 	git diff one.t >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_done
 |