mirror of
https://mau.dev/maunium/synapse.git
synced 2024-10-01 01:36:05 -04:00
Support handling registration requests across multiple client readers. (#7830)
This commit is contained in:
parent
504c8f3483
commit
457096e6df
1
changelog.d/7830.feature
Normal file
1
changelog.d/7830.feature
Normal file
@ -0,0 +1 @@
|
|||||||
|
Add support for handling registration requests across multiple client reader workers.
|
@ -40,7 +40,8 @@ class DeactivateAccountHandler(BaseHandler):
|
|||||||
|
|
||||||
# Start the user parter loop so it can resume parting users from rooms where
|
# Start the user parter loop so it can resume parting users from rooms where
|
||||||
# it left off (if it has work left to do).
|
# it left off (if it has work left to do).
|
||||||
hs.get_reactor().callWhenRunning(self._start_user_parting)
|
if hs.config.worker_app is None:
|
||||||
|
hs.get_reactor().callWhenRunning(self._start_user_parting)
|
||||||
|
|
||||||
self._account_validity_enabled = hs.config.account_validity.enabled
|
self._account_validity_enabled = hs.config.account_validity.enabled
|
||||||
|
|
||||||
|
133
tests/replication/test_client_reader_shard.py
Normal file
133
tests/replication/test_client_reader_shard.py
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright 2020 The Matrix.org Foundation C.I.C.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
import logging
|
||||||
|
|
||||||
|
from synapse.api.constants import LoginType
|
||||||
|
from synapse.app.generic_worker import GenericWorkerServer
|
||||||
|
from synapse.http.server import JsonResource
|
||||||
|
from synapse.http.site import SynapseRequest
|
||||||
|
from synapse.replication.tcp.resource import ReplicationStreamProtocolFactory
|
||||||
|
from synapse.rest.client.v2_alpha import register
|
||||||
|
|
||||||
|
from tests import unittest
|
||||||
|
from tests.rest.client.v2_alpha.test_auth import DummyRecaptchaChecker
|
||||||
|
from tests.server import FakeChannel, render
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class ClientReaderTestCase(unittest.HomeserverTestCase):
|
||||||
|
"""Base class for tests of the replication streams"""
|
||||||
|
|
||||||
|
servlets = [
|
||||||
|
register.register_servlets,
|
||||||
|
]
|
||||||
|
|
||||||
|
def prepare(self, reactor, clock, hs):
|
||||||
|
# build a replication server
|
||||||
|
self.server_factory = ReplicationStreamProtocolFactory(hs)
|
||||||
|
self.streamer = hs.get_replication_streamer()
|
||||||
|
|
||||||
|
store = hs.get_datastore()
|
||||||
|
self.database = store.db
|
||||||
|
|
||||||
|
self.recaptcha_checker = DummyRecaptchaChecker(hs)
|
||||||
|
auth_handler = hs.get_auth_handler()
|
||||||
|
auth_handler.checkers[LoginType.RECAPTCHA] = self.recaptcha_checker
|
||||||
|
|
||||||
|
self.reactor.lookups["testserv"] = "1.2.3.4"
|
||||||
|
|
||||||
|
def make_worker_hs(self, extra_config={}):
|
||||||
|
config = self._get_worker_hs_config()
|
||||||
|
config.update(extra_config)
|
||||||
|
|
||||||
|
worker_hs = self.setup_test_homeserver(
|
||||||
|
homeserverToUse=GenericWorkerServer, config=config, reactor=self.reactor,
|
||||||
|
)
|
||||||
|
|
||||||
|
store = worker_hs.get_datastore()
|
||||||
|
store.db._db_pool = self.database._db_pool
|
||||||
|
|
||||||
|
# Register the expected servlets, essentially this is HomeserverTestCase.create_test_json_resource.
|
||||||
|
resource = JsonResource(self.hs)
|
||||||
|
|
||||||
|
for servlet in self.servlets:
|
||||||
|
servlet(worker_hs, resource)
|
||||||
|
|
||||||
|
# Essentially HomeserverTestCase.render.
|
||||||
|
def _render(request):
|
||||||
|
render(request, self.resource, self.reactor)
|
||||||
|
|
||||||
|
return worker_hs, _render
|
||||||
|
|
||||||
|
def _get_worker_hs_config(self) -> dict:
|
||||||
|
config = self.default_config()
|
||||||
|
config["worker_app"] = "synapse.app.client_reader"
|
||||||
|
config["worker_replication_host"] = "testserv"
|
||||||
|
config["worker_replication_http_port"] = "8765"
|
||||||
|
return config
|
||||||
|
|
||||||
|
def test_register_single_worker(self):
|
||||||
|
"""Test that registration works when using a single client reader worker.
|
||||||
|
"""
|
||||||
|
_, worker_render = self.make_worker_hs()
|
||||||
|
|
||||||
|
request_1, channel_1 = self.make_request(
|
||||||
|
"POST",
|
||||||
|
"register",
|
||||||
|
{"username": "user", "type": "m.login.password", "password": "bar"},
|
||||||
|
) # type: SynapseRequest, FakeChannel
|
||||||
|
worker_render(request_1)
|
||||||
|
self.assertEqual(request_1.code, 401)
|
||||||
|
|
||||||
|
# Grab the session
|
||||||
|
session = channel_1.json_body["session"]
|
||||||
|
|
||||||
|
# also complete the dummy auth
|
||||||
|
request_2, channel_2 = self.make_request(
|
||||||
|
"POST", "register", {"auth": {"session": session, "type": "m.login.dummy"}}
|
||||||
|
) # type: SynapseRequest, FakeChannel
|
||||||
|
worker_render(request_2)
|
||||||
|
self.assertEqual(request_2.code, 200)
|
||||||
|
|
||||||
|
# We're given a registered user.
|
||||||
|
self.assertEqual(channel_2.json_body["user_id"], "@user:test")
|
||||||
|
|
||||||
|
def test_register_multi_worker(self):
|
||||||
|
"""Test that registration works when using multiple client reader workers.
|
||||||
|
"""
|
||||||
|
_, worker_render_1 = self.make_worker_hs()
|
||||||
|
_, worker_render_2 = self.make_worker_hs()
|
||||||
|
|
||||||
|
request_1, channel_1 = self.make_request(
|
||||||
|
"POST",
|
||||||
|
"register",
|
||||||
|
{"username": "user", "type": "m.login.password", "password": "bar"},
|
||||||
|
) # type: SynapseRequest, FakeChannel
|
||||||
|
worker_render_1(request_1)
|
||||||
|
self.assertEqual(request_1.code, 401)
|
||||||
|
|
||||||
|
# Grab the session
|
||||||
|
session = channel_1.json_body["session"]
|
||||||
|
|
||||||
|
# also complete the dummy auth
|
||||||
|
request_2, channel_2 = self.make_request(
|
||||||
|
"POST", "register", {"auth": {"session": session, "type": "m.login.dummy"}}
|
||||||
|
) # type: SynapseRequest, FakeChannel
|
||||||
|
worker_render_2(request_2)
|
||||||
|
self.assertEqual(request_2.code, 200)
|
||||||
|
|
||||||
|
# We're given a registered user.
|
||||||
|
self.assertEqual(channel_2.json_body["user_id"], "@user:test")
|
Loading…
Reference in New Issue
Block a user