From 3f5bb41380be0587c3dae4ba9724d0e66f4b039b Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Sun, 17 Jul 2022 15:59:51 -0700 Subject: [PATCH 1/2] Unit test for creating rating status --- bookwyrm/tests/views/test_status.py | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/bookwyrm/tests/views/test_status.py b/bookwyrm/tests/views/test_status.py index 1159b3863..e05d888e5 100644 --- a/bookwyrm/tests/views/test_status.py +++ b/bookwyrm/tests/views/test_status.py @@ -76,6 +76,28 @@ class StatusViews(TestCase): self.assertEqual(status.book, self.book) self.assertIsNone(status.edited_date) + def test_create_status_rating(self, *_): + """create a status""" + view = views.CreateStatus.as_view() + form = forms.RatingForm( + { + "user": self.local_user.id, + "rating": 4, + "book": self.book.id, + "privacy": "public", + } + ) + request = self.factory.post("", form.data) + request.user = self.local_user + + view(request, "rating") + + status = models.ReviewRating.objects.get() + self.assertEqual(status.user, self.local_user) + self.assertEqual(status.book, self.book) + self.assertEqual(status.rating, 4.0) + self.assertIsNone(status.edited_date) + def test_create_status_wrong_user(self, *_): """You can't compose statuses for someone else""" view = views.CreateStatus.as_view() From 639b727c92670ba35c0159358f6a531e8375b344 Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Sun, 17 Jul 2022 16:21:43 -0700 Subject: [PATCH 2/2] Fixes perms check for ratings --- bookwyrm/models/status.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/bookwyrm/models/status.py b/bookwyrm/models/status.py index 3949e09a9..fce69cae2 100644 --- a/bookwyrm/models/status.py +++ b/bookwyrm/models/status.py @@ -218,7 +218,8 @@ class Status(OrderedCollectionPageMixin, BookWyrmModel): """certain types of status aren't editable""" # first, the standard raise super().raise_not_editable(viewer) - if isinstance(self, (GeneratedNote, ReviewRating)): + # if it's an edit (not a create) you can only edit content statuses + if self.id and isinstance(self, (GeneratedNote, ReviewRating)): raise PermissionDenied() @classmethod