2020-04-29 14:30:36 +03:00
|
|
|
#
|
2023-11-21 23:29:58 +03:00
|
|
|
# This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
|
|
#
|
2024-01-23 14:26:48 +03:00
|
|
|
# Copyright 2020 The Matrix.org Foundation C.I.C
|
2023-11-21 23:29:58 +03:00
|
|
|
# Copyright (C) 2023 New Vector, Ltd
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as
|
|
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
|
|
# License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# See the GNU Affero General Public License for more details:
|
|
|
|
# <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
|
|
#
|
|
|
|
# Originally licensed under the Apache License, Version 2.0:
|
|
|
|
# <http://www.apache.org/licenses/LICENSE-2.0>.
|
|
|
|
#
|
|
|
|
# [This file includes modifications made by New Vector Limited]
|
2020-04-29 14:30:36 +03:00
|
|
|
#
|
|
|
|
#
|
2023-02-09 00:29:49 +03:00
|
|
|
from typing import Any, List, Optional, Tuple
|
2020-04-29 14:30:36 +03:00
|
|
|
|
|
|
|
import synapse.server
|
|
|
|
from synapse.api.constants import EventTypes
|
|
|
|
from synapse.api.room_versions import KNOWN_ROOM_VERSIONS
|
|
|
|
from synapse.events import EventBase
|
2020-05-05 16:17:27 +03:00
|
|
|
from synapse.events.snapshot import EventContext
|
2020-04-29 14:30:36 +03:00
|
|
|
|
|
|
|
"""
|
|
|
|
Utility functions for poking events into the storage of the server under test.
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
2020-07-22 19:29:15 +03:00
|
|
|
async def inject_member_event(
|
2020-04-29 14:30:36 +03:00
|
|
|
hs: synapse.server.HomeServer,
|
|
|
|
room_id: str,
|
|
|
|
sender: str,
|
|
|
|
membership: str,
|
|
|
|
target: Optional[str] = None,
|
|
|
|
extra_content: Optional[dict] = None,
|
2023-02-09 00:29:49 +03:00
|
|
|
**kwargs: Any,
|
2020-04-29 14:30:36 +03:00
|
|
|
) -> EventBase:
|
|
|
|
"""Inject a membership event into a room."""
|
|
|
|
if target is None:
|
|
|
|
target = sender
|
|
|
|
|
|
|
|
content = {"membership": membership}
|
|
|
|
if extra_content:
|
|
|
|
content.update(extra_content)
|
|
|
|
|
2020-07-22 19:29:15 +03:00
|
|
|
return await inject_event(
|
2020-04-29 14:30:36 +03:00
|
|
|
hs,
|
|
|
|
room_id=room_id,
|
|
|
|
type=EventTypes.Member,
|
|
|
|
sender=sender,
|
|
|
|
state_key=target,
|
|
|
|
content=content,
|
|
|
|
**kwargs,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2020-07-22 19:29:15 +03:00
|
|
|
async def inject_event(
|
2020-04-29 14:30:36 +03:00
|
|
|
hs: synapse.server.HomeServer,
|
|
|
|
room_version: Optional[str] = None,
|
2020-09-01 15:39:04 +03:00
|
|
|
prev_event_ids: Optional[List[str]] = None,
|
2023-02-09 00:29:49 +03:00
|
|
|
**kwargs: Any,
|
2020-04-29 14:30:36 +03:00
|
|
|
) -> EventBase:
|
|
|
|
"""Inject a generic event into a room
|
|
|
|
|
|
|
|
Args:
|
|
|
|
hs: the homeserver under test
|
|
|
|
room_version: the version of the room we're inserting into.
|
|
|
|
if not specified, will be looked up
|
|
|
|
prev_event_ids: prev_events for the event. If not specified, will be looked up
|
|
|
|
kwargs: fields for the event to be created
|
|
|
|
"""
|
2020-07-22 19:29:15 +03:00
|
|
|
event, context = await create_event(hs, room_version, prev_event_ids, **kwargs)
|
2020-05-05 16:17:27 +03:00
|
|
|
|
2022-05-31 15:17:50 +03:00
|
|
|
persistence = hs.get_storage_controllers().persistence
|
2020-09-11 14:22:55 +03:00
|
|
|
assert persistence is not None
|
|
|
|
|
|
|
|
await persistence.persist_event(event, context)
|
2020-05-05 16:17:27 +03:00
|
|
|
|
|
|
|
return event
|
|
|
|
|
|
|
|
|
2020-07-22 19:29:15 +03:00
|
|
|
async def create_event(
|
2020-05-05 16:17:27 +03:00
|
|
|
hs: synapse.server.HomeServer,
|
|
|
|
room_version: Optional[str] = None,
|
2020-09-01 15:39:04 +03:00
|
|
|
prev_event_ids: Optional[List[str]] = None,
|
2023-02-09 00:29:49 +03:00
|
|
|
**kwargs: Any,
|
2020-05-05 16:17:27 +03:00
|
|
|
) -> Tuple[EventBase, EventContext]:
|
2020-04-29 14:30:36 +03:00
|
|
|
if room_version is None:
|
2022-02-23 14:04:02 +03:00
|
|
|
room_version = await hs.get_datastores().main.get_room_version_id(
|
|
|
|
kwargs["room_id"]
|
|
|
|
)
|
2020-04-29 14:30:36 +03:00
|
|
|
|
|
|
|
builder = hs.get_event_builder_factory().for_room_version(
|
|
|
|
KNOWN_ROOM_VERSIONS[room_version], kwargs
|
|
|
|
)
|
2023-02-10 00:05:02 +03:00
|
|
|
(
|
|
|
|
event,
|
|
|
|
unpersisted_context,
|
|
|
|
) = await hs.get_event_creation_handler().create_new_client_event(
|
2020-04-29 14:30:36 +03:00
|
|
|
builder, prev_event_ids=prev_event_ids
|
|
|
|
)
|
|
|
|
|
2023-02-10 00:05:02 +03:00
|
|
|
context = await unpersisted_context.persist(event)
|
|
|
|
|
2020-05-05 16:17:27 +03:00
|
|
|
return event, context
|
2023-03-13 15:31:19 +03:00
|
|
|
|
|
|
|
|
|
|
|
async def mark_event_as_partial_state(
|
|
|
|
hs: synapse.server.HomeServer,
|
|
|
|
event_id: str,
|
|
|
|
room_id: str,
|
|
|
|
) -> None:
|
|
|
|
"""
|
|
|
|
(Falsely) mark an event as having partial state.
|
|
|
|
|
|
|
|
Naughty, but occasionally useful when checking that partial state doesn't
|
|
|
|
block something from happening.
|
|
|
|
|
|
|
|
If the event already has partial state, this insert will fail (event_id is unique
|
|
|
|
in this table).
|
|
|
|
"""
|
|
|
|
store = hs.get_datastores().main
|
2024-07-04 20:25:36 +03:00
|
|
|
# Use the store helper to insert into the database so the caches are busted
|
|
|
|
await store.store_partial_state_room(
|
|
|
|
room_id=room_id,
|
|
|
|
servers={hs.hostname},
|
|
|
|
device_lists_stream_id=0,
|
|
|
|
joined_via=hs.hostname,
|
2023-03-13 15:31:19 +03:00
|
|
|
)
|
|
|
|
|
2024-07-04 20:25:36 +03:00
|
|
|
# FIXME: Bust the cache
|
2023-03-13 15:31:19 +03:00
|
|
|
await store.db_pool.simple_insert(
|
|
|
|
table="partial_state_events",
|
|
|
|
values={
|
|
|
|
"room_id": room_id,
|
|
|
|
"event_id": event_id,
|
|
|
|
},
|
|
|
|
)
|