]> git.ipfire.org Git - thirdparty/git.git/commitdiff
submodule: correct remote name with fetch
authorDaniel Black <daniel@mariadb.org>
Wed, 9 Oct 2024 03:32:54 +0000 (14:32 +1100)
committerJunio C Hamano <gitster@pobox.com>
Wed, 9 Oct 2024 17:48:08 +0000 (10:48 -0700)
The code fetches the submodules remote based on the superproject remote name
instead of the submodule remote name[1].

Instead of grabbing the default remote of the superproject repository, ask
the default remote of the submodule we are going to run 'git fetch' in.

1. https://lore.kernel.org/git/ZJR5SPDj4Wt_gmRO@pweza/

Signed-off-by: Daniel Black <daniel@mariadb.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/submodule--helper.c
t/t5572-pull-submodule.sh

index dc89488a7da335e7ff7f0259da6d8d131eaa009b..b6b5f1ebde7c2e4780af4097a0c4d6d838948aee 100644 (file)
@@ -2333,7 +2333,14 @@ static int fetch_in_submodule(const char *module_path, int depth, int quiet,
                strvec_pushf(&cp.args, "--depth=%d", depth);
        if (oid) {
                char *hex = oid_to_hex(oid);
-               char *remote = get_default_remote();
+               char *remote;
+               int code;
+
+               code = get_default_remote_submodule(module_path, &remote);
+               if (code) {
+                       child_process_clear(&cp);
+                       return code;
+               }
 
                strvec_pushl(&cp.args, remote, hex, NULL);
                free(remote);
index 916e58c16696ba2676c3eb90e377c455f29c4016..9b6cf8d88b9fbc32ebdfeb7f89e1bfa7e27e200a 100755 (executable)
@@ -230,6 +230,7 @@ test_expect_success 'branch has no merge base with remote-tracking counterpart'
 
        test_create_repo a-submodule &&
        test_commit -C a-submodule foo &&
+       test_commit -C a-submodule bar &&
 
        test_create_repo parent &&
        git -C parent submodule add "$(pwd)/a-submodule" &&
@@ -246,4 +247,23 @@ test_expect_success 'branch has no merge base with remote-tracking counterpart'
        git -C child pull --recurse-submodules --rebase
 '
 
+test_expect_success 'fetch submodule remote of different name from superproject' '
+       git -C child remote rename origin o1 &&
+       git -C child submodule update --init &&
+
+       # Needs to create unreachable commit from current master branch.
+       git -C a-submodule checkout -b newmain HEAD^ &&
+       test_commit -C a-submodule echo &&
+       test_commit -C a-submodule moreecho &&
+       subc=$(git -C a-submodule rev-parse --short HEAD) &&
+
+       git -C parent/a-submodule fetch &&
+       git -C parent/a-submodule checkout "$subc" &&
+       git -C parent commit -m "update submodule" a-submodule &&
+       git -C a-submodule reset --hard HEAD^^ &&
+
+       git -C child pull --no-recurse-submodules &&
+       git -C child submodule update
+'
+
 test_done