##// END OF EJS Templates
bookmarks: cache reverse mapping (issue5868)...
bookmarks: cache reverse mapping (issue5868) I chose a simpler implementation. If the initial cost of building reverse mapping is significant, we'll have to move it under @propertycache. The nodemap could be a dict of sets, but I think keeping a sorted list is better since each node is likely to have zero/one bookmark. Micro-benchmark with 1001 bookmarks and 1001 revisions: $ for n in `seq 0 1000`; do touch $n; hg book book$n; hg ci -qAm$n; done $ hg bookmarks --time > /dev/null (orig) time: real 0.040 secs (user 0.050+0.000 sys 0.000+0.000) (new) time: real 0.040 secs (user 0.040+0.000 sys 0.010+0.000) $ hg log -T '{bookmarks}\n' --time > /dev/null (orig) time: real 0.160 secs (user 0.160+0.000 sys 0.000+0.000) (new) time: real 0.090 secs (user 0.100+0.000 sys 0.000+0.000)

File last commit:

r36625:c6061cad default
r37869:04ceb267 @26 default
Show More
fakedirstatewritetime.py
78 lines | 2.5 KiB | text/x-python | PythonLexer
/ tests / fakedirstatewritetime.py
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 # extension to emulate invoking 'dirstate.write()' at the time
# specified by '[fakedirstatewritetime] fakenow', only when
# 'dirstate.write()' is invoked via functions below:
#
Siddharth Agarwal
workingctx: factor out post-status dirstate fixup...
r32812 # - 'workingctx._poststatusfixup()' (= 'repo.status()')
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 # - 'committablectx.markcommitted()'
Gregory Szorc
tests/fakedirstatewritetime.py: use absolute_import
r27283 from __future__ import absolute_import
from mercurial import (
context,
dirstate,
extensions,
Yuya Nishihara
parsers: switch to policy importer...
r32372 policy,
Boris Feld
configitems: register the test 'fakedirstatewritetime.fakenow' config
r34772 registrar,
Gregory Szorc
tests/fakedirstatewritetime.py: use absolute_import
r27283 )
Boris Feld
util: extract all date-related utils in utils/dateutil module...
r36625 from mercurial.utils import dateutil
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752
Boris Feld
configitems: register the test 'fakedirstatewritetime.fakenow' config
r34772 configtable = {}
configitem = registrar.configitem(configtable)
Pulkit Goyal
py3: add b'' prefixes in fakedirstatewritetime.py...
r36342 configitem(b'fakedirstatewritetime', b'fakenow',
Boris Feld
configitems: register the test 'fakedirstatewritetime.fakenow' config
r34772 default=None,
)
Yuya Nishihara
parsers: switch to policy importer...
r32372 parsers = policy.importmod(r'parsers')
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 def pack_dirstate(fakenow, orig, dmap, copymap, pl, now):
# execute what original parsers.pack_dirstate should do actually
# for consistency
actualnow = int(now)
Pulkit Goyal
py3: use dict.items() instead of dict.iteritems() in tests...
r36345 for f, e in dmap.items():
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 if e[0] == 'n' and e[3] == actualnow:
e = parsers.dirstatetuple(e[0], e[1], e[2], -1)
dmap[f] = e
return orig(dmap, copymap, pl, fakenow)
def fakewrite(ui, func):
# fake "now" of 'pack_dirstate' only if it is invoked while 'func'
Pulkit Goyal
py3: add b'' prefixes in fakedirstatewritetime.py...
r36342 fakenow = ui.config(b'fakedirstatewritetime', b'fakenow')
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 if not fakenow:
# Execute original one, if fakenow isn't configured. This is
# useful to prevent subrepos from executing replaced one,
# because replacing 'parsers.pack_dirstate' is also effective
# in subrepos.
return func()
# parsing 'fakenow' in YYYYmmddHHMM format makes comparison between
# 'fakenow' value and 'touch -t YYYYmmddHHMM' argument easy
Boris Feld
util: extract all date-related utils in utils/dateutil module...
r36625 fakenow = dateutil.parsedate(fakenow, [b'%Y%m%d%H%M'])[0]
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752
orig_pack_dirstate = parsers.pack_dirstate
FUJIWARA Katsunori
dirstate: make writing in-memory changes aware of transaction activity...
r26634 orig_dirstate_getfsnow = dirstate._getfsnow
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 wrapper = lambda *args: pack_dirstate(fakenow, orig_pack_dirstate, *args)
parsers.pack_dirstate = wrapper
FUJIWARA Katsunori
dirstate: make writing in-memory changes aware of transaction activity...
r26634 dirstate._getfsnow = lambda *args: fakenow
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 try:
return func()
finally:
parsers.pack_dirstate = orig_pack_dirstate
FUJIWARA Katsunori
dirstate: make writing in-memory changes aware of transaction activity...
r26634 dirstate._getfsnow = orig_dirstate_getfsnow
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752
Siddharth Agarwal
workingctx: also pass status tuple into poststatusfixup...
r32813 def _poststatusfixup(orig, workingctx, status, fixup):
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 ui = workingctx.repo().ui
Siddharth Agarwal
workingctx: also pass status tuple into poststatusfixup...
r32813 return fakewrite(ui, lambda : orig(workingctx, status, fixup))
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752
def markcommitted(orig, committablectx, node):
ui = committablectx.repo().ui
return fakewrite(ui, lambda : orig(committablectx, node))
def extsetup(ui):
Siddharth Agarwal
workingctx: factor out post-status dirstate fixup...
r32812 extensions.wrapfunction(context.workingctx, '_poststatusfixup',
_poststatusfixup)
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 extensions.wrapfunction(context.committablectx, 'markcommitted',
markcommitted)