forked from mirrors/bookwyrm
35696934da
is it better? idk
587 lines
24 KiB
Python
587 lines
24 KiB
Python
''' test for app action functionality '''
|
|
import json
|
|
from unittest.mock import patch
|
|
|
|
from django.contrib.auth.models import AnonymousUser
|
|
from django.http import JsonResponse
|
|
from django.template.response import TemplateResponse
|
|
from django.test import TestCase
|
|
from django.test.client import RequestFactory
|
|
|
|
from bookwyrm import models, views
|
|
from bookwyrm.activitypub import ActivitypubResponse
|
|
from bookwyrm.connectors import abstract_connector
|
|
from bookwyrm.settings import DOMAIN, USER_AGENT
|
|
|
|
|
|
# pylint: disable=too-many-public-methods
|
|
class Views(TestCase):
|
|
''' every response to a get request, html or json '''
|
|
def setUp(self):
|
|
''' we need basic test data and mocks '''
|
|
self.factory = RequestFactory()
|
|
self.work = models.Work.objects.create(title='Test Work')
|
|
self.book = models.Edition.objects.create(
|
|
title='Test Book', parent_work=self.work)
|
|
models.Connector.objects.create(
|
|
identifier='self',
|
|
connector_file='self_connector',
|
|
local=True
|
|
)
|
|
self.local_user = models.User.objects.create_user(
|
|
'mouse@local.com', 'mouse@mouse.mouse', 'password',
|
|
local=True, localname='mouse')
|
|
with patch('bookwyrm.models.user.set_remote_server.delay'):
|
|
self.remote_user = models.User.objects.create_user(
|
|
'rat', 'rat@rat.com', 'ratword',
|
|
local=False,
|
|
remote_id='https://example.com/users/rat',
|
|
inbox='https://example.com/users/rat/inbox',
|
|
outbox='https://example.com/users/rat/outbox',
|
|
)
|
|
|
|
|
|
def test_get_edition(self):
|
|
''' given an edition or a work, returns an edition '''
|
|
self.assertEqual(
|
|
views.get_edition(self.book.id), self.book)
|
|
self.assertEqual(
|
|
views.get_edition(self.work.id), self.book)
|
|
|
|
|
|
def test_get_user_from_username(self):
|
|
''' works for either localname or username '''
|
|
self.assertEqual(
|
|
views.get_user_from_username('mouse'), self.local_user)
|
|
self.assertEqual(
|
|
views.get_user_from_username('mouse@local.com'), self.local_user)
|
|
with self.assertRaises(models.User.DoesNotExist):
|
|
views.get_user_from_username('mojfse@example.com')
|
|
|
|
|
|
def test_is_api_request(self):
|
|
''' should it return html or json '''
|
|
request = self.factory.get('/path')
|
|
request.headers = {'Accept': 'application/json'}
|
|
self.assertTrue(views.is_api_request(request))
|
|
|
|
request = self.factory.get('/path.json')
|
|
request.headers = {'Accept': 'Praise'}
|
|
self.assertTrue(views.is_api_request(request))
|
|
|
|
request = self.factory.get('/path')
|
|
request.headers = {'Accept': 'Praise'}
|
|
self.assertFalse(views.is_api_request(request))
|
|
|
|
|
|
def test_home_tab(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.home_tab(request, 'local')
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'feed.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_direct_messages_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.direct_messages_page(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'direct_messages.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_get_activity_feed(self):
|
|
''' loads statuses '''
|
|
rat = models.User.objects.create_user(
|
|
'rat', 'rat@rat.rat', 'password', local=True)
|
|
|
|
public_status = models.Comment.objects.create(
|
|
content='public status', book=self.book, user=self.local_user)
|
|
direct_status = models.Status.objects.create(
|
|
content='direct', user=self.local_user, privacy='direct')
|
|
|
|
rat_public = models.Status.objects.create(
|
|
content='blah blah', user=rat)
|
|
rat_unlisted = models.Status.objects.create(
|
|
content='blah blah', user=rat, privacy='unlisted')
|
|
remote_status = models.Status.objects.create(
|
|
content='blah blah', user=self.remote_user)
|
|
followers_status = models.Status.objects.create(
|
|
content='blah', user=rat, privacy='followers')
|
|
rat_mention = models.Status.objects.create(
|
|
content='blah blah blah', user=rat, privacy='followers')
|
|
rat_mention.mention_users.set([self.local_user])
|
|
|
|
statuses = views.get_activity_feed(
|
|
self.local_user,
|
|
['public', 'unlisted', 'followers'],
|
|
following_only=True,
|
|
queryset=models.Comment.objects
|
|
)
|
|
self.assertEqual(len(statuses), 1)
|
|
self.assertEqual(statuses[0], public_status)
|
|
|
|
statuses = views.get_activity_feed(
|
|
self.local_user,
|
|
['public', 'followers'],
|
|
local_only=True
|
|
)
|
|
self.assertEqual(len(statuses), 2)
|
|
self.assertEqual(statuses[1], public_status)
|
|
self.assertEqual(statuses[0], rat_public)
|
|
|
|
statuses = views.get_activity_feed(self.local_user, 'direct')
|
|
self.assertEqual(len(statuses), 1)
|
|
self.assertEqual(statuses[0], direct_status)
|
|
|
|
statuses = views.get_activity_feed(
|
|
self.local_user,
|
|
['public', 'followers'],
|
|
)
|
|
self.assertEqual(len(statuses), 3)
|
|
self.assertEqual(statuses[2], public_status)
|
|
self.assertEqual(statuses[1], rat_public)
|
|
self.assertEqual(statuses[0], remote_status)
|
|
|
|
statuses = views.get_activity_feed(
|
|
self.local_user,
|
|
['public', 'unlisted', 'followers'],
|
|
following_only=True
|
|
)
|
|
self.assertEqual(len(statuses), 2)
|
|
self.assertEqual(statuses[1], public_status)
|
|
self.assertEqual(statuses[0], rat_mention)
|
|
|
|
rat.followers.add(self.local_user)
|
|
statuses = views.get_activity_feed(
|
|
self.local_user,
|
|
['public', 'unlisted', 'followers'],
|
|
following_only=True
|
|
)
|
|
self.assertEqual(len(statuses), 5)
|
|
self.assertEqual(statuses[4], public_status)
|
|
self.assertEqual(statuses[3], rat_public)
|
|
self.assertEqual(statuses[2], rat_unlisted)
|
|
self.assertEqual(statuses[1], followers_status)
|
|
self.assertEqual(statuses[0], rat_mention)
|
|
|
|
|
|
def test_search_json_response(self):
|
|
''' searches local data only and returns book data in json format '''
|
|
# we need a connector for this, sorry
|
|
request = self.factory.get('', {'q': 'Test Book'})
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
response = views.search(request)
|
|
self.assertIsInstance(response, JsonResponse)
|
|
|
|
data = json.loads(response.content)
|
|
self.assertEqual(len(data), 1)
|
|
self.assertEqual(data[0]['title'], 'Test Book')
|
|
self.assertEqual(
|
|
data[0]['key'], 'https://%s/book/%d' % (DOMAIN, self.book.id))
|
|
|
|
|
|
def test_search_html_response(self):
|
|
''' searches remote connectors '''
|
|
class TestConnector(abstract_connector.AbstractMinimalConnector):
|
|
''' nothing added here '''
|
|
def format_search_result(self, search_result):
|
|
pass
|
|
def get_or_create_book(self, remote_id):
|
|
pass
|
|
def parse_search_data(self, data):
|
|
pass
|
|
models.Connector.objects.create(
|
|
identifier='example.com',
|
|
connector_file='openlibrary',
|
|
base_url='https://example.com',
|
|
books_url='https://example.com/books',
|
|
covers_url='https://example.com/covers',
|
|
search_url='https://example.com/search?q=',
|
|
)
|
|
connector = TestConnector('example.com')
|
|
|
|
search_result = abstract_connector.SearchResult(
|
|
key='http://www.example.com/book/1',
|
|
title='Gideon the Ninth',
|
|
author='Tamsyn Muir',
|
|
year='2019',
|
|
connector=connector
|
|
)
|
|
|
|
request = self.factory.get('', {'q': 'Test Book'})
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
with patch(
|
|
'bookwyrm.connectors.connector_manager.search') as manager:
|
|
manager.return_value = [search_result]
|
|
response = views.search(request)
|
|
self.assertIsInstance(response, TemplateResponse)
|
|
self.assertEqual(response.template_name, 'search_results.html')
|
|
self.assertEqual(
|
|
response.context_data['book_results'][0].title, 'Gideon the Ninth')
|
|
|
|
|
|
def test_search_html_response_users(self):
|
|
''' searches remote connectors '''
|
|
request = self.factory.get('', {'q': 'mouse'})
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
with patch('bookwyrm.connectors.connector_manager.search'):
|
|
response = views.search(request)
|
|
self.assertIsInstance(response, TemplateResponse)
|
|
self.assertEqual(response.template_name, 'search_results.html')
|
|
self.assertEqual(
|
|
response.context_data['user_results'][0], self.local_user)
|
|
|
|
|
|
def test_import_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.import_page(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'import.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_import_status(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
import_job = models.ImportJob.objects.create(user=self.local_user)
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.tasks.app.AsyncResult') as async_result:
|
|
async_result.return_value = []
|
|
result = views.import_status(request, import_job.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'import_status.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_login_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = AnonymousUser
|
|
result = views.login_page(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'login.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
request.user = self.local_user
|
|
result = views.login_page(request)
|
|
self.assertEqual(result.url, '/')
|
|
self.assertEqual(result.status_code, 302)
|
|
|
|
|
|
def test_about_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.about_page(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'about.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_password_reset_request(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.password_reset_request(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'password_reset_request.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_password_reset(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
code = models.PasswordReset.objects.create(user=self.local_user)
|
|
request = self.factory.get('')
|
|
request.user = AnonymousUser
|
|
result = views.password_reset(request, code.code)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'password_reset.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_invite_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
models.SiteInvite.objects.create(code='hi', user=self.local_user)
|
|
request = self.factory.get('')
|
|
request.user = AnonymousUser
|
|
# why?? this is annoying.
|
|
request.user.is_authenticated = False
|
|
with patch('bookwyrm.models.site.SiteInvite.valid') as invite:
|
|
invite.return_value = True
|
|
result = views.invite_page(request, 'hi')
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'invite.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_manage_invites(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
request.user.is_superuser = True
|
|
result = views.manage_invites(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'manage_invites.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_notifications_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.notifications_page(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'notifications.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_user_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.user_page(request, 'mouse')
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'user.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.user_page(request, 'mouse')
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_followers_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.followers_page(request, 'mouse')
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'followers.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.followers_page(request, 'mouse')
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_following_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.following_page(request, 'mouse')
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'following.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.following_page(request, 'mouse')
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_status_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
status = models.Status.objects.create(
|
|
content='hi', user=self.local_user)
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.status_page(request, 'mouse', status.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'status.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.status_page(request, 'mouse', status.id)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_replies_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
status = models.Status.objects.create(
|
|
content='hi', user=self.local_user)
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.replies_page(request, 'mouse', status.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'status.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.replies_page(request, 'mouse', status.id)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_edit_profile_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
result = views.edit_profile_page(request)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'edit_user.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_book_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.book_page(request, self.book.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'book.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.book_page(request, self.book.id)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_edit_book_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
request.user.is_superuser = True
|
|
result = views.edit_book_page(request, self.book.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'edit_book.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_edit_author_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
author = models.Author.objects.create(name='Test Author')
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
request.user.is_superuser = True
|
|
result = views.edit_author_page(request, author.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'edit_author.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_editions_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.editions_page(request, self.work.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'editions.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.editions_page(request, self.work.id)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_author_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
author = models.Author.objects.create(name='Jessica')
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.author_page(request, author.id)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'author.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.author_page(request, author.id)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_tag_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
tag = models.Tag.objects.create(name='hi there')
|
|
models.UserTag.objects.create(
|
|
tag=tag, user=self.local_user, book=self.book)
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.tag_page(request, tag.identifier)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'tag.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
request = self.factory.get('')
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.tag_page(request, tag.identifier)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_shelf_page(self):
|
|
''' there are so many views, this just makes sure it LOADS '''
|
|
shelf = self.local_user.shelf_set.first()
|
|
request = self.factory.get('')
|
|
request.user = self.local_user
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = False
|
|
result = views.shelf_page(
|
|
request, self.local_user.username, shelf.identifier)
|
|
self.assertIsInstance(result, TemplateResponse)
|
|
self.assertEqual(result.template_name, 'shelf.html')
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
with patch('bookwyrm.views.is_api_request') as is_api:
|
|
is_api.return_value = True
|
|
result = views.shelf_page(
|
|
request, self.local_user.username, shelf.identifier)
|
|
self.assertIsInstance(result, ActivitypubResponse)
|
|
self.assertEqual(result.status_code, 200)
|
|
|
|
|
|
def test_is_bookwyrm_request(self):
|
|
''' checks if a request came from a bookwyrm instance '''
|
|
request = self.factory.get('', {'q': 'Test Book'})
|
|
self.assertFalse(views.is_bookworm_request(request))
|
|
|
|
request = self.factory.get(
|
|
'', {'q': 'Test Book'},
|
|
HTTP_USER_AGENT=\
|
|
"http.rb/4.4.1 (Mastodon/3.3.0; +https://mastodon.social/)"
|
|
)
|
|
self.assertFalse(views.is_bookworm_request(request))
|
|
|
|
request = self.factory.get(
|
|
'', {'q': 'Test Book'}, HTTP_USER_AGENT=USER_AGENT)
|
|
self.assertTrue(views.is_bookworm_request(request))
|