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

Add type hints for tests/unittest.py. #12347

Merged
merged 9 commits into from
Apr 1, 2022
Merged
Show file tree
Hide file tree
Changes from all 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/12347.misc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add type annotations for `tests/unittest.py`.
1 change: 0 additions & 1 deletion mypy.ini
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,6 @@ exclude = (?x)
|tests/test_server.py
|tests/test_state.py
|tests/test_terms_auth.py
|tests/unittest.py
|tests/util/caches/test_cached_call.py
|tests/util/caches/test_deferred_cache.py
|tests/util/caches/test_descriptors.py
Expand Down
6 changes: 4 additions & 2 deletions tests/handlers/test_e2e_keys.py
Original file line number Diff line number Diff line change
Expand Up @@ -463,8 +463,10 @@ def test_self_signing_key_doesnt_show_up_as_device(self) -> None:
res = e.value.code
self.assertEqual(res, 400)

res = self.get_success(self.handler.query_local_devices({local_user: None}))
self.assertDictEqual(res, {local_user: {}})
query_res = self.get_success(
self.handler.query_local_devices({local_user: None})
)
self.assertDictEqual(query_res, {local_user: {}})

def test_upload_signatures(self) -> None:
"""should check signatures that are uploaded"""
Expand Down
5 changes: 3 additions & 2 deletions tests/handlers/test_federation.py
Original file line number Diff line number Diff line change
Expand Up @@ -375,7 +375,8 @@ def test_backfill_floating_outlier_membership_auth(self) -> None:
member_event.signatures = member_event_dict["signatures"]

