diff --git a/mercurial/hg.py b/mercurial/hg.py --- a/mercurial/hg.py +++ b/mercurial/hg.py @@ -171,13 +171,15 @@ 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 @@ reposetup called for a ui == repo.ui debug.extensions: > reposetup for 'foobar' took * (glob) + debug.extensions: > all reposetup took * (glob) Foo $ cd ..