comparison mercurial/localrepo.py @ 44943:9e5b4dbe8ff2

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
author Gregory Szorc <gregory.szorc@gmail.com>
date Sat, 18 Jan 2020 10:07:07 -0800
parents edd08aa193fb
children 5797dbb630df
comparison
equal deleted inserted replaced
44942:25512a65cefd 44943:9e5b4dbe8ff2
507 try: 507 try:
508 hgvfs.stat() 508 hgvfs.stat()
509 except OSError as e: 509 except OSError as e:
510 if e.errno != errno.ENOENT: 510 if e.errno != errno.ENOENT:
511 raise 511 raise
512 except ValueError as e:
513 # Can be raised on Python 3.8 when path is invalid.
514 raise error.Abort(
515 _(b'invalid path %s: %s') % (path, pycompat.bytestr(e))
516 )
512 517
513 raise error.RepoError(_(b'repository %s not found') % path) 518 raise error.RepoError(_(b'repository %s not found') % path)
514 519
515 # .hg/requires file contains a newline-delimited list of 520 # .hg/requires file contains a newline-delimited list of
516 # features/capabilities the opener (us) must have in order to use 521 # features/capabilities the opener (us) must have in order to use