Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | # |
| 3 | # Copyright (c) 2006 Eric Wong |
| 4 | # |
| 5 | |
Junio C Hamano | 5be6007 | 2007-07-02 22:52:14 -0700 | [diff] [blame] | 6 | test_description='git apply should not get confused with type changes. |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 7 | |
| 8 | ' |
| 9 | |
| 10 | . ./test-lib.sh |
| 11 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 12 | test_expect_success 'setup repository and commits' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 13 | echo "hello world" > foo && |
| 14 | echo "hi planet" > bar && |
| 15 | git update-index --add foo bar && |
| 16 | git commit -m initial && |
| 17 | git branch initial && |
| 18 | rm -f foo && |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 19 | test_ln_s_add bar foo && |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 20 | git commit -m "foo symlinked to bar" && |
| 21 | git branch foo-symlinked-to-bar && |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 22 | git rm -f foo && |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 23 | echo "how far is the sun?" > foo && |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 24 | git update-index --add foo && |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 25 | git commit -m "foo back to file" && |
| 26 | git branch foo-back-to-file && |
Junio C Hamano | b67b961 | 2009-01-26 00:08:24 -0800 | [diff] [blame] | 27 | printf "\0" > foo && |
| 28 | git update-index foo && |
| 29 | git commit -m "foo becomes binary" && |
| 30 | git branch foo-becomes-binary && |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 31 | rm -f foo && |
| 32 | git update-index --remove foo && |
| 33 | mkdir foo && |
| 34 | echo "if only I knew" > foo/baz && |
| 35 | git update-index --add foo/baz && |
| 36 | git commit -m "foo becomes a directory" && |
| 37 | git branch "foo-becomes-a-directory" && |
| 38 | echo "hello world" > foo/baz && |
| 39 | git update-index foo/baz && |
| 40 | git commit -m "foo/baz is the original foo" && |
| 41 | git branch foo-baz-renamed-from-foo |
| 42 | ' |
| 43 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 44 | test_expect_success 'file renamed from foo to foo/baz' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 45 | git checkout -f initial && |
| 46 | git diff-tree -M -p HEAD foo-baz-renamed-from-foo > patch && |
| 47 | git apply --index < patch |
| 48 | ' |
| 49 | test_debug 'cat patch' |
| 50 | |
| 51 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 52 | test_expect_success 'file renamed from foo/baz to foo' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 53 | git checkout -f foo-baz-renamed-from-foo && |
| 54 | git diff-tree -M -p HEAD initial > patch && |
| 55 | git apply --index < patch |
| 56 | ' |
| 57 | test_debug 'cat patch' |
| 58 | |
| 59 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 60 | test_expect_success 'directory becomes file' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 61 | git checkout -f foo-becomes-a-directory && |
| 62 | git diff-tree -p HEAD initial > patch && |
| 63 | git apply --index < patch |
| 64 | ' |
| 65 | test_debug 'cat patch' |
| 66 | |
| 67 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 68 | test_expect_success 'file becomes directory' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 69 | git checkout -f initial && |
| 70 | git diff-tree -p HEAD foo-becomes-a-directory > patch && |
| 71 | git apply --index < patch |
| 72 | ' |
| 73 | test_debug 'cat patch' |
| 74 | |
| 75 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 76 | test_expect_success 'file becomes symlink' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 77 | git checkout -f initial && |
| 78 | git diff-tree -p HEAD foo-symlinked-to-bar > patch && |
| 79 | git apply --index < patch |
| 80 | ' |
| 81 | test_debug 'cat patch' |
| 82 | |
| 83 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 84 | test_expect_success 'symlink becomes file' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 85 | git checkout -f foo-symlinked-to-bar && |
| 86 | git diff-tree -p HEAD foo-back-to-file > patch && |
| 87 | git apply --index < patch |
| 88 | ' |
| 89 | test_debug 'cat patch' |
| 90 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 91 | test_expect_success 'binary file becomes symlink' ' |
Junio C Hamano | b67b961 | 2009-01-26 00:08:24 -0800 | [diff] [blame] | 92 | git checkout -f foo-becomes-binary && |
| 93 | git diff-tree -p --binary HEAD foo-symlinked-to-bar > patch && |
| 94 | git apply --index < patch |
| 95 | ' |
| 96 | test_debug 'cat patch' |
| 97 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 98 | test_expect_success 'symlink becomes binary file' ' |
Junio C Hamano | b67b961 | 2009-01-26 00:08:24 -0800 | [diff] [blame] | 99 | git checkout -f foo-symlinked-to-bar && |
| 100 | git diff-tree -p --binary HEAD foo-becomes-binary > patch && |
| 101 | git apply --index < patch |
| 102 | ' |
| 103 | test_debug 'cat patch' |
| 104 | |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 105 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 106 | test_expect_success 'symlink becomes directory' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 107 | git checkout -f foo-symlinked-to-bar && |
| 108 | git diff-tree -p HEAD foo-becomes-a-directory > patch && |
| 109 | git apply --index < patch |
| 110 | ' |
| 111 | test_debug 'cat patch' |
| 112 | |
| 113 | |
Johannes Sixt | 622f98e | 2013-06-07 22:53:32 +0200 | [diff] [blame] | 114 | test_expect_success 'directory becomes symlink' ' |
Eric Wong | 8641fb2 | 2006-07-16 03:38:40 -0700 | [diff] [blame] | 115 | git checkout -f foo-becomes-a-directory && |
| 116 | git diff-tree -p HEAD foo-symlinked-to-bar > patch && |
| 117 | git apply --index < patch |
| 118 | ' |
| 119 | test_debug 'cat patch' |
| 120 | |
| 121 | |
| 122 | test_done |