2020-11-27 22:15:13 +00:00
|
|
|
from unittest.mock import patch
|
2020-10-16 00:32:24 +00:00
|
|
|
from django.test import TestCase
|
|
|
|
|
|
|
|
from bookwyrm import models, incoming
|
|
|
|
|
|
|
|
|
2020-10-16 21:04:06 +00:00
|
|
|
class IncomingFollow(TestCase):
|
2020-10-16 00:32:24 +00:00
|
|
|
def setUp(self):
|
2020-12-03 21:35:51 +00:00
|
|
|
with patch('bookwyrm.models.user.set_remote_server.delay'):
|
|
|
|
with patch('bookwyrm.models.user.get_remote_reviews.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',
|
|
|
|
)
|
2020-10-16 00:32:24 +00:00
|
|
|
self.local_user = models.User.objects.create_user(
|
2020-12-03 21:35:51 +00:00
|
|
|
'mouse', 'mouse@mouse.com', 'mouseword', local=True)
|
2020-10-16 00:32:24 +00:00
|
|
|
self.local_user.remote_id = 'http://local.com/user/mouse'
|
|
|
|
self.local_user.save()
|
|
|
|
|
|
|
|
|
2020-11-27 22:15:13 +00:00
|
|
|
def test_handle_follow(self):
|
|
|
|
activity = {
|
|
|
|
"@context": "https://www.w3.org/ns/activitystreams",
|
|
|
|
"id": "https://example.com/users/rat/follows/123",
|
|
|
|
"type": "Follow",
|
|
|
|
"actor": "https://example.com/users/rat",
|
|
|
|
"object": "http://local.com/user/mouse"
|
|
|
|
}
|
|
|
|
|
|
|
|
with patch('bookwyrm.broadcast.broadcast_task.delay') as _:
|
|
|
|
incoming.handle_follow(activity)
|
|
|
|
|
|
|
|
# notification created
|
|
|
|
notification = models.Notification.objects.get()
|
|
|
|
self.assertEqual(notification.user, self.local_user)
|
|
|
|
self.assertEqual(notification.notification_type, 'FOLLOW')
|
|
|
|
|
|
|
|
# the request should have been deleted
|
|
|
|
requests = models.UserFollowRequest.objects.all()
|
|
|
|
self.assertEqual(list(requests), [])
|
|
|
|
|
|
|
|
# the follow relationship should exist
|
|
|
|
follow = models.UserFollows.objects.get(user_object=self.local_user)
|
|
|
|
self.assertEqual(follow.user_subject, self.remote_user)
|
2020-10-16 00:32:24 +00:00
|
|
|
|
2020-10-16 00:46:23 +00:00
|
|
|
|
|
|
|
def test_handle_follow_manually_approved(self):
|
|
|
|
activity = {
|
|
|
|
"@context": "https://www.w3.org/ns/activitystreams",
|
|
|
|
"id": "https://example.com/users/rat/follows/123",
|
|
|
|
"type": "Follow",
|
|
|
|
"actor": "https://example.com/users/rat",
|
|
|
|
"object": "http://local.com/user/mouse"
|
|
|
|
}
|
|
|
|
|
|
|
|
self.local_user.manually_approves_followers = True
|
|
|
|
self.local_user.save()
|
|
|
|
|
2020-11-27 22:15:13 +00:00
|
|
|
with patch('bookwyrm.broadcast.broadcast_task.delay') as _:
|
|
|
|
incoming.handle_follow(activity)
|
2020-10-16 00:46:23 +00:00
|
|
|
|
|
|
|
# notification created
|
|
|
|
notification = models.Notification.objects.get()
|
|
|
|
self.assertEqual(notification.user, self.local_user)
|
|
|
|
self.assertEqual(notification.notification_type, 'FOLLOW_REQUEST')
|
|
|
|
|
|
|
|
# the request should exist
|
|
|
|
request = models.UserFollowRequest.objects.get()
|
|
|
|
self.assertEqual(request.user_subject, self.remote_user)
|
|
|
|
self.assertEqual(request.user_object, self.local_user)
|
|
|
|
|
|
|
|
# the follow relationship should not exist
|
|
|
|
follow = models.UserFollows.objects.all()
|
|
|
|
self.assertEqual(list(follow), [])
|
|
|
|
|
|
|
|
|
|
|
|
def test_nonexistent_user_follow(self):
|
|
|
|
activity = {
|
|
|
|
"@context": "https://www.w3.org/ns/activitystreams",
|
|
|
|
"id": "https://example.com/users/rat/follows/123",
|
|
|
|
"type": "Follow",
|
|
|
|
"actor": "https://example.com/users/rat",
|
|
|
|
"object": "http://local.com/user/nonexistent-user"
|
|
|
|
}
|
|
|
|
|
2020-11-27 22:15:13 +00:00
|
|
|
with patch('bookwyrm.broadcast.broadcast_task.delay') as _:
|
|
|
|
incoming.handle_follow(activity)
|
2020-10-16 00:46:23 +00:00
|
|
|
|
|
|
|
# do nothing
|
|
|
|
notifications = models.Notification.objects.all()
|
|
|
|
self.assertEqual(list(notifications), [])
|
|
|
|
requests = models.UserFollowRequest.objects.all()
|
|
|
|
self.assertEqual(list(requests), [])
|
|
|
|
follows = models.UserFollows.objects.all()
|
|
|
|
self.assertEqual(list(follows), [])
|