2018-07-09 23:22:26 +02:00
|
|
|
from importlib import import_module
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
from asgiref.sync import sync_to_async
|
|
|
|
from channels.testing import WebsocketCommunicator
|
|
|
|
from django.conf import settings
|
|
|
|
from django.contrib.auth import (
|
|
|
|
BACKEND_SESSION_KEY,
|
|
|
|
HASH_SESSION_KEY,
|
|
|
|
SESSION_KEY,
|
|
|
|
)
|
|
|
|
|
|
|
|
from openslides.asgi import application
|
|
|
|
from openslides.core.config import config
|
|
|
|
from openslides.utils.autoupdate import inform_deleted_data
|
|
|
|
from openslides.utils.cache import element_cache
|
|
|
|
|
|
|
|
from ...unit.utils.cache_provider import (
|
|
|
|
Collection1,
|
|
|
|
Collection2,
|
|
|
|
get_cachable_provider,
|
|
|
|
)
|
|
|
|
from ..helpers import TConfig, TUser, set_config
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
2018-09-01 08:00:00 +02:00
|
|
|
async def prepare_element_cache(settings):
|
2018-07-09 23:22:26 +02:00
|
|
|
"""
|
|
|
|
Resets the element cache.
|
|
|
|
|
|
|
|
Uses a cacheable_provider for tests with example data.
|
|
|
|
"""
|
2018-09-01 08:00:00 +02:00
|
|
|
await element_cache.cache_provider.clear_cache()
|
2018-07-09 23:22:26 +02:00
|
|
|
orig_cachable_provider = element_cache.cachable_provider
|
|
|
|
element_cache.cachable_provider = get_cachable_provider([Collection1(), Collection2(), TConfig(), TUser()])
|
|
|
|
element_cache._cachables = None
|
2018-09-01 08:00:00 +02:00
|
|
|
await sync_to_async(element_cache.ensure_cache)()
|
2018-07-09 23:22:26 +02:00
|
|
|
yield
|
|
|
|
# Reset the cachable_provider
|
|
|
|
element_cache.cachable_provider = orig_cachable_provider
|
|
|
|
element_cache._cachables = None
|
2018-09-01 08:00:00 +02:00
|
|
|
await element_cache.cache_provider.clear_cache()
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2018-08-22 22:00:08 +02:00
|
|
|
async def communicator(request, event_loop):
|
2018-07-09 23:22:26 +02:00
|
|
|
communicator = WebsocketCommunicator(application, "/ws/site/")
|
2018-08-22 22:00:08 +02:00
|
|
|
yield communicator
|
|
|
|
await communicator.disconnect()
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_normal_connection(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
type = response.get('type')
|
|
|
|
content = response.get('content')
|
|
|
|
assert type == 'autoupdate'
|
2018-10-14 08:26:51 +02:00
|
|
|
assert 'changed' in content
|
|
|
|
assert 'deleted' in content
|
|
|
|
assert 'change_id' in content
|
|
|
|
assert Collection1().get_collection_string() in content['changed']
|
|
|
|
assert Collection2().get_collection_string() in content['changed']
|
|
|
|
assert TConfig().get_collection_string() in content['changed']
|
|
|
|
assert TUser().get_collection_string() in content['changed']
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_receive_changed_data(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
# Change a config value after the startup data has been received
|
|
|
|
await set_config('general_event_name', 'Test Event')
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
|
|
|
id = config.get_key_to_id()['general_event_name']
|
2018-08-22 16:50:23 +02:00
|
|
|
type = response.get('type')
|
|
|
|
content = response.get('content')
|
|
|
|
assert type == 'autoupdate'
|
2018-10-14 08:26:51 +02:00
|
|
|
assert content['changed'] == {
|
|
|
|
'core/config': [{'id': id, 'key': 'general_event_name', 'value': 'Test Event'}]}
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_anonymous_disabled(communicator):
|
|
|
|
connected, __ = await communicator.connect()
|
|
|
|
|
|
|
|
assert not connected
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_with_user():
|
|
|
|
# login user with id 1
|
|
|
|
engine = import_module(settings.SESSION_ENGINE)
|
|
|
|
session = engine.SessionStore() # type: ignore
|
|
|
|
session[SESSION_KEY] = '1'
|
|
|
|
session[HASH_SESSION_KEY] = '362d4f2de1463293cb3aaba7727c967c35de43ee' # see helpers.TUser
|
|
|
|
session[BACKEND_SESSION_KEY] = 'django.contrib.auth.backends.ModelBackend'
|
|
|
|
session.save()
|
|
|
|
scn = settings.SESSION_COOKIE_NAME
|
|
|
|
cookies = (b'cookie', '{}={}'.format(scn, session.session_key).encode())
|
|
|
|
communicator = WebsocketCommunicator(application, "/ws/site/", headers=[cookies])
|
|
|
|
|
|
|
|
connected, __ = await communicator.connect()
|
|
|
|
|
|
|
|
assert connected
|
|
|
|
|
|
|
|
await communicator.disconnect()
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_receive_deleted_data(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
# Delete test element
|
|
|
|
await sync_to_async(inform_deleted_data)([(Collection1().get_collection_string(), 1)])
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
type = response.get('type')
|
|
|
|
content = response.get('content')
|
|
|
|
assert type == 'autoupdate'
|
2018-10-14 08:26:51 +02:00
|
|
|
assert content['deleted'] == {Collection1().get_collection_string(): [1]}
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_send_invalid_notify_not_a_list(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
await communicator.send_json_to({'type': 'notify', 'content': {'testmessage': 'foobar, what else.'}, 'id': 'test_send_invalid_notify_not_a_list'})
|
2018-07-09 23:22:26 +02:00
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
assert response['type'] == 'error'
|
|
|
|
assert response['content'] == 'Invalid notify message'
|
|
|
|
assert response['in_response'] == 'test_send_invalid_notify_not_a_list'
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_send_invalid_notify_no_elements(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
await communicator.send_json_to({'type': 'notify', 'content': [], 'id': 'test_send_invalid_notify_no_elements'})
|
2018-07-09 23:22:26 +02:00
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
assert response['type'] == 'error'
|
|
|
|
assert response['content'] == 'Invalid notify message'
|
|
|
|
assert response['in_response'] == 'test_send_invalid_notify_no_elements'
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_send_invalid_notify_str_in_list(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
await communicator.send_json_to({'type': 'notify', 'content': [{}, 'testmessage'], 'id': 'test_send_invalid_notify_str_in_list'})
|
2018-07-09 23:22:26 +02:00
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
assert response['type'] == 'error'
|
|
|
|
assert response['content'] == 'Invalid notify message'
|
|
|
|
assert response['in_response'] == 'test_send_invalid_notify_str_in_list'
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_send_valid_notify(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
await communicator.send_json_to({'type': 'notify', 'content': [{'testmessage': 'foobar, what else.'}], 'id': 'test'})
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
|
|
|
|
content = response['content']
|
|
|
|
assert isinstance(content, list)
|
|
|
|
assert len(content) == 1
|
|
|
|
assert content[0]['testmessage'] == 'foobar, what else.'
|
|
|
|
assert 'senderReplyChannelName' in content[0]
|
|
|
|
assert content[0]['senderUserId'] == 0
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_invalid_websocket_message_type(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
await communicator.send_json_to([])
|
|
|
|
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
assert response['type'] == 'error'
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_invalid_websocket_message_no_id(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
await communicator.send_json_to({'type': 'test', 'content': 'foobar'})
|
|
|
|
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
assert response['type'] == 'error'
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_invalid_websocket_message_no_content(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
await communicator.send_json_to({'type': 'test', 'id': 'test_id'})
|
2018-07-09 23:22:26 +02:00
|
|
|
|
|
|
|
response = await communicator.receive_json_from()
|
2018-08-22 16:50:23 +02:00
|
|
|
assert response['type'] == 'error'
|
|
|
|
|
2018-07-09 23:22:26 +02:00
|
|
|
|
2018-08-22 16:50:23 +02:00
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_send_unknown_type(communicator):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
await communicator.send_json_to({'type': 'if_you_add_this_type_to_openslides_I_will_be_sad', 'content': True, 'id': 'test_id'})
|
|
|
|
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
assert response['type'] == 'error'
|
|
|
|
assert response['in_response'] == 'test_id'
|
2018-08-30 09:07:06 +02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
|
|
async def test_request_constants(communicator, settings):
|
|
|
|
await set_config('general_system_enable_anonymous', True)
|
|
|
|
await communicator.connect()
|
|
|
|
# Await the startup data
|
|
|
|
await communicator.receive_json_from()
|
|
|
|
|
|
|
|
await communicator.send_json_to({'type': 'constants', 'content': '', 'id': 'test_id'})
|
|
|
|
|
|
|
|
response = await communicator.receive_json_from()
|
|
|
|
assert response['type'] == 'constants'
|
|
|
|
# See conftest.py for the content of 'content'
|
|
|
|
assert response['content'] == {'constant1': 'value1', 'constant2': 'value2'}
|