Skip to content

Commit

Permalink
Retry in the case of failures. nedbat#1010
Browse files Browse the repository at this point in the history
PyPy seems prone to intermittent SQLite failures.  An immediate retry
avoids them.  Not great, but it works.
  • Loading branch information
nedbat committed Dec 5, 2020
1 parent 104d51e commit 3f18bfc
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 1 deletion.
5 changes: 5 additions & 0 deletions CHANGES.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,14 @@ Unreleased
- When using ``--source`` on a large source tree, v5.x was slower than previous
versions. This performance regression is now fixed, closing `issue 1037`_.

- Mysterious SQLite errors can happen on PyPy, as reported in `issue 1010`_. An
immediate retry seems to fix the problem, although it is an unsatisfying
solution.

- Continuous integration has moved from Travis and AppVeyor to GitHub Actions.

.. _issue 1037: https://github.com/nedbat/coveragepy/issues/1037
.. _issue 1010: https://github.com/nedbat/coveragepy/issues/1010


.. _changes_53:
Expand Down
8 changes: 7 additions & 1 deletion coverage/sqldata.py
Original file line number Diff line number Diff line change
Expand Up @@ -1056,7 +1056,13 @@ def execute(self, sql, parameters=()):
tail = " with {!r}".format(parameters) if parameters else ""
self.debug.write("Executing {!r}{}".format(sql, tail))
try:
return self.con.execute(sql, parameters)
try:
return self.con.execute(sql, parameters)
except Exception:
# In some cases, an error might happen that isn't really an
# error. Try again immediately.
# https://github.com/nedbat/coveragepy/issues/1010
return self.con.execute(sql, parameters)
except sqlite3.Error as exc:
msg = str(exc)
try:
Expand Down

0 comments on commit 3f18bfc

Please sign in to comment.