Skip to content

Commit bd52d9a

Browse files
ttaylorrpeff
authored andcommitted
fetch: fix following tags when fetching specific OID
In 3f763dd (fetch: set remote/HEAD if it does not exist, 2024-11-22), unconditionally adds "HEAD" to the list of ref prefixes we send to the server. This breaks a core assumption that the list of prefixes we send to the server is complete. We must either send all prefixes we care about, or none at all (in the latter case the server then advertises everything). The tag following code is careful to only add "refs/tags/" to the list of prefixes if there are already entries in the prefix list. But because the new code from 3f763dd runs after the tag code, and because it unconditionally adds to the prefix list, we may end up with a prefix list that _should_ have "refs/tags/" in it, but doesn't. When that is the case, the server does not advertise any tags, and our auto-following breaks because we never learned about any tags in the first place. Fix this by only adding "HEAD" to the ref prefixes when we know that we are already limiting the advertisement. In either case we'll learn about HEAD (either through the limited advertisement, or implicitly through a full advertisement). Reported-by: Igor Todorovski <[email protected]> Co-authored-by: Jeff King <[email protected]> Signed-off-by: Jeff King <[email protected]> Signed-off-by: Taylor Blau <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent f93ff17 commit bd52d9a

File tree

2 files changed

+17
-1
lines changed

2 files changed

+17
-1
lines changed

builtin/fetch.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1777,7 +1777,9 @@ static int do_fetch(struct transport *transport,
17771777

17781778
if (uses_remote_tracking(transport, rs)) {
17791779
must_list_refs = 1;
1780-
strvec_push(&transport_ls_refs_options.ref_prefixes, "HEAD");
1780+
if (transport_ls_refs_options.ref_prefixes.nr)
1781+
strvec_push(&transport_ls_refs_options.ref_prefixes,
1782+
"HEAD");
17811783
}
17821784

17831785
if (must_list_refs) {

t/t5503-tagfollow.sh

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -160,4 +160,18 @@ test_expect_success 'new clone fetch main and tags' '
160160
test_cmp expect actual
161161
'
162162

163+
test_expect_success 'fetch specific OID with tag following' '
164+
git init --bare clone3.git &&
165+
(
166+
cd clone3.git &&
167+
git remote add origin .. &&
168+
git fetch origin $B:refs/heads/main &&
169+
170+
git -C .. for-each-ref >expect &&
171+
git for-each-ref >actual &&
172+
173+
test_cmp expect actual
174+
)
175+
'
176+
163177
test_done

0 commit comments

Comments
 (0)