Skip to content

Commit 38da988

Browse files
author
Paul "LeoNerd" Evans
committed
Implement .call_later() in MockClock
1 parent be9a8d6 commit 38da988

File tree

2 files changed

+48
-0
lines changed

2 files changed

+48
-0
lines changed

tests/test_test_utils.py

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,3 +28,25 @@ def test_advance_time(self):
2828
self.clock.advance_time(20)
2929

3030
self.assertEquals(20, self.clock.time() - start_time)
31+
32+
def test_later(self):
33+
invoked = [0, 0]
34+
35+
def _cb0():
36+
invoked[0] = 1
37+
self.clock.call_later(10, _cb0)
38+
39+
def _cb1():
40+
invoked[1] = 1
41+
self.clock.call_later(20, _cb1)
42+
43+
self.assertFalse(invoked[0])
44+
45+
self.clock.advance_time(15)
46+
47+
self.assertTrue(invoked[0])
48+
self.assertFalse(invoked[1])
49+
50+
self.clock.advance_time(5)
51+
52+
self.assertTrue(invoked[1])

tests/utils.py

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818
from synapse.api.constants import Membership
1919
from synapse.storage import prepare_database
2020

21+
from synapse.util.logcontext import LoggingContext
22+
2123
from synapse.api.events.room import (
2224
RoomMemberEvent, MessageEvent
2325
)
@@ -134,16 +136,40 @@ def verify(self, message, sig):
134136
class MockClock(object):
135137
now = 1000
136138

139+
def __init__(self):
140+
# list of tuples of (absolute_time, callback) in no particular order
141+
self.timers = []
142+
137143
def time(self):
138144
return self.now
139145

140146
def time_msec(self):
141147
return self.time() * 1000
142148

149+
def call_later(self, delay, callback):
150+
current_context = LoggingContext.current_context()
151+
152+
def wrapped_callback():
153+
LoggingContext.thread_local.current_context = current_context
154+
callback()
155+
self.timers.append((self.now + delay, wrapped_callback))
156+
157+
def cancel_call_later(self, timer):
158+
raise NotImplementedError("Oopsie")
159+
143160
# For unit testing
144161
def advance_time(self, secs):
145162
self.now += secs
146163

164+
timers = self.timers
165+
self.timers = []
166+
167+
for time, callback in timers:
168+
if self.now >= time:
169+
callback()
170+
else:
171+
self.timers.append((time, callback))
172+
147173

148174
class SQLiteMemoryDbPool(ConnectionPool, object):
149175
def __init__(self):

0 commit comments

Comments
 (0)