Browse Source
* sp/fetch-optim: Teach git-fetch to exploit server side automatic tag following Teach fetch-pack/upload-pack about --include-tag git-pack-objects: Automatically pack annotated tags if object was packed Teach git-fetch to grab a tag at the same time as a commit Make git-fetch follow tags we already have objects for sooner Teach upload-pack to log the received need lines to an fd Free the path_lists used to find non-local tags in git-fetch Allow builtin-fetch's find_non_local_tags to append onto a list Ensure tail pointer gets setup correctly when we fetch HEAD only Remove unnecessary delaying of free_refs(ref_map) in builtin-fetch Remove unused variable in builtin-fetch find_non_local_tagsmaint

11 changed files with 338 additions and 24 deletions
@ -0,0 +1,84 @@
@@ -0,0 +1,84 @@
|
||||
#!/bin/sh |
||||
|
||||
test_description='git-pack-object --include-tag' |
||||
. ./test-lib.sh |
||||
|
||||
TRASH=`pwd` |
||||
|
||||
test_expect_success setup ' |
||||
echo c >d && |
||||
git update-index --add d && |
||||
tree=`git write-tree` && |
||||
commit=`git commit-tree $tree </dev/null` && |
||||
echo "object $commit" >sig && |
||||
echo "type commit" >>sig && |
||||
echo "tag mytag" >>sig && |
||||
echo "tagger $(git var GIT_COMMITTER_IDENT)" >>sig && |
||||
echo >>sig && |
||||
echo "our test tag" >>sig && |
||||
tag=`git mktag <sig` && |
||||
rm d sig && |
||||
git update-ref refs/tags/mytag $tag && { |
||||
echo $tree && |
||||
echo $commit && |
||||
git ls-tree $tree | sed -e "s/.* \\([0-9a-f]*\\) .*/\\1/" |
||||
} >obj-list |
||||
' |
||||
|
||||
rm -rf clone.git |
||||
test_expect_success 'pack without --include-tag' ' |
||||
packname_1=$(git pack-objects \ |
||||
--window=0 \ |
||||
test-1 <obj-list) |
||||
' |
||||
|
||||
test_expect_success 'unpack objects' ' |
||||
( |
||||
GIT_DIR=clone.git && |
||||
export GIT_DIR && |
||||
git init && |
||||
git unpack-objects -n <test-1-${packname_1}.pack && |
||||
git unpack-objects <test-1-${packname_1}.pack |
||||
) |
||||
' |
||||
|
||||
test_expect_success 'check unpacked result (have commit, no tag)' ' |
||||
git rev-list --objects $commit >list.expect && |
||||
( |
||||
GIT_DIR=clone.git && |
||||
export GIT_DIR && |
||||
test_must_fail git cat-file -e $tag && |
||||
git rev-list --objects $commit |
||||
) >list.actual && |
||||
git diff list.expect list.actual |
||||
' |
||||
|
||||
rm -rf clone.git |
||||
test_expect_success 'pack with --include-tag' ' |
||||
packname_1=$(git pack-objects \ |
||||
--window=0 \ |
||||
--include-tag \ |
||||
test-2 <obj-list) |
||||
' |
||||
|
||||
test_expect_success 'unpack objects' ' |
||||
( |
||||
GIT_DIR=clone.git && |
||||
export GIT_DIR && |
||||
git init && |
||||
git unpack-objects -n <test-2-${packname_1}.pack && |
||||
git unpack-objects <test-2-${packname_1}.pack |
||||
) |
||||
' |
||||
|
||||
test_expect_success 'check unpacked result (have commit, have tag)' ' |
||||
git rev-list --objects mytag >list.expect && |
||||
( |
||||
GIT_DIR=clone.git && |
||||
export GIT_DIR && |
||||
git rev-list --objects $tag |
||||
) >list.actual && |
||||
git diff list.expect list.actual |
||||
' |
||||
|
||||
test_done |
@ -0,0 +1,150 @@
@@ -0,0 +1,150 @@
|
||||
#!/bin/sh |
||||
|
||||
test_description='test automatic tag following' |
||||
|
||||
. ./test-lib.sh |
||||
|
||||
# End state of the repository: |
||||
# |
||||
# T - tag1 S - tag2 |
||||
# / / |
||||
# L - A ------ O ------ B |
||||
# \ \ \ |
||||
# \ C - origin/cat \ |
||||
# origin/master master |
||||
|
||||
test_expect_success setup ' |
||||
test_tick && |
||||
echo ichi >file && |
||||
git add file && |
||||
git commit -m L && |
||||
L=$(git rev-parse --verify HEAD) && |
||||
|
||||
( |
||||
mkdir cloned && |
||||
cd cloned && |
||||
git init-db && |
||||
git remote add -f origin .. |
||||
) && |
||||
|
||||
test_tick && |
||||
echo A >file && |
||||
git add file && |
||||
git commit -m A && |
||||
A=$(git rev-parse --verify HEAD) |
||||
' |
||||
|
||||
U=UPLOAD_LOG |
||||
|
||||
cat - <<EOF >expect |
||||
#S |
||||
want $A |
||||
#E |
||||
EOF |
||||
test_expect_success 'fetch A (new commit : 1 connection)' ' |
||||
rm -f $U |
||||
( |
||||
cd cloned && |
||||
GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U && |
||||
test $A = $(git rev-parse --verify origin/master) |
||||
) && |
||||
test -s $U && |
||||
cut -d" " -f1,2 $U >actual && |
||||
git diff expect actual |
||||
' |
||||
|
||||
test_expect_success "create tag T on A, create C on branch cat" ' |
||||
git tag -a -m tag1 tag1 $A && |
||||
T=$(git rev-parse --verify tag1) && |
||||
|
||||
git checkout -b cat && |
||||
echo C >file && |
||||
git add file && |
||||
git commit -m C && |
||||
C=$(git rev-parse --verify HEAD) && |
||||
git checkout master |
||||
' |
||||
|
||||
cat - <<EOF >expect |
||||
#S |
||||
want $C |
||||
want $T |
||||
#E |
||||
EOF |
||||
test_expect_success 'fetch C, T (new branch, tag : 1 connection)' ' |
||||
rm -f $U |
||||
( |
||||
cd cloned && |
||||
GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U && |
||||
test $C = $(git rev-parse --verify origin/cat) && |
||||
test $T = $(git rev-parse --verify tag1) && |
||||
test $A = $(git rev-parse --verify tag1^0) |
||||
) && |
||||
test -s $U && |
||||
cut -d" " -f1,2 $U >actual && |
||||
git diff expect actual |
||||
' |
||||
|
||||
test_expect_success "create commits O, B, tag S on B" ' |
||||
test_tick && |
||||
echo O >file && |
||||
git add file && |
||||
git commit -m O && |
||||
|
||||
test_tick && |
||||
echo B >file && |
||||
git add file && |
||||
git commit -m B && |
||||
B=$(git rev-parse --verify HEAD) && |
||||
|
||||
git tag -a -m tag2 tag2 $B && |
||||
S=$(git rev-parse --verify tag2) |
||||
' |
||||
|
||||
cat - <<EOF >expect |
||||
#S |
||||
want $B |
||||
want $S |
||||
#E |
||||
EOF |
||||
test_expect_success 'fetch B, S (commit and tag : 1 connection)' ' |
||||
rm -f $U |
||||
( |
||||
cd cloned && |
||||
GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U && |
||||
test $B = $(git rev-parse --verify origin/master) && |
||||
test $B = $(git rev-parse --verify tag2^0) && |
||||
test $S = $(git rev-parse --verify tag2) |
||||
) && |
||||
test -s $U && |
||||
cut -d" " -f1,2 $U >actual && |
||||
git diff expect actual |
||||
' |
||||
|
||||
cat - <<EOF >expect |
||||
#S |
||||
want $B |
||||
want $S |
||||
#E |
||||
EOF |
||||
test_expect_success 'new clone fetch master and tags' ' |
||||
git branch -D cat |
||||
rm -f $U |
||||
( |
||||
mkdir clone2 && |
||||
cd clone2 && |
||||
git init && |
||||
git remote add origin .. && |
||||
GIT_DEBUG_SEND_PACK=3 git fetch 3>../$U && |
||||
test $B = $(git rev-parse --verify origin/master) && |
||||
test $S = $(git rev-parse --verify tag2) && |
||||
test $B = $(git rev-parse --verify tag2^0) && |
||||
test $T = $(git rev-parse --verify tag1) && |
||||
test $A = $(git rev-parse --verify tag1^0) |
||||
) && |
||||
test -s $U && |
||||
cut -d" " -f1,2 $U >actual && |
||||
git diff expect actual |
||||
' |
||||
|
||||
test_done |
Loading…
Reference in new issue