@@ -1594,12 +1594,17 @@ static void update_head(int fetch_missing, const struct ref *head,
if (!head || !head->symref || !remote)
return;
- ref = apply_refspecs(&remote->fetch, "refs/heads/HEAD");
- target = apply_refspecs(&remote->fetch, head->symref);
+ if (!remote->mirror) {
+ ref = apply_refspecs(&remote->fetch, "refs/heads/HEAD");
+ target = apply_refspecs(&remote->fetch, head->symref);
- if (!ref || !target) {
- warning(_("could not update remote head"));
- return;
+ if (!ref || !target) {
+ warning(_("could not update remote head"));
+ return;
+ }
+ } else {
+ ref = "HEAD";
+ target = head->symref;
}
r = resolve_ref_unsafe(ref, 0, NULL, &flags);
@@ -845,6 +845,24 @@ test_expect_success 'updatehead' '
)
'
+test_expect_success 'updatehead mirror' '
+ test_when_finished "rm -rf updatehead" &&
+
+ git clone --mirror . updatehead &&
+ (
+ cd updatehead &&
+
+ git config fetch.updateHead missing &&
+ git symbolic-ref HEAD refs/heads/side &&
+ git fetch &&
+ test_cmp_symbolic_ref HEAD refs/heads/side &&
+
+ git config fetch.updateHead always &&
+ git fetch &&
+ test_cmp_symbolic_ref HEAD refs/heads/main
+ )
+'
+
# configured prune tests
set_config_tristate () {
Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com> --- builtin/fetch.c | 15 ++++++++++----- t/t5510-fetch.sh | 18 ++++++++++++++++++ 2 files changed, 28 insertions(+), 5 deletions(-)