moviewyrm/bookwyrm/tests/views/test_feed.py

144 lines
5.7 KiB
Python
Raw Normal View History

2021-03-08 16:49:10 +00:00
""" test for app action functionality """
2021-03-15 20:55:48 +00:00
from io import BytesIO
from unittest.mock import patch
2021-03-15 20:55:48 +00:00
import pathlib
from PIL import Image
from django.core.files.base import ContentFile
from django.template.response import TemplateResponse
from django.test import TestCase
from django.test.client import RequestFactory
from bookwyrm import models
from bookwyrm import views
from bookwyrm.activitypub import ActivitypubResponse
2021-03-15 20:55:48 +00:00
class FeedViews(TestCase):
""" activity feed, statuses, dms """
2021-03-08 16:49:10 +00:00
def setUp(self):
2021-03-08 16:49:10 +00:00
""" we need basic test data and mocks """
self.factory = RequestFactory()
self.local_user = models.User.objects.create_user(
2021-03-08 16:49:10 +00:00
"mouse@local.com",
"mouse@mouse.mouse",
"password",
local=True,
localname="mouse",
)
self.book = models.Edition.objects.create(
2021-03-08 16:49:10 +00:00
parent_work=models.Work.objects.create(title="hi"),
title="Example Edition",
remote_id="https://example.com/book/1",
)
models.SiteSettings.objects.create()
def test_feed(self):
2021-03-08 16:49:10 +00:00
""" there are so many views, this just makes sure it LOADS """
view = views.Feed.as_view()
2021-03-08 16:49:10 +00:00
request = self.factory.get("")
request.user = self.local_user
2021-03-08 16:49:10 +00:00
result = view(request, "local")
self.assertIsInstance(result, TemplateResponse)
result.render()
self.assertEqual(result.status_code, 200)
def test_status_page(self):
2021-03-08 16:49:10 +00:00
""" there are so many views, this just makes sure it LOADS """
view = views.Status.as_view()
2021-03-08 16:49:10 +00:00
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
status = models.Status.objects.create(content="hi", user=self.local_user)
request = self.factory.get("")
request.user = self.local_user
2021-03-08 16:49:10 +00:00
with patch("bookwyrm.views.feed.is_api_request") as is_api:
is_api.return_value = False
2021-03-08 16:49:10 +00:00
result = view(request, "mouse", status.id)
self.assertIsInstance(result, TemplateResponse)
result.render()
self.assertEqual(result.status_code, 200)
2021-03-08 16:49:10 +00:00
with patch("bookwyrm.views.feed.is_api_request") as is_api:
is_api.return_value = True
2021-03-08 16:49:10 +00:00
result = view(request, "mouse", status.id)
self.assertIsInstance(result, ActivitypubResponse)
2021-03-15 20:55:48 +00:00
self.assertEqual(result.status_code, 200)
def test_status_page_with_image(self):
""" there are so many views, this just makes sure it LOADS """
view = views.Status.as_view()
image_file = pathlib.Path(__file__).parent.joinpath(
"../../static/images/default_avi.jpg"
)
image = Image.open(image_file)
output = BytesIO()
image.save(output, format=image.format)
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
status = models.Review.objects.create(
content="hi",
user=self.local_user,
book=self.book,
)
attachment = models.Image.objects.create(
status=status, caption="alt text here"
)
attachment.image.save("test.jpg", ContentFile(output.getvalue()))
request = self.factory.get("")
request.user = self.local_user
with patch("bookwyrm.views.feed.is_api_request") as is_api:
is_api.return_value = False
result = view(request, "mouse", status.id)
self.assertIsInstance(result, TemplateResponse)
result.render()
self.assertEqual(result.status_code, 200)
with patch("bookwyrm.views.feed.is_api_request") as is_api:
is_api.return_value = True
result = view(request, "mouse", status.id)
self.assertIsInstance(result, ActivitypubResponse)
self.assertEqual(result.status_code, 200)
def test_replies_page(self):
2021-03-08 16:49:10 +00:00
""" there are so many views, this just makes sure it LOADS """
view = views.Replies.as_view()
2021-03-08 16:49:10 +00:00
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
status = models.Status.objects.create(content="hi", user=self.local_user)
request = self.factory.get("")
request.user = self.local_user
2021-03-08 16:49:10 +00:00
with patch("bookwyrm.views.feed.is_api_request") as is_api:
is_api.return_value = False
2021-03-08 16:49:10 +00:00
result = view(request, "mouse", status.id)
self.assertIsInstance(result, TemplateResponse)
result.render()
self.assertEqual(result.status_code, 200)
2021-03-08 16:49:10 +00:00
with patch("bookwyrm.views.feed.is_api_request") as is_api:
is_api.return_value = True
2021-03-08 16:49:10 +00:00
result = view(request, "mouse", status.id)
self.assertIsInstance(result, ActivitypubResponse)
self.assertEqual(result.status_code, 200)
def test_direct_messages_page(self):
2021-03-08 16:49:10 +00:00
""" there are so many views, this just makes sure it LOADS """
view = views.DirectMessage.as_view()
2021-03-08 16:49:10 +00:00
request = self.factory.get("")
request.user = self.local_user
result = view(request)
self.assertIsInstance(result, TemplateResponse)
result.render()
self.assertEqual(result.status_code, 200)
def test_get_suggested_book(self):
2021-03-08 16:49:10 +00:00
""" gets books the ~*~ algorithm ~*~ thinks you want to post about """
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
2021-02-07 06:37:19 +00:00
models.ShelfBook.objects.create(
book=self.book,
user=self.local_user,
2021-03-08 16:49:10 +00:00
shelf=self.local_user.shelf_set.get(identifier="reading"),
2021-02-07 06:37:19 +00:00
)
suggestions = views.feed.get_suggested_books(self.local_user)
2021-03-08 16:49:10 +00:00
self.assertEqual(suggestions[0]["name"], "Currently Reading")
self.assertEqual(suggestions[0]["books"][0], self.book)