##// 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:

r45142:d359f0d1 default
r45469:9e5b4dbe default
Show More
filtertraceback.py
40 lines | 853 B | text/x-python | PythonLexer
/ tests / filtertraceback.py
Gregory Szorc
hgweb: log error before attempting I/O...
r41603 #!/usr/bin/env python
# Filters traceback lines from stdin.
from __future__ import absolute_import, print_function
Gregory Szorc
tests: force \n newlines when writing to sys.stdout...
r45142 import io
Gregory Szorc
hgweb: log error before attempting I/O...
r41603 import sys
Gregory Szorc
tests: force \n newlines when writing to sys.stdout...
r45142 if sys.version_info[0] >= 3:
# Prevent \r from being inserted on Windows.
sys.stdout = io.TextIOWrapper(
sys.stdout.buffer,
sys.stdout.encoding,
sys.stdout.errors,
newline="\n",
line_buffering=sys.stdout.line_buffering,
)
Gregory Szorc
hgweb: log error before attempting I/O...
r41603 state = 'none'
for line in sys.stdin:
if state == 'none':
if line.startswith('Traceback '):
state = 'tb'
elif state == 'tb':
if line.startswith(' File '):
state = 'file'
continue
elif not line.startswith(' '):
state = 'none'
elif state == 'file':
# Ignore lines after " File "
state = 'tb'
continue
print(line, end='')