summary refs log tree commit diff
diff options
context:
space:
mode:
authorPatrick Cloke <clokep@users.noreply.github.com>2023-08-22 09:08:24 -0400
committerGitHub <noreply@github.com>2023-08-22 09:08:24 -0400
commitb657e89005bc48e5e061d63ae35e12bf23b81d88 (patch)
tree1dc70503fd8ebd9843dc36fa99b126101eb053f6
parentRaise poetry-core version cap to 1.7.0 (#16152) (diff)
downloadsynapse-b657e89005bc48e5e061d63ae35e12bf23b81d88.tar.xz
Fix user directory test for deactivated support user. (#16157)
Support users should not be added to the user directory after
being deactivated.
-rw-r--r--changelog.d/16157.misc1
-rw-r--r--tests/handlers/test_user_directory.py19
2 files changed, 12 insertions, 8 deletions
diff --git a/changelog.d/16157.misc b/changelog.d/16157.misc
new file mode 100644

index 0000000000..c9d8999cca --- /dev/null +++ b/changelog.d/16157.misc
@@ -0,0 +1 @@ +Fix assertion in user directory unit tests. diff --git a/tests/handlers/test_user_directory.py b/tests/handlers/test_user_directory.py
index 9785dd698b..430209705e 100644 --- a/tests/handlers/test_user_directory.py +++ b/tests/handlers/test_user_directory.py
@@ -446,6 +446,7 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase): self.assertIsNone(profile) def test_handle_user_deactivated_support_user(self) -> None: + """Ensure a support user doesn't get added to the user directory after deactivation.""" s_user_id = "@support:test" self.get_success( self.store.register_user( @@ -453,14 +454,16 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase): ) ) - mock_remove_from_user_dir = Mock(return_value=make_awaitable(None)) - with patch.object( - self.store, "remove_from_user_dir", mock_remove_from_user_dir - ): - self.get_success(self.handler.handle_local_user_deactivated(s_user_id)) - # BUG: the correct spelling is assert_not_called, but that makes the test fail - # and it's not clear that this is actually the behaviour we want. - mock_remove_from_user_dir.not_called() + # The profile should not be in the directory. + profile = self.get_success(self.store._get_user_in_directory(s_user_id)) + self.assertIsNone(profile) + + # Remove the user from the directory. + self.get_success(self.handler.handle_local_user_deactivated(s_user_id)) + + # The profile should still not be in the user directory. + profile = self.get_success(self.store._get_user_in_directory(s_user_id)) + self.assertIsNone(profile) def test_handle_user_deactivated_regular_user(self) -> None: r_user_id = "@regular:test"