git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
* [Bug] 'git submodule update --single-branch' still fetching master
@ 2021-01-06  0:19 - -
  2021-01-06 19:30 ` Philippe Blain
  0 siblings, 1 reply; 3+ messages in thread
From: - - @ 2021-01-06  0:19 UTC (permalink / raw)
  To: git@vger.kernel.org

Hello,

I encountered today some problems while trying to track a single branch with 'git submodule add' and 'git submodule update'. Please find my bug report below.
Any help would be very welcome! :)

Kind regards,
Sven Krummen


What did you do before the bug happened? (Steps to reproduce your issue)
I've got two repositories, 'project' and 'lib', and I want to add 'lib' into 'project' as a git submodule.
The 'lib' repository contains the 'master' branch, which is quite heavy-weighted (~900MB), and a 'light' branch (~10MB) with a mostly unrelated history to 'master'. The 'master' branch is the default branch.
Similar to using 'git clone -b light --single-branch path/to/lib' I want to track only the 'light' branch as a submodule to reduce traffic on our build server.

To add the submodule to 'project' I tried to run:
(a) 'git submodule add -b light path/to/lib'
(b) 'git submodule add -b light --single-branch path/to/lib'
But git was always fetching the whole 'master' branch of 'lib' before switching to 'light'.

After commiting & pushing everything to 'project''s remote, I started over with a fresh clone of 'project' to test whether 'git submodule update' would only fetch the 'light' branch (typical use-case for our build jobs):
(c) 'git clone path/to/project && cd project'
(d) 'git submodule update --init --remote --single-branch lib'
But again, git was fetching the whole 'master' branch of 'lib' before switching to 'light'. This behaviour seems to be independent of the used options of 'git submodule update'.


What did you expect to happen? (Expected behavior)
(a) or (b) To create a submodule which is tracking the 'light' branch of 'lib' and to fetch *only* this branch.
(d) To fetch and checkout *only* the 'light' branch of 'lib'.


What happened instead? (Actual behavior)
(a) Fetching 'master' (or the full 'lib' repo?), then checking out the 'light' branch.
(b) Error as option '--single-branch' is not supported for 'git submodule add'.
(d) Fetching 'master' (or the full 'lib' repo?), then checking out the 'light' branch.


What's different between what you expected and what actually happened?
As the 'master' branch of 'lib' is quite heavy-weighted, I do not want to fetch 'master' at all. By using the option '-b light' to specify which branch shall be tracked, there is no need to fetch other branches besides 'light'. I'm not sure if it is really necessary for 'git submodule add' to fetch anything, as this could also be done by a subsequent 'git submodule update'.


Anything else you want to add:
This issue could be related to: https://stackoverflow.com/questions/61483547/how-to-shallow-pull-submodule-that-is-tracked-by-branch-name


[System Info]
git version:
git version 2.29.2.windows.2
cpu: x86_64
built from commit: 3464b98ce6803c98bf8fb34390cd150d66e4a0d3
sizeof-long: 4
sizeof-size_t: 8
shell-path: /bin/sh
uname: Windows 10.0 17763 
compiler info: gnuc: 10.2
libc info: no libc information available
$SHELL (typically, interactive shell): C:\Program Files\Git\usr\bin\bash.exe


[Enabled Hooks]

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [Bug] 'git submodule update --single-branch' still fetching master
  2021-01-06  0:19 [Bug] 'git submodule update --single-branch' still fetching master - -
@ 2021-01-06 19:30 ` Philippe Blain
  2021-01-08 14:27   ` - -
  0 siblings, 1 reply; 3+ messages in thread
From: Philippe Blain @ 2021-01-06 19:30 UTC (permalink / raw)
  To: - -, git@vger.kernel.org; +Cc: Emily Shaffer, Jeff King

Hi Sven,

Le 2021-01-05 à 19:19, - - a écrit :
> Hello,
> 
> I encountered today some problems while trying to track a single branch with 'git submodule add' and 'git submodule update'. Please find my bug report below.
> Any help would be very welcome! :)
> 
> Kind regards,
> Sven Krummen
> 
> 
> What did you do before the bug happened? (Steps to reproduce your issue)
> I've got two repositories, 'project' and 'lib', and I want to add 'lib' into 'project' as a git submodule.
> The 'lib' repository contains the 'master' branch, which is quite heavy-weighted (~900MB), and a 'light' branch (~10MB) with a mostly unrelated history to 'master'. The 'master' branch is the default branch.
> Similar to using 'git clone -b light --single-branch path/to/lib' I want to track only the 'light' branch as a submodule to reduce traffic on our build server.

Thanks for a nice scenario description. Just a note on wording though (to make sure
we are on the same page): you can't have a submodule "track" a branch, at least
not in the sense that the submodule is always "checked out" on a branch, and the superproject
knows that the submodule should always be "on that branch"; that's not how submodules work.
As specified in [1], the config `submodule.<name>.branch` is only ever used by
`git submodule update --remote`, i.e. the superproject itself only records at which *commit* the
submodule is at.

> 
> To add the submodule to 'project' I tried to run:
> (a) 'git submodule add -b light path/to/lib'
> (b) 'git submodule add -b light --single-branch path/to/lib'
> But git was always fetching the whole 'master' branch of 'lib' before switching to 'light'.

That's not a bug (in my opinion) since it's in a line with the documentation [1].
There is no way at the moment for the initial `git submodule add` to pass
'--single-branch' and '--branch' to the underlying `git clone`.

> 
> After commiting & pushing everything to 'project''s remote, I started over with a fresh clone of 'project' to test whether 'git submodule update' would only fetch the 'light' branch (typical use-case for our build jobs):
> (c) 'git clone path/to/project && cd project'
> (d) 'git submodule update --init --remote --single-branch lib'
> But again, git was fetching the whole 'master' branch of 'lib' before switching to 'light'. This behaviour seems to be independent of the used options of 'git submodule update'.
> 
  
I can partly reproduce that behaviour. The following script creates "lib" with two branches,
master and light, that *do not* share any history.

~~~
#!/bin/bash

TEST_AUTHOR_LOCALNAME=author
TEST_AUTHOR_DOMAIN=example.com
GIT_AUTHOR_EMAIL=${TEST_AUTHOR_LOCALNAME}@${TEST_AUTHOR_DOMAIN}
GIT_AUTHOR_NAME='A U Thor'
GIT_AUTHOR_DATE='1112354055 +0200'
TEST_COMMITTER_LOCALNAME=committer
TEST_COMMITTER_DOMAIN=example.com
GIT_COMMITTER_EMAIL=${TEST_COMMITTER_LOCALNAME}@${TEST_COMMITTER_DOMAIN}
GIT_COMMITTER_NAME='C O Mitter'
GIT_COMMITTER_DATE='1112354055 +0200'
export GIT_AUTHOR_EMAIL GIT_AUTHOR_NAME
export GIT_COMMITTER_EMAIL GIT_COMMITTER_NAME
export GIT_COMMITTER_DATE GIT_AUTHOR_DATE

mkdir test
cd test

rm -rf project lib clone

git init lib && cd lib
echo "content">file
git add file
git commit -m "initial on master in lib"
git checkout --orphan light
echo "content">file
git add file
git commit -m "initial on light in lib"
# Switch HEAD back to master
git checkout master
cd ../

git init project && cd project
echo "content">file
git add file
git commit -m "initial in proj"
git submodule add -b light ../lib
git commit -m "add lib to project"
cd ../

git clone project clone && cd clone
echo 'RUNNING: git submodule update --init --remote --single-branch'
# This fails
git submodule update --init --remote --single-branch
echo 'RUNNING: ls -al lib'
ls -al lib
echo 'RUNNING: git -C lib ls-files -s'
git -C lib ls-files -s
echo 'RUNNING: git -C lib branch --all'
git -C lib branch --all
echo 'RUNNING: git -C lib config --get remote.origin.fetch'
git -C lib config --get remote.origin.fetch
# Try to update again
echo 'RUNNING: git submodule update'
GIT_TRACE2=1 git submodule update 2> >(grep -E 'start git fetch|^From|^ \*' )
~~~

The output should end with:

RUNNING: git submodule update --init --remote --single-branch
Submodule 'lib' (/Users/Philippe/Code/GIT-devel/test/lib) registered for path 'lib'
Cloning into '/Users/Philippe/Code/GIT-devel/test/clone/lib'...
done.
fatal: Needed a single revision
Unable to find current origin/light revision in submodule path 'lib'
RUNNING: ls -al lib
total 8
drwxr-xr-x  3 Philippe  staff  102 Jan  6 14:03 .
drwxr-xr-x  6 Philippe  staff  204 Jan  6 14:03 ..
-rw-r--r--  1 Philippe  staff   28 Jan  6 14:03 .git
RUNNING: git -C lib ls-files -s
RUNNING: git -C lib branch --all
* master
   remotes/origin/HEAD -> origin/master
   remotes/origin/master
RUNNING: git -C lib config --get remote.origin.fetch
+refs/heads/master:refs/remotes/origin/master
RUNNING: git submodule update
14:14:09.745288 common-main.c:49                  start git fetch
14:14:09.892463 common-main.c:49                  start git fetch origin cc09362ae7314174785faed3e5ee72a8e2db5460
 From /Users/Philippe/Code/GIT-devel/test/lib
  * branch            cc09362ae7314174785faed3e5ee72a8e2db5460 -> FETCH_HEAD
Submodule path 'lib': checked out 'cc09362ae7314174785faed3e5ee72a8e2db5460'

You can see that the first 'git submodule update --init --remote --single-branch'
fails. 'ls' and 'ls-files' tell us that the submodule is not checked out,
and that the submodule index is empty.
'git branch' and 'git config' then reveal that indeed only the 'master' branch exists
in the submodule, so '--single-branch' was passed correctly but not the branch itself.
Afterwards, issuing 'git submodule update' a second time will issue a simple 'git fetch',
which will not work because of the single-branch refspec, then it will try fetching
the commit by its hash, which works, and then it will checkout that commit.

Looking at commit 132f600b06 (clone: pass --single-branch during,
  --recurse-submodules, 2020-02-20), which introduced the '--single-branch'
option for 'git submodule update', it seems that what we have at the moment
is partly a documentation bug, i.e. the doc should say
"Clone only the history leading up to the remote HEAD during update",
and not mention '--branch' at all. I'm CC-ing Emily and Peff who were involved
in that series. Looking at the mailing list thread where
this feature was discussed [2], it seems that mentioning 'branch' in the description
of 'single-branch' was just a leftover from v1 of the series that was forgotten
in later iterations.

Also,looking at the code, the '--remote' option has no effect at all for the initial clone
of the submodule. It is only taken into account after the initial clone.
I think it would make sense for it to also influence the initial
clone, so that it would behave as you expect, i.e. the code looks at the branch
in '.gitmodules' and this branch is passed to the underlying 'git clone' if '--single-branch'
was passed to 'git submodule update'.


> What did you expect to happen? (Expected behavior)
> (a) or (b) To create a submodule which is tracking the 'light' branch of 'lib' and to fetch *only* this branch.

That would be a diffenret feature request, and I think it does make sense
for (b) to work. I don't think that '--branch' should automatically
imply '--single-branch' though (i.e. I don't think (a) should change
behaviour).

> (d) To fetch and checkout *only* the 'light' branch of 'lib'.
> 
> 
> What happened instead? (Actual behavior)
> (a) Fetching 'master' (or the full 'lib' repo?), then checking out the 'light' branch.

Yes, this does a plain 'git clone' so all branches are fetched.

> (b) Error as option '--single-branch' is not supported for 'git submodule add'.
> (d) Fetching 'master' (or the full 'lib' repo?), then checking out the 'light' branch.

As my script above shows, this does fetch only the 'master' branch, and then *if* we issue
a second 'git submodule update' it then fetches the required commmit by hash and checks it out.
It would be nice if you could send a reproducer (i.e. a complete script like the above) that
shows exactly the behaviour you are seeing, if indeed in your scenario it really checks out
the 'light' branch. I'm not sure I understand how that could happen...

> 
> 
> What's different between what you expected and what actually happened?
> As the 'master' branch of 'lib' is quite heavy-weighted, I do not want to fetch 'master' at all. By using the option '-b light' to specify which branch shall be tracked, there is no need to fetch other branches besides 'light'. I'm not sure if it is really necessary for 'git submodule add' to fetch anything, as this could also be done by a subsequent 'git submodule update'.

In the past, 'git submodule add' used to not clone the submodule at all,
but this was deemed not very useful so now it does 'git clone' underneath.


Hope that helps,

Philippe.

[1] https://git-scm.com/docs/git-submodule#Documentation/git-submodule.txt--bltbranchgt
[2] https://lore.kernel.org/git/20200108231900.192476-1-emilyshaffer@google.com/t/#u

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [Bug] 'git submodule update --single-branch' still fetching master
  2021-01-06 19:30 ` Philippe Blain
