mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 21:09:03 +02:00
bitbake: fetch2/git: Prevent git fetcher from fetching gitlab repository metadata
The bitbake git fetcher currently fetches 'refs/*:refs/*', i.e. every single object in the remote repository. This works poorly with gitlab and github, which use the remote git repository to track its metadata like merge requests, CI pipelines and such. Specifically, gitlab generates refs/merge-requests/*, refs/pipelines/* and refs/keep-around/* and they all contain massive amount of data that are useless for the bitbake build purposes. The amount of useless data can in fact be so massive (e.g. with FDO mesa.git repository) that some proxies may outright terminate the 'git fetch' connection, and make it appear as if bitbake got stuck on 'git fetch' with no output. To avoid fetching all these useless metadata, tweak the git fetcher such that it only fetches refs/heads/* and refs/tags/* . Avoid using negative refspecs as those are only available in new git versions. Per feedback on the ML, Gerrit may push commits outsides of branches or tags during CI runs, which currently works with the 'nobranch=1' fetcher parameter. To retain this functionality, keep fetching everything in case the 'nobranch=1' is present. This still avoids fetching massive amount of data in the common case, since 'nobranch=1' is rare. Update 'nobranch' documentation. Reviewed-by: Peter Kjellerstedt <peter.kjellerstedt@axis.com> (Bitbake rev: d32e5b0ec2ab85ffad7e56ac5b3160860b732556) Signed-off-by: Marek Vasut <marex@denx.de> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
89ccf603d8
commit
2ee1fdb840
|
@ -424,8 +424,8 @@ This fetcher supports the following parameters:
|
||||||
|
|
||||||
- *"nobranch":* Tells the fetcher to not check the SHA validation for
|
- *"nobranch":* Tells the fetcher to not check the SHA validation for
|
||||||
the branch when set to "1". The default is "0". Set this option for
|
the branch when set to "1". The default is "0". Set this option for
|
||||||
the recipe that refers to the commit that is valid for a tag instead
|
the recipe that refers to the commit that is valid for a any namespace
|
||||||
of the branch.
|
instead of the branch.
|
||||||
|
|
||||||
- *"bareclone":* Tells the fetcher to clone a bare clone into the
|
- *"bareclone":* Tells the fetcher to clone a bare clone into the
|
||||||
destination directory without checking out a working tree. Only the
|
destination directory without checking out a working tree. Only the
|
||||||
|
|
|
@ -44,7 +44,7 @@ Supported SRC_URI options are:
|
||||||
|
|
||||||
- nobranch
|
- nobranch
|
||||||
Don't check the SHA validation for branch. set this option for the recipe
|
Don't check the SHA validation for branch. set this option for the recipe
|
||||||
referring to commit which is valid in tag instead of branch.
|
referring to commit which is valid in any namespace instead of branch.
|
||||||
The default is "0", set nobranch=1 if needed.
|
The default is "0", set nobranch=1 if needed.
|
||||||
|
|
||||||
- usehead
|
- usehead
|
||||||
|
@ -382,7 +382,11 @@ class Git(FetchMethod):
|
||||||
runfetchcmd("%s remote rm origin" % ud.basecmd, d, workdir=ud.clonedir)
|
runfetchcmd("%s remote rm origin" % ud.basecmd, d, workdir=ud.clonedir)
|
||||||
|
|
||||||
runfetchcmd("%s remote add --mirror=fetch origin %s" % (ud.basecmd, shlex.quote(repourl)), d, workdir=ud.clonedir)
|
runfetchcmd("%s remote add --mirror=fetch origin %s" % (ud.basecmd, shlex.quote(repourl)), d, workdir=ud.clonedir)
|
||||||
|
|
||||||
|
if ud.nobranch:
|
||||||
fetch_cmd = "LANG=C %s fetch -f --progress %s refs/*:refs/*" % (ud.basecmd, shlex.quote(repourl))
|
fetch_cmd = "LANG=C %s fetch -f --progress %s refs/*:refs/*" % (ud.basecmd, shlex.quote(repourl))
|
||||||
|
else:
|
||||||
|
fetch_cmd = "LANG=C %s fetch -f --progress %s refs/heads/*:refs/heads/* refs/tags/*:refs/tags/*" % (ud.basecmd, shlex.quote(repourl))
|
||||||
if ud.proto.lower() != 'file':
|
if ud.proto.lower() != 'file':
|
||||||
bb.fetch2.check_network_access(d, fetch_cmd, ud.url)
|
bb.fetch2.check_network_access(d, fetch_cmd, ud.url)
|
||||||
progresshandler = GitProgressHandler(d)
|
progresshandler = GitProgressHandler(d)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user