This repository has been archived by the owner on Apr 26, 2024. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Synapse 1.69.0rc2 (2022-10-06) ============================== Please note that legacy Prometheus metric names are now deprecated and will be removed in Synapse 1.73.0. Server administrators should update their dashboards and alerting rules to avoid using the deprecated metric names. See the [upgrade notes](https://matrix-org.github.io/synapse/v1.69/upgrade.html#upgrading-to-v1690) for more details. Deprecations and Removals ------------------------- - Deprecate the `generate_short_term_login_token` method in favor of an async `create_login_token` method in the Module API. ([\#13842](#13842)) Internal Changes ---------------- - Ensure Synapse v1.69 works with upcoming database changes in v1.70. ([\#14045](#14045)) - Fix a bug introduced in Synapse v1.68.0 where messages could not be sent in rooms with non-integer `notifications` power level. ([\#14073](#14073)) - Temporarily pin build-system requirements to workaround an incompatibility with poetry-core 1.3.0. This will be reverted before the v1.69.0 release proper, see [\#14079](#14079). ([\#14080](#14080))
- Loading branch information
Showing
8 changed files
with
186 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
from unittest.mock import patch | ||
|
||
from synapse.api.room_versions import RoomVersions | ||
from synapse.push.bulk_push_rule_evaluator import BulkPushRuleEvaluator | ||
from synapse.rest import admin | ||
from synapse.rest.client import login, register, room | ||
from synapse.types import create_requester | ||
|
||
from tests import unittest | ||
|
||
|
||
class TestBulkPushRuleEvaluator(unittest.HomeserverTestCase): | ||
|
||
servlets = [ | ||
admin.register_servlets_for_client_rest_resource, | ||
room.register_servlets, | ||
login.register_servlets, | ||
register.register_servlets, | ||
] | ||
|
||
def test_action_for_event_by_user_handles_noninteger_power_levels(self) -> None: | ||
"""We should convert floats and strings to integers before passing to Rust. | ||
Reproduces #14060. | ||
A lack of validation: the gift that keeps on giving. | ||
""" | ||
# Create a new user and room. | ||
alice = self.register_user("alice", "pass") | ||
token = self.login(alice, "pass") | ||
|
||
room_id = self.helper.create_room_as( | ||
alice, room_version=RoomVersions.V9.identifier, tok=token | ||
) | ||
|
||
# Alter the power levels in that room to include stringy and floaty levels. | ||
# We need to suppress the validation logic or else it will reject these dodgy | ||
# values. (Presumably this validation was not always present.) | ||
event_creation_handler = self.hs.get_event_creation_handler() | ||
requester = create_requester(alice) | ||
with patch("synapse.events.validator.validate_canonicaljson"), patch( | ||
"synapse.events.validator.jsonschema.validate" | ||
): | ||
self.helper.send_state( | ||
room_id, | ||
"m.room.power_levels", | ||
{ | ||
"users": {alice: "100"}, # stringy | ||
"notifications": {"room": 100.0}, # float | ||
}, | ||
token, | ||
state_key="", | ||
) | ||
|
||
# Create a new message event, and try to evaluate it under the dodgy | ||
# power level event. | ||
event, context = self.get_success( | ||
event_creation_handler.create_event( | ||
requester, | ||
{ | ||
"type": "m.room.message", | ||
"room_id": room_id, | ||
"content": { | ||
"msgtype": "m.text", | ||
"body": "helo", | ||
}, | ||
"sender": alice, | ||
}, | ||
) | ||
) | ||
|
||
bulk_evaluator = BulkPushRuleEvaluator(self.hs) | ||
# should not raise | ||
self.get_success(bulk_evaluator.action_for_event_by_user(event, context)) |