@ 2021-01-08 14:27   ` - -
  0 siblings, 0 replies; 3+ messages in thread
From: - - @ 2021-01-08 14:27 UTC (permalink / raw)
  To: Philippe Blain, git@vger.kernel.org; +Cc: Emily Shaffer, Jeff King

Dear Philippe,

Thanks for your fast and very detailed feedback! Please find below some further details.

> Philippe Blain <levraiphilippeblain@gmail.com> hat am 06.01.2021 20:30 geschrieben:
> 
> 
> Hi Sven,
> 
> Le 2021-01-05 à 19:19, - - a écrit :
> > Hello,
> > 
> > I encountered today some problems while trying to track a single branch with 'git submodule add' and 'git submodule update'. Please find my bug report below.
> > Any help would be very welcome! :)
> > 
> > Kind regards,
> > Sven Krummen
> > 
> > 
> > What did you do before the bug happened? (Steps to reproduce your issue)
> > I've got two repositories, 'project' and 'lib', and I want to add 'lib' into 'project' as a git submodule.
> > The 'lib' repository contains the 'master' branch, which is quite heavy-weighted (~900MB), and a 'light' branch (~10MB) with a mostly unrelated history to 'master'. The 'master' branch is the default branch.
> > Similar to using 'git clone -b light --single-branch path/to/lib' I want to track only the 'light' branch as a submodule to reduce traffic on our build server.
> Thanks for a nice scenario description. Just a note on wording though (to make sure
> we are on the same page): you can't have a submodule "track" a branch, at least
> not in the sense that the submodule is always "checked out" on a branch, and the superproject
> knows that the submodule should always be "on that branch"; that's not how submodules work.
> As specified in [1], the config `submodule.<name>.branch` is only ever used by
> `git submodule update --remote`, i.e. the superproject itself only records at which *commit* the
> submodule is at.

Agreed & understood. :)

> > To add the submodule to 'project' I tried to run:
> > (a) 'git submodule add -b light path/to/lib'
> > (b) 'git submodule add -b light --single-branch path/to/lib'
> > But git was always fetching the whole 'master' branch of 'lib' before switching to 'light'.
> That's not a bug (in my opinion) since it's in a line with the documentation [1].
> There is no way at the moment for the initial `git submodule add` to pass
> '--single-branch' and '--branch' to the underlying `git clone`.

OK, after further reading the documentation I think I now better understand the intended behaviour of (a) and agree that this is not a bug. However, if this is the default behaviour, I would appreciate a way to somehow pass '--single-branch' and '--branch' to the underlying 'git clone' when calling 'git submodule add'. In my use-case I want to avoid fetching the 'master' branch by any measure, as it is heavy-weighted and simply not needed.
Personally, I think it would be very valuable to introduce the '--single-branch' option to 'git submodule add' to achieve this behaviour (as in (b)).

> > After commiting & pushing everything to 'project''s remote, I started over with a fresh clone of 'project' to test whether 'git submodule update' would only fetch the 'light' branch (typical use-case for our build jobs):
> > (c) 'git clone path/to/project && cd project'
> > (d) 'git submodule update --init --remote --single-branch lib'
> > But again, git was fetching the whole 'master' branch of 'lib' before switching to 'light'. This behaviour seems to be independent of the used options of 'git submodule update'.
> > 
> 
> I can partly reproduce that behaviour. The following script creates "lib" with two branches,
> master and light, that *do not* share any history.
> 
> ~~~
> #!/bin/bash
> 
> TEST_AUTHOR_LOCALNAME=author
> TEST_AUTHOR_DOMAIN=example.com
> GIT_AUTHOR_EMAIL=${TEST_AUTHOR_LOCALNAME}@${TEST_AUTHOR_DOMAIN}
> GIT_AUTHOR_NAME='A U Thor'
> GIT_AUTHOR_DATE='1112354055 +0200'
> TEST_COMMITTER_LOCALNAME=committer
> TEST_COMMITTER_DOMAIN=example.com
> GIT_COMMITTER_EMAIL=${TEST_COMMITTER_LOCALNAME}@${TEST_COMMITTER_DOMAIN}
> GIT_COMMITTER_NAME='C O Mitter'
> GIT_COMMITTER_DATE='1112354055 +0200'
> export GIT_AUTHOR_EMAIL GIT_AUTHOR_NAME
> export GIT_COMMITTER_EMAIL GIT_COMMITTER_NAME
> export GIT_COMMITTER_DATE GIT_AUTHOR_DATE
> 
> mkdir test
> cd test
> 
> rm -rf project lib clone
> 
> git init lib && cd lib
> echo "content">file
> git add file
> git commit -m "initial on master in lib"
> git checkout --orphan light
> echo "content">file
> git add file
> git commit -m "initial on light in lib"
> # Switch HEAD back to master
> git checkout master
> cd ../
> 
> git init project && cd project
> echo "content">file
> git add file
> git commit -m "initial in proj"
> git submodule add -b light ../lib
> git commit -m "add lib to project"
> cd ../
> 
> git clone project clone && cd clone
> echo 'RUNNING: git submodule update --init --remote --single-branch'
> # This fails
> git submodule update --init --remote --single-branch
> echo 'RUNNING: ls -al lib'
> ls -al lib
> echo 'RUNNING: git -C lib ls-files -s'
> git -C lib ls-files -s
> echo 'RUNNING: git -C lib branch --all'
> git -C lib branch --all
> echo 'RUNNING: git -C lib config --get remote.origin.fetch'
> git -C lib config --get remote.origin.fetch
> # Try to update again
> echo 'RUNNING: git submodule update'
> GIT_TRACE2=1 git submodule update 2> >(grep -E 'start git fetch|^From|^ \*' )
> ~~~
> 
> The output should end with:
> 
> RUNNING: git submodule update --init --remote --single-branch
> Submodule 'lib' (/Users/Philippe/Code/GIT-devel/test/lib) registered for path 'lib'
> Cloning into '/Users/Philippe/Code/GIT-devel/test/clone/lib'...
> done.
> fatal: Needed a single revision
> Unable to find current origin/light revision in submodule path 'lib'
> RUNNING: ls -al lib
> total 8
> drwxr-xr-x 3 Philippe staff 102 Jan 6 14:03 .
> drwxr-xr-x 6 Philippe staff 204 Jan 6 14:03 ..
> -rw-r--r-- 1 Philippe staff 28 Jan 6 14:03 .git
> RUNNING: git -C lib ls-files -s
> RUNNING: git -C lib branch --all
> * master
> remotes/origin/HEAD -> origin/master
> remotes/origin/master
> RUNNING: git -C lib config --get remote.origin.fetch
> +refs/heads/master:refs/remotes/origin/master
> RUNNING: git submodule update
> 14:14:09.745288 common-main.c:49 start git fetch
> 14:14:09.892463 common-main.c:49 start git fetch origin cc09362ae7314174785faed3e5ee72a8e2db5460
> From /Users/Philippe/Code/GIT-devel/test/lib
> * branch cc09362ae7314174785faed3e5ee72a8e2db5460 -> FETCH_HEAD
> Submodule path 'lib': checked out 'cc09362ae7314174785faed3e5ee72a8e2db5460'
> 
> You can see that the first 'git submodule update --init --remote --single-branch'
> fails. 'ls' and 'ls-files' tell us that the submodule is not checked out,
> and that the submodule index is empty.
> 'git branch' and 'git config' then reveal that indeed only the 'master' branch exists
> in the submodule, so '--single-branch' was passed correctly but not the branch itself.
> Afterwards, issuing 'git submodule update' a second time will issue a simple 'git fetch',
> which will not work because of the single-branch refspec, then it will try fetching
> the commit by its hash, which works, and then it will checkout that commit.

Thanks for your work! I can confirm that your script is reproducing the bug.
However, I could observe when removing the '--remote' option, that 'git submodule update' would already fetch & checkout the commit during the first run: 

RUNNING: git submodule update --init --single-branch
Submodule 'lib' (D:/Repositories/test/lib) registered for path 'lib'
Cloning into 'D:/Repositories/test/clone/lib'...
done.
From D:/Repositories/test/lib
 * branch            cc09362ae7314174785faed3e5ee72a8e2db5460 -> FETCH_HEAD
Submodule path 'lib': checked out 'cc09362ae7314174785faed3e5ee72a8e2db5460'
RUNNING: ls -al lib
total 2
drwxr-xr-x 1 krum_sv 1363622  0 Jan  8 13:37 .
drwxr-xr-x 1 krum_sv 1363622  0 Jan  8 13:37 ..
-rw-r--r-- 1 krum_sv 1363622 28 Jan  8 13:37 .git
-rw-r--r-- 1 krum_sv 1363622  9 Jan  8 13:37 file
RUNNING: git -C lib ls-files -s
100644 d95f3ad14dee633a758d2e331151e950dd13e4ed 0       file
RUNNING: git -C lib branch --all
* (HEAD detached at cc09362)
  master
  remotes/origin/HEAD -> origin/master
  remotes/origin/master
RUNNING: git -C lib config --get remote.origin.fetch
+refs/heads/master:refs/remotes/origin/master
RUNNING: git submodule update

> Looking at commit 132f600b06 (clone: pass --single-branch during,
> --recurse-submodules, 2020-02-20), which introduced the '--single-branch'
> option for 'git submodule update', it seems that what we have at the moment
> is partly a documentation bug, i.e. the doc should say
> "Clone only the history leading up to the remote HEAD during update",
> and not mention '--branch' at all. I'm CC-ing Emily and Peff who were involved
> in that series. Looking at the mailing list thread where
> this feature was discussed [2], it seems that mentioning 'branch' in the description
> of 'single-branch' was just a leftover from v1 of the series that was forgotten
> in later iterations.

I do not fully agree that this is just a documentation bug, as in my use-case I do not want fetch the 'master' branch at all (~900MB vs. ~10MB traffic on our build servers for each job). As you can see in the output above the remote HEAD (pointing to 'master') will be fetched any time. However, for fetching the 'light' branch, or the corresponding commit by hash, this traffic would not be necessary.
In the example script this problem is not so obvious as the 'master' branch does not contain any large files.

> Also,looking at the code, the '--remote' option has no effect at all for the initial clone
> of the submodule. It is only taken into account after the initial clone.
> I think it would make sense for it to also influence the initial
> clone, so that it would behave as you expect, i.e. the code looks at the branch
> in '.gitmodules' and this branch is passed to the underlying 'git clone' if '--single-branch'
> was passed to 'git submodule update'.

Please see above the different behaviour with or without the '--remote' option - I guess we have here two closely related bugs.
Besides that, I agree that the '--remote' option should also influence the initial clone.

> > What did you expect to happen? (Expected behavior)
> > (a) or (b) To create a submodule which is tracking the 'light' branch of 'lib' and to fetch *only* this branch.
> That would be a diffenret feature request, and I think it does make sense
> for (b) to work. I don't think that '--branch' should automatically
> imply '--single-branch' though (i.e. I don't think (a) should change
> behaviour).

Yes, adding the '--single-branch' option to 'git submodule add' would be very helpful!

> > (d) To fetch and checkout *only* the 'light' branch of 'lib'.
> > 
> > 
> > What happened instead? (Actual behavior)
> > (a) Fetching 'master' (or the full 'lib' repo?), then checking out the 'light' branch.
> Yes, this does a plain 'git clone' so all branches are fetched.
> 
> > (b) Error as option '--single-branch' is not supported for 'git submodule add'.
> > (d) Fetching 'master' (or the full 'lib' repo?), then checking out the 'light' branch.
> As my script above shows, this does fetch only the 'master' branch, and then *if* we issue
> a second 'git submodule update' it then fetches the required commmit by hash and checks it out.
> It would be nice if you could send a reproducer (i.e. a complete script like the above) that
> shows exactly the behaviour you are seeing, if indeed in your scenario it really checks out
> the 'light' branch. I'm not sure I understand how that could happen...

Sorry, I think I was describing the behaviour of 'git submodule update --init --single-branch' instead
of 'git submodule update --init --remote --single-branch' (I've been playing around with a lot of different setups). 
Your script is reproducing this bug quite well when omitting the '--remote' option, so I recommend to stay with this baseline.

> > What's different between what you expected and what actually happened?
> > As the 'master' branch of 'lib' is quite heavy-weighted, I do not want to fetch 'master' at all. By using the option '-b light' to specify which branch shall be tracked, there is no need to fetch other branches besides 'light'. I'm not sure if it is really necessary for 'git submodule add' to fetch anything, as this could also be done by a subsequent 'git submodule update'.
> In the past, 'git submodule add' used to not clone the submodule at all,
> but this was deemed not very useful so now it does 'git clone' underneath.
> 
> > Anything else you want to add:
> > This issue could be related to: https://stackoverflow.com/questions/61483547/how-to-shallow-pull-submodule-that-is-tracked-by-branch-name
> 
> 
> Hope that helps,
> 
> Philippe.
> 
> [1] https://git-scm.com/docs/git-submodule#Documentation/git-submodule.txt--bltbranchgt
> [2] https://lore.kernel.org/git/20200108231900.192476-1-emilyshaffer@google.com/t/#u

Thanks for your help! :)

Kind regards,
Sven Krummen

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2021-01-08 14:31 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-01-06  0:19 [Bug] 'git submodule update --single-branch' still fetching master - -
2021-01-06 19:30 ` Philippe Blain
2021-01-08 14:27   ` - -

Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).