diff options
author | Erik Johnston <erik@matrix.org> | 2019-10-30 14:06:34 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-10-30 14:06:34 +0100 |
commit | e5c3a990916bf0508f705be599f6d0bcb3c20d59 (patch) | |
tree | 6535228ec5c1325bc9f0d89a750bda250416e707 /synapse | |
parent | Modify doc to update Google ReCaptcha terms (#6257) (diff) | |
parent | Clarify docstring (diff) | |
download | synapse-e5c3a990916bf0508f705be599f6d0bcb3c20d59.tar.xz |
Merge pull request #6291 from matrix-org/erikj/fix_cache_descriptor
Make ObservableDeferred.observe() always return deferred.
Diffstat (limited to 'synapse')
-rw-r--r-- | synapse/util/async_helpers.py | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/synapse/util/async_helpers.py b/synapse/util/async_helpers.py index 7659eaeb42..b60a604474 100644 --- a/synapse/util/async_helpers.py +++ b/synapse/util/async_helpers.py @@ -86,11 +86,12 @@ class ObservableDeferred(object): deferred.addCallbacks(callback, errback) - def observe(self): + def observe(self) -> defer.Deferred: """Observe the underlying deferred. - Can return either a deferred if the underlying deferred is still pending - (or has failed), or the actual value. Callers may need to use maybeDeferred. + This returns a brand new deferred that is resolved when the underlying + deferred is resolved. Interacting with the returned deferred does not + effect the underdlying deferred. """ if not self._result: d = defer.Deferred() @@ -105,7 +106,7 @@ class ObservableDeferred(object): return d else: success, res = self._result - return res if success else defer.fail(res) + return defer.succeed(res) if success else defer.fail(res) def observers(self): return self._observers |