mirror of
https://github.com/git/git.git
synced 2024-12-02 22:43:44 +08:00
4399345d5e
The construct is error-prone; "test" being built-in in most modern shells, the reason to avoid "test <cond> && test <cond>" spawning one extra process by using a single "test <cond> -a <cond>" no longer exists. Signed-off-by: Elia Pinto <gitter.spiros@gmail.com> Reviewed-by: Matthieu Moy <Matthieu.Moy@imag.fr> Signed-off-by: Junio C Hamano <gitster@pobox.com>
58 lines
1.0 KiB
Bash
Executable File
58 lines
1.0 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Copyright (c) 2005 Junio C Hamano
|
|
#
|
|
|
|
test_description='git apply handling copy/rename patch.
|
|
|
|
'
|
|
. ./test-lib.sh
|
|
|
|
# setup
|
|
|
|
cat >test-patch <<\EOF
|
|
diff --git a/foo b/bar
|
|
similarity index 47%
|
|
rename from foo
|
|
rename to bar
|
|
--- a/foo
|
|
+++ b/bar
|
|
@@ -1 +1 @@
|
|
-This is foo
|
|
+This is bar
|
|
EOF
|
|
|
|
echo 'This is foo' >foo
|
|
chmod +x foo
|
|
|
|
test_expect_success setup \
|
|
'git update-index --add foo'
|
|
|
|
test_expect_success apply \
|
|
'git apply --index --stat --summary --apply test-patch'
|
|
|
|
test_expect_success FILEMODE validate \
|
|
'test -f bar && ls -l bar | grep "^-..x......"'
|
|
|
|
test_expect_success 'apply reverse' \
|
|
'git apply -R --index --stat --summary --apply test-patch &&
|
|
test "$(cat foo)" = "This is foo"'
|
|
|
|
cat >test-patch <<\EOF
|
|
diff --git a/foo b/bar
|
|
similarity index 47%
|
|
copy from foo
|
|
copy to bar
|
|
--- a/foo
|
|
+++ b/bar
|
|
@@ -1 +1 @@
|
|
-This is foo
|
|
+This is bar
|
|
EOF
|
|
|
|
test_expect_success 'apply copy' \
|
|
'git apply --index --stat --summary --apply test-patch &&
|
|
test "$(cat bar)" = "This is bar" && test "$(cat foo)" = "This is foo"'
|
|
|
|
test_done
|