Newer
Older
from django.contrib.auth import get_user_model
from django.conf import settings
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
from django.urls import reverse
class TestOAuthAcces(TestCase):
def test_oauth_page_requires_login(self):
"""
This checks that /account/oauth requires the user to be logged in
"""
oauth_page = reverse('users:oauth')
response = self.client.get(oauth_page)
self.assertRedirects(response, reverse('users:login') + '?next=' + oauth_page)
@override_settings()
def test_oauth_not_set_up(self):
del settings.SOCIAL_AUTH_GOOGLE_OAUTH2_WHITELISTED_DOMAINS
self.login()
response = self.client.get(reverse('users:oauth'))
self.assertEqual(response.status_code, 403)
def test_oauth_user_email_not_whitelisted(self):
self.login()
response = self.client.get(reverse('users:oauth'))
self.assertEqual(response.status_code, 403)
@override_settings(SOCIAL_AUTH_GOOGLE_OAUTH2_WHITELISTED_DOMAINS=['email.com'])
def test_oauth_whitelisted_user_can_access_oauth_settings_page(self):
"""
Checks that the test user can access the OAuth page as their email is whitelisted
"""
self.login()
response = self.client.get(reverse('users:account'))
self.assertContains(response, 'Manage OAuth')
response = self.client.get(reverse('users:oauth'))
self.assertEqual(response.status_code, 200)
self.assertContains(response, 'Google OAuth')
self.assertNotContains(response, 'Disconnect Google OAuth')
self.assertTemplateUsed(response, 'users/oauth.html')
def login(self):
user = get_user_model().objects.create_user(username='test', email='test@email.com', password='password')
self.assertTrue(
self.client.login(username='test', password='password')
)
return user