tests: Improve the pan client test.

This commit is contained in:
Damir Jelić 2019-07-04 14:58:15 +02:00
parent fb0bc090c7
commit 25f284f8de

View File

@ -3,9 +3,18 @@ import re
import janus import janus
import pytest import pytest
from nio import (LoginResponse, SyncResponse, Timeline, RoomMemberEvent, Rooms, from nio import (
RoomInfo, DeviceOneTimeKeyCount, RoomEncryptionEvent, DeviceList, DeviceList,
RoomSummary) DeviceOneTimeKeyCount,
LoginResponse,
RoomEncryptionEvent,
RoomInfo,
RoomMemberEvent,
Rooms,
RoomSummary,
SyncResponse,
Timeline,
)
from pantalaimon.client import PanClient from pantalaimon.client import PanClient
from pantalaimon.config import ServerConfig from pantalaimon.config import ServerConfig
@ -22,6 +31,7 @@ async def client(tmpdir, loop):
store = PanStore(tmpdir) store = PanStore(tmpdir)
queue = janus.Queue(loop=loop) queue = janus.Queue(loop=loop)
conf = ServerConfig("example", "https://exapmle.org") conf = ServerConfig("example", "https://exapmle.org")
conf.history_fetch_delay = 0.1
store.save_server_user("example", "@example:example.org") store.save_server_user("example", "@example:example.org")
@ -306,13 +316,91 @@ class TestClass(object):
@property @property
def empty_sync(self): def empty_sync(self):
return SyncResponse( return {
"tokenf#a#inf", "account_data": {
Rooms(), "events": []
DeviceOneTimeKeyCount(50, 50), },
DeviceList([], []), "device_lists": {
[] "changed": [],
) "left": []
},
"device_one_time_keys_count": {
"signed_curve25519": 50
},
"groups": {
"invite": {},
"join": {},
"leave": {}
},
"next_batch": "s1059_133339_44_763_246_1_586_12411_1",
"presence": {
"events": []
},
"rooms": {
"invite": {},
"join": {},
"leave": {}
},
"to_device": {
"events": []
}
}
@property
def messages_response(self):
return {
"chunk": [
{
"age": 1042,
"content": {
"body": "hello world",
"msgtype": "m.text"
},
"event_id": "$1444812213350496Caaaa:example.com",
"origin_server_ts": 1444812213737,
"room_id": "!Xq3620DUiqCaoxq:example.com",
"sender": "@alice:example.com",
"type": "m.room.message"
},
{
"age": 20123,
"content": {
"body": "the world is big",
"msgtype": "m.text"
},
"event_id": "$1444812213350496Cbbbb:example.com",
"origin_server_ts": 1444812194656,
"room_id": "!Xq3620DUiqCaoxq:example.com",
"sender": "@alice:example.com",
"type": "m.room.message"
},
{
"age": 50789,
"content": {
"name": "New room name"
},
"event_id": "$1444812213350496Ccccc:example.com",
"origin_server_ts": 1444812163990,
"prev_content": {
"name": "Old room name"
},
"room_id": "!Xq3620DUiqCaoxq:example.com",
"sender": "@alice:example.com",
"state_key": "",
"type": "m.room.name"
}
],
"end": "t47409-4357353_219380_26003_2265",
"start": "t47429-4392820_219380_26003_2265"
}
@property
def empty_messages(self):
return {
"chunk": [],
"end": "t47429-4392820_219380_26003_2277",
"start": "t47409-4357353_219380_26003_2265"
}
async def test_login(self, client): async def test_login(self, client):
await client.receive_response(self.login_response) await client.receive_response(self.login_response)
@ -346,11 +434,21 @@ class TestClass(object):
await client.receive_response(self.login_response) await client.receive_response(self.login_response)
# Set a big history fetch delay so it doesn't consume the fetch tasks.
client.pan_conf.history_fetch_delay = 10
client.start_loop(100) client.start_loop(100)
# Sync tasks are done after we get a sync event so wait for two of them
await client.synced.wait() await client.synced.wait()
await client.synced.wait() await client.synced.wait()
# Make sure that we have only a single history fetch task for the
# single room we have
assert not client.history_fetch_queue.empty() assert not client.history_fetch_queue.empty()
assert client.history_fetch_queue.qsize() == 1
# Do another round to be sure we don't get more tasks than necessary.
await client.synced.wait()
assert client.history_fetch_queue.qsize() == 1
await client.loop_stop() await client.loop_stop()