From c6102dfd0ee9630e704f71be278363bbb8266e81 Mon Sep 17 00:00:00 2001 From: Tai Sakuma Date: Tue, 25 Jun 2024 09:32:05 -0400 Subject: [PATCH] Add `test_stdout.py` --- .../ctrl/schema/subscriptions/__init__.py | 0 .../ctrl/schema/subscriptions/test_stdout.py | 41 +++++++++++++++++++ 2 files changed, 41 insertions(+) create mode 100644 tests/plugins/ctrl/schema/subscriptions/__init__.py create mode 100644 tests/plugins/ctrl/schema/subscriptions/test_stdout.py diff --git a/tests/plugins/ctrl/schema/subscriptions/__init__.py b/tests/plugins/ctrl/schema/subscriptions/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/tests/plugins/ctrl/schema/subscriptions/test_stdout.py b/tests/plugins/ctrl/schema/subscriptions/test_stdout.py new file mode 100644 index 0000000..8359325 --- /dev/null +++ b/tests/plugins/ctrl/schema/subscriptions/test_stdout.py @@ -0,0 +1,41 @@ +import asyncio +from typing import Any + +from nextline import Nextline + +from nextlinegraphql.plugins.ctrl.cache import CacheStdout +from nextlinegraphql.plugins.ctrl.graphql import SUBSCRIBE_STDOUT +from tests.plugins.ctrl.schema.conftest import Schema + +SOURCE = ''' +for i in range(10): + print(i) +'''.strip() + + +async def test_schema(schema: Schema) -> None: + nextline = Nextline(SOURCE, trace_modules=True, trace_threads=True) + cache = list[str]() + nextline.register(CacheStdout(cache)) + started = asyncio.Event() + context = {'nextline': nextline, 'stdout_cache': cache} + async with nextline: + task = asyncio.create_task(nextline.run_continue_and_wait(started=started)) + await started.wait() + sub = asyncio.create_task(_subscribe_stdout(schema, context=context)) + await task + await nextline.reset() + await asyncio.create_task(nextline.run_continue_and_wait(started=started)) + + stdout = await sub + assert stdout == '0\n1\n2\n3\n4\n5\n6\n7\n8\n9\n' '0\n1\n2\n3\n4\n5\n6\n7\n8\n9\n' + + +async def _subscribe_stdout(schema: Schema, context: Any) -> str: + sub = await schema.subscribe(SUBSCRIBE_STDOUT, context_value=context) + assert hasattr(sub, '__aiter__') + ret = '' + async for result in sub: + assert (data := result.data) + ret += data['ctrlStdout'] + return ret