##// END OF EJS Templates
localrepo: handle ValueError during repository opening...
localrepo: handle ValueError during repository opening Python 3.8 can raise ValueError on attempt of an I/O operation against an illegal path. This was causing test-remotefilelog-gc.t to fail on Python 3.8. This commit teaches repository opening to handle ValueError and re-raise an Abort on failure. An arguably better solution would be to implement this logic in the vfs layer. But that seems like a bag of worms and I don't want to go down that rabbit hole. Until users report uncaught ValueError exceptions in the wild, I think it is fine to patch this at the only occurrence our test harness is finding it. Differential Revision: https://phab.mercurial-scm.org/D7944

File last commit:

r43812:2fe6121c default
r45469:9e5b4dbe default
Show More
fakedirstatewritetime.py
104 lines | 3.1 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
Raphaël Gomès
rust-dirstate: call parse/pack bindings from Python...
r42490 try:
from mercurial import rustext
Augie Fackler
formatting: blacken the codebase...
r43346
Raphaël Gomès
rust-dirstate: call parse/pack bindings from Python...
r42490 rustext.__name__ # force actual import (see hgdemandimport)
except ImportError:
rustext = None
Boris Feld
configitems: register the test 'fakedirstatewritetime.fakenow' config
r34772 configtable = {}
configitem = registrar.configitem(configtable)
Augie Fackler
formatting: blacken the codebase...
r43346 configitem(
b'fakedirstatewritetime', b'fakenow', default=None,
Boris Feld
configitems: register the test 'fakedirstatewritetime.fakenow' config
r34772 )
Augie Fackler
cleanup: remove pointless r-prefixes on single-quoted strings...
r43906 parsers = policy.importmod('parsers')
rustmod = policy.importrust('parsers')
Yuya Nishihara
parsers: switch to policy importer...
r32372
Augie Fackler
formatting: blacken the codebase...
r43346
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)
Augie Fackler
formatting: blacken the codebase...
r43346
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752 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
Raphaël Gomès
rust-parsers: move parser bindings to their own file and Python module...
r42992 if rustmod is not None:
# The Rust implementation does not use public parse/pack dirstate
# to prevent conversion round-trips
orig_dirstatemap_write = dirstate.dirstatemap.write
Augie Fackler
formatting: blacken the codebase...
r43346 wrapper = lambda self, st, now: orig_dirstatemap_write(
self, st, fakenow
)
Raphaël Gomès
rust-parsers: move parser bindings to their own file and Python module...
r42992 dirstate.dirstatemap.write = wrapper
Raphaël Gomès
rust-dirstate: call parse/pack bindings from Python...
r42490
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)
Raphaël Gomès
rust-parsers: move parser bindings to their own file and Python module...
r42992 orig_module = parsers
orig_pack_dirstate = parsers.pack_dirstate
Raphaël Gomès
rust-dirstate: call parse/pack bindings from Python...
r42490 orig_module.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:
Raphaël Gomès
rust-dirstate: call parse/pack bindings from Python...
r42490 orig_module.pack_dirstate = orig_pack_dirstate
FUJIWARA Katsunori
dirstate: make writing in-memory changes aware of transaction activity...
r26634 dirstate._getfsnow = orig_dirstate_getfsnow
Raphaël Gomès
rust-parsers: move parser bindings to their own file and Python module...
r42992 if rustmod is not None:
dirstate.dirstatemap.write = orig_dirstatemap_write
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752
Augie Fackler
formatting: blacken the codebase...
r43346
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
Augie Fackler
formatting: blacken the codebase...
r43346 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
Augie Fackler
formatting: blacken the codebase...
r43346 return fakewrite(ui, lambda: orig(committablectx, node))
FUJIWARA Katsunori
tests: add extension to emulate invoking dirstate.write at the specific time...
r25752
def extsetup(ui):
Augie Fackler
formatting: blacken the codebase...
r43346 extensions.wrapfunction(
context.workingctx, '_poststatusfixup', _poststatusfixup
)
extensions.wrapfunction(context.workingctx, 'markcommitted', markcommitted)