mirror of
https://gerrit.googlesource.com/git-repo
synced 2025-01-02 16:14:25 +00:00
progress/sync: include active number of jobs
Provide a bit more info to users that things are actively running. Bug: https://crbug.com/gerrit/11293 Change-Id: Ie8eeaa8804d1ca71cf5c78ad850fa2d17d26208c Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/297904 Reviewed-by: Michael Mortensen <mmortensen@google.com> Tested-by: Mike Frysinger <vapier@google.com>
This commit is contained in:
parent
4e05f650e0
commit
fbb95a4342
20
progress.py
20
progress.py
@ -34,6 +34,19 @@ class Progress(object):
|
|||||||
self._show = False
|
self._show = False
|
||||||
self._units = units
|
self._units = units
|
||||||
self._print_newline = print_newline
|
self._print_newline = print_newline
|
||||||
|
# Only show the active jobs section if we run more than one in parallel.
|
||||||
|
self._show_jobs = False
|
||||||
|
self._active = 0
|
||||||
|
|
||||||
|
def start(self, name):
|
||||||
|
self._active += 1
|
||||||
|
if not self._show_jobs:
|
||||||
|
self._show_jobs = self._active > 1
|
||||||
|
self.update(inc=0, msg='started ' + name)
|
||||||
|
|
||||||
|
def finish(self, name):
|
||||||
|
self.update(msg='finished ' + name)
|
||||||
|
self._active -= 1
|
||||||
|
|
||||||
def update(self, inc=1, msg=''):
|
def update(self, inc=1, msg=''):
|
||||||
self._done += inc
|
self._done += inc
|
||||||
@ -55,10 +68,15 @@ class Progress(object):
|
|||||||
sys.stderr.flush()
|
sys.stderr.flush()
|
||||||
else:
|
else:
|
||||||
p = (100 * self._done) / self._total
|
p = (100 * self._done) / self._total
|
||||||
sys.stderr.write('%s\r%s: %3d%% (%d%s/%d%s)%s%s%s' % (
|
if self._show_jobs:
|
||||||
|
jobs = '[%d job%s] ' % (self._active, 's' if self._active > 1 else '')
|
||||||
|
else:
|
||||||
|
jobs = ''
|
||||||
|
sys.stderr.write('%s\r%s: %2d%% %s(%d%s/%d%s)%s%s%s' % (
|
||||||
CSI_ERASE_LINE,
|
CSI_ERASE_LINE,
|
||||||
self._title,
|
self._title,
|
||||||
p,
|
p,
|
||||||
|
jobs,
|
||||||
self._done, self._units,
|
self._done, self._units,
|
||||||
self._total, self._units,
|
self._total, self._units,
|
||||||
' ' if msg else '', msg,
|
' ' if msg else '', msg,
|
||||||
|
@ -354,6 +354,8 @@ later is required to fix a server side protocol bug.
|
|||||||
# - We always make sure we unlock the lock if we locked it.
|
# - We always make sure we unlock the lock if we locked it.
|
||||||
start = time.time()
|
start = time.time()
|
||||||
success = False
|
success = False
|
||||||
|
with lock:
|
||||||
|
pm.start(project.name)
|
||||||
try:
|
try:
|
||||||
try:
|
try:
|
||||||
success = project.Sync_NetworkHalf(
|
success = project.Sync_NetworkHalf(
|
||||||
@ -383,7 +385,6 @@ later is required to fix a server side protocol bug.
|
|||||||
raise _FetchError()
|
raise _FetchError()
|
||||||
|
|
||||||
fetched.add(project.gitdir)
|
fetched.add(project.gitdir)
|
||||||
pm.update(msg=project.name)
|
|
||||||
except _FetchError:
|
except _FetchError:
|
||||||
pass
|
pass
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
@ -392,7 +393,9 @@ later is required to fix a server side protocol bug.
|
|||||||
err_event.set()
|
err_event.set()
|
||||||
raise
|
raise
|
||||||
finally:
|
finally:
|
||||||
if did_lock:
|
if not did_lock:
|
||||||
|
lock.acquire()
|
||||||
|
pm.finish(project.name)
|
||||||
lock.release()
|
lock.release()
|
||||||
finish = time.time()
|
finish = time.time()
|
||||||
self.event_log.AddSync(project, event_log.TASK_SYNC_NETWORK,
|
self.event_log.AddSync(project, event_log.TASK_SYNC_NETWORK,
|
||||||
@ -403,7 +406,7 @@ later is required to fix a server side protocol bug.
|
|||||||
def _Fetch(self, projects, opt, err_event):
|
def _Fetch(self, projects, opt, err_event):
|
||||||
fetched = set()
|
fetched = set()
|
||||||
lock = _threading.Lock()
|
lock = _threading.Lock()
|
||||||
pm = Progress('Fetching projects', len(projects))
|
pm = Progress('Fetching', len(projects))
|
||||||
|
|
||||||
objdir_project_map = dict()
|
objdir_project_map = dict()
|
||||||
for project in projects:
|
for project in projects:
|
||||||
@ -493,6 +496,8 @@ later is required to fix a server side protocol bug.
|
|||||||
syncbuf = SyncBuffer(self.manifest.manifestProject.config,
|
syncbuf = SyncBuffer(self.manifest.manifestProject.config,
|
||||||
detach_head=opt.detach_head)
|
detach_head=opt.detach_head)
|
||||||
success = False
|
success = False
|
||||||
|
with lock:
|
||||||
|
pm.start(project.name)
|
||||||
try:
|
try:
|
||||||
try:
|
try:
|
||||||
project.Sync_LocalHalf(syncbuf, force_sync=opt.force_sync)
|
project.Sync_LocalHalf(syncbuf, force_sync=opt.force_sync)
|
||||||
@ -508,8 +513,6 @@ later is required to fix a server side protocol bug.
|
|||||||
print('error: Cannot checkout %s' % (project.name),
|
print('error: Cannot checkout %s' % (project.name),
|
||||||
file=sys.stderr)
|
file=sys.stderr)
|
||||||
raise _CheckoutError()
|
raise _CheckoutError()
|
||||||
|
|
||||||
pm.update(msg=project.name)
|
|
||||||
except _CheckoutError:
|
except _CheckoutError:
|
||||||
pass
|
pass
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
@ -519,9 +522,11 @@ later is required to fix a server side protocol bug.
|
|||||||
err_event.set()
|
err_event.set()
|
||||||
raise
|
raise
|
||||||
finally:
|
finally:
|
||||||
if did_lock:
|
if not did_lock:
|
||||||
|
lock.acquire()
|
||||||
if not success:
|
if not success:
|
||||||
err_results.append(project.relpath)
|
err_results.append(project.relpath)
|
||||||
|
pm.finish(project.name)
|
||||||
lock.release()
|
lock.release()
|
||||||
finish = time.time()
|
finish = time.time()
|
||||||
self.event_log.AddSync(project, event_log.TASK_SYNC_LOCAL,
|
self.event_log.AddSync(project, event_log.TASK_SYNC_LOCAL,
|
||||||
@ -553,7 +558,7 @@ later is required to fix a server side protocol bug.
|
|||||||
syncjobs = 1
|
syncjobs = 1
|
||||||
|
|
||||||
lock = _threading.Lock()
|
lock = _threading.Lock()
|
||||||
pm = Progress('Checking out projects', len(all_projects))
|
pm = Progress('Checking out', len(all_projects))
|
||||||
|
|
||||||
threads = set()
|
threads = set()
|
||||||
sem = _threading.Semaphore(syncjobs)
|
sem = _threading.Semaphore(syncjobs)
|
||||||
|
Loading…
Reference in New Issue
Block a user