summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorankitjavalkar2017-02-07 10:36:30 +0530
committerankitjavalkar2017-02-07 10:36:30 +0530
commit820448e70830d8248e91a19a225e43673877f0c1 (patch)
treedf69eda511be9571ce22dd9ad2867277545179a2
parenta3886ca604760acee2940daae162940e86b7ac98 (diff)
downloadonline_test-820448e70830d8248e91a19a225e43673877f0c1.tar.gz
online_test-820448e70830d8248e91a19a225e43673877f0c1.tar.bz2
online_test-820448e70830d8248e91a19a225e43673877f0c1.zip
Add view test case for password reset and password change
-rw-r--r--yaksh/test_views.py69
1 files changed, 69 insertions, 0 deletions
diff --git a/yaksh/test_views.py b/yaksh/test_views.py
index e052441..7757f70 100644
--- a/yaksh/test_views.py
+++ b/yaksh/test_views.py
@@ -2,6 +2,7 @@ from datetime import datetime
import pytz
import os
from django.contrib.auth.models import Group
+from django.contrib.auth import authenticate
from django.core.urlresolvers import reverse
from django.test import TestCase
from django.test import Client
@@ -48,6 +49,7 @@ class TestProfile(TestCase):
self.user1.delete()
self.user2.delete()
+
def test_has_profile_for_user_without_profile(self):
"""
If no profile exists for user passed as argument return False
@@ -1573,3 +1575,70 @@ class TestGrader(TestCase):
# Then
self.assertEqual(response.status_code, 404)
+
+class TestPasswordReset(TestCase):
+ def setUp(self):
+ # Create User with profile
+ self.user1_plaintext_pass = 'demo1'
+ self.user1 = User.objects.create_user(
+ username='demo_user1',
+ password=self.user1_plaintext_pass,
+ first_name='first_name',
+ last_name='last_name',
+ email='demo1@test.com'
+ )
+
+ Profile.objects.create(
+ user=self.user1,
+ roll_number=10,
+ institute='IIT',
+ department='Chemical',
+ position='Student',
+ timezone='UTC'
+ )
+
+ def tearDown(self):
+ self.user1.delete()
+
+ def test_password_reset_post(self):
+ """
+ POST request to password_reset view should return a valid response
+ """
+ # When
+ response = self.client.post(reverse('password_reset'),
+ data={
+ 'email': self.user1.email,
+ }
+ )
+
+ # Then
+ self.assertEqual(response.context['email'], self.user1.email)
+ self.assertEqual(response.status_code, 302)
+ self.assertRedirects(response, '/exam/reset/password_reset/mail_sent/')
+
+ def test_password_change_post(self):
+ """
+ POST request to password_change view should change the user password
+ """
+ # Given
+ self.client.login(
+ username=self.user1.username,
+ password=self.user1_plaintext_pass
+ )
+
+ # When
+ response = self.client.post(reverse('password_change'),
+ data={
+ 'old_password': self.user1_plaintext_pass,
+ 'new_password1': 'new_demo1_pass',
+ 'new_password2': 'new_demo1_pass'
+ }
+ )
+
+ # Then
+ self.assertIsNotNone(authenticate(username='demo_user1', password='new_demo1_pass'))
+ self.assertEqual(response.status_code, 302)
+ self.assertRedirects(response, '/exam/reset/password_change/done/')
+
+ # Finally
+ self.client.logout()