Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
| 3 | test_description='read-tree D/F conflict corner cases' |
| 4 | |
| 5 | . ./test-lib.sh |
Jens Lehmann | ea5070c | 2011-05-25 22:10:41 +0200 | [diff] [blame] | 6 | . "$TEST_DIRECTORY"/lib-read-tree.sh |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 7 | |
| 8 | maketree () { |
| 9 | ( |
| 10 | rm -f .git/index .git/index.lock && |
| 11 | git clean -d -f -f -q -x && |
| 12 | name="$1" && |
| 13 | shift && |
| 14 | for it |
| 15 | do |
| 16 | path=$(expr "$it" : '\([^:]*\)') && |
| 17 | mkdir -p $(dirname "$path") && |
| 18 | echo "$it" >"$path" && |
| 19 | git update-index --add "$path" || exit |
| 20 | done && |
| 21 | git tag "$name" $(git write-tree) |
| 22 | ) |
| 23 | } |
| 24 | |
| 25 | settree () { |
| 26 | rm -f .git/index .git/index.lock && |
| 27 | git clean -d -f -f -q -x && |
| 28 | git read-tree "$1" && |
| 29 | git checkout-index -f -q -u -a && |
| 30 | git update-index --refresh |
| 31 | } |
| 32 | |
| 33 | checkindex () { |
| 34 | git ls-files -s | |
| 35 | sed "s|^[0-7][0-7]* $_x40 \([0-3]\) |\1 |" >current && |
| 36 | cat >expect && |
| 37 | test_cmp expect current |
| 38 | } |
| 39 | |
| 40 | test_expect_success setup ' |
| 41 | maketree O-000 a/b-2/c/d a/b/c/d a/x && |
| 42 | maketree A-000 a/b-2/c/d a/b/c/d a/x && |
| 43 | maketree A-001 a/b-2/c/d a/b/c/d a/b/c/e a/x && |
| 44 | maketree B-000 a/b-2/c/d a/b a/x && |
| 45 | |
| 46 | maketree O-010 t-0 t/1 t/2 t=3 && |
| 47 | maketree A-010 t-0 t t=3 && |
| 48 | maketree B-010 t/1: t=3: && |
| 49 | |
| 50 | maketree O-020 ds/dma/ioat.c ds/dma/ioat_dca.c && |
| 51 | maketree A-020 ds/dma/ioat/Makefile ds/dma/ioat/registers.h && |
| 52 | : |
| 53 | ' |
| 54 | |
Junio C Hamano | 730f728 | 2009-09-20 00:03:39 -0700 | [diff] [blame] | 55 | test_expect_success '3-way (1)' ' |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 56 | settree A-000 && |
Jens Lehmann | ea5070c | 2011-05-25 22:10:41 +0200 | [diff] [blame] | 57 | read_tree_u_must_succeed -m -u O-000 A-000 B-000 && |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 58 | checkindex <<-EOF |
| 59 | 3 a/b |
| 60 | 0 a/b-2/c/d |
| 61 | 1 a/b/c/d |
| 62 | 2 a/b/c/d |
| 63 | 0 a/x |
| 64 | EOF |
| 65 | ' |
| 66 | |
Junio C Hamano | 730f728 | 2009-09-20 00:03:39 -0700 | [diff] [blame] | 67 | test_expect_success '3-way (2)' ' |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 68 | settree A-001 && |
Jens Lehmann | ea5070c | 2011-05-25 22:10:41 +0200 | [diff] [blame] | 69 | read_tree_u_must_succeed -m -u O-000 A-001 B-000 && |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 70 | checkindex <<-EOF |
| 71 | 3 a/b |
| 72 | 0 a/b-2/c/d |
| 73 | 1 a/b/c/d |
| 74 | 2 a/b/c/d |
| 75 | 2 a/b/c/e |
| 76 | 0 a/x |
| 77 | EOF |
| 78 | ' |
| 79 | |
Junio C Hamano | 730f728 | 2009-09-20 00:03:39 -0700 | [diff] [blame] | 80 | test_expect_success '3-way (3)' ' |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 81 | settree A-010 && |
Jens Lehmann | ea5070c | 2011-05-25 22:10:41 +0200 | [diff] [blame] | 82 | read_tree_u_must_succeed -m -u O-010 A-010 B-010 && |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 83 | checkindex <<-EOF |
| 84 | 2 t |
| 85 | 1 t-0 |
| 86 | 2 t-0 |
| 87 | 1 t/1 |
| 88 | 3 t/1 |
| 89 | 1 t/2 |
| 90 | 0 t=3 |
| 91 | EOF |
| 92 | ' |
| 93 | |
Junio C Hamano | 730f728 | 2009-09-20 00:03:39 -0700 | [diff] [blame] | 94 | test_expect_success '2-way (1)' ' |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 95 | settree O-020 && |
Jens Lehmann | ea5070c | 2011-05-25 22:10:41 +0200 | [diff] [blame] | 96 | read_tree_u_must_succeed -m -u O-020 A-020 && |
Junio C Hamano | 934f930 | 2009-09-20 11:49:56 -0700 | [diff] [blame] | 97 | checkindex <<-EOF |
| 98 | 0 ds/dma/ioat/Makefile |
| 99 | 0 ds/dma/ioat/registers.h |
| 100 | EOF |
| 101 | ' |
| 102 | |
| 103 | test_done |