diff options
author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2014-03-11 13:59:46 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-03-11 21:32:10 +0100 |
commit | b790e0f67cd97f29b72cb9007632b0329e5eebec (patch) | |
tree | 4c35abd01b4207524fe87a85334c3d65bf755abe /t/t5537-fetch-shallow.sh | |
parent | i18n: proposed command missing leading dash (diff) | |
download | git-b790e0f67cd97f29b72cb9007632b0329e5eebec.tar.xz git-b790e0f67cd97f29b72cb9007632b0329e5eebec.zip |
upload-pack: send shallow info over stdin to pack-objects
Before cdab485 (upload-pack: delegate rev walking in shallow fetch to
pack-objects - 2013-08-16) upload-pack does not write to the source
repository. cdab485 starts to write $GIT_DIR/shallow_XXXXXX if it's a
shallow fetch, so the source repo must be writable.
git:// servers do not need write access to repos and usually don't
have it, which means cdab485 breaks shallow clone over git://
Instead of using a temporary file as the media for shallow points, we
can send them over stdin to pack-objects as well. Prepend shallow
SHA-1 with --shallow so pack-objects knows what is what.
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t5537-fetch-shallow.sh')
-rwxr-xr-x | t/t5537-fetch-shallow.sh | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/t/t5537-fetch-shallow.sh b/t/t5537-fetch-shallow.sh index b0fa7387cb..be951a4679 100755 --- a/t/t5537-fetch-shallow.sh +++ b/t/t5537-fetch-shallow.sh @@ -200,5 +200,18 @@ EOF ) ' +test_expect_success POSIXPERM,SANITY 'shallow fetch from a read-only repo' ' + cp -R .git read-only.git && + find read-only.git -print | xargs chmod -w && + test_when_finished "find read-only.git -type d -print | xargs chmod +w" && + git clone --no-local --depth=2 read-only.git from-read-only && + git --git-dir=from-read-only/.git log --format=%s >actual && + cat >expect <<EOF && +add-1-back +4 +EOF + test_cmp expect actual +' + stop_httpd test_done |