Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 3 | test_description="git merge |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 4 | |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 5 | Testing a custom strategy. |
| 6 | |
Johannes Schindelin | 1e2ae14 | 2020-11-18 23:44:40 +0000 | [diff] [blame] | 7 | * (HEAD, main) Merge commit 'c3' |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 8 | |\ |
Jonathan Nieder | 52b48ef | 2010-08-15 20:11:06 -0500 | [diff] [blame] | 9 | | * (tag: c3) c3 |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 10 | * | (tag: c1) c1 |
| 11 | |/ |
Jonathan Nieder | 52b48ef | 2010-08-15 20:11:06 -0500 | [diff] [blame] | 12 | | * tag: c2) c2 |
| 13 | |/ |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 14 | * (tag: c0) c0 |
| 15 | " |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 16 | |
| 17 | . ./test-lib.sh |
| 18 | |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 19 | test_expect_success 'set up custom strategy' ' |
| 20 | cat >git-merge-theirs <<-EOF && |
| 21 | #!$SHELL_PATH |
| 22 | eval git read-tree --reset -u \\\$\$# |
| 23 | EOF |
| 24 | |
| 25 | chmod +x git-merge-theirs && |
| 26 | PATH=.:$PATH && |
| 27 | export PATH |
| 28 | ' |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 29 | |
| 30 | test_expect_success 'setup' ' |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 31 | test_commit c0 c0.c && |
| 32 | test_commit c1 c1.c && |
| 33 | git reset --keep c0 && |
Junio C Hamano | e596cdd | 2008-08-23 19:23:22 -0700 | [diff] [blame] | 34 | echo c1c1 >c1.c && |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 35 | git add c1.c && |
Jonathan Nieder | 52b48ef | 2010-08-15 20:11:06 -0500 | [diff] [blame] | 36 | test_commit c2 c2.c && |
| 37 | git reset --keep c0 && |
| 38 | test_commit c3 c3.c |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 39 | ' |
| 40 | |
| 41 | test_expect_success 'merge c2 with a custom strategy' ' |
| 42 | git reset --hard c1 && |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 43 | |
| 44 | git rev-parse c1 >head.old && |
| 45 | git rev-parse c2 >second-parent.expected && |
| 46 | git rev-parse c2^{tree} >tree.expected && |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 47 | git merge -s theirs c2 && |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 48 | |
Brian Gernhardt | 0e1b501 | 2010-08-23 16:15:47 -0400 | [diff] [blame] | 49 | git rev-parse HEAD >head.new && |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 50 | git rev-parse HEAD^1 >first-parent && |
| 51 | git rev-parse HEAD^2 >second-parent && |
| 52 | git rev-parse HEAD^{tree} >tree && |
| 53 | git update-index --refresh && |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 54 | git diff --exit-code && |
Junio C Hamano | e596cdd | 2008-08-23 19:23:22 -0700 | [diff] [blame] | 55 | git diff --exit-code c2 HEAD && |
| 56 | git diff --exit-code c2 && |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 57 | |
Brian Gernhardt | 0e1b501 | 2010-08-23 16:15:47 -0400 | [diff] [blame] | 58 | ! test_cmp head.old head.new && |
Jonathan Nieder | 6209036 | 2010-08-15 20:08:46 -0500 | [diff] [blame] | 59 | test_cmp head.old first-parent && |
| 60 | test_cmp second-parent.expected second-parent && |
| 61 | test_cmp tree.expected tree && |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 62 | test -f c0.c && |
Junio C Hamano | e596cdd | 2008-08-23 19:23:22 -0700 | [diff] [blame] | 63 | grep c1c1 c1.c && |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 64 | test -f c2.c |
| 65 | ' |
| 66 | |
Jonathan Nieder | 52b48ef | 2010-08-15 20:11:06 -0500 | [diff] [blame] | 67 | test_expect_success 'trivial merge with custom strategy' ' |
| 68 | git reset --hard c1 && |
| 69 | |
| 70 | git rev-parse c1 >head.old && |
| 71 | git rev-parse c3 >second-parent.expected && |
| 72 | git rev-parse c3^{tree} >tree.expected && |
| 73 | git merge -s theirs c3 && |
| 74 | |
Brian Gernhardt | 0e1b501 | 2010-08-23 16:15:47 -0400 | [diff] [blame] | 75 | git rev-parse HEAD >head.new && |
Jonathan Nieder | 52b48ef | 2010-08-15 20:11:06 -0500 | [diff] [blame] | 76 | git rev-parse HEAD^1 >first-parent && |
| 77 | git rev-parse HEAD^2 >second-parent && |
| 78 | git rev-parse HEAD^{tree} >tree && |
| 79 | git update-index --refresh && |
| 80 | git diff --exit-code && |
| 81 | git diff --exit-code c3 HEAD && |
| 82 | git diff --exit-code c3 && |
| 83 | |
Brian Gernhardt | 0e1b501 | 2010-08-23 16:15:47 -0400 | [diff] [blame] | 84 | ! test_cmp head.old head.new && |
Jonathan Nieder | 52b48ef | 2010-08-15 20:11:06 -0500 | [diff] [blame] | 85 | test_cmp head.old first-parent && |
| 86 | test_cmp second-parent.expected second-parent && |
| 87 | test_cmp tree.expected tree && |
| 88 | test -f c0.c && |
| 89 | ! test -e c1.c && |
| 90 | test -f c3.c |
| 91 | ' |
| 92 | |
Miklos Vajna | 1b1d78f | 2008-07-30 01:17:00 +0200 | [diff] [blame] | 93 | test_done |