diff options
author | Erik Johnston <erikj@jki.re> | 2016-08-02 09:50:37 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-08-02 09:50:37 +0100 |
commit | f14cd95342cb7cb674b5d7efa9177365345bc17f (patch) | |
tree | b6746ee20bc1f3b22472be7c4e7f881255cf1838 /synapse/push/emailpusher.py | |
parent | missing --upgrade (diff) | |
parent | Ignore AlreadyCalled errors on timer cancel (diff) | |
download | synapse-f14cd95342cb7cb674b5d7efa9177365345bc17f.tar.xz |
Merge pull request #970 from matrix-org/erikj/clock
Ignore AlreadyCalled errors on timer cancel
Diffstat (limited to 'synapse/push/emailpusher.py')
-rw-r--r-- | synapse/push/emailpusher.py | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/synapse/push/emailpusher.py b/synapse/push/emailpusher.py index e224b68291..6600c9cd55 100644 --- a/synapse/push/emailpusher.py +++ b/synapse/push/emailpusher.py @@ -14,6 +14,7 @@ # limitations under the License. from twisted.internet import defer, reactor +from twisted.internet.error import AlreadyCalled, AlreadyCancelled import logging @@ -92,7 +93,11 @@ class EmailPusher(object): def on_stop(self): if self.timed_call: - self.timed_call.cancel() + try: + self.timed_call.cancel() + except (AlreadyCalled, AlreadyCancelled): + pass + self.timed_call = None @defer.inlineCallbacks def on_new_notifications(self, min_stream_ordering, max_stream_ordering): @@ -189,7 +194,10 @@ class EmailPusher(object): soonest_due_at = should_notify_at if self.timed_call is not None: - self.timed_call.cancel() + try: + self.timed_call.cancel() + except (AlreadyCalled, AlreadyCancelled): + pass self.timed_call = None if soonest_due_at is not None: |