123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- from django.urls import reverse
- from misago.threads import testutils
- from .test_threads_api import ThreadsApiTestCase
- class ThreadPostEditsApiTestCase(ThreadsApiTestCase):
- def setUp(self):
- super().setUp()
- self.post = testutils.reply_thread(self.thread, poster=self.user)
- self.api_link = reverse(
- 'misago:api:thread-post-edits',
- kwargs={
- 'thread_pk': self.thread.pk,
- 'pk': self.post.pk,
- }
- )
- self.override_acl()
- def mock_edit_record(self):
- edits_record = [
- self.post.edits_record.create(
- category=self.category,
- thread=self.thread,
- editor=self.user,
- editor_name=self.user.username,
- editor_slug=self.user.slug,
- edited_from="Original body",
- edited_to="First Edit",
- ),
- self.post.edits_record.create(
- category=self.category,
- thread=self.thread,
- editor_name='Deleted',
- editor_slug='deleted',
- edited_from="First Edit",
- edited_to="Second Edit",
- ),
- self.post.edits_record.create(
- category=self.category,
- thread=self.thread,
- editor=self.user,
- editor_name=self.user.username,
- editor_slug=self.user.slug,
- edited_from="Second Edit",
- edited_to="Last Edit",
- ),
- ]
- self.post.original = 'Last Edit'
- self.post.parsed = '<p>Last Edit</p>'
- self.post.save()
- return edits_record
- class ThreadPostGetEditTests(ThreadPostEditsApiTestCase):
- def test_no_edits(self):
- """api returns 403 if post has no edits record"""
- response = self.client.get(self.api_link)
- self.assertContains(response, "Edits record is unavailable", status_code=403)
- self.logout_user()
- response = self.client.get(self.api_link)
- self.assertContains(response, "Edits record is unavailable", status_code=403)
- def test_empty_edit_id(self):
- """api handles empty edit in querystring"""
- response = self.client.get('{}?edit='.format(self.api_link))
- self.assertEqual(response.status_code, 404)
- def test_invalid_edit_id(self):
- """api handles invalid edit in querystring"""
- response = self.client.get('{}?edit=dsa67d8sa68'.format(self.api_link))
- self.assertEqual(response.status_code, 404)
- def test_nonexistant_edit_id(self):
- """api handles nonexistant edit in querystring"""
- response = self.client.get('{}?edit=1321'.format(self.api_link))
- self.assertEqual(response.status_code, 404)
- def test_get_last_edit(self):
- """api returns last edit record"""
- edits = self.mock_edit_record()
- response = self.client.get(self.api_link)
- self.assertEqual(response.status_code, 200)
- response_json = response.json()
- self.assertEqual(response_json['id'], edits[-1].id)
- self.assertIsNone(response_json['next'])
- self.assertEqual(response_json['previous'], edits[1].id)
- def test_get_middle_edit(self):
- """api returns middle edit record"""
- edits = self.mock_edit_record()
- response = self.client.get('{}?edit={}'.format(self.api_link, edits[1].id))
- self.assertEqual(response.status_code, 200)
- response_json = response.json()
- self.assertEqual(response_json['id'], edits[1].id)
- self.assertEqual(response_json['next'], edits[-1].id)
- self.assertEqual(response_json['previous'], edits[0].id)
- def test_get_first_edit(self):
- """api returns middle edit record"""
- edits = self.mock_edit_record()
- response = self.client.get('{}?edit={}'.format(self.api_link, edits[0].id))
- self.assertEqual(response.status_code, 200)
- response_json = response.json()
- self.assertEqual(response_json['id'], edits[0].id)
- self.assertEqual(response_json['next'], edits[1].id)
- self.assertIsNone(response_json['previous'])
- class ThreadPostPostEditTests(ThreadPostEditsApiTestCase):
- def setUp(self):
- super().setUp()
- self.edits = self.mock_edit_record()
- self.override_acl({'can_edit_posts': 2})
- def test_empty_edit_id(self):
- """api handles empty edit in querystring"""
- response = self.client.post('{}?edit='.format(self.api_link))
- self.assertEqual(response.status_code, 404)
- def test_invalid_edit_id(self):
- """api handles invalid edit in querystring"""
- response = self.client.post('{}?edit=dsa67d8sa68'.format(self.api_link))
- self.assertEqual(response.status_code, 404)
- def test_nonexistant_edit_id(self):
- """api handles nonexistant edit in querystring"""
- response = self.client.post('{}?edit=1321'.format(self.api_link))
- self.assertEqual(response.status_code, 404)
- def test_anonymous(self):
- """only signed in users can rever ports"""
- self.logout_user()
- response = self.client.post('{}?edit={}'.format(self.api_link, self.edits[0].id))
- self.assertEqual(response.status_code, 403)
- def test_no_permission(self):
- """api validates permission to revert post"""
- self.override_acl({'can_edit_posts': 0})
- response = self.client.post('{}?edit=1321'.format(self.api_link))
- self.assertEqual(response.status_code, 403)
- def test_revert_post(self):
- """api reverts post to version from before specified edit"""
- response = self.client.post('{}?edit={}'.format(self.api_link, self.edits[0].id))
- self.assertEqual(response.status_code, 200)
- response_json = response.json()
- self.assertEqual(response_json['edits'], 1)
- self.assertEqual(response_json['content'], "<p>Original body</p>")
- self.assertEqual(self.post.edits_record.count(), 4)
- edit = self.post.edits_record.first()
- self.assertEqual(edit.edited_from, self.post.original)
- self.assertEqual(edit.edited_to, "Original body")
|