# HG changeset patch # User Boris Feld # Date 2018-09-06 20:49:37 # Node ID 340170192874b887644c5e6dec9b0bc4d26cbd38 # Parent 3a86f7eb8b78bdd08d357d654eaf3db93d707b1c extensions: trace the total time of running all reposetup callbacks Differential Revision: https://phab.mercurial-scm.org/D4512 diff --git a/mercurial/hg.py b/mercurial/hg.py --- a/mercurial/hg.py +++ b/mercurial/hg.py @@ -170,13 +170,15 @@ def _peerorrepo(ui, path, create=False, for f in presetupfuncs or []: f(ui, obj) log('- executing reposetup hooks\n') - for name, module in extensions.extensions(ui): - log(' - running reposetup for %s\n' % (name,)) - hook = getattr(module, 'reposetup', None) - if hook: - with util.timedcm('reposetup %r', name) as stats: - hook(ui, obj) - log(' > reposetup for %r took %s\n', name, stats) + with util.timedcm('all reposetup') as allreposetupstats: + for name, module in extensions.extensions(ui): + log(' - running reposetup for %s\n' % (name,)) + hook = getattr(module, 'reposetup', None) + if hook: + with util.timedcm('reposetup %r', name) as stats: + hook(ui, obj) + log(' > reposetup for %r took %s\n', name, stats) + log('> all reposetup took %s\n', allreposetupstats) if not obj.local(): for f in wirepeersetupfuncs: f(ui, obj) diff --git a/tests/test-extension-timing.t b/tests/test-extension-timing.t --- a/tests/test-extension-timing.t +++ b/tests/test-extension-timing.t @@ -87,6 +87,7 @@ Test extension setup timings reposetup called for a ui == repo.ui debug.extensions: > reposetup for 'foobar' took * (glob) + debug.extensions: > all reposetup took * (glob) Foo $ cd ..