blob: 8ff364076673747adaaa74aec3f0a966caf033e5 [file] [log] [blame]
Eric Wong8641fb22006-07-16 03:38:40 -07001#!/bin/sh
2#
3# Copyright (c) 2006 Eric Wong
4#
5
Junio C Hamano5be60072007-07-02 22:52:14 -07006test_description='git apply should not get confused with type changes.
Eric Wong8641fb22006-07-16 03:38:40 -07007
8'
9
Ævar Arnfjörð Bjarmason3e3b9322022-07-28 01:13:41 +020010TEST_PASSES_SANITIZE_LEAK=true
Eric Wong8641fb22006-07-16 03:38:40 -070011. ./test-lib.sh
12
Johannes Sixt622f98e2013-06-07 22:53:32 +020013test_expect_success 'setup repository and commits' '
Eric Wong8641fb22006-07-16 03:38:40 -070014 echo "hello world" > foo &&
15 echo "hi planet" > bar &&
16 git update-index --add foo bar &&
17 git commit -m initial &&
18 git branch initial &&
19 rm -f foo &&
Johannes Sixt622f98e2013-06-07 22:53:32 +020020 test_ln_s_add bar foo &&
Eric Wong8641fb22006-07-16 03:38:40 -070021 git commit -m "foo symlinked to bar" &&
22 git branch foo-symlinked-to-bar &&
Johannes Sixt622f98e2013-06-07 22:53:32 +020023 git rm -f foo &&
Eric Wong8641fb22006-07-16 03:38:40 -070024 echo "how far is the sun?" > foo &&
Johannes Sixt622f98e2013-06-07 22:53:32 +020025 git update-index --add foo &&
Eric Wong8641fb22006-07-16 03:38:40 -070026 git commit -m "foo back to file" &&
27 git branch foo-back-to-file &&
Junio C Hamanob67b9612009-01-26 00:08:24 -080028 printf "\0" > foo &&
29 git update-index foo &&
30 git commit -m "foo becomes binary" &&
31 git branch foo-becomes-binary &&
Eric Wong8641fb22006-07-16 03:38:40 -070032 rm -f foo &&
33 git update-index --remove foo &&
34 mkdir foo &&
35 echo "if only I knew" > foo/baz &&
36 git update-index --add foo/baz &&
37 git commit -m "foo becomes a directory" &&
38 git branch "foo-becomes-a-directory" &&
39 echo "hello world" > foo/baz &&
40 git update-index foo/baz &&
41 git commit -m "foo/baz is the original foo" &&
42 git branch foo-baz-renamed-from-foo
43 '
44
Johannes Sixt622f98e2013-06-07 22:53:32 +020045test_expect_success 'file renamed from foo to foo/baz' '
Eric Wong8641fb22006-07-16 03:38:40 -070046 git checkout -f initial &&
47 git diff-tree -M -p HEAD foo-baz-renamed-from-foo > patch &&
48 git apply --index < patch
49 '
50test_debug 'cat patch'
51
52
Johannes Sixt622f98e2013-06-07 22:53:32 +020053test_expect_success 'file renamed from foo/baz to foo' '
Eric Wong8641fb22006-07-16 03:38:40 -070054 git checkout -f foo-baz-renamed-from-foo &&
55 git diff-tree -M -p HEAD initial > patch &&
56 git apply --index < patch
57 '
58test_debug 'cat patch'
59
60
Johannes Sixt622f98e2013-06-07 22:53:32 +020061test_expect_success 'directory becomes file' '
Eric Wong8641fb22006-07-16 03:38:40 -070062 git checkout -f foo-becomes-a-directory &&
63 git diff-tree -p HEAD initial > patch &&
64 git apply --index < patch
65 '
66test_debug 'cat patch'
67
68
Johannes Sixt622f98e2013-06-07 22:53:32 +020069test_expect_success 'file becomes directory' '
Eric Wong8641fb22006-07-16 03:38:40 -070070 git checkout -f initial &&
71 git diff-tree -p HEAD foo-becomes-a-directory > patch &&
72 git apply --index < patch
73 '
74test_debug 'cat patch'
75
76
Johannes Sixt622f98e2013-06-07 22:53:32 +020077test_expect_success 'file becomes symlink' '
Eric Wong8641fb22006-07-16 03:38:40 -070078 git checkout -f initial &&
79 git diff-tree -p HEAD foo-symlinked-to-bar > patch &&
80 git apply --index < patch
81 '
82test_debug 'cat patch'
83
84
Johannes Sixt622f98e2013-06-07 22:53:32 +020085test_expect_success 'symlink becomes file' '
Eric Wong8641fb22006-07-16 03:38:40 -070086 git checkout -f foo-symlinked-to-bar &&
87 git diff-tree -p HEAD foo-back-to-file > patch &&
88 git apply --index < patch
89 '
90test_debug 'cat patch'
91
Jonathan Tanb0f266d2020-10-20 15:04:52 -070092test_expect_success 'symlink becomes file, in reverse' '
93 git checkout -f foo-symlinked-to-bar &&
94 git diff-tree -p HEAD foo-back-to-file > patch &&
95 git checkout foo-back-to-file &&
96 git apply -R --index < patch
97 '
98
Johannes Sixt622f98e2013-06-07 22:53:32 +020099test_expect_success 'binary file becomes symlink' '
Junio C Hamanob67b9612009-01-26 00:08:24 -0800100 git checkout -f foo-becomes-binary &&
101 git diff-tree -p --binary HEAD foo-symlinked-to-bar > patch &&
102 git apply --index < patch
103 '
104test_debug 'cat patch'
105
Johannes Sixt622f98e2013-06-07 22:53:32 +0200106test_expect_success 'symlink becomes binary file' '
Junio C Hamanob67b9612009-01-26 00:08:24 -0800107 git checkout -f foo-symlinked-to-bar &&
108 git diff-tree -p --binary HEAD foo-becomes-binary > patch &&
109 git apply --index < patch
110 '
111test_debug 'cat patch'
112
Eric Wong8641fb22006-07-16 03:38:40 -0700113
Johannes Sixt622f98e2013-06-07 22:53:32 +0200114test_expect_success 'symlink becomes directory' '
Eric Wong8641fb22006-07-16 03:38:40 -0700115 git checkout -f foo-symlinked-to-bar &&
116 git diff-tree -p HEAD foo-becomes-a-directory > patch &&
117 git apply --index < patch
118 '
119test_debug 'cat patch'
120
121
Johannes Sixt622f98e2013-06-07 22:53:32 +0200122test_expect_success 'directory becomes symlink' '
Eric Wong8641fb22006-07-16 03:38:40 -0700123 git checkout -f foo-becomes-a-directory &&
124 git diff-tree -p HEAD foo-symlinked-to-bar > patch &&
125 git apply --index < patch
126 '
127test_debug 'cat patch'
128
129
130test_done