From 608a6a97bc292b4c2a4b4c79ebb4d1fc861cea0a Mon Sep 17 00:00:00 2001 From: Andrew Svetlov Date: Mon, 21 Jan 2019 16:43:21 -0500 Subject: [PATCH] [3.5] Test for stream .read() / .readany() / .iter_any() (#3525) (#3527) (#3560) (#3565) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit (cherry picked from commit c3f494f) Co-authored-by: Коренберг Марк --- tests/test_streams.py | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/tests/test_streams.py b/tests/test_streams.py index 4d4b8357ce4..1c11a77447f 100644 --- a/tests/test_streams.py +++ b/tests/test_streams.py @@ -649,6 +649,39 @@ async def test_begin_and_end_chunk_receiving(self) -> None: assert b'' == data assert not end_of_chunk + async def test_readany_chunk_end_race(self) -> None: + stream = self._make_one() + stream.begin_http_chunk_receiving() + stream.feed_data(b'part1') + + data = await stream.readany() + assert data == b'part1' + + loop = asyncio.get_event_loop() + task = loop.create_task(stream.readany()) + + # Give a chance for task to create waiter and start waiting for it. + await asyncio.sleep(0.1) + assert stream._waiter is not None + assert not task.done() # Just for sure. + + # This will trigger waiter, but without feeding any data. + # The stream should re-create waiter again. + stream.end_http_chunk_receiving() + + # Give a chance for task to resolve. + # If everything is OK, previous action SHOULD NOT resolve the task. + await asyncio.sleep(0.1) + assert not task.done() # The actual test. + + stream.begin_http_chunk_receiving() + # This SHOULD unblock the task actually. + stream.feed_data(b'part2') + stream.end_http_chunk_receiving() + + data = await task + assert data == b'part2' + async def test_end_chunk_receiving_without_begin(self) -> None: stream = self._make_one() with pytest.raises(RuntimeError):