forked from mirrors/bookwyrm
more activitystreams tests
This commit is contained in:
parent
d147c6ac2f
commit
82ad1abe9a
2 changed files with 74 additions and 1 deletions
69
bookwyrm/tests/activitystreams/test_signals.py
Normal file
69
bookwyrm/tests/activitystreams/test_signals.py
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
""" testing activitystreams """
|
||||||
|
from unittest.mock import patch
|
||||||
|
from django.test import TestCase
|
||||||
|
from bookwyrm import activitystreams, models
|
||||||
|
|
||||||
|
|
||||||
|
@patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay")
|
||||||
|
class ActivitystreamsSignals(TestCase):
|
||||||
|
"""using redis to build activity streams"""
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
"""use a test csv"""
|
||||||
|
with patch("bookwyrm.suggested_users.rerank_suggestions_task.delay"), patch(
|
||||||
|
"bookwyrm.activitystreams.populate_stream_task.delay"
|
||||||
|
):
|
||||||
|
self.local_user = models.User.objects.create_user(
|
||||||
|
"mouse", "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",
|
||||||
|
)
|
||||||
|
work = models.Work.objects.create(title="test work")
|
||||||
|
self.book = models.Edition.objects.create(title="test book", parent_work=work)
|
||||||
|
|
||||||
|
|
||||||
|
def test_add_status_on_create_ignore(self, _):
|
||||||
|
"""a new statuses has entered"""
|
||||||
|
activitystreams.add_status_on_create(models.User, self.local_user, False)
|
||||||
|
|
||||||
|
def test_add_status_on_create_deleted(self, _):
|
||||||
|
"""a new statuses has entered"""
|
||||||
|
with patch("bookwyrm.activitystreams.remove_status_task.delay"):
|
||||||
|
status = models.Status.objects.create(
|
||||||
|
user=self.remote_user, content="hi", privacy="public", deleted=True
|
||||||
|
)
|
||||||
|
with patch("bookwyrm.activitystreams.remove_status_task.delay") as mock:
|
||||||
|
activitystreams.add_status_on_create(models.Status, status, False)
|
||||||
|
self.assertEqual(mock.call_count, 1)
|
||||||
|
args = mock.call_args[0]
|
||||||
|
self.assertEqual(args[0], status.id)
|
||||||
|
|
||||||
|
def test_add_status_on_create_created(self, _):
|
||||||
|
"""a new statuses has entered"""
|
||||||
|
status = models.Status.objects.create(
|
||||||
|
user=self.remote_user, content="hi", privacy="public"
|
||||||
|
)
|
||||||
|
with patch("bookwyrm.activitystreams.add_status_task.delay") as mock:
|
||||||
|
activitystreams.add_status_on_create_command(models.Status, status, False)
|
||||||
|
self.assertEqual(mock.call_count, 1)
|
||||||
|
args = mock.call_args[0]
|
||||||
|
self.assertEqual(args[0], status.id)
|
||||||
|
|
||||||
|
def test_populate_streams_on_account_create(self):
|
||||||
|
"""create streams for a user"""
|
||||||
|
with patch("bookwyrm.activitystreams.populate_stream_task") as mock:
|
||||||
|
activitystreams.populate_streams_on_account_create(
|
||||||
|
models.User, self.local_user, True
|
||||||
|
)
|
||||||
|
self.assertEqual(mock.call_count, 3)
|
||||||
|
args = mock.call_args[0]
|
||||||
|
self.assertEqual(args[0], "home")
|
||||||
|
self.assertEqual(args[1], self.local_user.id)
|
|
@ -24,7 +24,8 @@ class Activitystreams(TestCase):
|
||||||
)
|
)
|
||||||
work = models.Work.objects.create(title="test work")
|
work = models.Work.objects.create(title="test work")
|
||||||
self.book = models.Edition.objects.create(title="test book", parent_work=work)
|
self.book = models.Edition.objects.create(title="test book", parent_work=work)
|
||||||
self.status = models.Status.objects.create(content="hi", user=self.local_user)
|
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
|
||||||
|
self.status = models.Status.objects.create(content="hi", user=self.local_user)
|
||||||
|
|
||||||
def test_add_book_statuses_task(self):
|
def test_add_book_statuses_task(self):
|
||||||
"""statuses related to a book"""
|
"""statuses related to a book"""
|
||||||
|
@ -120,6 +121,7 @@ class Activitystreams(TestCase):
|
||||||
|
|
||||||
@patch("bookwyrm.activitystreams.LocalStream.remove_object_from_related_stores")
|
@patch("bookwyrm.activitystreams.LocalStream.remove_object_from_related_stores")
|
||||||
@patch("bookwyrm.activitystreams.BooksStream.remove_object_from_related_stores")
|
@patch("bookwyrm.activitystreams.BooksStream.remove_object_from_related_stores")
|
||||||
|
@patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay")
|
||||||
def test_boost_to_another_timeline(self, *_):
|
def test_boost_to_another_timeline(self, *_):
|
||||||
"""add a boost and deduplicate the boosted status on the timeline"""
|
"""add a boost and deduplicate the boosted status on the timeline"""
|
||||||
status = models.Status.objects.create(user=self.local_user, content="hi")
|
status = models.Status.objects.create(user=self.local_user, content="hi")
|
||||||
|
@ -142,6 +144,7 @@ class Activitystreams(TestCase):
|
||||||
|
|
||||||
@patch("bookwyrm.activitystreams.LocalStream.remove_object_from_related_stores")
|
@patch("bookwyrm.activitystreams.LocalStream.remove_object_from_related_stores")
|
||||||
@patch("bookwyrm.activitystreams.BooksStream.remove_object_from_related_stores")
|
@patch("bookwyrm.activitystreams.BooksStream.remove_object_from_related_stores")
|
||||||
|
@patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay")
|
||||||
def test_boost_to_following_timeline(self, *_):
|
def test_boost_to_following_timeline(self, *_):
|
||||||
"""add a boost and deduplicate the boosted status on the timeline"""
|
"""add a boost and deduplicate the boosted status on the timeline"""
|
||||||
self.local_user.following.add(self.another_user)
|
self.local_user.following.add(self.another_user)
|
||||||
|
@ -167,6 +170,7 @@ class Activitystreams(TestCase):
|
||||||
|
|
||||||
@patch("bookwyrm.activitystreams.LocalStream.remove_object_from_related_stores")
|
@patch("bookwyrm.activitystreams.LocalStream.remove_object_from_related_stores")
|
||||||
@patch("bookwyrm.activitystreams.BooksStream.remove_object_from_related_stores")
|
@patch("bookwyrm.activitystreams.BooksStream.remove_object_from_related_stores")
|
||||||
|
@patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay")
|
||||||
def test_boost_to_same_timeline(self, *_):
|
def test_boost_to_same_timeline(self, *_):
|
||||||
"""add a boost and deduplicate the boosted status on the timeline"""
|
"""add a boost and deduplicate the boosted status on the timeline"""
|
||||||
status = models.Status.objects.create(user=self.local_user, content="hi")
|
status = models.Status.objects.create(user=self.local_user, content="hi")
|
||||||
|
|
Loading…
Reference in a new issue