Re: [PATCH] push: make "HEAD:tags/my-tag" consistently push to a branch

From: Junio C Hamano
Date: Fri Jun 21 2019 - 12:05:46 EST


Ãvar ArnfjÃrà Bjarmason <avarab@xxxxxxxxx> writes:

> This resulted in a case[1] where someone on LKML did:
>
> git push kvm +HEAD:tags/for-linus
>
> Which would have created a new "refs/heads/tags/for-linus" branch in
> their "kvm" repository. But since they happened to have an existing
> "refs/tags/for-linus" reference we pushed there instead, and replaced
> an annotated tag with a lightweight tag.

I do not think that is a problematic behaviour in the context of
asking Linus to pull when every time a merge window opens. One
would keep refs/tags/for-linus at the publishing site, and update it
(forcing as necessary) before request-pull. If it went to a branch
with confusing name tags/for-linus, that would be a disaster.

> Now we'll print out the following advice when this happens, and act
> differently as described therein:
>
> hint: The <dst> part of the refspec matched both of:
> hint:
> hint: 1. tags/my-tag -> refs/tags/my-tag
> hint: 2. tags/my-tag -> refs/heads/tags/my-tag
> hint:
> hint: Earlier versions of git would have picked (1) as the RHS starts
> hint: with a second-level ref prefix which could be fully-qualified by
> hint: adding 'refs/' in front of it. We now pick (2) which uses the prefix
> hint: inferred from the <src> part of the refspec.
> hint:
> hint: See the "<refspec>..." rules discussed in 'git help push'.

"matched" in past tense means that your example scenario actually
has such a confusing branch? Then I think the above is OK (or just
silently updating the branch is also fine, I think). If there were
no such branch currently, the above woudl be a serious regression,
but as long as both exist, I think it is probably OK. From my quick
scan of your new tests, I couldn't quite tell if that case (i.e. the
a tag "my-tag" exists but a bbranch "tags/my-tag"does not exist at
the receiving end when push happens, and the tag is updated without
touching the branch nor giving extra warnings and hints) is covered,
though.

Thanks.