Mercurial > hg
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 |