Skip to content

Commit

Permalink
run test_async_filters under trio, and ensure async generators are cl…
Browse files Browse the repository at this point in the history
…osed
  • Loading branch information
graingert committed Apr 16, 2024
1 parent b4da451 commit b105db5
Showing 1 changed file with 54 additions and 13 deletions.
67 changes: 54 additions & 13 deletions tests/test_async_filters.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
import asyncio
import contextlib
from collections import namedtuple

import pytest
import trio
from markupsafe import Markup

from jinja2 import Environment
Expand All @@ -26,10 +29,39 @@ def env_async():
return Environment(enable_async=True)


def _asyncio_run(async_fn, *args):
return asyncio.run(async_fn(*args))


@pytest.fixture(params=[_asyncio_run, trio.run], ids=["asyncio", "trio"])
def run_async_fn(request):
return request.param


@contextlib.asynccontextmanager
async def closing_factory():
async with contextlib.AsyncExitStack() as stack:

def closing(maybe_agen):
try:
aclose = maybe_agen.aclose
except AttributeError:
pass
else:
stack.push_async_callback(aclose)
return maybe_agen

yield closing


@mark_dualiter("foo", lambda: range(10))
def test_first(env_async, foo):
tmpl = env_async.from_string("{{ foo()|first }}")
out = tmpl.render(foo=foo)
def test_first(env_async, foo, run_async_fn):
async def test():
async with closing_factory() as closing:
tmpl = env_async.from_string("{{ closing(foo())|first }}")
return await tmpl.render_async(foo=foo, closing=closing)

out = run_async_fn(test)
assert out == "0"


Expand Down Expand Up @@ -245,18 +277,23 @@ def test_slice(env_async, items):
)


def test_custom_async_filter(env_async):
def test_custom_async_filter(env_async, run_async_fn):
async def customfilter(val):
return str(val)

env_async.filters["customfilter"] = customfilter
tmpl = env_async.from_string("{{ 'static'|customfilter }} {{ arg|customfilter }}")
out = tmpl.render(arg="dynamic")
async def test():
env_async.filters["customfilter"] = customfilter
tmpl = env_async.from_string(
"{{ 'static'|customfilter }} {{ arg|customfilter }}"
)
return await tmpl.render_async(arg="dynamic")

out = run_async_fn(test)
assert out == "static dynamic"


@mark_dualiter("items", lambda: range(10))
def test_custom_async_iteratable_filter(env_async, items):
def test_custom_async_iteratable_filter(env_async, items, run_async_fn):
async def customfilter(iterable):
items = []
async for item in auto_aiter(iterable):
Expand All @@ -265,9 +302,13 @@ async def customfilter(iterable):
break
return ",".join(items)

env_async.filters["customfilter"] = customfilter
tmpl = env_async.from_string(
"{{ items()|customfilter }} .. {{ [3, 4, 5, 6]|customfilter }}"
)
out = tmpl.render(items=items)
async def test():
async with closing_factory() as closing:
env_async.filters["customfilter"] = customfilter
tmpl = env_async.from_string(
"{{ closing(items())|customfilter }} .. {{ [3, 4, 5, 6]|customfilter }}"
)
return await tmpl.render_async(items=items, closing=closing)

out = run_async_fn(test)
assert out == "0,1,2 .. 3,4,5"

0 comments on commit b105db5

Please sign in to comment.