test_auth_api.py 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import json
  2. from django.contrib.auth import get_user_model
  3. from django.core.urlresolvers import reverse
  4. from django.test import TestCase
  5. from misago.users.models import Ban, BAN_USERNAME
  6. class AuthenticateAPITests(TestCase):
  7. def test_api_invalid_credentials(self):
  8. """login api returns 400 on invalid POST"""
  9. response = self.client.post(
  10. reverse('misago:api:login'),
  11. data={'username': 'nope', 'password': 'nope'})
  12. self.assertEqual(response.status_code, 400)
  13. self.assertIn("Login or password is incorrect.", response.content)
  14. response = self.client.get(reverse('misago:api:auth_user'))
  15. self.assertEqual(response.status_code, 200)
  16. user_json = json.loads(response.content)
  17. self.assertIsNone(user_json['id'])
  18. def test_api_signin(self):
  19. """api signs user in"""
  20. User = get_user_model()
  21. user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  22. response = self.client.post(
  23. reverse('misago:api:login'),
  24. data={'username': 'Bob', 'password': 'Pass.123'})
  25. self.assertEqual(response.status_code, 200)
  26. response = self.client.get(reverse('misago:api:auth_user'))
  27. self.assertEqual(response.status_code, 200)
  28. user_json = json.loads(response.content)
  29. self.assertEqual(user_json['id'], user.id)
  30. self.assertEqual(user_json['username'], user.username)
  31. def test_api_signin_banned(self):
  32. """login api fails to sign banned user in"""
  33. User = get_user_model()
  34. User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  35. ban = Ban.objects.create(check_type=BAN_USERNAME,
  36. banned_value='bob',
  37. user_message='You are tragically banned.')
  38. response = self.client.post(
  39. reverse('misago:api:login'),
  40. data={'username': 'Bob', 'password': 'Pass.123'})
  41. self.assertEqual(response.status_code, 400)
  42. response_json = json.loads(response.content)
  43. self.assertEqual(response_json['code'], 'banned')
  44. self.assertEqual(response_json['detail']['message']['plain'],
  45. ban.user_message)
  46. self.assertEqual(response_json['detail']['message']['html'],
  47. '<p>%s</p>' % ban.user_message)
  48. def test_api_signin_inactive_admin(self):
  49. """login api fails to sign admin-activated user in"""
  50. User = get_user_model()
  51. User.objects.create_user('Bob', 'bob@test.com', 'Pass.123',
  52. requires_activation=1)
  53. response = self.client.post(
  54. reverse('misago:api:login'),
  55. data={'username': 'Bob', 'password': 'Pass.123'})
  56. self.assertEqual(response.status_code, 400)
  57. response_json = json.loads(response.content)
  58. self.assertEqual(response_json['code'], 'inactive_user')
  59. def test_api_signin_inactive_user(self):
  60. """login api fails to sign user-activated user in"""
  61. User = get_user_model()
  62. User.objects.create_user('Bob', 'bob@test.com', 'Pass.123',
  63. requires_activation=2)
  64. response = self.client.post(
  65. reverse('misago:api:login'),
  66. data={'username': 'Bob', 'password': 'Pass.123'})
  67. self.assertEqual(response.status_code, 400)
  68. response_json = json.loads(response.content)
  69. self.assertEqual(response_json['code'], 'inactive_admin')