django-notifications/notifications/tests/tests.py

405 lines
19 KiB
Python
Raw Normal View History

2023-06-24 00:10:23 +00:00
"""
2015-03-29 06:37:27 +00:00
This file demonstrates writing tests using the unittest module. These will pass
when you run "manage.py test".
Replace this with more appropriate tests for your application.
2023-06-24 00:10:23 +00:00
"""
2018-05-31 04:05:53 +00:00
# -*- coding: utf-8 -*-
import json
2023-06-24 00:10:23 +00:00
from datetime import datetime, timezone
2018-05-31 04:05:53 +00:00
2023-06-24 00:10:23 +00:00
from django.contrib.auth import get_user_model
from django.shortcuts import render
from django.test import override_settings # noqa
from django.test import RequestFactory, TestCase
from django.urls import reverse
2023-06-24 00:10:23 +00:00
from django.utils.timezone import localtime
from swapper import load_model
2024-04-20 00:37:39 +00:00
from notifications.signals import notify
2018-05-31 04:05:53 +00:00
2023-06-24 00:10:23 +00:00
Notification = load_model("notifications", "Notification")
User = get_user_model()
2015-03-29 06:37:27 +00:00
2023-05-22 23:26:41 +00:00
MALICIOUS_NEXT_URLS = [
"http://bla.com",
"http://www.bla.com",
"https://bla.com",
"https://www.bla.com",
"ftp://www.bla.com/file.exe",
]
2023-06-24 00:10:23 +00:00
2015-03-29 06:37:27 +00:00
class NotificationTest(TestCase):
2023-06-24 00:10:23 +00:00
"""Django notifications automated tests"""
2015-03-29 06:37:27 +00:00
@override_settings(USE_TZ=True)
2023-06-24 00:10:23 +00:00
@override_settings(TIME_ZONE="Asia/Shanghai")
2015-03-29 06:37:27 +00:00
def test_use_timezone(self):
from_user = User.objects.create(username="from", password="pwd", email="example@example.com")
to_user = User.objects.create(username="to", password="pwd", email="example@example.com")
2023-06-24 00:10:23 +00:00
notify.send(from_user, recipient=to_user, verb="commented", action_object=from_user)
2015-03-29 06:37:27 +00:00
notification = Notification.objects.get(recipient=to_user)
delta = datetime.now(tz=timezone.utc) - localtime(notification.timestamp)
2015-03-29 06:37:27 +00:00
self.assertTrue(delta.seconds < 60)
# The delta between the two events will still be less than a second despite the different timezones
2016-01-01 02:59:51 +00:00
# The call to now and the immediate call afterwards will be within a short period of time, not 8 hours as the
# test above was originally.
2015-03-29 06:37:27 +00:00
@override_settings(USE_TZ=False)
2023-06-24 00:10:23 +00:00
@override_settings(TIME_ZONE="Asia/Shanghai")
2015-03-29 06:37:27 +00:00
def test_disable_timezone(self):
from_user = User.objects.create(username="from2", password="pwd", email="example@example.com")
to_user = User.objects.create(username="to2", password="pwd", email="example@example.com")
2023-06-24 00:10:23 +00:00
notify.send(from_user, recipient=to_user, verb="commented", action_object=from_user)
2015-03-29 06:37:27 +00:00
notification = Notification.objects.get(recipient=to_user)
2023-06-24 00:10:23 +00:00
delta = datetime.now() - notification.timestamp
2015-03-29 06:37:27 +00:00
self.assertTrue(delta.seconds < 60)
class NotificationTestPages(TestCase):
2023-06-24 00:10:23 +00:00
"""Django notifications automated page tests"""
def setUp(self):
self.message_count = 10
self.from_user = User.objects.create_user(username="from", password="pwd", email="example@example.com")
self.to_user = User.objects.create_user(username="to", password="pwd", email="example@example.com")
self.to_user.is_staff = True
self.to_user.save()
2018-05-31 04:05:53 +00:00
for _ in range(self.message_count):
2023-06-24 00:10:23 +00:00
notify.send(self.from_user, recipient=self.to_user, verb="commented", action_object=self.from_user)
def logout(self):
2023-06-24 00:10:23 +00:00
self.client.post(reverse("admin:logout") + "?next=/", {})
2015-12-11 13:32:20 +00:00
def login(self, username, password):
self.logout()
2023-07-06 20:54:22 +00:00
response = self.client.post(reverse("admin:login"), {"username": username, "password": password})
2015-12-11 13:32:20 +00:00
self.assertEqual(response.status_code, 302)
return response
def test_all_messages_page(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
response = self.client.get(reverse("notifications:all"))
2015-12-11 13:32:20 +00:00
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.all())
)
def test_unread_messages_pages(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
response = self.client.get(reverse("notifications:unread"))
2015-12-11 13:32:20 +00:00
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.unread())
)
2023-06-24 00:10:23 +00:00
self.assertEqual(len(response.context["notifications"]), self.message_count)
for index, notification in enumerate(self.to_user.notifications_notification_related.all()):
2018-05-31 04:05:53 +00:00
if index % 3 == 0:
2023-06-27 00:06:44 +00:00
response = self.client.get(reverse("notifications:mark_as_read", args=[notification.id]))
2015-12-11 13:32:20 +00:00
self.assertEqual(response.status_code, 302)
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:unread"))
2015-12-11 13:32:20 +00:00
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.unread())
)
2023-06-24 00:10:23 +00:00
self.assertTrue(len(response.context["notifications"]) < self.message_count)
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:mark_all_as_read"))
self.assertRedirects(response, reverse("notifications:unread"))
response = self.client.get(reverse("notifications:unread"))
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.unread())
)
2023-06-24 00:10:23 +00:00
self.assertEqual(len(response.context["notifications"]), 0)
def test_next_pages(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
query_parameters = "?var1=hello&var2=world"
2023-06-24 00:10:23 +00:00
response = self.client.get(
reverse("notifications:mark_all_as_read"),
data={
"next": reverse("notifications:unread") + query_parameters,
},
)
self.assertRedirects(response, reverse("notifications:unread") + query_parameters)
slug = self.to_user.notifications_notification_related.first().id
2023-06-24 00:10:23 +00:00
response = self.client.get(
reverse("notifications:mark_as_read", args=[slug]),
data={
"next": reverse("notifications:unread") + query_parameters,
},
)
self.assertRedirects(response, reverse("notifications:unread") + query_parameters)
slug = self.to_user.notifications_notification_related.first().id
2023-06-24 00:10:23 +00:00
response = self.client.get(
reverse("notifications:mark_as_unread", args=[slug]),
{
"next": reverse("notifications:unread") + query_parameters,
},
)
self.assertRedirects(response, reverse("notifications:unread") + query_parameters)
@override_settings(ALLOWED_HOSTS=["www.notifications_notification_related.com"])
2023-05-22 23:26:41 +00:00
def test_malicious_next_pages(self):
self.client.force_login(self.to_user)
2023-06-24 00:10:23 +00:00
query_parameters = "?var1=hello&var2=world"
2023-05-22 23:26:41 +00:00
for next_url in MALICIOUS_NEXT_URLS:
2023-06-24 00:10:23 +00:00
response = self.client.get(
reverse("notifications:mark_all_as_read"),
data={
"next": next_url + query_parameters,
},
)
self.assertRedirects(response, reverse("notifications:unread"))
2023-05-22 23:26:41 +00:00
def test_delete_messages_pages(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
slug = self.to_user.notifications_notification_related.first().id
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:delete", args=[slug]))
self.assertRedirects(response, reverse("notifications:all"))
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:all"))
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.all())
)
2023-06-24 00:10:23 +00:00
self.assertEqual(len(response.context["notifications"]), self.message_count - 1)
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:unread"))
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.unread())
)
2023-06-24 00:10:23 +00:00
self.assertEqual(len(response.context["notifications"]), self.message_count - 1)
2023-11-03 17:52:58 +00:00
@override_settings(DJANGO_NOTIFICATIONS_CONFIG={"SOFT_DELETE": True})
def test_soft_delete_messages_manager(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
slug = self.to_user.notifications_notification_related.first().id
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:delete", args=[slug]))
self.assertRedirects(response, reverse("notifications:all"))
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:all"))
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.active())
)
2023-06-24 00:10:23 +00:00
self.assertEqual(len(response.context["notifications"]), self.message_count - 1)
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:unread"))
self.assertEqual(response.status_code, 200)
self.assertEqual(
len(response.context["notifications"]), len(self.to_user.notifications_notification_related.unread())
)
2023-06-24 00:10:23 +00:00
self.assertEqual(len(response.context["notifications"]), self.message_count - 1)
2015-07-20 09:51:00 +00:00
def test_unread_count_api(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
2015-07-20 09:51:00 +00:00
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_unread_notification_count"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(list(data.keys()), ["unread_count"])
self.assertEqual(data["unread_count"], self.message_count)
2015-07-20 09:51:00 +00:00
Notification.objects.filter(recipient=self.to_user).mark_all_as_read()
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_unread_notification_count"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(list(data.keys()), ["unread_count"])
self.assertEqual(data["unread_count"], 0)
2015-07-20 09:51:00 +00:00
2023-06-24 00:10:23 +00:00
notify.send(self.from_user, recipient=self.to_user, verb="commented", action_object=self.from_user)
response = self.client.get(reverse("notifications:live_unread_notification_count"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(list(data.keys()), ["unread_count"])
self.assertEqual(data["unread_count"], 1)
2015-07-20 09:51:00 +00:00
def test_all_count_api(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_all_notification_count"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(list(data.keys()), ["all_count"])
self.assertEqual(data["all_count"], self.message_count)
Notification.objects.filter(recipient=self.to_user).mark_all_as_read()
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_all_notification_count"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(list(data.keys()), ["all_count"])
self.assertEqual(data["all_count"], self.message_count)
2023-06-24 00:10:23 +00:00
notify.send(self.from_user, recipient=self.to_user, verb="commented", action_object=self.from_user)
response = self.client.get(reverse("notifications:live_all_notification_count"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(list(data.keys()), ["all_count"])
self.assertEqual(data["all_count"], self.message_count + 1)
2015-07-20 09:51:00 +00:00
def test_unread_list_api(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
2015-07-20 09:51:00 +00:00
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_unread_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["unread_count", "unread_list"])
self.assertEqual(data["unread_count"], self.message_count)
self.assertEqual(len(data["unread_list"]), self.message_count)
2015-07-20 09:51:00 +00:00
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_unread_notification_list"), data={"max": 5})
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["unread_count", "unread_list"])
self.assertEqual(data["unread_count"], self.message_count)
self.assertEqual(len(data["unread_list"]), 5)
2015-07-20 09:51:00 +00:00
# Test with a bad 'max' value
2023-06-24 00:10:23 +00:00
response = self.client.get(
reverse("notifications:live_unread_notification_list"),
data={
"max": "this_is_wrong",
},
)
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["unread_count", "unread_list"])
self.assertEqual(data["unread_count"], self.message_count)
self.assertEqual(len(data["unread_list"]), self.message_count)
2015-07-20 09:51:00 +00:00
Notification.objects.filter(recipient=self.to_user).mark_all_as_read()
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_unread_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["unread_count", "unread_list"])
self.assertEqual(data["unread_count"], 0)
self.assertEqual(len(data["unread_list"]), 0)
notify.send(self.from_user, recipient=self.to_user, verb="commented", action_object=self.from_user)
response = self.client.get(reverse("notifications:live_unread_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["unread_count", "unread_list"])
self.assertEqual(data["unread_count"], 1)
self.assertEqual(len(data["unread_list"]), 1)
self.assertEqual(data["unread_list"][0]["verb"], "commented")
2023-06-27 00:06:44 +00:00
self.assertEqual(data["unread_list"][0]["slug"], data["unread_list"][0]["id"])
2015-07-20 09:51:00 +00:00
def test_all_list_api(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_all_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["all_count", "all_list"])
self.assertEqual(data["all_count"], self.message_count)
self.assertEqual(len(data["all_list"]), self.message_count)
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_all_notification_list"), data={"max": 5})
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["all_count", "all_list"])
self.assertEqual(data["all_count"], self.message_count)
self.assertEqual(len(data["all_list"]), 5)
# Test with a bad 'max' value
2023-06-24 00:10:23 +00:00
response = self.client.get(
reverse("notifications:live_all_notification_list"),
data={
"max": "this_is_wrong",
},
)
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["all_count", "all_list"])
self.assertEqual(data["all_count"], self.message_count)
self.assertEqual(len(data["all_list"]), self.message_count)
Notification.objects.filter(recipient=self.to_user).mark_all_as_read()
2023-06-24 00:10:23 +00:00
response = self.client.get(reverse("notifications:live_all_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["all_count", "all_list"])
self.assertEqual(data["all_count"], self.message_count)
self.assertEqual(len(data["all_list"]), self.message_count)
notify.send(self.from_user, recipient=self.to_user, verb="commented", action_object=self.from_user)
response = self.client.get(reverse("notifications:live_all_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(sorted(list(data.keys())), ["all_count", "all_list"])
self.assertEqual(data["all_count"], self.message_count + 1)
self.assertEqual(len(data["all_list"]), self.message_count)
self.assertEqual(data["all_list"][0]["verb"], "commented")
2023-06-27 00:06:44 +00:00
self.assertEqual(data["all_list"][0]["slug"], data["all_list"][0]["id"])
2023-11-03 17:52:58 +00:00
def test_unread_list_api_mark_as_read(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
2016-09-25 12:06:45 +00:00
num_requested = 3
2016-09-25 12:43:56 +00:00
response = self.client.get(
2023-06-24 00:10:23 +00:00
reverse("notifications:live_unread_notification_list"), data={"max": num_requested, "mark_as_read": 1}
2016-09-25 12:43:56 +00:00
)
2023-06-24 00:10:23 +00:00
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(data["unread_count"], self.message_count - num_requested)
self.assertEqual(len(data["unread_list"]), num_requested)
2016-09-25 12:43:56 +00:00
response = self.client.get(
2023-06-24 00:10:23 +00:00
reverse("notifications:live_unread_notification_list"), data={"max": num_requested, "mark_as_read": 1}
2016-09-25 12:43:56 +00:00
)
2023-06-24 00:10:23 +00:00
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(data["unread_count"], self.message_count - 2 * num_requested)
self.assertEqual(len(data["unread_list"]), num_requested)
2016-09-25 12:06:45 +00:00
2015-07-20 09:51:00 +00:00
def test_live_update_tags(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
2018-05-31 04:05:53 +00:00
factory = RequestFactory()
2015-07-20 09:51:00 +00:00
2023-06-24 00:10:23 +00:00
request = factory.get("/notification/live_updater")
2015-07-20 09:51:00 +00:00
request.user = self.to_user
2023-06-24 00:10:23 +00:00
render(request, "notifications/test_tags.html", {"request": request, "nonce": "nonce-T5esDNXMnDe5lKMQ6ZzTUw=="})
2015-12-11 13:32:20 +00:00
2016-01-01 02:59:51 +00:00
# TODO: Add more tests to check what is being output.
def test_anon_user_gets_nothing(self):
2023-06-24 00:10:23 +00:00
response = self.client.post(reverse("notifications:live_unread_notification_count"))
self.assertEqual(response.status_code, 200)
2023-06-24 00:10:23 +00:00
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(data["unread_count"], 0)
2023-06-24 00:10:23 +00:00
response = self.client.post(reverse("notifications:live_unread_notification_list"))
self.assertEqual(response.status_code, 200)
2023-06-24 00:10:23 +00:00
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(data["unread_count"], 0)
self.assertEqual(data["unread_list"], [])
2017-06-27 01:34:27 +00:00
class NotificationTestExtraData(TestCase):
2023-06-24 00:10:23 +00:00
"""Django notifications automated extra data tests"""
2017-06-27 01:34:27 +00:00
def setUp(self):
self.message_count = 1
self.from_user = User.objects.create_user(username="from", password="pwd", email="example@example.com")
self.to_user = User.objects.create_user(username="to", password="pwd", email="example@example.com")
self.to_user.is_staff = True
self.to_user.save()
2018-05-31 04:05:53 +00:00
for _ in range(self.message_count):
notify.send(
self.from_user,
recipient=self.to_user,
2023-06-24 00:10:23 +00:00
verb="commented",
2018-05-31 04:05:53 +00:00
action_object=self.from_user,
url="/learn/ask-a-pro/q/test-question-9/299/",
2023-06-24 00:10:23 +00:00
other_content="Hello my 'world'",
2018-05-31 04:05:53 +00:00
)
2017-06-27 01:34:27 +00:00
def logout(self):
2023-06-24 00:10:23 +00:00
self.client.post(reverse("admin:logout") + "?next=/", {})
2017-06-27 01:34:27 +00:00
def login(self, username, password):
self.logout()
2023-07-06 20:54:22 +00:00
response = self.client.post(reverse("admin:login"), {"username": username, "password": password})
2017-06-27 01:34:27 +00:00
self.assertEqual(response.status_code, 302)
return response
def test_extra_data(self):
2023-06-24 00:10:23 +00:00
self.login("to", "pwd")
response = self.client.post(reverse("notifications:live_unread_notification_list"))
data = json.loads(response.content.decode("utf-8"))
self.assertEqual(data["unread_list"][0]["data"]["url"], "/learn/ask-a-pro/q/test-question-9/299/")
self.assertEqual(data["unread_list"][0]["data"]["other_content"], "Hello my 'world'")