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

Remove unused test code. #12291

Merged
merged 4 commits into from
Mar 24, 2022
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions changelog.d/12291.misc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Remove unused test utilities.
105 changes: 0 additions & 105 deletions tests/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -187,111 +187,6 @@ def getRawHeaders(name, default=None):
return getRawHeaders


# This is a mock /resource/ not an entire server
class MockHttpResource:
def __init__(self, prefix=""):
self.callbacks = [] # 3-tuple of method/pattern/function
self.prefix = prefix

def trigger_get(self, path):
return self.trigger(b"GET", path, None)

@patch("twisted.web.http.Request")
@defer.inlineCallbacks
def trigger(
self, http_method, path, content, mock_request, federation_auth_origin=None
):
"""Fire an HTTP event.

Args:
http_method : The HTTP method
path : The HTTP path
content : The HTTP body
mock_request : Mocked request to pass to the event so it can get
content.
federation_auth_origin (bytes|None): domain to authenticate as, for federation
Returns:
A tuple of (code, response)
Raises:
KeyError If no event is found which will handle the path.
"""
path = self.prefix + path

# annoyingly we return a twisted http request which has chained calls
# to get at the http content, hence mock it here.
mock_content = Mock()
config = {"read.return_value": content}
mock_content.configure_mock(**config)
mock_request.content = mock_content

mock_request.method = http_method.encode("ascii")
mock_request.uri = path.encode("ascii")

mock_request.getClientIP.return_value = "-"

headers = {}
if federation_auth_origin is not None:
headers[b"Authorization"] = [
b"X-Matrix origin=%s,key=,sig=" % (federation_auth_origin,)
]
mock_request.requestHeaders.getRawHeaders = mock_getRawHeaders(headers)

# return the right path if the event requires it
mock_request.path = path

# add in query params to the right place
try:
mock_request.args = urlparse.parse_qs(path.split("?")[1])
mock_request.path = path.split("?")[0]
path = mock_request.path
except Exception:
pass

if isinstance(path, bytes):
path = path.decode("utf8")

for (method, pattern, func) in self.callbacks:
if http_method != method:
continue

matcher = pattern.match(path)
if matcher:
try:
args = [urlparse.unquote(u) for u in matcher.groups()]

(code, response) = yield defer.ensureDeferred(
func(mock_request, *args)
)
return code, response
except CodeMessageException as e:
return e.code, cs_error(e.msg, code=e.errcode)

raise KeyError("No event can handle %s" % path)

def register_paths(self, method, path_patterns, callback, servlet_name):
for path_pattern in path_patterns:
self.callbacks.append((method, path_pattern, callback))


class MockKey:
alg = "mock_alg"
version = "mock_version"
signature = b"\x9a\x87$"

@property
def verify_key(self):
return self

def sign(self, message):
return self

def verify(self, message, sig):
assert sig == b"\x9a\x87$"

def encode(self):
return b"<fake_encoded_key>"


class MockClock:
now = 1000

Expand Down