Skip to content

Commit

Permalink
Make Metronome tests fast
Browse files Browse the repository at this point in the history
  • Loading branch information
mikenerone committed Jan 20, 2024
1 parent d0fead2 commit 9da517d
Showing 1 changed file with 14 additions and 15 deletions.
29 changes: 14 additions & 15 deletions tests/test_producers.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
import trio

from slurry import Pipeline
from slurry.sections import Repeat, Metronome, InsertValue
from slurry.sections import Repeat, Metronome, InsertValue, _producers

from .fixtures import produce_alphabet

Expand Down Expand Up @@ -51,32 +51,31 @@ async def test_repeat_input(autojump_clock):
break
assert results == [('a', 1), ('a', 2), ('b', 2.5), ('b', 3.5), ('c', 4)]

async def test_metronome():
async def test_metronome(autojump_clock, monkeypatch):
monkeypatch.setattr(_producers, "time", trio.current_time)
async with Pipeline.create(
produce_alphabet(5, max=3),
produce_alphabet(5, max=6, delay=1),
Metronome(5)
) as pipeline, pipeline.tap() as aiter:
results = []
start_time = trio.current_time()
async for item in aiter:
results.append((item, trio.current_time() - start_time))
if len(results) == 2:
while True:
try:
results.append((await aiter.__anext__(), trio.current_time() - start_time))
except StopAsyncIteration:
break
assert [x[0] for x in results] == ['a', 'b']
assert 5 - results[1][1] + results[0][1] < 0.1
assert results == [(letter, 5.0 * (i + 1)) for i, letter in enumerate("abcde")]

async def test_metronome_no_input():
async def test_metronome_no_input(autojump_clock, monkeypatch):
monkeypatch.setattr(_producers, "time", trio.current_time)
async with Pipeline.create(
Metronome(5, "a")
) as pipeline, pipeline.tap() as aiter:
results = []
start_time = trio.current_time()
async for item in aiter:
results.append((item, trio.current_time() - start_time))
if len(results) == 2:
break
assert [x[0] for x in results] == ['a', 'a']
assert 5 - results[1][1] + results[0][1] < 0.1
for _ in range(5):
results.append((await aiter.__anext__(), trio.current_time() - start_time))
assert results == [("a", 5.0 * (i + 1)) for i in range(5)]

async def test_insert_value(autojump_clock):
async with Pipeline.create(
Expand Down

0 comments on commit 9da517d

Please sign in to comment.