Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
| 3 | test_description='Return value of diffs' |
| 4 | |
| 5 | . ./test-lib.sh |
| 6 | |
| 7 | test_expect_success 'setup' ' |
Larry D'Anna | 1caaf22 | 2010-02-21 21:58:44 -0500 | [diff] [blame] | 8 | echo "1 " >a && |
| 9 | git add . && |
| 10 | git commit -m zeroth && |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 11 | echo 1 >a && |
| 12 | git add . && |
| 13 | git commit -m first && |
| 14 | echo 2 >b && |
| 15 | git add . && |
| 16 | git commit -a -m second |
| 17 | ' |
| 18 | |
Larry D'Anna | 1caaf22 | 2010-02-21 21:58:44 -0500 | [diff] [blame] | 19 | test_expect_success 'git diff --quiet -w HEAD^^ HEAD^' ' |
| 20 | git diff --quiet -w HEAD^^ HEAD^ |
| 21 | ' |
| 22 | |
| 23 | test_expect_success 'git diff --quiet HEAD^^ HEAD^' ' |
| 24 | test_must_fail git diff --quiet HEAD^^ HEAD^ |
| 25 | ' |
| 26 | |
| 27 | test_expect_success 'git diff --quiet -w HEAD^ HEAD' ' |
| 28 | test_must_fail git diff --quiet -w HEAD^ HEAD |
| 29 | ' |
| 30 | |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 31 | test_expect_success 'git diff-tree HEAD^ HEAD' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 32 | test_expect_code 1 git diff-tree --exit-code HEAD^ HEAD |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 33 | ' |
| 34 | test_expect_success 'git diff-tree HEAD^ HEAD -- a' ' |
| 35 | git diff-tree --exit-code HEAD^ HEAD -- a |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 36 | ' |
| 37 | test_expect_success 'git diff-tree HEAD^ HEAD -- b' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 38 | test_expect_code 1 git diff-tree --exit-code HEAD^ HEAD -- b |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 39 | ' |
| 40 | test_expect_success 'echo HEAD | git diff-tree --stdin' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 41 | echo $(git rev-parse HEAD) | test_expect_code 1 git diff-tree --exit-code --stdin |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 42 | ' |
| 43 | test_expect_success 'git diff-tree HEAD HEAD' ' |
| 44 | git diff-tree --exit-code HEAD HEAD |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 45 | ' |
| 46 | test_expect_success 'git diff-files' ' |
| 47 | git diff-files --exit-code |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 48 | ' |
| 49 | test_expect_success 'git diff-index --cached HEAD' ' |
| 50 | git diff-index --exit-code --cached HEAD |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 51 | ' |
| 52 | test_expect_success 'git diff-index --cached HEAD^' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 53 | test_expect_code 1 git diff-index --exit-code --cached HEAD^ |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 54 | ' |
| 55 | test_expect_success 'git diff-index --cached HEAD^' ' |
| 56 | echo text >>b && |
| 57 | echo 3 >c && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 58 | git add . && |
| 59 | test_expect_code 1 git diff-index --exit-code --cached HEAD^ |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 60 | ' |
| 61 | test_expect_success 'git diff-tree -Stext HEAD^ HEAD -- b' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 62 | git commit -m "text in b" && |
| 63 | test_expect_code 1 git diff-tree -p --exit-code -Stext HEAD^ HEAD -- b |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 64 | ' |
| 65 | test_expect_success 'git diff-tree -Snot-found HEAD^ HEAD -- b' ' |
| 66 | git diff-tree -p --exit-code -Snot-found HEAD^ HEAD -- b |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 67 | ' |
| 68 | test_expect_success 'git diff-files' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 69 | echo 3 >>c && |
| 70 | test_expect_code 1 git diff-files --exit-code |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 71 | ' |
| 72 | test_expect_success 'git diff-index --cached HEAD' ' |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 73 | git update-index c && |
| 74 | test_expect_code 1 git diff-index --exit-code --cached HEAD |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 75 | ' |
| 76 | |
Wincent Colaiuta | 5973a07 | 2007-12-14 12:23:44 +0100 | [diff] [blame] | 77 | test_expect_success '--check --exit-code returns 0 for no difference' ' |
| 78 | |
| 79 | git diff --check --exit-code |
| 80 | |
| 81 | ' |
| 82 | |
| 83 | test_expect_success '--check --exit-code returns 1 for a clean difference' ' |
| 84 | |
| 85 | echo "good" > a && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 86 | test_expect_code 1 git diff --check --exit-code |
Wincent Colaiuta | 5973a07 | 2007-12-14 12:23:44 +0100 | [diff] [blame] | 87 | |
| 88 | ' |
| 89 | |
| 90 | test_expect_success '--check --exit-code returns 3 for a dirty difference' ' |
| 91 | |
| 92 | echo "bad " >> a && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 93 | test_expect_code 3 git diff --check --exit-code |
Wincent Colaiuta | 5973a07 | 2007-12-14 12:23:44 +0100 | [diff] [blame] | 94 | |
| 95 | ' |
| 96 | |
| 97 | test_expect_success '--check with --no-pager returns 2 for dirty difference' ' |
| 98 | |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 99 | test_expect_code 2 git --no-pager diff --check |
Wincent Colaiuta | 5973a07 | 2007-12-14 12:23:44 +0100 | [diff] [blame] | 100 | |
| 101 | ' |
| 102 | |
Junio C Hamano | 18374e5 | 2008-06-26 13:16:33 -0700 | [diff] [blame] | 103 | test_expect_success 'check should test not just the last line' ' |
| 104 | echo "" >>a && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 105 | test_expect_code 2 git --no-pager diff --check |
Junio C Hamano | 18374e5 | 2008-06-26 13:16:33 -0700 | [diff] [blame] | 106 | |
| 107 | ' |
| 108 | |
Junio C Hamano | 0495404 | 2008-06-26 15:37:21 -0700 | [diff] [blame] | 109 | test_expect_success 'check detects leftover conflict markers' ' |
| 110 | git reset --hard && |
| 111 | git checkout HEAD^ && |
| 112 | echo binary >>b && |
| 113 | git commit -m "side" b && |
| 114 | test_must_fail git merge master && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 115 | git add b && |
| 116 | test_expect_code 2 git --no-pager diff --cached --check >test.out && |
Brian Gernhardt | ab20fda | 2008-06-29 16:49:06 -0400 | [diff] [blame] | 117 | test 3 = $(grep "conflict marker" test.out | wc -l) && |
Junio C Hamano | 0495404 | 2008-06-26 15:37:21 -0700 | [diff] [blame] | 118 | git reset --hard |
| 119 | ' |
| 120 | |
Junio C Hamano | a757c64 | 2010-03-24 19:21:32 -0700 | [diff] [blame] | 121 | test_expect_success 'check honors conflict marker length' ' |
| 122 | git reset --hard && |
| 123 | echo ">>>>>>> boo" >>b && |
| 124 | echo "======" >>a && |
| 125 | git diff --check a && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 126 | test_expect_code 2 git diff --check b && |
Junio C Hamano | a757c64 | 2010-03-24 19:21:32 -0700 | [diff] [blame] | 127 | git reset --hard && |
| 128 | echo ">>>>>>>> boo" >>b && |
| 129 | echo "========" >>a && |
| 130 | git diff --check && |
| 131 | echo "b conflict-marker-size=8" >.gitattributes && |
Elijah Newren | dd0c69e | 2010-10-03 14:00:01 -0600 | [diff] [blame] | 132 | test_expect_code 2 git diff --check b && |
Junio C Hamano | a757c64 | 2010-03-24 19:21:32 -0700 | [diff] [blame] | 133 | git diff --check a && |
| 134 | git reset --hard |
| 135 | ' |
| 136 | |
Alex Riesen | 41bbf9d | 2007-03-14 01:17:04 +0100 | [diff] [blame] | 137 | test_done |