| #!/bin/sh |
| # |
| # Copyright (c) 2009 Junio C Hamano |
| |
| test_description='git-apply notices removal patches generated by GNU diff' |
| |
| . ./test-lib.sh |
| |
| test_expect_success setup ' |
| cat <<-EOF >c && |
| diff -ruN a/file b/file |
| --- a/file TS0 |
| +++ b/file TS1 |
| @@ -0,0 +1 @@ |
| +something |
| EOF |
| |
| cat <<-EOF >d && |
| diff -ruN a/file b/file |
| --- a/file TS0 |
| +++ b/file TS1 |
| @@ -1 +0,0 @@ |
| -something |
| EOF |
| |
| timeWest="1982-09-16 07:00:00.000000000 -0800" && |
| timeGMT="1982-09-16 15:00:00.000000000 +0000" && |
| timeEast="1982-09-17 00:00:00.000000000 +0900" && |
| |
| epocWest="1969-12-31 16:00:00.000000000 -0800" && |
| epocGMT="1970-01-01 00:00:00.000000000 +0000" && |
| epocEast="1970-01-01 09:00:00.000000000 +0900" && |
| epocWest2="1969-12-31 16:00:00 -08:00" && |
| |
| sed -e "s/TS0/$epocWest/" -e "s/TS1/$timeWest/" <c >createWest.patch && |
| sed -e "s/TS0/$epocEast/" -e "s/TS1/$timeEast/" <c >createEast.patch && |
| sed -e "s/TS0/$epocGMT/" -e "s/TS1/$timeGMT/" <c >createGMT.patch && |
| |
| sed -e "s/TS0/$timeWest/" -e "s/TS1/$timeWest/" <c >addWest.patch && |
| sed -e "s/TS0/$timeEast/" -e "s/TS1/$timeEast/" <c >addEast.patch && |
| sed -e "s/TS0/$timeGMT/" -e "s/TS1/$timeGMT/" <c >addGMT.patch && |
| |
| sed -e "s/TS0/$timeWest/" -e "s/TS1/$timeWest/" <d >emptyWest.patch && |
| sed -e "s/TS0/$timeEast/" -e "s/TS1/$timeEast/" <d >emptyEast.patch && |
| sed -e "s/TS0/$timeGMT/" -e "s/TS1/$timeGMT/" <d >emptyGMT.patch && |
| |
| sed -e "s/TS0/$timeWest/" -e "s/TS1/$epocWest/" <d >removeWest.patch && |
| sed -e "s/TS0/$timeEast/" -e "s/TS1/$epocEast/" <d >removeEast.patch && |
| sed -e "s/TS0/$timeGMT/" -e "s/TS1/$epocGMT/" <d >removeGMT.patch && |
| sed -e "s/TS0/$timeWest/" -e "s/TS1/$epocWest2/" <d >removeWest2.patch && |
| |
| echo something >something |
| ' |
| |
| for patch in *.patch |
| do |
| test_expect_success "test $patch" ' |
| rm -f file .git/index && |
| case "$patch" in |
| create*) |
| # must be able to create |
| git apply --index $patch && |
| test_cmp file something && |
| # must notice the file is already there |
| >file && |
| git add file && |
| test_must_fail git apply $patch |
| ;; |
| add*) |
| # must be able to create or patch |
| git apply $patch && |
| test_cmp file something && |
| >file && |
| git apply $patch && |
| test_cmp file something |
| ;; |
| empty*) |
| # must leave an empty file |
| cat something >file && |
| git add file && |
| git apply --index $patch && |
| test -f file && |
| test_must_be_empty file |
| ;; |
| remove*) |
| # must remove the file |
| cat something >file && |
| git add file && |
| git apply --index $patch && |
| ! test -f file |
| ;; |
| esac |
| ' |
| done |
| |
| test_done |