mirror of
https://git.anonymousland.org/anonymousland/synapse-product.git
synced 2025-07-31 05:18:39 -04:00
Stop the transaction cache caching failures
The transaction cache has some code which tries to stop it caching failures, but if the callback function failed straight away, then things would happen backwards and we'd end up with the failure stuck in the cache.
This commit is contained in:
parent
d689e0dba1
commit
6d6e7288fe
2 changed files with 67 additions and 9 deletions
|
@ -87,19 +87,23 @@ class HttpTransactionCache(object):
|
|||
|
||||
deferred = fn(*args, **kwargs)
|
||||
|
||||
# if the request fails with a Twisted failure, remove it
|
||||
# from the transaction map. This is done to ensure that we don't
|
||||
# cache transient errors like rate-limiting errors, etc.
|
||||
observable = ObservableDeferred(deferred, consumeErrors=False)
|
||||
self.transactions[txn_key] = (observable, self.clock.time_msec())
|
||||
|
||||
# if the request fails with an exception, remove it from the
|
||||
# transaction map. This is done to ensure that we don't cache
|
||||
# transient errors like rate-limiting errors, etc.
|
||||
#
|
||||
# (make sure we add this errback *after* adding the key above, in case
|
||||
# the deferred has already failed and is running errbacks
|
||||
# synchronously)
|
||||
def remove_from_map(err):
|
||||
self.transactions.pop(txn_key, None)
|
||||
return err
|
||||
# we deliberately do not propagate the error any further, as we
|
||||
# expect the observers to have reported it.
|
||||
|
||||
deferred.addErrback(remove_from_map)
|
||||
|
||||
# We don't add any other errbacks to the raw deferred, so we ask
|
||||
# ObservableDeferred to swallow the error. This is fine as the error will
|
||||
# still be reported to the observers.
|
||||
observable = ObservableDeferred(deferred, consumeErrors=True)
|
||||
self.transactions[txn_key] = (observable, self.clock.time_msec())
|
||||
return observable.observe()
|
||||
|
||||
def _cleanup(self):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue