mirror of
https://github.com/git/git.git
synced 2024-09-28 18:32:37 +02:00
fetch: send "refs/tags/" prefix upon CLI refspecs
When performing tag following, in addition to using the server's "include-tag" capability to send tag objects (and emulating it if the server does not support that capability), "git fetch" relies upon the presence of refs/tags/* entries in the initial ref advertisement to locally create refs pointing to the aforementioned tag objects. When using protocol v2, refs/tags/* entries in the initial ref advertisement may be suppressed by a ref-prefix argument, leading to the tag object being downloaded, but the ref not being created. Commit dcc73cf7ff ("fetch: generate ref-prefixes when using a configured refspec", 2018-05-18) ensured that "refs/tags/" is always sent as a ref prefix when "git fetch" is invoked with no refspecs, but not when "git fetch" is invoked with refspecs. Extend that functionality to make it work in both situations. This also necessitates a change another test which tested ref advertisement filtering using tag refs - since tag refs are sent by default now, the test has been switched to using branch refs instead. Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
15cfc985e0
commit
2b554353a5
@ -359,7 +359,7 @@ static struct ref *get_ref_map(struct transport *transport,
|
||||
refspec_ref_prefixes(&transport->remote->fetch, &ref_prefixes);
|
||||
|
||||
if (ref_prefixes.argc &&
|
||||
(tags == TAGS_SET || (tags == TAGS_DEFAULT && !rs->nr))) {
|
||||
(tags == TAGS_SET || tags == TAGS_DEFAULT)) {
|
||||
argv_array_push(&ref_prefixes, "refs/tags/");
|
||||
}
|
||||
|
||||
|
@ -204,6 +204,7 @@ test_expect_success 'ref advertisment is filtered during fetch using protocol v2
|
||||
test_when_finished "rm -f log" &&
|
||||
|
||||
test_commit -C file_parent three &&
|
||||
git -C file_parent branch unwanted-branch three &&
|
||||
|
||||
GIT_TRACE_PACKET="$(pwd)/log" git -C file_child -c protocol.version=2 \
|
||||
fetch origin master &&
|
||||
@ -212,9 +213,8 @@ test_expect_success 'ref advertisment is filtered during fetch using protocol v2
|
||||
git -C file_parent log -1 --format=%s >expect &&
|
||||
test_cmp expect actual &&
|
||||
|
||||
! grep "refs/tags/one" log &&
|
||||
! grep "refs/tags/two" log &&
|
||||
! grep "refs/tags/three" log
|
||||
grep "refs/heads/master" log &&
|
||||
! grep "refs/heads/unwanted-branch" log
|
||||
'
|
||||
|
||||
test_expect_success 'server-options are sent when fetching' '
|
||||
@ -406,6 +406,24 @@ test_expect_success 'fetch supports various ways of have lines' '
|
||||
$(git -C server rev-parse completely-unrelated)
|
||||
'
|
||||
|
||||
test_expect_success 'fetch supports include-tag and tag following' '
|
||||
rm -rf server client trace &&
|
||||
git init server &&
|
||||
|
||||
test_commit -C server to_fetch &&
|
||||
git -C server tag -a annotated_tag -m message &&
|
||||
|
||||
git init client &&
|
||||
GIT_TRACE_PACKET="$(pwd)/trace" git -C client -c protocol.version=2 \
|
||||
fetch "$(pwd)/server" to_fetch:to_fetch &&
|
||||
|
||||
grep "fetch> ref-prefix to_fetch" trace &&
|
||||
grep "fetch> ref-prefix refs/tags/" trace &&
|
||||
grep "fetch> include-tag" trace &&
|
||||
|
||||
git -C client cat-file -e $(git -C client rev-parse annotated_tag)
|
||||
'
|
||||
|
||||
# Test protocol v2 with 'http://' transport
|
||||
#
|
||||
. "$TEST_DIRECTORY"/lib-httpd.sh
|
||||
|
Loading…
Reference in New Issue
Block a user