2015-09-04 16:22:02 -04:00
|
|
|
import sqlite3
|
|
|
|
from twisted.internet import task, reactor
|
|
|
|
import logging
|
|
|
|
|
|
|
|
|
2015-09-08 15:42:56 -04:00
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2015-09-04 16:22:02 -04:00
|
|
|
def rerun_if_locked(f):
|
|
|
|
|
|
|
|
def rerun(err, *args, **kwargs):
|
|
|
|
if err.check(sqlite3.OperationalError) and err.value.message == "database is locked":
|
2015-09-08 15:42:56 -04:00
|
|
|
log.warning("database was locked. rerunning %s with args %s, kwargs %s",
|
|
|
|
str(f), str(args), str(kwargs))
|
2015-09-04 16:22:02 -04:00
|
|
|
return task.deferLater(reactor, 0, wrapper, *args, **kwargs)
|
|
|
|
return err
|
|
|
|
|
|
|
|
def wrapper(*args, **kwargs):
|
|
|
|
d = f(*args, **kwargs)
|
|
|
|
d.addErrback(rerun, *args, **kwargs)
|
|
|
|
return d
|
|
|
|
|
|
|
|
return wrapper
|