mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-12 10:15:29 +00:00
Simplifies outgoing follow logic
This commit is contained in:
parent
694de44f3f
commit
a567bd4e61
4 changed files with 23 additions and 4 deletions
|
@ -143,7 +143,7 @@ def handle_follow(activity):
|
||||||
'FOLLOW',
|
'FOLLOW',
|
||||||
related_user=actor
|
related_user=actor
|
||||||
)
|
)
|
||||||
outgoing.handle_accept(actor, to_follow, relationship)
|
outgoing.handle_accept(relationship)
|
||||||
else:
|
else:
|
||||||
# Accept will be triggered manually
|
# Accept will be triggered manually
|
||||||
status_builder.create_notification(
|
status_builder.create_notification(
|
||||||
|
|
|
@ -80,8 +80,10 @@ def handle_unfollow(user, to_unfollow):
|
||||||
to_unfollow.followers.remove(user)
|
to_unfollow.followers.remove(user)
|
||||||
|
|
||||||
|
|
||||||
def handle_accept(user, to_follow, follow_request):
|
def handle_accept(follow_request):
|
||||||
''' send an acceptance message to a follow request '''
|
''' send an acceptance message to a follow request '''
|
||||||
|
user = follow_request.user_subject
|
||||||
|
to_follow = follow_request.user_object
|
||||||
with transaction.atomic():
|
with transaction.atomic():
|
||||||
relationship = models.UserFollows.from_request(follow_request)
|
relationship = models.UserFollows.from_request(follow_request)
|
||||||
follow_request.delete()
|
follow_request.delete()
|
||||||
|
|
|
@ -3,7 +3,7 @@ from django.test import TestCase
|
||||||
from bookwyrm import models, outgoing
|
from bookwyrm import models, outgoing
|
||||||
|
|
||||||
|
|
||||||
class OutgoingFollow(TestCase):
|
class Following(TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.remote_user = models.User.objects.create_user(
|
self.remote_user = models.User.objects.create_user(
|
||||||
'rat', 'rat@rat.com', 'ratword',
|
'rat', 'rat@rat.com', 'ratword',
|
||||||
|
@ -29,9 +29,26 @@ class OutgoingFollow(TestCase):
|
||||||
self.assertEqual(rel.user_object, self.remote_user)
|
self.assertEqual(rel.user_object, self.remote_user)
|
||||||
self.assertEqual(rel.status, 'follow_request')
|
self.assertEqual(rel.status, 'follow_request')
|
||||||
|
|
||||||
|
|
||||||
def test_handle_unfollow(self):
|
def test_handle_unfollow(self):
|
||||||
self.remote_user.followers.add(self.local_user)
|
self.remote_user.followers.add(self.local_user)
|
||||||
self.assertEqual(self.remote_user.followers.count(), 1)
|
self.assertEqual(self.remote_user.followers.count(), 1)
|
||||||
outgoing.handle_unfollow(self.local_user, self.remote_user)
|
outgoing.handle_unfollow(self.local_user, self.remote_user)
|
||||||
|
|
||||||
self.assertEqual(self.remote_user.followers.count(), 0)
|
self.assertEqual(self.remote_user.followers.count(), 0)
|
||||||
|
|
||||||
|
|
||||||
|
def test_handle_accept(self):
|
||||||
|
rel = models.UserFollowRequest.objects.create(
|
||||||
|
user_subject=self.local_user,
|
||||||
|
user_object=self.remote_user
|
||||||
|
)
|
||||||
|
rel_id = rel.id
|
||||||
|
|
||||||
|
outgoing.handle_accept(rel)
|
||||||
|
# request should be deleted
|
||||||
|
self.assertEqual(
|
||||||
|
models.UserFollowRequest.objects.filter(id=rel_id).count(), 0
|
||||||
|
)
|
||||||
|
# follow relationship should exist
|
||||||
|
self.assertEqual(self.remote_user.followers.first(), self.local_user)
|
||||||
|
|
|
@ -473,7 +473,7 @@ def accept_follow_request(request):
|
||||||
# Request already dealt with.
|
# Request already dealt with.
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
outgoing.handle_accept(requester, request.user, follow_request)
|
outgoing.handle_accept(follow_request)
|
||||||
|
|
||||||
return redirect('/user/%s' % request.user.localname)
|
return redirect('/user/%s' % request.user.localname)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue