2017-02-09 22:58:43 +01:00
|
|
|
import glob
|
2018-01-26 21:12:58 +01:00
|
|
|
import os
|
|
|
|
import re
|
2017-02-09 22:58:43 +01:00
|
|
|
from datetime import timedelta
|
2018-08-23 11:02:47 +02:00
|
|
|
from email.utils import parseaddr
|
2020-06-11 00:54:34 +02:00
|
|
|
from typing import Any, Dict, List, Optional
|
2020-05-26 07:16:25 +02:00
|
|
|
from unittest import mock
|
2020-06-11 00:54:34 +02:00
|
|
|
from unittest.mock import MagicMock, call, patch
|
2017-02-09 22:58:43 +01:00
|
|
|
|
2016-04-14 23:39:37 +02:00
|
|
|
from django.conf import settings
|
|
|
|
from django.core.management import call_command
|
2018-01-26 21:15:51 +01:00
|
|
|
from django.test import TestCase, override_settings
|
2019-05-10 14:28:38 +02:00
|
|
|
from django.utils.timezone import now as timezone_now
|
2018-01-22 21:50:22 +01:00
|
|
|
|
2016-06-22 21:16:02 +02:00
|
|
|
from confirmation.models import RealmCreationKey, generate_realm_creation_url
|
2020-06-11 00:54:34 +02:00
|
|
|
from zerver.lib.actions import do_add_reaction, do_create_user
|
|
|
|
from zerver.lib.management import CommandError, ZulipBaseCommand, check_config
|
|
|
|
from zerver.lib.test_classes import ZulipTestCase
|
|
|
|
from zerver.lib.test_helpers import most_recent_message, stdout_suppressed
|
|
|
|
from zerver.lib.test_runner import slow
|
|
|
|
from zerver.models import (
|
|
|
|
Message,
|
|
|
|
Reaction,
|
|
|
|
Realm,
|
|
|
|
Recipient,
|
|
|
|
UserProfile,
|
|
|
|
get_realm,
|
|
|
|
get_stream,
|
|
|
|
get_user_profile_by_email,
|
|
|
|
)
|
|
|
|
|
2017-02-09 22:58:43 +01:00
|
|
|
|
2018-05-04 01:04:12 +02:00
|
|
|
class TestCheckConfig(ZulipTestCase):
|
|
|
|
def test_check_config(self) -> None:
|
2020-06-08 03:24:49 +02:00
|
|
|
check_config()
|
2018-05-14 17:45:32 +02:00
|
|
|
with self.settings(REQUIRED_SETTINGS=[('asdf', 'not asdf')]):
|
|
|
|
with self.assertRaisesRegex(CommandError, "Error: You must set asdf in /etc/zulip/settings.py."):
|
|
|
|
check_config()
|
2018-05-04 01:04:12 +02:00
|
|
|
|
2018-05-14 21:01:48 +02:00
|
|
|
@override_settings(WARN_NO_EMAIL=True)
|
|
|
|
def test_check_send_email(self) -> None:
|
|
|
|
with self.assertRaisesRegex(CommandError, "Outgoing email not yet configured, see"):
|
|
|
|
call_command("send_test_email", 'test@example.com')
|
|
|
|
|
2017-07-07 20:35:31 +02:00
|
|
|
class TestZulipBaseCommand(ZulipTestCase):
|
2017-11-05 10:51:25 +01:00
|
|
|
def setUp(self) -> None:
|
2019-10-19 20:47:00 +02:00
|
|
|
super().setUp()
|
2017-08-19 21:00:19 +02:00
|
|
|
self.zulip_realm = get_realm("zulip")
|
2017-08-25 00:12:36 +02:00
|
|
|
self.command = ZulipBaseCommand()
|
2017-08-19 21:00:19 +02:00
|
|
|
|
2018-03-14 00:25:31 +01:00
|
|
|
def test_get_client(self) -> None:
|
|
|
|
self.assertEqual(self.command.get_client().name, "ZulipServer")
|
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_get_realm(self) -> None:
|
2017-08-25 00:12:36 +02:00
|
|
|
self.assertEqual(self.command.get_realm(dict(realm_id='zulip')), self.zulip_realm)
|
|
|
|
self.assertEqual(self.command.get_realm(dict(realm_id=None)), None)
|
2019-07-15 22:59:18 +02:00
|
|
|
self.assertEqual(self.command.get_realm(dict(realm_id=str(self.zulip_realm.id))),
|
|
|
|
self.zulip_realm)
|
2017-08-07 21:32:10 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, "There is no realm with id"):
|
2017-08-25 00:12:36 +02:00
|
|
|
self.command.get_realm(dict(realm_id='17'))
|
2017-08-07 21:32:10 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, "There is no realm with id"):
|
2017-08-25 00:12:36 +02:00
|
|
|
self.command.get_realm(dict(realm_id='mit'))
|
2017-07-07 20:35:31 +02:00
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_get_user(self) -> None:
|
2017-07-07 20:35:31 +02:00
|
|
|
mit_realm = get_realm("zephyr")
|
|
|
|
user_profile = self.example_user("hamlet")
|
2020-03-12 14:17:25 +01:00
|
|
|
email = user_profile.delivery_email
|
2017-07-07 20:35:31 +02:00
|
|
|
|
2017-08-25 00:12:36 +02:00
|
|
|
self.assertEqual(self.command.get_user(email, self.zulip_realm), user_profile)
|
|
|
|
self.assertEqual(self.command.get_user(email, None), user_profile)
|
|
|
|
|
2020-06-10 06:41:04 +02:00
|
|
|
error_message = f"The realm '{mit_realm}' does not contain a user with email"
|
2017-08-25 00:12:36 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, error_message):
|
|
|
|
self.command.get_user(email, mit_realm)
|
|
|
|
|
2017-07-07 20:35:31 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, "server does not contain a user with email"):
|
2017-08-25 00:12:36 +02:00
|
|
|
self.command.get_user('invalid_email@example.com', None)
|
2018-03-18 20:31:48 +01:00
|
|
|
|
|
|
|
do_create_user(email, 'password', mit_realm, 'full_name', 'short_name')
|
|
|
|
|
|
|
|
with self.assertRaisesRegex(CommandError, "server contains multiple users with that email"):
|
|
|
|
self.command.get_user(email, None)
|
2017-07-07 20:35:31 +02:00
|
|
|
|
2018-03-17 18:11:26 +01:00
|
|
|
def test_get_user_profile_by_email(self) -> None:
|
|
|
|
user_profile = self.example_user("hamlet")
|
2020-03-12 14:17:25 +01:00
|
|
|
email = user_profile.delivery_email
|
2018-03-17 18:11:26 +01:00
|
|
|
|
|
|
|
self.assertEqual(get_user_profile_by_email(email), user_profile)
|
|
|
|
|
2019-01-11 11:25:36 +01:00
|
|
|
def get_users_sorted(self, options: Dict[str, Any], realm: Optional[Realm],
|
2019-08-14 19:48:54 +02:00
|
|
|
**kwargs: Any) -> List[UserProfile]:
|
|
|
|
user_profiles = self.command.get_users(options, realm, **kwargs)
|
2017-08-25 00:12:36 +02:00
|
|
|
return sorted(user_profiles, key = lambda x: x.email)
|
|
|
|
|
2020-03-12 14:17:25 +01:00
|
|
|
def sorted_users(self, users: List[UserProfile]) -> List[UserProfile]:
|
|
|
|
return sorted(users, key = lambda x: x.email)
|
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_get_users(self) -> None:
|
2020-03-12 14:17:25 +01:00
|
|
|
expected_user_profiles = self.sorted_users([
|
|
|
|
self.example_user('hamlet'),
|
|
|
|
self.example_user('iago'),
|
|
|
|
])
|
|
|
|
|
|
|
|
user_emails = ','.join(u.delivery_email for u in expected_user_profiles)
|
2017-08-25 00:12:36 +02:00
|
|
|
user_profiles = self.get_users_sorted(dict(users=user_emails), self.zulip_realm)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
|
|
|
user_profiles = self.get_users_sorted(dict(users=user_emails), None)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
2017-08-19 21:00:19 +02:00
|
|
|
|
2020-03-12 14:17:25 +01:00
|
|
|
expected_user_profiles = self.sorted_users([
|
|
|
|
self.mit_user('sipbtest'),
|
|
|
|
self.example_user('iago'),
|
|
|
|
])
|
|
|
|
user_emails = ','.join(u.delivery_email for u in expected_user_profiles)
|
2017-08-25 00:12:36 +02:00
|
|
|
user_profiles = self.get_users_sorted(dict(users=user_emails), None)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
2020-06-10 06:41:04 +02:00
|
|
|
error_message = f"The realm '{self.zulip_realm}' does not contain a user with email"
|
2017-08-25 00:12:36 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, error_message):
|
|
|
|
self.command.get_users(dict(users=user_emails), self.zulip_realm)
|
2017-08-19 21:00:19 +02:00
|
|
|
|
2017-08-25 00:12:36 +02:00
|
|
|
self.assertEqual(self.command.get_users(dict(users=self.example_email("iago")), self.zulip_realm),
|
2017-08-19 21:00:19 +02:00
|
|
|
[self.example_user("iago")])
|
2017-08-25 00:12:36 +02:00
|
|
|
|
|
|
|
self.assertEqual(self.command.get_users(dict(users=None), None), [])
|
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_get_users_with_all_users_argument_enabled(self) -> None:
|
2020-03-12 14:17:25 +01:00
|
|
|
expected_user_profiles = self.sorted_users([
|
|
|
|
self.example_user('hamlet'),
|
|
|
|
self.example_user('iago'),
|
|
|
|
])
|
|
|
|
user_emails = ','.join(u.delivery_email for u in expected_user_profiles)
|
2017-08-25 00:12:36 +02:00
|
|
|
user_profiles = self.get_users_sorted(dict(users=user_emails, all_users=False), self.zulip_realm)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
|
|
|
error_message = "You can't use both -u/--users and -a/--all-users."
|
|
|
|
with self.assertRaisesRegex(CommandError, error_message):
|
|
|
|
self.command.get_users(dict(users=user_emails, all_users=True), None)
|
|
|
|
|
2019-08-14 19:48:54 +02:00
|
|
|
# Test the default mode excluding bots and deactivated users
|
|
|
|
expected_user_profiles = sorted(UserProfile.objects.filter(realm=self.zulip_realm,
|
|
|
|
is_active=True, is_bot=False),
|
|
|
|
key = lambda x: x.email)
|
|
|
|
user_profiles = self.get_users_sorted(dict(users=None, all_users=True),
|
|
|
|
self.zulip_realm,
|
|
|
|
is_bot=False)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
|
|
|
|
|
|
|
# Test the default mode excluding bots and deactivated users
|
|
|
|
expected_user_profiles = sorted(UserProfile.objects.filter(realm=self.zulip_realm,
|
|
|
|
is_active=True),
|
2017-08-25 00:12:36 +02:00
|
|
|
key = lambda x: x.email)
|
2019-08-14 19:48:54 +02:00
|
|
|
user_profiles = self.get_users_sorted(dict(users=None, all_users=True),
|
|
|
|
self.zulip_realm)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
|
|
|
|
|
|
|
# Test include_deactivated
|
|
|
|
expected_user_profiles = sorted(UserProfile.objects.filter(realm=self.zulip_realm,
|
|
|
|
is_bot=False),
|
|
|
|
key = lambda x: x.email)
|
|
|
|
user_profiles = self.get_users_sorted(dict(users=None, all_users=True),
|
|
|
|
self.zulip_realm,
|
|
|
|
is_bot=False, include_deactivated=True)
|
2017-08-25 00:12:36 +02:00
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
|
|
|
|
|
|
|
error_message = "You have to pass either -u/--users or -a/--all-users."
|
|
|
|
with self.assertRaisesRegex(CommandError, error_message):
|
|
|
|
self.command.get_users(dict(users=None, all_users=False), None)
|
|
|
|
|
|
|
|
error_message = "The --all-users option requires a realm; please pass --realm."
|
|
|
|
with self.assertRaisesRegex(CommandError, error_message):
|
|
|
|
self.command.get_users(dict(users=None, all_users=True), None)
|
2017-08-19 21:00:19 +02:00
|
|
|
|
2019-01-11 11:25:36 +01:00
|
|
|
def test_get_non_bot_users(self) -> None:
|
|
|
|
expected_user_profiles = sorted(UserProfile.objects.filter(realm=self.zulip_realm,
|
|
|
|
is_bot=False),
|
|
|
|
key = lambda x: x.email)
|
|
|
|
user_profiles = self.get_users_sorted(dict(users=None, all_users=True),
|
|
|
|
self.zulip_realm,
|
|
|
|
is_bot=False)
|
|
|
|
self.assertEqual(user_profiles, expected_user_profiles)
|
|
|
|
|
2017-02-09 22:58:43 +01:00
|
|
|
class TestCommandsCanStart(TestCase):
|
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def setUp(self) -> None:
|
2019-10-19 20:47:00 +02:00
|
|
|
super().setUp()
|
2020-06-10 07:28:15 +02:00
|
|
|
self.commands = [
|
|
|
|
command
|
|
|
|
for filename in glob.iglob('*/management/commands/*.py')
|
|
|
|
for command in [os.path.basename(filename).replace('.py', '')]
|
|
|
|
if command != '__init__'
|
|
|
|
]
|
2017-02-09 22:58:43 +01:00
|
|
|
|
2017-10-07 00:29:18 +02:00
|
|
|
@slow("Aggregate of runs dozens of individual --help tests")
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_management_commands_show_help(self) -> None:
|
2019-09-12 23:06:36 +02:00
|
|
|
with stdout_suppressed():
|
2017-02-09 22:58:43 +01:00
|
|
|
for command in self.commands:
|
2019-09-12 23:06:36 +02:00
|
|
|
with self.subTest(management_command=command):
|
|
|
|
with self.assertRaises(SystemExit):
|
|
|
|
call_command(command, '--help')
|
2017-03-24 07:55:20 +01:00
|
|
|
# zerver/management/commands/runtornado.py sets this to True;
|
|
|
|
# we need to reset it here. See #3685 for details.
|
|
|
|
settings.RUNNING_INSIDE_TORNADO = False
|
2016-04-14 23:39:37 +02:00
|
|
|
|
|
|
|
class TestSendWebhookFixtureMessage(TestCase):
|
|
|
|
COMMAND_NAME = 'send_webhook_fixture_message'
|
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def setUp(self) -> None:
|
2019-10-19 20:47:00 +02:00
|
|
|
super().setUp()
|
2016-04-14 23:39:37 +02:00
|
|
|
self.fixture_path = os.path.join('some', 'fake', 'path.json')
|
|
|
|
self.url = '/some/url/with/hook'
|
|
|
|
|
|
|
|
@patch('zerver.management.commands.send_webhook_fixture_message.Command.print_help')
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_check_if_command_exits_when_fixture_param_is_empty(self, print_help_mock: MagicMock) -> None:
|
2019-05-03 23:20:39 +02:00
|
|
|
with self.assertRaises(CommandError):
|
2016-04-14 23:39:37 +02:00
|
|
|
call_command(self.COMMAND_NAME, url=self.url)
|
|
|
|
|
2016-11-22 01:44:16 +01:00
|
|
|
print_help_mock.assert_any_call('./manage.py', self.COMMAND_NAME)
|
2016-04-14 23:39:37 +02:00
|
|
|
|
|
|
|
@patch('zerver.management.commands.send_webhook_fixture_message.Command.print_help')
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_check_if_command_exits_when_url_param_is_empty(self, print_help_mock: MagicMock) -> None:
|
2019-05-03 23:20:39 +02:00
|
|
|
with self.assertRaises(CommandError):
|
2016-04-14 23:39:37 +02:00
|
|
|
call_command(self.COMMAND_NAME, fixture=self.fixture_path)
|
|
|
|
|
2016-11-22 01:44:16 +01:00
|
|
|
print_help_mock.assert_any_call('./manage.py', self.COMMAND_NAME)
|
2016-04-14 23:39:37 +02:00
|
|
|
|
|
|
|
@patch('zerver.management.commands.send_webhook_fixture_message.os.path.exists')
|
2017-11-17 07:00:53 +01:00
|
|
|
def test_check_if_command_exits_when_fixture_path_does_not_exist(
|
|
|
|
self, os_path_exists_mock: MagicMock) -> None:
|
2016-04-14 23:39:37 +02:00
|
|
|
os_path_exists_mock.return_value = False
|
|
|
|
|
2019-05-03 23:20:39 +02:00
|
|
|
with self.assertRaises(CommandError):
|
2016-04-14 23:39:37 +02:00
|
|
|
call_command(self.COMMAND_NAME, fixture=self.fixture_path, url=self.url)
|
|
|
|
|
|
|
|
os_path_exists_mock.assert_any_call(os.path.join(settings.DEPLOY_ROOT, self.fixture_path))
|
|
|
|
|
|
|
|
@patch('zerver.management.commands.send_webhook_fixture_message.os.path.exists')
|
|
|
|
@patch('zerver.management.commands.send_webhook_fixture_message.Client')
|
|
|
|
@patch('zerver.management.commands.send_webhook_fixture_message.ujson')
|
|
|
|
@patch("zerver.management.commands.send_webhook_fixture_message.open", create=True)
|
|
|
|
def test_check_if_command_post_request_to_url_with_fixture(self,
|
2017-11-20 03:22:57 +01:00
|
|
|
open_mock: MagicMock,
|
|
|
|
ujson_mock: MagicMock,
|
|
|
|
client_mock: MagicMock,
|
|
|
|
os_path_exists_mock: MagicMock) -> None:
|
2020-03-20 02:12:02 +01:00
|
|
|
ujson_mock.load.return_value = {}
|
2019-06-21 04:41:30 +02:00
|
|
|
ujson_mock.dumps.return_value = "{}"
|
2016-04-14 23:39:37 +02:00
|
|
|
os_path_exists_mock.return_value = True
|
|
|
|
|
|
|
|
client = client_mock()
|
|
|
|
|
2019-05-03 23:20:39 +02:00
|
|
|
with self.assertRaises(CommandError):
|
2017-10-20 18:16:38 +02:00
|
|
|
call_command(self.COMMAND_NAME, fixture=self.fixture_path, url=self.url)
|
2016-04-14 23:39:37 +02:00
|
|
|
self.assertTrue(ujson_mock.dumps.called)
|
2020-03-20 02:12:02 +01:00
|
|
|
self.assertTrue(ujson_mock.load.called)
|
2016-04-14 23:39:37 +02:00
|
|
|
self.assertTrue(open_mock.called)
|
2019-06-21 04:41:30 +02:00
|
|
|
client.post.assert_called_once_with(self.url, "{}", content_type="application/json",
|
2017-10-09 06:20:35 +02:00
|
|
|
HTTP_HOST="zulip.testserver")
|
2016-06-22 21:16:02 +02:00
|
|
|
|
2016-08-23 02:08:42 +02:00
|
|
|
class TestGenerateRealmCreationLink(ZulipTestCase):
|
2016-06-22 21:16:02 +02:00
|
|
|
COMMAND_NAME = "generate_realm_creation_link"
|
|
|
|
|
2018-01-26 21:15:51 +01:00
|
|
|
@override_settings(OPEN_REALM_CREATION=False)
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_generate_link_and_create_realm(self) -> None:
|
2016-06-22 21:16:02 +02:00
|
|
|
email = "user1@test.com"
|
2018-01-29 19:58:52 +01:00
|
|
|
generated_link = generate_realm_creation_url(by_admin=True)
|
2016-06-22 21:16:02 +02:00
|
|
|
|
2018-01-26 21:19:20 +01:00
|
|
|
# Get realm creation page
|
2018-01-26 21:15:51 +01:00
|
|
|
result = self.client_get(generated_link)
|
2020-04-09 21:51:58 +02:00
|
|
|
self.assert_in_success_response(["Create a new Zulip organization"], result)
|
2016-06-22 21:16:02 +02:00
|
|
|
|
2018-01-26 21:19:20 +01:00
|
|
|
# Enter email
|
2019-05-04 04:47:44 +02:00
|
|
|
with self.assertRaises(Realm.DoesNotExist):
|
|
|
|
get_realm('test')
|
2018-01-26 21:15:51 +01:00
|
|
|
result = self.client_post(generated_link, {'email': email})
|
|
|
|
self.assertEqual(result.status_code, 302)
|
2018-07-02 00:05:24 +02:00
|
|
|
self.assertTrue(re.search(r'/accounts/do_confirm/\w+$', result["Location"]))
|
2018-01-26 21:19:20 +01:00
|
|
|
|
|
|
|
# Bypass sending mail for confirmation, go straight to creation form
|
2018-01-26 21:15:51 +01:00
|
|
|
result = self.client_get(result["Location"])
|
|
|
|
self.assert_in_response('action="/accounts/register/"', result)
|
2016-06-22 21:16:02 +02:00
|
|
|
|
2018-01-26 21:19:20 +01:00
|
|
|
# Original link is now dead
|
2018-01-26 21:15:51 +01:00
|
|
|
result = self.client_get(generated_link)
|
|
|
|
self.assert_in_success_response(["The organization creation link has expired or is not valid."], result)
|
2016-06-22 21:16:02 +02:00
|
|
|
|
2018-01-26 21:15:51 +01:00
|
|
|
@override_settings(OPEN_REALM_CREATION=False)
|
2018-01-26 21:12:58 +01:00
|
|
|
def test_generate_link_confirm_email(self) -> None:
|
|
|
|
email = "user1@test.com"
|
|
|
|
generated_link = generate_realm_creation_url(by_admin=False)
|
|
|
|
|
2018-01-26 21:15:51 +01:00
|
|
|
result = self.client_post(generated_link, {'email': email})
|
|
|
|
self.assertEqual(result.status_code, 302)
|
2020-06-09 00:25:09 +02:00
|
|
|
self.assertTrue(re.search(f'/accounts/new/send_confirm/{email}$',
|
2018-01-26 21:15:51 +01:00
|
|
|
result["Location"]))
|
|
|
|
result = self.client_get(result["Location"])
|
|
|
|
self.assert_in_response("Check your email so we can get started", result)
|
2018-01-26 21:12:58 +01:00
|
|
|
|
2018-01-26 21:15:51 +01:00
|
|
|
# Original link is now dead
|
|
|
|
result = self.client_get(generated_link)
|
|
|
|
self.assert_in_success_response(["The organization creation link has expired or is not valid."], result)
|
2018-01-26 21:12:58 +01:00
|
|
|
|
2018-01-26 21:15:51 +01:00
|
|
|
@override_settings(OPEN_REALM_CREATION=False)
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_realm_creation_with_random_link(self) -> None:
|
2018-01-26 21:15:51 +01:00
|
|
|
# Realm creation attempt with an invalid link should fail
|
2018-02-28 16:41:21 +01:00
|
|
|
random_link = "/new/5e89081eb13984e0f3b130bf7a4121d153f1614b"
|
2018-01-26 21:15:51 +01:00
|
|
|
result = self.client_get(random_link)
|
|
|
|
self.assert_in_success_response(["The organization creation link has expired or is not valid."], result)
|
2016-06-22 21:16:02 +02:00
|
|
|
|
2018-01-26 21:15:51 +01:00
|
|
|
@override_settings(OPEN_REALM_CREATION=False)
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_realm_creation_with_expired_link(self) -> None:
|
2018-01-26 21:15:51 +01:00
|
|
|
generated_link = generate_realm_creation_url(by_admin=True)
|
|
|
|
key = generated_link[-24:]
|
|
|
|
# Manually expire the link by changing the date of creation
|
|
|
|
obj = RealmCreationKey.objects.get(creation_key=key)
|
|
|
|
obj.date_created = obj.date_created - timedelta(days=settings.REALM_CREATION_LINK_VALIDITY_DAYS + 1)
|
|
|
|
obj.save()
|
|
|
|
|
|
|
|
result = self.client_get(generated_link)
|
|
|
|
self.assert_in_success_response(["The organization creation link has expired or is not valid."], result)
|
2018-01-22 21:50:22 +01:00
|
|
|
|
|
|
|
class TestCalculateFirstVisibleMessageID(ZulipTestCase):
|
|
|
|
COMMAND_NAME = 'calculate_first_visible_message_id'
|
|
|
|
|
|
|
|
def test_check_if_command_calls_maybe_update_first_visible_message_id(self) -> None:
|
2019-05-08 10:05:44 +02:00
|
|
|
func_name = "zilencer.management.commands.calculate_first_visible_message_id.maybe_update_first_visible_message_id"
|
|
|
|
with patch(func_name) as m:
|
2018-01-22 21:50:22 +01:00
|
|
|
call_command(self.COMMAND_NAME, "--realm=zulip", "--lookback-hours=30")
|
|
|
|
m.assert_called_with(get_realm("zulip"), 30)
|
|
|
|
|
2019-05-08 10:05:44 +02:00
|
|
|
with patch(func_name) as m:
|
2018-01-22 21:50:22 +01:00
|
|
|
call_command(self.COMMAND_NAME, "--lookback-hours=35")
|
|
|
|
calls = [call(realm, 35) for realm in Realm.objects.all()]
|
|
|
|
m.has_calls(calls, any_order=True)
|
2018-08-23 11:02:47 +02:00
|
|
|
|
|
|
|
class TestPasswordRestEmail(ZulipTestCase):
|
|
|
|
COMMAND_NAME = "send_password_reset_email"
|
|
|
|
|
|
|
|
def test_if_command_sends_password_reset_email(self) -> None:
|
|
|
|
call_command(self.COMMAND_NAME, users=self.example_email("iago"))
|
|
|
|
from django.core.mail import outbox
|
|
|
|
from_email = outbox[0].from_email
|
|
|
|
self.assertIn("Zulip Account Security", from_email)
|
|
|
|
tokenized_no_reply_email = parseaddr(from_email)[1]
|
|
|
|
self.assertTrue(re.search(self.TOKENIZED_NOREPLY_REGEX, tokenized_no_reply_email))
|
2018-12-20 09:44:18 +01:00
|
|
|
self.assertIn("reset your password", outbox[0].body)
|
2018-11-12 14:15:49 +01:00
|
|
|
|
|
|
|
class TestRealmReactivationEmail(ZulipTestCase):
|
|
|
|
COMMAND_NAME = "send_realm_reactivation_email"
|
|
|
|
|
|
|
|
def test_if_realm_not_deactivated(self) -> None:
|
|
|
|
realm = get_realm('zulip')
|
2020-06-10 06:41:04 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, f"The realm {realm.name} is already active."):
|
2018-11-12 14:15:49 +01:00
|
|
|
call_command(self.COMMAND_NAME, "--realm=zulip")
|
2019-01-09 12:27:29 +01:00
|
|
|
|
|
|
|
class TestSendToEmailMirror(ZulipTestCase):
|
|
|
|
COMMAND_NAME = "send_to_email_mirror"
|
|
|
|
|
|
|
|
def test_sending_a_fixture(self) -> None:
|
|
|
|
fixture_path = "zerver/tests/fixtures/email/1.txt"
|
|
|
|
user_profile = self.example_user('hamlet')
|
2020-03-06 18:40:46 +01:00
|
|
|
self.login_user(user_profile)
|
2019-01-09 12:27:29 +01:00
|
|
|
self.subscribe(user_profile, "Denmark")
|
|
|
|
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, f"--fixture={fixture_path}")
|
2019-01-09 12:27:29 +01:00
|
|
|
message = most_recent_message(user_profile)
|
|
|
|
|
|
|
|
# last message should be equal to the body of the email in 1.txt
|
|
|
|
self.assertEqual(message.content, "Email fixture 1.txt body")
|
|
|
|
|
|
|
|
def test_sending_a_json_fixture(self) -> None:
|
|
|
|
fixture_path = "zerver/tests/fixtures/email/1.json"
|
|
|
|
user_profile = self.example_user('hamlet')
|
2020-03-06 18:40:46 +01:00
|
|
|
self.login_user(user_profile)
|
2019-01-09 12:27:29 +01:00
|
|
|
self.subscribe(user_profile, "Denmark")
|
|
|
|
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, f"--fixture={fixture_path}")
|
2019-01-09 12:27:29 +01:00
|
|
|
message = most_recent_message(user_profile)
|
|
|
|
|
|
|
|
# last message should be equal to the body of the email in 1.json
|
|
|
|
self.assertEqual(message.content, "Email fixture 1.json body")
|
|
|
|
|
|
|
|
def test_stream_option(self) -> None:
|
|
|
|
fixture_path = "zerver/tests/fixtures/email/1.txt"
|
|
|
|
user_profile = self.example_user('hamlet')
|
2020-03-06 18:40:46 +01:00
|
|
|
self.login_user(user_profile)
|
2019-01-09 12:27:29 +01:00
|
|
|
self.subscribe(user_profile, "Denmark2")
|
|
|
|
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, f"--fixture={fixture_path}", "--stream=Denmark2")
|
2019-01-09 12:27:29 +01:00
|
|
|
message = most_recent_message(user_profile)
|
|
|
|
|
|
|
|
# last message should be equal to the body of the email in 1.txt
|
|
|
|
self.assertEqual(message.content, "Email fixture 1.txt body")
|
|
|
|
|
2019-07-15 22:59:18 +02:00
|
|
|
stream_id = get_stream("Denmark2", get_realm("zulip")).id
|
2019-01-09 12:27:29 +01:00
|
|
|
self.assertEqual(message.recipient.type, Recipient.STREAM)
|
|
|
|
self.assertEqual(message.recipient.type_id, stream_id)
|
2019-04-04 13:16:02 +02:00
|
|
|
|
|
|
|
class TestConvertMattermostData(ZulipTestCase):
|
|
|
|
COMMAND_NAME = 'convert_mattermost_data'
|
|
|
|
|
2019-04-26 13:25:52 +02:00
|
|
|
def test_if_command_calls_do_convert_data(self) -> None:
|
2019-04-04 13:16:02 +02:00
|
|
|
with patch('zerver.management.commands.convert_mattermost_data.do_convert_data') as m:
|
|
|
|
mm_fixtures = self.fixture_file_name("", "mattermost_fixtures")
|
|
|
|
output_dir = self.make_import_output_dir("mattermost")
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, mm_fixtures, f"--output={output_dir}")
|
2019-04-04 13:16:02 +02:00
|
|
|
|
|
|
|
m.assert_called_with(
|
|
|
|
masking_content=False,
|
|
|
|
mattermost_data_dir=os.path.realpath(mm_fixtures),
|
|
|
|
output_dir=os.path.realpath(output_dir),
|
|
|
|
)
|
2019-04-26 13:15:11 +02:00
|
|
|
|
|
|
|
class TestInvoicePlans(ZulipTestCase):
|
|
|
|
COMMAND_NAME = 'invoice_plans'
|
|
|
|
|
|
|
|
def test_if_command_calls_invoice_plans_as_needed(self) -> None:
|
|
|
|
with patch('zilencer.management.commands.invoice_plans.invoice_plans_as_needed') as m:
|
|
|
|
call_command(self.COMMAND_NAME)
|
|
|
|
|
|
|
|
m.assert_called_once()
|
2019-05-10 14:28:38 +02:00
|
|
|
|
|
|
|
class TestExport(ZulipTestCase):
|
|
|
|
COMMAND_NAME = 'export'
|
|
|
|
|
|
|
|
def test_command_with_consented_message_id(self) -> None:
|
|
|
|
realm = get_realm("zulip")
|
2020-03-07 11:43:05 +01:00
|
|
|
self.send_stream_message(self.example_user("othello"), "Verona",
|
2019-05-10 14:28:38 +02:00
|
|
|
topic_name="Export",
|
|
|
|
content="Thumbs up for export")
|
|
|
|
message = Message.objects.last()
|
2019-06-18 00:37:49 +02:00
|
|
|
do_add_reaction(self.example_user("iago"), message, "outbox", "1f4e4", Reaction.UNICODE_EMOJI)
|
|
|
|
do_add_reaction(self.example_user("hamlet"), message, "outbox", "1f4e4", Reaction.UNICODE_EMOJI)
|
2019-05-10 14:28:38 +02:00
|
|
|
|
|
|
|
with patch("zerver.management.commands.export.export_realm_wrapper") as m:
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, "-r=zulip", f"--consent-message-id={message.id}")
|
2019-05-10 14:28:38 +02:00
|
|
|
m.assert_called_once_with(realm=realm, public_only=False, consent_message_id=message.id,
|
|
|
|
delete_after_upload=False, threads=mock.ANY, output_dir=mock.ANY,
|
2019-05-10 09:10:47 +02:00
|
|
|
upload=False)
|
2019-05-10 14:28:38 +02:00
|
|
|
|
|
|
|
with self.assertRaisesRegex(CommandError, "Message with given ID does not"):
|
|
|
|
call_command(self.COMMAND_NAME, "-r=zulip", "--consent-message-id=123456")
|
|
|
|
|
|
|
|
message.last_edit_time = timezone_now()
|
|
|
|
message.save()
|
|
|
|
with self.assertRaisesRegex(CommandError, "Message was edited. Aborting..."):
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, "-r=zulip", f"--consent-message-id={message.id}")
|
2019-05-10 14:28:38 +02:00
|
|
|
|
|
|
|
message.last_edit_time = None
|
|
|
|
message.save()
|
2019-06-18 00:37:49 +02:00
|
|
|
do_add_reaction(self.mit_user("sipbtest"), message, "outbox", "1f4e4", Reaction.UNICODE_EMOJI)
|
2019-05-10 14:28:38 +02:00
|
|
|
with self.assertRaisesRegex(CommandError, "Users from a different realm reacted to message. Aborting..."):
|
2020-06-09 00:25:09 +02:00
|
|
|
call_command(self.COMMAND_NAME, "-r=zulip", f"--consent-message-id={message.id}")
|