Mercurial > public > mercurial-scm > hg
annotate tests/testlib/ext-phase-report.py @ 40788:41f0529b5112 stable
commandserver: get around ETIMEDOUT raised by selectors2
selector.select() should exits with an empty event list on timed out, but
selectors2 raises OSError if timeout expires while recovering from EINTR.
Spotted while debugging new chg feature.
author | Yuya Nishihara <yuya@tcha.org> |
---|---|
date | Mon, 03 Dec 2018 21:45:15 +0900 |
parents | 3b4d14beac3d |
children | 2372284d9457 |
rev | line source |
---|---|
33459
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
1 # tiny extension to report phase changes during transaction |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
2 |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
3 from __future__ import absolute_import |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
4 |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
5 def reposetup(ui, repo): |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
6 |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
7 def reportphasemove(tr): |
36044
3b4d14beac3d
py3: port ext-phase-report.py extension
Gregory Szorc <gregory.szorc@gmail.com>
parents:
33459
diff
changeset
|
8 for rev, move in sorted(tr.changes[b'phases'].items()): |
33459
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
9 if move[0] is None: |
36044
3b4d14beac3d
py3: port ext-phase-report.py extension
Gregory Szorc <gregory.szorc@gmail.com>
parents:
33459
diff
changeset
|
10 ui.write((b'test-debug-phase: new rev %d: x -> %d\n' |
33459
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
11 % (rev, move[1]))) |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
12 else: |
36044
3b4d14beac3d
py3: port ext-phase-report.py extension
Gregory Szorc <gregory.szorc@gmail.com>
parents:
33459
diff
changeset
|
13 ui.write((b'test-debug-phase: move rev %d: %d -> %d\n' |
33459
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
14 % (rev, move[0], move[1]))) |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
15 |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
16 class reportphaserepo(repo.__class__): |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
17 def transaction(self, *args, **kwargs): |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
18 tr = super(reportphaserepo, self).transaction(*args, **kwargs) |
36044
3b4d14beac3d
py3: port ext-phase-report.py extension
Gregory Szorc <gregory.szorc@gmail.com>
parents:
33459
diff
changeset
|
19 tr.addpostclose(b'report-phase', reportphasemove) |
33459
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
20 return tr |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
21 |
67a3204c83c1
phases: test phases tracking at the transaction level
Boris Feld <boris.feld@octobus.net>
parents:
diff
changeset
|
22 repo.__class__ = reportphaserepo |