mirror of
https://gerrit.googlesource.com/git-repo
synced 2025-01-08 16:14:26 +00:00
gitc_utils: rewrite to use multiprocessing
This is the only code in the tree that uses GitCommand asynchronously. Rewrite it to use multiprocessing.Pool as it makes the code a little bit easier to understand and simpler. Change-Id: I3ed3b037f24aa1e9dfe8eec9ec21815cdda7678a Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/297143 Tested-by: Mike Frysinger <vapier@google.com> Reviewed-by: Michael Mortensen <mmortensen@google.com>
This commit is contained in:
parent
84230009ee
commit
8c1e9e62a3
@ -13,6 +13,7 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import multiprocessing
|
||||||
import platform
|
import platform
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
@ -35,6 +36,15 @@ def parse_clientdir(gitc_fs_path):
|
|||||||
return wrapper.Wrapper().gitc_parse_clientdir(gitc_fs_path)
|
return wrapper.Wrapper().gitc_parse_clientdir(gitc_fs_path)
|
||||||
|
|
||||||
|
|
||||||
|
def _get_project_revision(args):
|
||||||
|
"""Worker for _set_project_revisions to lookup one project remote."""
|
||||||
|
(i, url, expr) = args
|
||||||
|
gitcmd = git_command.GitCommand(
|
||||||
|
None, ['ls-remote', url, expr], capture_stdout=True, cwd='/tmp')
|
||||||
|
rc = gitcmd.Wait()
|
||||||
|
return (i, rc, gitcmd.stdout.split('\t', 1)[0])
|
||||||
|
|
||||||
|
|
||||||
def _set_project_revisions(projects):
|
def _set_project_revisions(projects):
|
||||||
"""Sets the revisionExpr for a list of projects.
|
"""Sets the revisionExpr for a list of projects.
|
||||||
|
|
||||||
@ -47,22 +57,24 @@ def _set_project_revisions(projects):
|
|||||||
"""
|
"""
|
||||||
# Retrieve the commit id for each project based off of it's current
|
# Retrieve the commit id for each project based off of it's current
|
||||||
# revisionExpr and it is not already a commit id.
|
# revisionExpr and it is not already a commit id.
|
||||||
project_gitcmds = [(
|
with multiprocessing.Pool(NUM_BATCH_RETRIEVE_REVISIONID) as pool:
|
||||||
project, git_command.GitCommand(None,
|
results_iter = pool.imap_unordered(
|
||||||
['ls-remote',
|
_get_project_revision,
|
||||||
project.remote.url,
|
((i, project.remote.url, project.revisionExpr)
|
||||||
project.revisionExpr],
|
for i, project in enumerate(projects)
|
||||||
capture_stdout=True, cwd='/tmp'))
|
if not git_config.IsId(project.revisionExpr)),
|
||||||
for project in projects if not git_config.IsId(project.revisionExpr)]
|
chunksize=8)
|
||||||
for proj, gitcmd in project_gitcmds:
|
for (i, rc, revisionExpr) in results_iter:
|
||||||
if gitcmd.Wait():
|
project = projects[i]
|
||||||
print('FATAL: Failed to retrieve revisionExpr for %s' % proj)
|
if rc:
|
||||||
sys.exit(1)
|
print('FATAL: Failed to retrieve revisionExpr for %s' % project.name)
|
||||||
revisionExpr = gitcmd.stdout.split('\t')[0]
|
pool.terminate()
|
||||||
if not revisionExpr:
|
sys.exit(1)
|
||||||
raise ManifestParseError('Invalid SHA-1 revision project %s (%s)' %
|
if not revisionExpr:
|
||||||
(proj.remote.url, proj.revisionExpr))
|
pool.terminate()
|
||||||
proj.revisionExpr = revisionExpr
|
raise ManifestParseError('Invalid SHA-1 revision project %s (%s)' %
|
||||||
|
(project.remote.url, project.revisionExpr))
|
||||||
|
project.revisionExpr = revisionExpr
|
||||||
|
|
||||||
|
|
||||||
def _manifest_groups(manifest):
|
def _manifest_groups(manifest):
|
||||||
@ -123,11 +135,7 @@ def generate_gitc_manifest(gitc_manifest, manifest, paths=None):
|
|||||||
else:
|
else:
|
||||||
proj.revisionExpr = gitc_proj.revisionExpr
|
proj.revisionExpr = gitc_proj.revisionExpr
|
||||||
|
|
||||||
index = 0
|
_set_project_revisions(projects)
|
||||||
while index < len(projects):
|
|
||||||
_set_project_revisions(
|
|
||||||
projects[index:(index + NUM_BATCH_RETRIEVE_REVISIONID)])
|
|
||||||
index += NUM_BATCH_RETRIEVE_REVISIONID
|
|
||||||
|
|
||||||
if gitc_manifest is not None:
|
if gitc_manifest is not None:
|
||||||
for path, proj in gitc_manifest.paths.items():
|
for path, proj in gitc_manifest.paths.items():
|
||||||
|
Loading…
Reference in New Issue
Block a user