You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. from django.core import mail
  2. from django.urls import reverse, reverse_lazy
  3. from django.utils.translation import gettext_lazy as _
  4. from webtest import AppError
  5. from oscar.core.compat import get_user_model
  6. from oscar.core.loading import get_model
  7. from oscar.test.factories import ProductAlertFactory, UserFactory
  8. from oscar.test.testcases import WebTestCase
  9. User = get_user_model()
  10. ProductAlert = get_model('customer', 'ProductAlert')
  11. class IndexViewTests(WebTestCase):
  12. is_staff = True
  13. active_users_ids = []
  14. inactive_users_ids = []
  15. csrf_checks = False
  16. def setUp(self):
  17. super().setUp()
  18. for i in range(1, 25):
  19. UserFactory(is_active=True)
  20. for i in range(1, 25):
  21. UserFactory(is_active=False)
  22. user_queryset = User.objects.all()
  23. self.active_users_ids = user_queryset.filter(is_active=True).values_list('id', flat=True)
  24. self.inactive_users_ids = user_queryset.filter(is_active=False).values_list('id', flat=True)
  25. def test_user_list_view(self):
  26. response = self.get(reverse('dashboard:users-index'))
  27. self.assertInContext(response, 'users')
  28. def test_make_active(self):
  29. params = {'action': 'make_active',
  30. 'selected_user': self.inactive_users_ids}
  31. response = self.post(reverse('dashboard:users-index'), params=params)
  32. ex_inactive = User.objects.get(id=self.inactive_users_ids[10])
  33. self.assertIsRedirect(response)
  34. self.assertTrue(ex_inactive.is_active)
  35. def test_make_inactive(self):
  36. params = {'action': 'make_inactive',
  37. 'selected_user': self.active_users_ids}
  38. response = self.post(reverse('dashboard:users-index'), params=params)
  39. ex_active = User.objects.get(id=self.active_users_ids[10])
  40. self.assertIsRedirect(response)
  41. self.assertFalse(ex_active.is_active)
  42. class DetailViewTests(WebTestCase):
  43. is_staff = True
  44. def test_user_detail_view(self):
  45. response = self.get(
  46. reverse('dashboard:user-detail', kwargs={'pk': self.user.pk}))
  47. self.assertInContext(response, 'user')
  48. self.assertIsOk(response)
  49. class TestDetailViewForStaffUser(WebTestCase):
  50. is_staff = True
  51. def setUp(self):
  52. self.customer = UserFactory(
  53. username='jane', email='jane@example.org', password='password')
  54. super().setUp()
  55. def test_password_reset_url_only_available_via_post(self):
  56. try:
  57. reset_url = reverse(
  58. 'dashboard:user-password-reset',
  59. kwargs={'pk': self.customer.id}
  60. )
  61. self.get(reset_url)
  62. except AppError as e:
  63. self.assertIn('405', e.args[0])
  64. def test_admin_can_reset_user_passwords(self):
  65. customer_page_url = reverse(
  66. 'dashboard:user-detail',
  67. kwargs={'pk': self.customer.id}
  68. )
  69. customer_page = self.get(customer_page_url)
  70. reset_form = customer_page.forms['password_reset_form']
  71. response = reset_form.submit()
  72. # Check that the staff user is redirected back to the customer page
  73. self.assertRedirects(response, customer_page_url)
  74. # Check that the reset email has been sent
  75. self.assertEqual(len(mail.outbox), 1)
  76. self.assertIn("Resetting your password", mail.outbox[0].subject)
  77. # Check that success message shows up
  78. self.assertContains(
  79. response.follow(),
  80. _("A password reset email has been sent")
  81. )
  82. class SearchTests(WebTestCase):
  83. is_staff = True
  84. url = reverse_lazy('dashboard:users-index')
  85. def setUp(self):
  86. UserFactory(
  87. username='lars', email='lars@example.org', first_name='Lars', last_name='van der Berg')
  88. UserFactory(
  89. username='owen', email='owen@example.org', first_name='Owen', last_name='Davies')
  90. UserFactory(
  91. username='robalan', email='robalan@example.org', first_name='Rob Alan', last_name='Lewis'
  92. )
  93. super().setUp()
  94. def _search_by_form_args(self, form_args):
  95. response = self.get(self.url)
  96. search_form = response.forms[0]
  97. for field_name, val in form_args.items():
  98. search_form[field_name] = val
  99. search_response = search_form.submit('search')
  100. data = search_response.context['users'].data
  101. return data
  102. def test_user_name_2_parts(self):
  103. data = self._search_by_form_args({'name': 'Owen Davies'})
  104. self.assertEqual(len(data), 1)
  105. self.assertEqual(data[0].email, 'owen@example.org')
  106. self.assertEqual(data[0].first_name, 'Owen')
  107. self.assertEqual(data[0].last_name, 'Davies')
  108. def test_user_name_3_parts(self):
  109. data = self._search_by_form_args({'name': 'Rob Alan Lewis'})
  110. self.assertEqual(len(data), 1)
  111. self.assertEqual(data[0].email, 'robalan@example.org')
  112. self.assertEqual(data[0].first_name, 'Rob Alan')
  113. self.assertEqual(data[0].last_name, 'Lewis')
  114. def test_user_name_4_parts(self):
  115. data = self._search_by_form_args({'name': 'Lars van der Berg'})
  116. self.assertEqual(len(data), 1)
  117. self.assertEqual(data[0].email, 'lars@example.org')
  118. self.assertEqual(data[0].first_name, 'Lars')
  119. self.assertEqual(data[0].last_name, 'van der Berg')
  120. class ProductAlertListViewTestCase(WebTestCase):
  121. is_staff = True
  122. def test_list_view_get_queryset_ordering(self):
  123. ProductAlertFactory.create_batch(3)
  124. response = self.get(reverse('dashboard:user-alert-list'))
  125. self.assertEqual(
  126. list(response.context['alerts']),
  127. list(ProductAlert.objects.order_by('-date_created'))
  128. )
  129. def test_list_view_status_filtering(self):
  130. ProductAlertFactory.create_batch(3, status=ProductAlert.CANCELLED)
  131. ProductAlertFactory.create_batch(2, status=ProductAlert.ACTIVE)
  132. response = self.get(reverse('dashboard:user-alert-list'), params={'status': ProductAlert.ACTIVE})
  133. self.assertEqual(len(response.context['alerts']), 2)