Mercurial > hg
annotate tests/bruterebase.py @ 50400:95acba2c29f6
encoding: avoid quadratic time complexity when json-encoding non-UTF8 strings
Apparently the code uses "+=" with a bytes object, which is linear-time, so the
whole encoding is quadratic-time. This patch makes us use a bytearray object,
instead, which has a(n amortized-)constant-time append operation.
The encoding is still not particularly fast, but at least a 10MB file
takes tens of seconds, not many hours to encode.
author | Arseniy Alekseyev <aalekseyev@janestreet.com> |
---|---|
date | Mon, 06 Mar 2023 11:27:57 +0000 |
parents | 56f98406831b |
children |
rev | line source |
---|---|
33708 | 1 # bruterebase.py - brute force rebase testing |
2 # | |
3 # Copyright 2017 Facebook, Inc. | |
4 # | |
5 # This software may be used and distributed according to the terms of the | |
6 # GNU General Public License version 2 or any later version. | |
7 | |
8 | |
9 from mercurial import ( | |
10 error, | |
11 registrar, | |
12 revsetlang, | |
13 ) | |
14 | |
15 from hgext import rebase | |
16 | |
17 cmdtable = {} | |
18 command = registrar.command(cmdtable) | |
19 | |
43076
2372284d9457
formatting: blacken the codebase
Augie Fackler <augie@google.com>
parents:
39683
diff
changeset
|
20 |
34204
bab82c43c065
bruterebase: port to python 3
Augie Fackler <raf@durin42.com>
parents:
33708
diff
changeset
|
21 @command(b'debugbruterebase') |
33708 | 22 def debugbruterebase(ui, repo, source, dest): |
23 """for every non-empty subset of source, run rebase -r subset -d dest | |
24 | |
25 Print one line summary for each subset. Assume obsstore is enabled. | |
26 """ | |
27 srevs = list(repo.revs(source)) | |
28 | |
29 with repo.wlock(), repo.lock(): | |
30 repolen = len(repo) | |
31 cl = repo.changelog | |
32 | |
33 def getdesc(rev): | |
34 result = cl.changelogrevision(rev).description | |
35 if rev >= repolen: | |
34204
bab82c43c065
bruterebase: port to python 3
Augie Fackler <raf@durin42.com>
parents:
33708
diff
changeset
|
36 result += b"'" |
33708 | 37 return result |
38 | |
49285
56f98406831b
py3: remove xrange() compatibility code
Manuel Jacob <me@manueljacob.de>
parents:
48875
diff
changeset
|
39 for i in range(1, 2 ** len(srevs)): |
33708 | 40 subset = [rev for j, rev in enumerate(srevs) if i & (1 << j) != 0] |
34204
bab82c43c065
bruterebase: port to python 3
Augie Fackler <raf@durin42.com>
parents:
33708
diff
changeset
|
41 spec = revsetlang.formatspec(b'%ld', subset) |
bab82c43c065
bruterebase: port to python 3
Augie Fackler <raf@durin42.com>
parents:
33708
diff
changeset
|
42 tr = repo.transaction(b'rebase') |
43076
2372284d9457
formatting: blacken the codebase
Augie Fackler <augie@google.com>
parents:
39683
diff
changeset
|
43 tr._report = lambda x: 0 # hide "transaction abort" |
33708 | 44 |
47437
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
45 with ui.silent(): |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
46 try: |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
47 rebase.rebase(ui, repo, dest=dest, rev=[spec]) |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
48 except error.Abort as ex: |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
49 summary = b'ABORT: %s' % ex.message |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
50 except Exception as ex: |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
51 summary = b'CRASH: %s' % ex |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
52 else: |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
53 # short summary about new nodes |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
54 cl = repo.changelog |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
55 descs = [] |
49285
56f98406831b
py3: remove xrange() compatibility code
Manuel Jacob <me@manueljacob.de>
parents:
48875
diff
changeset
|
56 for rev in range(repolen, len(repo)): |
47437
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
57 desc = b'%s:' % getdesc(rev) |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
58 for prev in cl.parentrevs(rev): |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
59 if prev > -1: |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
60 desc += getdesc(prev) |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
61 descs.append(desc) |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
62 descs.sort() |
7a430116f639
ui: add a context manager for silencing the ui (pushbuffer+popbuffer)
Martin von Zweigbergk <martinvonz@google.com>
parents:
45682
diff
changeset
|
63 summary = b' '.join(descs) |
34204
bab82c43c065
bruterebase: port to python 3
Augie Fackler <raf@durin42.com>
parents:
33708
diff
changeset
|
64 repo.vfs.tryunlink(b'rebasestate') |
33708 | 65 |
34204
bab82c43c065
bruterebase: port to python 3
Augie Fackler <raf@durin42.com>
parents:
33708
diff
changeset
|
66 subsetdesc = b''.join(getdesc(rev) for rev in subset) |
43076
2372284d9457
formatting: blacken the codebase
Augie Fackler <augie@google.com>
parents:
39683
diff
changeset
|
67 ui.write(b'%s: %s\n' % (subsetdesc.rjust(len(srevs)), summary)) |
33708 | 68 tr.abort() |