Skip to content
This repository was archived by the owner on Apr 26, 2024. It is now read-only.

Commit 8cd7b00

Browse files
author
David Robertson
committed
Add a test case for the SendJoinParser
This would have caught the bug #11438 introduced in #11217 and fixed in #11439.
1 parent 1d8b80b commit 8cd7b00

File tree

1 file changed

+49
-0
lines changed

1 file changed

+49
-0
lines changed
Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
import json
2+
3+
from synapse.api.room_versions import RoomVersions
4+
from synapse.federation.transport.client import SendJoinParser
5+
from tests.unittest import TestCase
6+
7+
8+
class SendJoinParserTestCase(TestCase):
9+
def test_two_writes(self):
10+
"""Test that the parser can sensibly deserialise an input given in two slices."""
11+
parser = SendJoinParser(RoomVersions.V1, True)
12+
parent_event = {
13+
"content": {
14+
"see_room_version_spec": "The event format changes depending on the room version."
15+
},
16+
"event_id": "$authparent",
17+
"room_id": "!somewhere:example.org",
18+
"type": "m.room.minimal_pdu",
19+
}
20+
state = {
21+
"content": {
22+
"see_room_version_spec": "The event format changes depending on the room version."
23+
},
24+
"event_id": "$DoNotThinkAboutTheEvent",
25+
"room_id": "!somewhere:example.org",
26+
"type": "m.room.minimal_pdu",
27+
}
28+
response = [
29+
200,
30+
{
31+
"auth_chain": [parent_event],
32+
"origin": "matrix.org",
33+
"state": [state],
34+
},
35+
]
36+
serialised_response = json.dumps(response).encode()
37+
38+
# Send data to the parser
39+
parser.write(serialised_response[:100])
40+
parser.write(serialised_response[100:])
41+
42+
# Retrieve the parsed SendJoinResponse
43+
response = parser.finish()
44+
45+
# Sanity check the parsing gave us sensible data.
46+
self.assertEqual(len(response.auth_events), 1, response)
47+
self.assertEqual(len(response.state), 1, response)
48+
self.assertEqual(response.event_dict, {}, response)
49+
self.assertIsNone(response.event, response)

0 commit comments

Comments
 (0)