# Add the new member_event to the StateMap
prev_state_map[
updated_state_map = dict(prev_state_map)
updated_state_map[
(member_event.type, member_event.state_key)
] = member_event.event_id
auth_events.append(member_event)
Expand All @@ -399,7 +400,7 @@ def test_backfill_floating_outlier_membership_auth(self) -> None:
prev_event_ids=message_event_dict["prev_events"],
auth_event_ids=self._event_auth_handler.compute_auth_events(
builder,
prev_state_map,
updated_state_map,
for_verification=False,
),
depth=message_event_dict["depth"],
Expand Down
7 changes: 4 additions & 3 deletions tests/handlers/test_oidc.py
Original file line number Diff line number Diff line change
Expand Up @@ -354,10 +354,11 @@ def test_redirect_request(self) -> None:
req = Mock(spec=["cookies"])
req.cookies = []

url = self.get_success(
self.provider.handle_redirect_request(req, b"http://client/redirect")
url = urlparse(
self.get_success(
self.provider.handle_redirect_request(req, b"http://client/redirect")
)
)
url = urlparse(url)
auth_endpoint = urlparse(AUTHORIZATION_ENDPOINT)

self.assertEqual(url.scheme, auth_endpoint.scheme)
Expand Down
2 changes: 2 additions & 0 deletions tests/handlers/test_user_directory.py
Original file line number Diff line number Diff line change
Expand Up @@ -351,6 +351,7 @@ def test_handle_local_profile_change_with_support_user(self) -> None:
self.handler.handle_local_profile_change(regular_user_id, profile_info)
)
profile = self.get_success(self.store.get_user_in_directory(regular_user_id))
assert profile is not None
self.assertTrue(profile["display_name"] == display_name)

def test_handle_local_profile_change_with_deactivated_user(self) -> None:
Expand All @@ -369,6 +370,7 @@ def test_handle_local_profile_change_with_deactivated_user(self) -> None:

# profile is in directory
profile = self.get_success(self.store.get_user_in_directory(r_user_id))
assert profile is not None
self.assertTrue(profile["display_name"] == display_name)

# deactivate user
Expand Down
8 changes: 8 additions & 0 deletions tests/rest/admin/test_media.py
Original file line number Diff line number Diff line change
Expand Up @@ -702,6 +702,7 @@ def test_quarantine_media(self) -> None:
"""

media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertFalse(media_info["quarantined_by"])

# quarantining
Expand All @@ -715,6 +716,7 @@ def test_quarantine_media(self) -> None:
self.assertFalse(channel.json_body)

media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertTrue(media_info["quarantined_by"])

# remove from quarantine
Expand All @@ -728,6 +730,7 @@ def test_quarantine_media(self) -> None:
self.assertFalse(channel.json_body)

media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertFalse(media_info["quarantined_by"])

def test_quarantine_protected_media(self) -> None:
Expand All @@ -740,6 +743,7 @@ def test_quarantine_protected_media(self) -> None:

# verify protection
media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertTrue(media_info["safe_from_quarantine"])

# quarantining
Expand All @@ -754,6 +758,7 @@ def test_quarantine_protected_media(self) -> None:

# verify that is not in quarantine
media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertFalse(media_info["quarantined_by"])


Expand Down Expand Up @@ -830,6 +835,7 @@ def test_protect_media(self) -> None:
"""

media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertFalse(media_info["safe_from_quarantine"])

# protect
Expand All @@ -843,6 +849,7 @@ def test_protect_media(self) -> None:
self.assertFalse(channel.json_body)

media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertTrue(media_info["safe_from_quarantine"])

# unprotect
Expand All @@ -856,6 +863,7 @@ def test_protect_media(self) -> None:
self.assertFalse(channel.json_body)

media_info = self.get_success(self.store.get_local_media(self.media_id))
assert media_info is not None
self.assertFalse(media_info["safe_from_quarantine"])


Expand Down
15 changes: 9 additions & 6 deletions tests/rest/admin/test_user.py
Original file line number Diff line number Diff line change
Expand Up @@ -1590,10 +1590,9 @@ def test_create_user_email_notif_for_new_users(self) -> None:
self.assertEqual("email", channel.json_body["threepids"][0]["medium"])
self.assertEqual("bob@bob.bob", channel.json_body["threepids"][0]["address"])

pushers = self.get_success(
self.store.get_pushers_by({"user_name": "@bob:test"})
pushers = list(
self.get_success(self.store.get_pushers_by({"user_name": "@bob:test"}))
)
pushers = list(pushers)
self.assertEqual(len(pushers), 1)
self.assertEqual("@bob:test", pushers[0].user_name)

Expand Down Expand Up @@ -1632,10 +1631,9 @@ def test_create_user_email_no_notif_for_new_users(self) -> None:
self.assertEqual("email", channel.json_body["threepids"][0]["medium"])
self.assertEqual("bob@bob.bob", channel.json_body["threepids"][0]["address"])

pushers = self.get_success(
self.store.get_pushers_by({"user_name": "@bob:test"})
pushers = list(
self.get_success(self.store.get_pushers_by({"user_name": "@bob:test"}))
)
pushers = list(pushers)
self.assertEqual(len(pushers), 0)

def test_set_password(self) -> None:
Expand Down Expand Up @@ -2144,6 +2142,7 @@ def test_change_name_deactivate_user_user_directory(self) -> None:

# is in user directory
profile = self.get_success(self.store.get_user_in_directory(self.other_user))
assert profile is not None
self.assertTrue(profile["display_name"] == "User")

# Deactivate user
Expand Down Expand Up @@ -2711,6 +2710,7 @@ def test_get_pushers(self) -> None:
user_tuple = self.get_success(
self.store.get_user_by_access_token(other_user_token)
)
assert user_tuple is not None
token_id = user_tuple.token_id

self.get_success(
Expand Down Expand Up @@ -3676,6 +3676,7 @@ def test_success(self) -> None:
# The user starts off as not shadow-banned.
other_user_token = self.login("user", "pass")
result = self.get_success(self.store.get_user_by_access_token(other_user_token))
assert result is not None
self.assertFalse(result.shadow_banned)

channel = self.make_request("POST", self.url, access_token=self.admin_user_tok)
Expand All @@ -3684,6 +3685,7 @@ def test_success(self) -> None:

# Ensure the user is shadow-banned (and the cache was cleared).
result = self.get_success(self.store.get_user_by_access_token(other_user_token))
assert result is not None
self.assertTrue(result.shadow_banned)

# Un-shadow-ban the user.
Expand All @@ -3695,6 +3697,7 @@ def test_success(self) -> None:

# Ensure the user is no longer shadow-banned (and the cache was cleared).
result = self.get_success(self.store.get_user_by_access_token(other_user_token))
assert result is not None
self.assertFalse(result.shadow_banned)


Expand Down
6 changes: 4 additions & 2 deletions tests/server.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@
from collections import deque
from io import SEEK_END, BytesIO
from typing import (
AnyStr,
Callable,
Dict,
Iterable,
Expand Down Expand Up @@ -86,6 +85,9 @@

logger = logging.getLogger(__name__)

# the type of thing that can be passed into `make_request` in the headers list
CustomHeaderType = Tuple[Union[str, bytes], Union[str, bytes]]


class TimedOutException(Exception):
"""
Expand Down Expand Up @@ -260,7 +262,7 @@ def make_request(
federation_auth_origin: Optional[bytes] = None,
content_is_form: bool = False,
await_result: bool = True,
custom_headers: Optional[Iterable[Tuple[AnyStr, AnyStr]]] = None,
custom_headers: Optional[Iterable[CustomHeaderType]] = None,
client_ip: str = "127.0.0.1",
) -> FakeChannel:
"""
Expand Down
8 changes: 4 additions & 4 deletions tests/storage/databases/main/test_lock.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ def test_simple_lock(self):
"""
# First to acquire this lock, so it should complete
lock = self.get_success(self.store.try_acquire_lock("name", "key"))
self.assertIsNotNone(lock)
assert lock is not None
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I find it quite annoying that mypy doesn't handle assertIs(Not)None the same way...

python/mypy#5088 for cross-refs.


# Enter the context manager
self.get_success(lock.__aenter__())
Expand All @@ -45,15 +45,15 @@ def test_simple_lock(self):

# We can now acquire the lock again.
lock3 = self.get_success(self.store.try_acquire_lock("name", "key"))
self.assertIsNotNone(lock3)
assert lock3 is not None
self.get_success(lock3.__aenter__())
self.get_success(lock3.__aexit__(None, None, None))

def test_maintain_lock(self):
"""Test that we don't time out locks while they're still active"""

lock = self.get_success(self.store.try_acquire_lock("name", "key"))
self.assertIsNotNone(lock)
assert lock is not None

self.get_success(lock.__aenter__())

Expand All @@ -69,7 +69,7 @@ def test_timeout_lock(self):
"""Test that we time out locks if they're not updated for ages"""

lock = self.get_success(self.store.try_acquire_lock("name", "key"))
self.assertIsNotNone(lock)
assert lock is not None

self.get_success(lock.__aenter__())

Expand Down
1 change: 1 addition & 0 deletions tests/storage/test_appservice.py
Original file line number Diff line number Diff line change
Expand Up @@ -358,6 +358,7 @@ def test_get_oldest_unsent_txn(self) -> None:
self.get_success(self._insert_txn(service.id, 12, other_events))

txn = self.get_success(self.store.get_oldest_unsent_txn(service))
assert txn is not None
self.assertEqual(service, txn.service)
self.assertEqual(10, txn.id)
self.assertEqual(events, txn.events)
Expand Down
Loading