mirror of
https://github.com/gentoo-mirror/gentoo.git
synced 2026-04-29 16:37:30 -07:00
373 lines
18 KiB
Diff
373 lines
18 KiB
Diff
diff --git a/tests/test_aioclient.py b/tests/test_aioclient.py
|
|
index 01a772a..5ec12ff 100644
|
|
--- a/tests/test_aioclient.py
|
|
+++ b/tests/test_aioclient.py
|
|
@@ -1,15 +1,14 @@
|
|
import asyncio
|
|
-import unittest
|
|
from unittest import mock
|
|
import pytest # noqa: F401
|
|
|
|
from wsproto.events import AcceptConnection, CloseConnection, TextMessage, \
|
|
BytesMessage, Ping
|
|
import simple_websocket
|
|
-from .helpers import make_sync, AsyncMock
|
|
|
|
|
|
-class AioSimpleWebSocketClientTestCase(unittest.TestCase):
|
|
+@pytest.mark.asyncio
|
|
+class TestAioSimpleWebSocketClient:
|
|
async def get_client(self, mock_wsconn, url, events=[], subprotocols=None,
|
|
headers=None):
|
|
mock_wsconn().events.side_effect = \
|
|
@@ -19,11 +18,10 @@ async def get_client(self, mock_wsconn, url, events=[], subprotocols=None,
|
|
return await simple_websocket.AioClient.connect(
|
|
url, subprotocols=subprotocols, headers=headers)
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_make_client(self, mock_wsconn, mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(mock_wsconn, 'ws://example.com/ws?a=1')
|
|
@@ -40,12 +38,11 @@ async def test_make_client(self, mock_wsconn, mock_open_connection):
|
|
assert client.port == 80
|
|
assert client.path == '/ws?a=1'
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_make_client_subprotocol(self, mock_wsconn,
|
|
mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(mock_wsconn, 'ws://example.com/ws?a=1',
|
|
@@ -55,12 +52,11 @@ async def test_make_client_subprotocol(self, mock_wsconn,
|
|
b"Request(host='example.com', target='/ws?a=1', extensions=[], "
|
|
b"extra_headers=[], subprotocols=['foo'])")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_make_client_subprotocols(self, mock_wsconn,
|
|
mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(mock_wsconn, 'ws://example.com/ws?a=1',
|
|
@@ -70,12 +66,11 @@ async def test_make_client_subprotocols(self, mock_wsconn,
|
|
b"Request(host='example.com', target='/ws?a=1', extensions=[], "
|
|
b"extra_headers=[], subprotocols=['foo', 'bar'])")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_make_client_headers(self, mock_wsconn,
|
|
mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(mock_wsconn, 'ws://example.com/ws?a=1',
|
|
@@ -84,12 +79,11 @@ async def test_make_client_headers(self, mock_wsconn,
|
|
b"Request(host='example.com', target='/ws?a=1', extensions=[], "
|
|
b"extra_headers=[('Foo', 'Bar')], subprotocols=[])")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_make_client_headers2(self, mock_wsconn,
|
|
mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(
|
|
@@ -100,11 +94,10 @@ async def test_make_client_headers2(self, mock_wsconn,
|
|
b"extra_headers=[('Foo', 'Bar'), ('Foo', 'Baz')], "
|
|
b"subprotocols=[])")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_send(self, mock_wsconn, mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(mock_wsconn, 'ws://example.com/ws')
|
|
@@ -123,11 +116,10 @@ async def test_send(self, mock_wsconn, mock_open_connection):
|
|
b"Message(data=b'hello', frame_finished=True, "
|
|
b"message_finished=True)")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive(self, mock_wsconn, mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(
|
|
@@ -142,12 +134,11 @@ async def test_receive(self, mock_wsconn, mock_open_connection):
|
|
assert await client.receive() == b'hello'
|
|
assert await client.receive(timeout=0) is None
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_after_close(self, mock_wsconn,
|
|
mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(
|
|
@@ -160,11 +151,10 @@ async def test_receive_after_close(self, mock_wsconn,
|
|
with pytest.raises(simple_websocket.ConnectionClosed):
|
|
await client.receive()
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_ping(self, mock_wsconn, mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
@@ -176,11 +166,11 @@ async def test_receive_ping(self, mock_wsconn, mock_open_connection):
|
|
await asyncio.sleep(0.01)
|
|
wsock.write.assert_any_call(b"Pong(payload=b'hello')")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_empty(self, mock_wsconn, mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(side_effect=[b'x', b'x', b'']))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(
|
|
+ side_effect=[b'x', b'x', b'']))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(
|
|
@@ -193,11 +183,10 @@ async def test_receive_empty(self, mock_wsconn, mock_open_connection):
|
|
assert await client.receive() == 'hello'
|
|
assert await client.receive(timeout=0) is None
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_close(self, mock_wsconn, mock_open_connection):
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
client = await self.get_client(
|
|
diff --git a/tests/test_aioserver.py b/tests/test_aioserver.py
|
|
index a274019..071e035 100644
|
|
--- a/tests/test_aioserver.py
|
|
+++ b/tests/test_aioserver.py
|
|
@@ -1,15 +1,14 @@
|
|
import asyncio
|
|
-import unittest
|
|
from unittest import mock
|
|
import pytest # noqa: F401
|
|
|
|
from wsproto.events import Request, CloseConnection, TextMessage, \
|
|
BytesMessage, Ping, Pong
|
|
import simple_websocket
|
|
-from .helpers import make_sync, AsyncMock
|
|
|
|
|
|
-class AioSimpleWebSocketServerTestCase(unittest.TestCase):
|
|
+@pytest.mark.asyncio
|
|
+class TestAioSimpleWebSocketServer:
|
|
async def get_server(self, mock_wsconn, request, events=[],
|
|
client_subprotocols=None, server_subprotocols=None,
|
|
**kwargs):
|
|
@@ -29,12 +28,11 @@ async def get_server(self, mock_wsconn, request, events=[],
|
|
return await simple_websocket.AioServer.accept(
|
|
aiohttp=request, subprotocols=server_subprotocols, **kwargs)
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_aiohttp(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request)
|
|
@@ -53,19 +51,17 @@ async def test_aiohttp(self, mock_wsconn, mock_open_connection):
|
|
b'Sec-Websocket-Version: 13\r\n\r\n')
|
|
assert server.is_server
|
|
|
|
- @make_sync
|
|
async def test_invalid_request(self):
|
|
with pytest.raises(ValueError):
|
|
await simple_websocket.AioServer.accept(aiohttp='foo', asgi='bar')
|
|
with pytest.raises(ValueError):
|
|
await simple_websocket.AioServer.accept(asgi='bar', sock='baz')
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_send(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request)
|
|
@@ -84,12 +80,11 @@ async def test_send(self, mock_wsconn, mock_open_connection):
|
|
b"Message(data=b'hello', frame_finished=True, "
|
|
b"message_finished=True)")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -103,13 +98,12 @@ async def test_receive(self, mock_wsconn, mock_open_connection):
|
|
assert await server.receive() == b'hello'
|
|
assert await server.receive(timeout=0) is None
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_after_close(self, mock_wsconn,
|
|
mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -121,13 +115,12 @@ async def test_receive_after_close(self, mock_wsconn,
|
|
with pytest.raises(simple_websocket.ConnectionClosed):
|
|
await server.receive()
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_split_messages(self, mock_wsconn,
|
|
mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -151,12 +144,11 @@ async def test_receive_split_messages(self, mock_wsconn,
|
|
assert await server.receive() == b'hello'
|
|
assert await server.receive(timeout=0) is None
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_ping(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -166,12 +158,11 @@ async def test_receive_ping(self, mock_wsconn, mock_open_connection):
|
|
await asyncio.sleep(0.01)
|
|
wsock.write.assert_any_call(b"Pong(payload=b'hello')")
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_empty(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -183,12 +174,11 @@ async def test_receive_empty(self, mock_wsconn, mock_open_connection):
|
|
assert await server.receive() == 'hello'
|
|
assert await server.receive(timeout=0) is None
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_receive_large(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -201,12 +191,11 @@ async def test_receive_large(self, mock_wsconn, mock_open_connection):
|
|
assert await server.receive() == 'hello'
|
|
assert await server.receive(timeout=0) is None
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_close(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request)
|
|
@@ -222,7 +211,6 @@ async def test_close(self, mock_wsconn, mock_open_connection):
|
|
b'CloseConnection(code=<CloseReason.NORMAL_CLOSURE: 1000>, '
|
|
b'reason=None)')
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
@mock.patch('simple_websocket.aiows.time')
|
|
@@ -230,7 +218,7 @@ async def test_close(self, mock_wsconn, mock_open_connection):
|
|
async def test_ping_pong(self, mock_wait_for, mock_time, mock_wsconn,
|
|
mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock())
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock())
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
server = await self.get_server(mock_wsconn, mock_request, events=[
|
|
@@ -246,12 +234,11 @@ async def test_ping_pong(self, mock_wait_for, mock_time, mock_wsconn,
|
|
assert wsock.write.call_args_list[2][0][0].startswith(b'Ping')
|
|
assert wsock.write.call_args_list[3][0][0].startswith(b'Close')
|
|
|
|
- @make_sync
|
|
@mock.patch('simple_websocket.aiows.asyncio.open_connection')
|
|
@mock.patch('simple_websocket.aiows.WSConnection')
|
|
async def test_subprotocols(self, mock_wsconn, mock_open_connection):
|
|
mock_request = mock.MagicMock(headers={})
|
|
- rsock = mock.MagicMock(read=AsyncMock(return_value=b'x'))
|
|
+ rsock = mock.MagicMock(read=mock.AsyncMock(return_value=b'x'))
|
|
wsock = mock.MagicMock()
|
|
mock_open_connection.return_value = (rsock, wsock)
|
|
|
|
diff --git a/tests/test_server.py b/tests/test_server.py
|
|
index 7be5d15..ca5fe99 100644
|
|
--- a/tests/test_server.py
|
|
+++ b/tests/test_server.py
|
|
@@ -92,7 +92,7 @@ def test_send(self, mock_wsconn):
|
|
b"message_finished=True)")
|
|
server.connected = True
|
|
server.send(b'hello')
|
|
- mock_socket.send.assert_called_with(
|
|
+ mock_socket.send.assert_any_call(
|
|
b"Message(data=b'hello', frame_finished=True, "
|
|
b"message_finished=True)")
|
|
|