summaryrefslogtreecommitdiff
path: root/t/t4102-apply-rename.sh
blob: 1597965241c3566aa3a14e986fd5a630fb348479 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/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'
 
if test "$(git config --bool core.filemode)" = false
then
	say 'filemode disabled on the filesystem'
else
	test_set_prereq FILEMODE
fi
 
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" -a "$(cat foo)" = "This is foo"'
 
test_done