test_threads_api.py 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. import json
  2. from misago.acl.testutils import override_acl
  3. from misago.users.testutils import AuthenticatedUserTestCase
  4. from misago.categories.models import CATEGORIES_TREE_ID, Category
  5. from misago.threads import testutils
  6. from misago.threads.models import Thread
  7. class ThreadsApiTestCase(AuthenticatedUserTestCase):
  8. def setUp(self):
  9. super(ThreadsApiTestCase, self).setUp()
  10. self.root = Category.objects.get(tree_id=CATEGORIES_TREE_ID, level=0)
  11. self.category = Category.objects.get(slug='first-category')
  12. self.thread = testutils.post_thread(category=self.category)
  13. self.api_link = self.thread.get_api_url()
  14. def override_acl(self, acl):
  15. final_acl = {
  16. 'can_see': 1,
  17. 'can_browse': 1,
  18. 'can_see_all_threads': 1,
  19. 'can_see_own_threads': 0,
  20. 'can_hide_threads': 0,
  21. 'can_approve_content': 0,
  22. }
  23. final_acl.update(acl)
  24. override_acl(self.user, {
  25. 'categories': {
  26. self.category.pk: final_acl
  27. }
  28. })
  29. def get_thread_json(self):
  30. response = self.client.get(self.thread.get_api_url())
  31. self.assertEqual(response.status_code, 200)
  32. return json.loads(response.content)
  33. class ThreadDeleteApiTests(ThreadsApiTestCase):
  34. def test_delete_thread(self):
  35. """DELETE to API link with permission deletes thread"""
  36. self.override_acl({
  37. 'can_hide_threads': 2
  38. })
  39. response = self.client.delete(self.api_link)
  40. self.assertEqual(response.status_code, 200)
  41. with self.assertRaises(Thread.DoesNotExist):
  42. Thread.objects.get(pk=self.thread.pk)
  43. def test_delete_thread_no_permission(self):
  44. """DELETE to API link with no permission to delete fails"""
  45. self.override_acl({
  46. 'can_hide_threads': 1
  47. })
  48. response = self.client.delete(self.api_link)
  49. self.assertEqual(response.status_code, 403)
  50. self.override_acl({
  51. 'can_hide_threads': 0
  52. })
  53. response_json = json.loads(response.content)
  54. self.assertEqual(response_json['detail'],
  55. "You don't have permission to delete this thread.")
  56. response = self.client.delete(self.api_link)
  57. self.assertEqual(response.status_code, 403)
  58. class ThreadsReadApiTests(ThreadsApiTestCase):
  59. def setUp(self):
  60. super(ThreadsReadApiTests, self).setUp()
  61. self.api_link = '/api/threads/read/'
  62. def test_read_all_threads(self):
  63. """api sets all threads as read"""
  64. response = self.client.post(self.api_link)
  65. self.assertEqual(response.status_code, 200)
  66. self.assertEqual(self.user.categoryread_set.count(), 2)
  67. def test_read_threads_in_category(self):
  68. """api sets threads in category as read"""
  69. response = self.client.post(
  70. '%s?category=%s' % (self.api_link, self.category.pk))
  71. self.assertEqual(response.status_code, 200)
  72. self.assertEqual(self.user.categoryread_set.count(), 1)