mirror of
https://github.com/zulip/zulip.git
synced 2025-11-03 13:33:24 +00:00
create_user: Use transaction.atomic decorator for do_create_user.
We change the do_create_user function to use transaction.atomic decorator instead of using with block. Due to this change, all send_event calls are made inside transaction.on_commit. Some other changes - - Remove transaction.atomic decorator from send_inital_realm_messages since it is now called inside a transaction. - Made changes in tests which tests message events and notifications to make sure on_commit callbacks are executed.
This commit is contained in:
@@ -1,7 +1,6 @@
|
||||
from typing import Dict, List
|
||||
|
||||
from django.conf import settings
|
||||
from django.db import transaction
|
||||
from django.db.models import Count
|
||||
from django.utils.translation import gettext as _
|
||||
from django.utils.translation import override as override_language
|
||||
@@ -230,7 +229,6 @@ def send_welcome_bot_response(send_request: SendMessageRequest) -> None:
|
||||
)
|
||||
|
||||
|
||||
@transaction.atomic
|
||||
def send_initial_realm_messages(realm: Realm) -> None:
|
||||
welcome_bot = get_system_bot(settings.WELCOME_BOT, realm.id)
|
||||
# Make sure each stream created in the realm creation process has at least one message below
|
||||
|
||||
@@ -5,7 +5,7 @@ import shutil
|
||||
import subprocess
|
||||
import tempfile
|
||||
import urllib
|
||||
from contextlib import contextmanager
|
||||
from contextlib import contextmanager, nullcontext
|
||||
from datetime import timedelta
|
||||
from typing import (
|
||||
TYPE_CHECKING,
|
||||
@@ -967,18 +967,22 @@ Output:
|
||||
to_user: UserProfile,
|
||||
content: str = "test content",
|
||||
sending_client_name: str = "test suite",
|
||||
capture_on_commit_callbacks: bool = True,
|
||||
) -> int:
|
||||
recipient_list = [to_user.id]
|
||||
(sending_client, _) = Client.objects.get_or_create(name=sending_client_name)
|
||||
|
||||
return check_send_message(
|
||||
from_user,
|
||||
sending_client,
|
||||
"private",
|
||||
recipient_list,
|
||||
None,
|
||||
content,
|
||||
)
|
||||
with self.captureOnCommitCallbacks(
|
||||
execute=True
|
||||
) if capture_on_commit_callbacks else nullcontext():
|
||||
return check_send_message(
|
||||
from_user,
|
||||
sending_client,
|
||||
"private",
|
||||
recipient_list,
|
||||
None,
|
||||
content,
|
||||
)
|
||||
|
||||
def send_huddle_message(
|
||||
self,
|
||||
@@ -986,20 +990,24 @@ Output:
|
||||
to_users: List[UserProfile],
|
||||
content: str = "test content",
|
||||
sending_client_name: str = "test suite",
|
||||
capture_on_commit_callbacks: bool = True,
|
||||
) -> int:
|
||||
to_user_ids = [u.id for u in to_users]
|
||||
assert len(to_user_ids) >= 2
|
||||
|
||||
(sending_client, _) = Client.objects.get_or_create(name=sending_client_name)
|
||||
|
||||
return check_send_message(
|
||||
from_user,
|
||||
sending_client,
|
||||
"private",
|
||||
to_user_ids,
|
||||
None,
|
||||
content,
|
||||
)
|
||||
with self.captureOnCommitCallbacks(
|
||||
execute=True
|
||||
) if capture_on_commit_callbacks else nullcontext():
|
||||
return check_send_message(
|
||||
from_user,
|
||||
sending_client,
|
||||
"private",
|
||||
to_user_ids,
|
||||
None,
|
||||
content,
|
||||
)
|
||||
|
||||
def send_stream_message(
|
||||
self,
|
||||
@@ -1010,17 +1018,21 @@ Output:
|
||||
recipient_realm: Optional[Realm] = None,
|
||||
sending_client_name: str = "test suite",
|
||||
allow_unsubscribed_sender: bool = False,
|
||||
capture_on_commit_callbacks: bool = True,
|
||||
) -> int:
|
||||
(sending_client, _) = Client.objects.get_or_create(name=sending_client_name)
|
||||
|
||||
message_id = check_send_stream_message(
|
||||
sender=sender,
|
||||
client=sending_client,
|
||||
stream_name=stream_name,
|
||||
topic=topic_name,
|
||||
body=content,
|
||||
realm=recipient_realm,
|
||||
)
|
||||
with self.captureOnCommitCallbacks(
|
||||
execute=True
|
||||
) if capture_on_commit_callbacks else nullcontext():
|
||||
message_id = check_send_stream_message(
|
||||
sender=sender,
|
||||
client=sending_client,
|
||||
stream_name=stream_name,
|
||||
topic=topic_name,
|
||||
body=content,
|
||||
realm=recipient_realm,
|
||||
)
|
||||
if (
|
||||
not UserMessage.objects.filter(user_profile=sender, message_id=message_id).exists()
|
||||
and not sender.is_bot
|
||||
|
||||
Reference in New Issue
Block a user