Makes shelbook user required
This commit is contained in:
parent
ee2b656b08
commit
ad7a045582
|
@ -0,0 +1,30 @@
|
||||||
|
# Generated by Django 3.0.7 on 2021-02-07 19:24
|
||||||
|
|
||||||
|
import bookwyrm.models.fields
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
def set_user(app_registry, schema_editor):
|
||||||
|
db_alias = schema_editor.connection.alias
|
||||||
|
shelfbook = app_registry.get_model('bookwyrm', 'ShelfBook')
|
||||||
|
for item in shelfbook.objects.using(db_alias).filter(user__isnull=True):
|
||||||
|
item.user = item.shelf.user
|
||||||
|
item.save(broadcast=False)
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('bookwyrm', '0043_auto_20210204_2223'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RunPython(set_user),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='shelfbook',
|
||||||
|
name='user',
|
||||||
|
field=bookwyrm.models.fields.ForeignKey(default=2, on_delete=django.db.models.deletion.PROTECT, to=settings.AUTH_USER_MODEL),
|
||||||
|
preserve_default=False,
|
||||||
|
),
|
||||||
|
]
|
|
@ -55,12 +55,7 @@ class ShelfBook(CollectionItemMixin, BookWyrmModel):
|
||||||
shelf = fields.ForeignKey(
|
shelf = fields.ForeignKey(
|
||||||
'Shelf', on_delete=models.PROTECT, activitypub_field='target')
|
'Shelf', on_delete=models.PROTECT, activitypub_field='target')
|
||||||
user = fields.ForeignKey(
|
user = fields.ForeignKey(
|
||||||
'User',
|
'User', on_delete=models.PROTECT, activitypub_field='actor')
|
||||||
blank=True,
|
|
||||||
null=True,
|
|
||||||
on_delete=models.PROTECT,
|
|
||||||
activitypub_field='actor'
|
|
||||||
)
|
|
||||||
|
|
||||||
activity_serializer = activitypub.AddBook
|
activity_serializer = activitypub.AddBook
|
||||||
object_field = 'book'
|
object_field = 'book'
|
||||||
|
|
|
@ -25,11 +25,12 @@ class ShelfViews(TestCase):
|
||||||
remote_id='https://example.com/book/1',
|
remote_id='https://example.com/book/1',
|
||||||
parent_work=self.work
|
parent_work=self.work
|
||||||
)
|
)
|
||||||
self.shelf = models.Shelf.objects.create(
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
name='Test Shelf',
|
self.shelf = models.Shelf.objects.create(
|
||||||
identifier='test-shelf',
|
name='Test Shelf',
|
||||||
user=self.local_user
|
identifier='test-shelf',
|
||||||
)
|
user=self.local_user
|
||||||
|
)
|
||||||
models.SiteSettings.objects.create()
|
models.SiteSettings.objects.create()
|
||||||
|
|
||||||
|
|
||||||
|
@ -96,7 +97,8 @@ class ShelfViews(TestCase):
|
||||||
'name': 'cool name'
|
'name': 'cool name'
|
||||||
})
|
})
|
||||||
request.user = self.local_user
|
request.user = self.local_user
|
||||||
view(request, request.user.username, shelf.identifier)
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
|
view(request, request.user.username, shelf.identifier)
|
||||||
shelf.refresh_from_db()
|
shelf.refresh_from_db()
|
||||||
|
|
||||||
self.assertEqual(shelf.name, 'cool name')
|
self.assertEqual(shelf.name, 'cool name')
|
||||||
|
@ -116,7 +118,8 @@ class ShelfViews(TestCase):
|
||||||
'name': 'cool name'
|
'name': 'cool name'
|
||||||
})
|
})
|
||||||
request.user = self.local_user
|
request.user = self.local_user
|
||||||
view(request, request.user.username, shelf.identifier)
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
|
view(request, request.user.username, shelf.identifier)
|
||||||
|
|
||||||
self.assertEqual(shelf.name, 'To Read')
|
self.assertEqual(shelf.name, 'To Read')
|
||||||
|
|
||||||
|
@ -128,7 +131,8 @@ class ShelfViews(TestCase):
|
||||||
'shelf': self.shelf.identifier
|
'shelf': self.shelf.identifier
|
||||||
})
|
})
|
||||||
request.user = self.local_user
|
request.user = self.local_user
|
||||||
views.shelve(request)
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
|
views.shelve(request)
|
||||||
# make sure the book is on the shelf
|
# make sure the book is on the shelf
|
||||||
self.assertEqual(self.shelf.books.get(), self.book)
|
self.assertEqual(self.shelf.books.get(), self.book)
|
||||||
|
|
||||||
|
@ -142,7 +146,8 @@ class ShelfViews(TestCase):
|
||||||
})
|
})
|
||||||
request.user = self.local_user
|
request.user = self.local_user
|
||||||
|
|
||||||
views.shelve(request)
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
|
views.shelve(request)
|
||||||
# make sure the book is on the shelf
|
# make sure the book is on the shelf
|
||||||
self.assertEqual(shelf.books.get(), self.book)
|
self.assertEqual(shelf.books.get(), self.book)
|
||||||
|
|
||||||
|
@ -156,7 +161,8 @@ class ShelfViews(TestCase):
|
||||||
})
|
})
|
||||||
request.user = self.local_user
|
request.user = self.local_user
|
||||||
|
|
||||||
views.shelve(request)
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
|
views.shelve(request)
|
||||||
# make sure the book is on the shelf
|
# make sure the book is on the shelf
|
||||||
self.assertEqual(shelf.books.get(), self.book)
|
self.assertEqual(shelf.books.get(), self.book)
|
||||||
|
|
||||||
|
@ -178,7 +184,12 @@ class ShelfViews(TestCase):
|
||||||
|
|
||||||
def test_handle_unshelve(self, _):
|
def test_handle_unshelve(self, _):
|
||||||
''' remove a book from a shelf '''
|
''' remove a book from a shelf '''
|
||||||
self.shelf.books.add(self.book)
|
with patch('bookwyrm.models.activitypub_mixin.broadcast_task.delay'):
|
||||||
|
models.ShelfBook.objects.create(
|
||||||
|
book=self.book,
|
||||||
|
user=self.local_user,
|
||||||
|
shelf=self.shelf
|
||||||
|
)
|
||||||
self.shelf.save()
|
self.shelf.save()
|
||||||
self.assertEqual(self.shelf.books.count(), 1)
|
self.assertEqual(self.shelf.books.count(), 1)
|
||||||
request = self.factory.post('', {
|
request = self.factory.post('', {
|
||||||
|
|
Loading…
Reference in New Issue