aboutsummaryrefslogtreecommitdiff
blob: b6e641dc6e57c92a6345c381e57d40a7e6830caa (plain)
1
2
3
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
54
55
56
57
58
59
60
61
62
# vim:fileencoding=utf8:et:ts=4:sts=4:sw=4:ft=python

from django.conf import settings
from django.test import TestCase
from django.test.client import Client
from mockldap import MockLdap

from .. import vars


class SignupIntegrationTests(TestCase):
    @classmethod
    def setUpClass(cls):
        cls.mockldap = MockLdap(vars.DIRECTORY)

    def setUp(self):
        self.client = Client()
        self.mockldap.start()
        self.ldapobject = self.mockldap[settings.AUTH_LDAP_SERVER_URI]

    def tearDown(self):
        self.mockldap.stop()

    def test_signup_page_uses_correct_template(self):
        response = self.client.get('/signup/')
        self.assertTemplateUsed(response, 'signup.html')

    def test_wrong_activation_link_redirects_to_login(self):
        vars.QUEUEDUSER.save()
        response = self.client.get('/activate/invalidurl/')
        self.assertRedirects(response, '/login/', 302, 200)

    def test_valid_data_to_signup_redirects_to_login(self):
        response = self.client.post('/signup/', vars.SIGNUP_TESTUSER)
        self.assertRedirects(response, '/login/', 302, 200)

    def test_logged_in_user_signup_url_redirects_to_index(self):
        self.client.post('/login/', vars.LOGIN_ALICE)
        response = self.client.get('/signup/')
        self.assertRedirects(response, '/', 302, 200)

    def test_logged_in_user_activate_url_redirects_to_index(self):
        vars.QUEUEDUSER.save()
        activate_url = '/activate/%s/' % vars.QUEUEDUSER.encrypted_id
        self.client.post('/login/', vars.LOGIN_ALICE)
        response = self.client.get(activate_url)
        self.assertRedirects(response, '/', 302, 200)


class SignupIntegrationTestsNoLDAP(TestCase):
    def setUp(self):
        self.client = Client()

    def test_activate_no_ldap_connection_redirects_to_login(self):
        vars.QUEUEDUSER.save()
        activate_url = '/activate/%s/' % vars.QUEUEDUSER.encrypted_id
        response = self.client.get(activate_url)
        self.assertRedirects(response, '/login/', 302, 200)

    def test_activate_page_without_token_returns_404(self):
        response = self.client.get('/activate/')
        self.assertTrue(response.status_code, 404)