mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-06-19 08:04:07 -04:00
Fix client reader sharding tests (#7853)
* Fix client reader sharding tests * Newsfile * Fix typing * Update changelog.d/7853.misc Co-authored-by: Patrick Cloke <clokep@users.noreply.github.com> * Move mocking of http_client to tests Co-authored-by: Patrick Cloke <clokep@users.noreply.github.com>
This commit is contained in:
parent
b11450dedc
commit
f13061d515
7 changed files with 302 additions and 176 deletions
|
@ -15,63 +15,26 @@
|
|||
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.replication._base import BaseMultiWorkerStreamTestCase
|
||||
from tests.rest.client.v2_alpha.test_auth import DummyRecaptchaChecker
|
||||
from tests.server import FakeChannel, render
|
||||
from tests.server import FakeChannel
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class ClientReaderTestCase(unittest.HomeserverTestCase):
|
||||
class ClientReaderTestCase(BaseMultiWorkerStreamTestCase):
|
||||
"""Base class for tests of the replication streams"""
|
||||
|
||||
servlets = [
|
||||
register.register_servlets,
|
||||
]
|
||||
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"
|
||||
|
@ -82,14 +45,14 @@ class ClientReaderTestCase(unittest.HomeserverTestCase):
|
|||
def test_register_single_worker(self):
|
||||
"""Test that registration works when using a single client reader worker.
|
||||
"""
|
||||
_, worker_render = self.make_worker_hs()
|
||||
worker_hs = self.make_worker_hs("synapse.app.client_reader")
|
||||
|
||||
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.render_on_worker(worker_hs, request_1)
|
||||
self.assertEqual(request_1.code, 401)
|
||||
|
||||
# Grab the session
|
||||
|
@ -99,7 +62,7 @@ class ClientReaderTestCase(unittest.HomeserverTestCase):
|
|||
request_2, channel_2 = self.make_request(
|
||||
"POST", "register", {"auth": {"session": session, "type": "m.login.dummy"}}
|
||||
) # type: SynapseRequest, FakeChannel
|
||||
worker_render(request_2)
|
||||
self.render_on_worker(worker_hs, request_2)
|
||||
self.assertEqual(request_2.code, 200)
|
||||
|
||||
# We're given a registered user.
|
||||
|
@ -108,15 +71,15 @@ class ClientReaderTestCase(unittest.HomeserverTestCase):
|
|||
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()
|
||||
worker_hs_1 = self.make_worker_hs("synapse.app.client_reader")
|
||||
worker_hs_2 = self.make_worker_hs("synapse.app.client_reader")
|
||||
|
||||
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.render_on_worker(worker_hs_1, request_1)
|
||||
self.assertEqual(request_1.code, 401)
|
||||
|
||||
# Grab the session
|
||||
|
@ -126,7 +89,7 @@ class ClientReaderTestCase(unittest.HomeserverTestCase):
|
|||
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.render_on_worker(worker_hs_2, request_2)
|
||||
self.assertEqual(request_2.code, 200)
|
||||
|
||||
# We're given a registered user.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue