Browse Source
Recent versions of "git diff-files" shows a diff between the index and the working tree for "intent-to-add" paths as a "new file" patch; "git apply --cached" should be able to take "git diff-files" and should act as an equivalent to "git add" for the path, but the command failed to do so for such a path. * rp/apply-cached-with-i-t-a: t4140: test apply with i-t-a paths apply: make i-t-a entries never match worktree apply: allow "new file" patches on i-t-a entriesmaint
Junio C Hamano
4 years ago
2 changed files with 77 additions and 4 deletions
@ -0,0 +1,56 @@
@@ -0,0 +1,56 @@
|
||||
#!/bin/sh |
||||
|
||||
test_description='git apply of i-t-a file' |
||||
|
||||
. ./test-lib.sh |
||||
|
||||
test_expect_success setup ' |
||||
test_write_lines 1 2 3 4 5 >blueprint && |
||||
|
||||
cat blueprint >test-file && |
||||
git add -N test-file && |
||||
git diff >creation-patch && |
||||
grep "new file mode 100644" creation-patch && |
||||
|
||||
rm -f test-file && |
||||
git diff >deletion-patch && |
||||
grep "deleted file mode 100644" deletion-patch |
||||
' |
||||
|
||||
test_expect_success 'apply creation patch to ita path (--cached)' ' |
||||
git rm -f test-file && |
||||
cat blueprint >test-file && |
||||
git add -N test-file && |
||||
|
||||
git apply --cached creation-patch && |
||||
git cat-file blob :test-file >actual && |
||||
test_cmp blueprint actual |
||||
' |
||||
|
||||
test_expect_success 'apply creation patch to ita path (--index)' ' |
||||
git rm -f test-file && |
||||
cat blueprint >test-file && |
||||
git add -N test-file && |
||||
rm -f test-file && |
||||
|
||||
test_must_fail git apply --index creation-patch |
||||
' |
||||
|
||||
test_expect_success 'apply deletion patch to ita path (--cached)' ' |
||||
git rm -f test-file && |
||||
cat blueprint >test-file && |
||||
git add -N test-file && |
||||
|
||||
git apply --cached deletion-patch && |
||||
test_must_fail git ls-files --stage --error-unmatch test-file |
||||
' |
||||
|
||||
test_expect_success 'apply deletion patch to ita path (--index)' ' |
||||
cat blueprint >test-file && |
||||
git add -N test-file && |
||||
|
||||
test_must_fail git apply --index deletion-patch && |
||||
git ls-files --stage --error-unmatch test-file |
||||
' |
||||
|
||||
test_done |
Loading…
Reference in new issue