summaryrefslogtreecommitdiffstats
path: root/t
diff options
context:
space:
mode:
authorIngo Brückl <ib@wupperonline.de>2016-07-30 22:13:48 +0200
committerJunio C Hamano <gitster@pobox.com>2016-08-01 23:20:53 +0200
commitb38ab197c2842733c6a9cddd88900fc67d6ce945 (patch)
treea4a735ed76d1e2c86c4cf88a4af93631c466d2dc /t
parentt3700: remove unwanted leftover files before running new tests (diff)
downloadgit-b38ab197c2842733c6a9cddd88900fc67d6ce945.tar.xz
git-b38ab197c2842733c6a9cddd88900fc67d6ce945.zip
t3700: merge two tests into one
Depending on the underlying platform a chmod may be a noop. Although it wouldn't harm the result of the '--chmod=-x' test, there is a more robust way to make sure the --chmod option works both ways. Merge the two separate tests for the --chmod option into one, checking both permissions on the same file. Signed-off-by: Ingo Brückl <ib@wupperonline.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't')
-rwxr-xr-xt/t3700-add.sh18
1 files changed, 6 insertions, 12 deletions
diff --git a/t/t3700-add.sh b/t/t3700-add.sh
index 494f5b84f5..1fa5dfd5cc 100755
--- a/t/t3700-add.sh
+++ b/t/t3700-add.sh
@@ -332,24 +332,18 @@ test_expect_success 'git add --dry-run --ignore-missing of non-existing file out
test_i18ncmp expect.err actual.err
'
-test_expect_success 'git add --chmod=+x stages a non-executable file with +x' '
+test_expect_success 'git add --chmod=[+-]x stages correctly' '
rm -f foo1 &&
echo foo >foo1 &&
git add --chmod=+x foo1 &&
case "$(git ls-files --stage foo1)" in
100755" "*foo1) echo pass;;
*) echo fail; git ls-files --stage foo1; (exit 1);;
- esac
-'
-
-test_expect_success 'git add --chmod=-x stages an executable file with -x' '
- rm -f xfoo1 &&
- echo foo >xfoo1 &&
- chmod 755 xfoo1 &&
- git add --chmod=-x xfoo1 &&
- case "$(git ls-files --stage xfoo1)" in
- 100644" "*xfoo1) echo pass;;
- *) echo fail; git ls-files --stage xfoo1; (exit 1);;
+ esac &&
+ git add --chmod=-x foo1 &&
+ case "$(git ls-files --stage foo1)" in
+ 100644" "*foo1) echo pass;;
+ *) echo fail; git ls-files --stage foo1; (exit 1);;
esac
'