diff options
Diffstat (limited to 'workshop_app')
-rw-r--r-- | workshop_app/models.py | 7 | ||||
-rw-r--r-- | workshop_app/templates/workshop_app/activation.html | 20 | ||||
-rw-r--r-- | workshop_app/templates/workshop_app/create_workshop.html | 2 | ||||
-rw-r--r-- | workshop_app/templates/workshop_app/how_to_participate.html | 2 | ||||
-rw-r--r-- | workshop_app/test_models.py | 189 | ||||
-rw-r--r-- | workshop_app/test_views.py | 245 | ||||
-rw-r--r-- | workshop_app/tests.py | 3 | ||||
-rw-r--r-- | workshop_app/urls.py | 47 | ||||
-rw-r--r-- | workshop_app/views.py | 6 |
9 files changed, 507 insertions, 14 deletions
diff --git a/workshop_app/models.py b/workshop_app/models.py index 8eae29e..422eee7 100644 --- a/workshop_app/models.py +++ b/workshop_app/models.py @@ -23,11 +23,12 @@ class Profile(models.Model): phone_number = models.CharField( max_length=15, validators=[RegexValidator( - regex=r'^\+?1?\d{9,15}$', message=( + regex=r'^.{9}$', message=( "Phone number must be entered \ - in the format: '+929490956'.\ + in the format: '+99999999'.\ Up to 15 digits allowed.") - )]) + )] + ,null=False) position = models.CharField(max_length=32, choices=position_choices) is_email_verified = models.BooleanField(default=False) activation_key = models.CharField(max_length=255, blank=True, null=True) diff --git a/workshop_app/templates/workshop_app/activation.html b/workshop_app/templates/workshop_app/activation.html index 1262e22..88bada9 100644 --- a/workshop_app/templates/workshop_app/activation.html +++ b/workshop_app/templates/workshop_app/activation.html @@ -21,11 +21,25 @@ {% endblock %} {% block content %} - {% if status %} + {% if status == '2' %} <div class="container"> <div class="jumbotron"> - <p>{{ status }}</p> - {{ request.user.profile.activation_key }} + <p> Your email is already verified, Please view your profile <a href="{{ URL_ROOT }}/view_profile/">here</a> </p> + + </div> + </div> + {% elif status == '1' %} + <div class="container"> + <div class="jumbotron"> + <p> Your activation has expired please register again</p> + + </div> + </div> + {% elif status == '0' %} + <div class="container"> + <div class="jumbotron"> + <p> Your account has been activated. Please view your profile <a href="{{ URL_ROOT }}/view_profile/">here</a> </p> + </div> </div> {% else %} diff --git a/workshop_app/templates/workshop_app/create_workshop.html b/workshop_app/templates/workshop_app/create_workshop.html index 2977a58..8b4d4d1 100644 --- a/workshop_app/templates/workshop_app/create_workshop.html +++ b/workshop_app/templates/workshop_app/create_workshop.html @@ -1,7 +1,7 @@ {% extends "workshop_app/base.html" %} {% block title %} - Create Event + Create Workshop {% endblock %} {% block extra %} diff --git a/workshop_app/templates/workshop_app/how_to_participate.html b/workshop_app/templates/workshop_app/how_to_participate.html index 0d8cc6f..c732a7f 100644 --- a/workshop_app/templates/workshop_app/how_to_participate.html +++ b/workshop_app/templates/workshop_app/how_to_participate.html @@ -1,7 +1,7 @@ {% extends 'workshop_app/base.html' %} {% block title %} - View Benefits + How to Participate {% endblock %} {% block extra %} diff --git a/workshop_app/test_models.py b/workshop_app/test_models.py new file mode 100644 index 0000000..c9ac41c --- /dev/null +++ b/workshop_app/test_models.py @@ -0,0 +1,189 @@ +from django.test import TestCase +from .models import ( + Profile, User, Workshop, WorkshopType, + RequestedWorkshop, BookedWorkshop, ProposeWorkshopDate + ) +from datetime import datetime + +# Setup for Model Test +def setUpModule(): + ''' + Sets up database + demo user as coordinator and test user as instructor + ''' + + demoUser1 = User.objects.create(username='demouser1', + email='test.user@gmail.com', password='pass@123') + demoUser2 = User.objects.create(username='demouser2', + email='test.user@gmail.com', password='pass@123') + + testUser1 = User.objects.create(username='testuser1', + email='test.user@gmail.com',password='pass@123') + + testUser2 = User.objects.create(username='testuser2', + email='test.user@gmail.com', password='pass@123') + + instructor_profile = Profile.objects.create(user=testUser2, position='instructor', + department='cs', institute='ace', phone_number='1122334456', + is_email_verified=1) + + coordinator_profile = Profile.objects.create(user=demoUser2, position='coordinator', + department='IT', institute='iit', phone_number='1122334456', + is_email_verified=1) + + workshoptype1 = WorkshopType.objects.create(workshoptype_name='ISCP', + workshoptype_description='Introduction to Scientific Computing in\ + Python <br> > Numpy <br> > Matplotlib <br> > iPython <br>', + workshoptype_duration='1day, 8hours a day') + + requested_workshop = RequestedWorkshop.objects.create( + requested_workshop_instructor=testUser2, + requested_workshop_coordinator=demoUser2, + requested_workshop_title=workshoptype1, + requested_workshop_date='2017-07-24' + ) + + propose_workshop = ProposeWorkshopDate.objects.create( + proposed_workshop_coordinator=demoUser2, + proposed_workshop_instructor=testUser2, + proposed_workshop_title=workshoptype1, + proposed_workshop_date='2017-07-06', + condition_one=1, + condition_two=1, + condition_three=1 + ) + + +def tearDownModule(): + User.objects.all().delete() + Profile.objects.all().delete() + ProposeWorkshopDate.objects.all().delete() + RequestedWorkshop.objects.all().delete() + WorkshopType.objects.all().delete() + +class ProfileModelTest(TestCase): + ''' + This class tests the Profile Model + ''' + def setUp(self): + ''' + setsup profile for instructor and coordinator + ''' + self.testuser1 = User.objects.get(username='testuser1') + self.demouser1 = User.objects.get(username='demouser1') + + self.instructor_profile1 = Profile.objects.create(user=self.testuser1, position='instructor', + department='cs', institute='ace', phone_number='1123323344558899192', + is_email_verified=1) + + self.coordinator_profile1 = Profile.objects.create(user=self.demouser1, position='coordinator', + department='IT', institute='iit', phone_number='112233', + is_email_verified=1) + + def test_profile_model(self): + self.assertEqual(self.demouser1.email,'test.user@gmail.com') + self.assertEqual(self.testuser1.email,'test.user@gmail.com') + self.assertEqual(self.instructor_profile1.position,'instructor') + self.assertEqual(self.coordinator_profile1.position,'coordinator') + + +class WorkshopTypeModelTest(TestCase): + ''' + This class tests the WorkshopType Model + ''' + + def setUp(self): + self.workshoptype1 = WorkshopType.objects.create(workshoptype_name='ISCP', + workshoptype_description='Introduction to Scientific Computing in\ + Python <br> > Numpy <br> > Matplotlib <br> > iPython <br>', + workshoptype_duration='1day, 8hours a day') + + self.workshoptype2 = WorkshopType.objects.create(workshoptype_name='Basic Python', + workshoptype_description='Basic Python <br> > DataTypes <br> \ + > Conditions <br> > Loops <br> > Functions' + ,workshoptype_duration='3days, 8hours a day') + + def test_workshoptype_model(self): + self.assertEqual(self.workshoptype2.workshoptype_duration,'3days, 8hours a day') + self.assertEqual(self.workshoptype1.workshoptype_name, 'ISCP') + + +class WorkshopModelTest(TestCase): + ''' + This class tests the Workshop Model + ''' + + def setUp(self): + self.testuser2 = User.objects.get(username='testuser2') + self.instructor_profile = Profile.objects.get(user=self.testuser2) + self.workshoptype = WorkshopType.objects.get(workshoptype_name='ISCP') + self.workshop = Workshop.objects.create(workshop_instructor=self.testuser2, + workshop_title=self.workshoptype, + recurrences='RRULE:FREQ=WEEKLY;UNTIL=20170629T183000Z;BYDAY=TH') + + def test_workshop_model(self): + self.assertEqual(self.workshop.workshop_title.workshoptype_name,'ISCP' ) + self.assertEqual(self.workshop.recurrences.rrules[0].__dict__['freq'],2) + + +class RequestedWorkshopModelTest(TestCase): + ''' + This class tests the RequestedWorkshop Model + ''' + + def setUp(self): + self.testuser2 = User.objects.get(username='testuser2') + self.demouser2 = User.objects.get(username='demouser2') + self.workshoptype = WorkshopType.objects.get(workshoptype_name='ISCP') + self.requestedworkshop = RequestedWorkshop.objects.create( + requested_workshop_instructor=self.testuser2, + requested_workshop_coordinator=self.demouser2, + requested_workshop_title=self.workshoptype, + requested_workshop_date='2017-05-24' + ) + + def test_requestedworkshop_model(self): + self.assertEqual(self.requestedworkshop.requested_workshop_date, '2017-05-24') + self.assertEqual(self.requestedworkshop.status, 'Pending') + + +class ProposedWorkshopDateModelTest(TestCase): + ''' + This class tests the ProposeWorkshopDate Model + ''' + + def setUp(self): + self.testuser2 = User.objects.get(username='testuser2') + self.demouser2 = User.objects.get(username='demouser2') + self.workshoptype = WorkshopType.objects.get(workshoptype_name='ISCP') + self.propose_workshop = ProposeWorkshopDate.objects.create( + proposed_workshop_coordinator=self.demouser2, + proposed_workshop_instructor=self.testuser2, + proposed_workshop_title=self.workshoptype, + proposed_workshop_date='2017-06-06', + condition_one=1, + condition_two=1, + condition_three=1 + ) + + def test_proposedworkshopdate_model(self): + self.assertEqual(self.propose_workshop.proposed_workshop_title.workshoptype_name,'ISCP') + self.assertEqual(self.propose_workshop.condition_three, 1) + self.assertEqual(self.propose_workshop.status, 'Pending') + +class BookedWorkshopModelTest(TestCase): + ''' + This class tests the BookedWorkshop Model + ''' + + def setUp(self): + self.requestedworkshop = RequestedWorkshop.objects.get(requested_workshop_date='2017-07-24') + self.propose_workshop = ProposeWorkshopDate.objects.get(proposed_workshop_date='2017-07-06') + self.bwr = BookedWorkshop.objects.create(booked_workshop_requested=self.requestedworkshop) + self.bwp = BookedWorkshop.objects.create(booked_workshop_proposed=self.propose_workshop) + + def test_bookedworkshop_model(self): + self.assertEqual(self.bwp.booked_workshop_proposed.condition_one,1) + self.assertEqual(self.bwr.booked_workshop_requested.requested_workshop_title.workshoptype_name, + 'ISCP' ) + diff --git a/workshop_app/test_views.py b/workshop_app/test_views.py new file mode 100644 index 0000000..ebf48c0 --- /dev/null +++ b/workshop_app/test_views.py @@ -0,0 +1,245 @@ +from .views import view_profile, user_login, edit_profile +from django.test import TestCase +from .models import Profile, User, Workshop, WorkshopType,\ + RequestedWorkshop, BookedWorkshop, ProposeWorkshopDate,\ + has_profile + +from datetime import datetime +from json import dumps +from django.test import Client +from django.contrib.auth.models import Group, Permission +from django.contrib.auth import authenticate +from django.core.urlresolvers import reverse +from .forms import CreateWorkshop + +class TestProfile(TestCase): + def setUp(self): + self.client = Client() + + self.user1 = User.objects.create( + username='demo_test_user1', + password='pass@123', + email='test.user@gmail.com') + + self.user2 = User.objects.create( + username='demo_test_user2', + email='test.user@gmail.com') + + self.user2.set_password('pass@123') + self.user2.save() + + self.user2_profile = Profile.objects.create( + user=self.user2, + department='cs', + institute='ace', + position='instructor', + phone_number='1122993388', + is_email_verified=1 + ) + + def test_has_profile_for_user_without_profile(self): + """ + If no profile exists for user passed as argument return False + """ + has_profile_status = has_profile(self.user1) + self.assertFalse(has_profile_status) + + def test_has_profile_for_user_with_profile(self): + """ + If profile exists for user passed as argument return True + """ + has_profile_status = has_profile(self.user2) + self.assertTrue(has_profile_status) + + def test_view_profile_denies_anonymous(self): + """ + If not logged in redirect to login page + """ + response = self.client.get(reverse(view_profile), follow=True) + redirect_destination = '/login/?next=/view_profile/' + self.assertTrue(response.status_code,200) + self.assertRedirects(response, redirect_destination) + + def test_edit_profile_get(self): + """ + GET request to edit profile should display profile form + """ + + self.client.login(username=self.user2, password='pass@123') + response = self.client.get(reverse(edit_profile)) + self.assertEqual(response.status_code, 200) + self.client.logout() + + def test_edit_profile_post(self): + + self.client.login(username=self.user2, password='pass@123') + response = self.client.post('/edit_profile/', + data = { + 'first_name': 'demo_test', + 'last_name': 'user2', + 'institute': 'IIT', + 'department': 'Aerospace' + }) + + updated_profile_user = User.objects.get(id=self.user2.id) + updated_profile = Profile.objects.get(user=updated_profile_user) + + self.assertEqual(updated_profile.institute, 'IIT') + self.assertEqual(updated_profile.department, 'Aerospace') + self.assertEqual(updated_profile.position, 'instructor') + self.assertEqual(response.status_code, 200) + self.assertTemplateUsed(response, 'workshop_app/profile_updated.html') + + +class TestWorkshopCreation(TestCase): + def setUp(self): + ''' + demo user as coordinator and test user as instructor + ''' + self.superuser = User.objects.create_superuser( + username='admin', + password='pass@123', + email='test.user@gmail.com') + + self.mod_group = Group.objects.create(name='instructor') + + self.user_one = User.objects.create( + username='test_user1', + email='test.user@gmail.com') + + self.user_one.set_password('pass@123') + self.user_one.save() + + self.user_one_profile = Profile.objects.create( + user=self.user_one, + department='cs', + institute='IIT', + position='instructor', + phone_number='1122993388', + is_email_verified=1 + ) + + #Add user_one in instructor group and give required permissions + self.mod_group.user_set.add(self.user_one) + self.permission = (Permission.objects.all()) + self.user_one.user_permissions.add(self.permission[44]) + self.user_one.user_permissions.add(self.permission[43]) + self.user_one.user_permissions.add(self.permission[42]) + + self.user_two = User.objects.create( + username='demo_user2', + email='test.user@gmail.com') + + self.user_two.set_password('pass@123') + self.user_two.save() + + self.user_two_profile = Profile.objects.create( + user=self.user_two, + department='cs', + institute='ace', + position='coordinator', + phone_number='1122993388', + is_email_verified=1 + ) + + self.workshoptype = WorkshopType.objects.create(workshoptype_name='ISCP', workshoptype_description='Introduction to Scientific Computing in Python <br>\ + > Numpy <br> > Matplotlib <br> > iPython <br>', workshoptype_duration='1days, 8hours a day') + + def test_create_workshoptype_superuser(self): + self.client.login(username=self.superuser, password='pass@123') + self.client.post(('/admin/workshop_app/workshoptype/add/'), + data={ + 'workshoptype_name': 'Basic Python', + 'workshoptype_description': 'Basics of Python <br>\ + > Conditions <br> > Datatypes <br> > Loops <br>', + 'workshoptype_duration': '3days, 8hours a day' + }) + self.workshoptype_one = WorkshopType.objects.get(workshoptype_name='Basic Python') + self.assertEqual(self.workshoptype_one.workshoptype_name, 'Basic Python') + self.assertEqual(self.workshoptype_one.workshoptype_duration, '3days, 8hours a day') + self.client.logout() + + def test_create_workshop_instructor(self): + self.client.login(username=self.user_one, password='pass@123') + self.client.post('/create_workshop/', + { + 'workshop_title' : (2), + 'recurrences' : 'RRULE:FREQ=WEEKLY;UNTIL=20170624T183000Z;BYDAY=WE;' + }) + self.workshop = Workshop.objects.get(workshop_instructor=self.user_one) + self.assertEqual(str(self.workshop.workshop_title), 'ISCP 1days, 8hours a day') + self.client.logout() + + + def test_propose_workshop_coordinator(self): + self.client.login(username=self.user_two, password='pass@123') + self.client.post('/propose_workshop/', + { + 'condition_one': 1, + 'condition_two': 1, + 'condition_three': 1, + 'proposed_workshop_title': (2), + 'proposed_workshop_date': '2017-06-06' + }) + self.proposed_workshop = ProposeWorkshopDate.objects.get(proposed_workshop_date='2017-06-06') + self.assertEqual(str(self.proposed_workshop.proposed_workshop_title),'ISCP 1days, 8hours a day') + self.client.logout() + + +class TestWorkshopDashboard(TestCase): + def setUp(self): + self.superuser = User.objects.create_superuser( + username='admin', + password='pass@123', + email='test.user@gmail.com') + + self.mod_group = Group.objects.create(name='instructor') + + self.user_one = User.objects.create( + username='test_user1', + email='test.user@gmail.com') + + self.user_one.set_password('pass@123') + self.user_one.save() + + self.user_one_profile = Profile.objects.create( + user=self.user_one, + department='cs', + institute='IIT', + position='instructor', + phone_number='1122993388', + is_email_verified=1 + ) + + #Add user_one in instructor group and give required permissions + self.mod_group.user_set.add(self.user_one) + self.permissions = Permission.objects.all() + self.user_one.user_permissions.add(self.permissions[44]) + self.user_one.user_permissions.add(self.permissions[43]) + self.user_one.user_permissions.add(self.permissions[42]) + + self.user_two = User.objects.create( + username='demo_user2', + email='test.user@gmail.com') + + self.user_two.set_password('pass@123') + self.user_two.save() + + self.user_two_profile = Profile.objects.create( + user=self.user_two, + department='cs', + institute='ace', + position='coordinator', + phone_number='1122993388', + is_email_verified=1 + ) + + self.workshoptype = WorkshopType.objects.create(workshoptype_name='ISCP', workshoptype_description='Introduction to Scientific Computing in Python <br>\ + > Numpy <br> > Matplotlib <br> > iPython <br>', workshoptype_duration='1days, 8hours a day') + + self.workshop = Workshop.objects.create(workshop_instructor=self.user_one, + workshop_title=self.workshoptype, + recurrences='RRULE:FREQ=WEEKLY;UNTIL=20170624T183000Z;BYDAY=WE;' + ) + +
\ No newline at end of file diff --git a/workshop_app/tests.py b/workshop_app/tests.py deleted file mode 100644 index 7ce503c..0000000 --- a/workshop_app/tests.py +++ /dev/null @@ -1,3 +0,0 @@ -from django.test import TestCase - -# Create your tests here. diff --git a/workshop_app/urls.py b/workshop_app/urls.py new file mode 100644 index 0000000..60da52e --- /dev/null +++ b/workshop_app/urls.py @@ -0,0 +1,47 @@ +"""workshop_portal URL Configuration + +The `urlpatterns` list routes URLs to views. For more information please see: + https://docs.djangoproject.com/en/1.10/topics/http/urls/ +Examples: +Function views + 1. Add an import: from my_app import views + 2. Add a URL to urlpatterns: url(r'^$', views.home, name='home') +Class-based views + 1. Add an import: from other_app.views import Home + 2. Add a URL to urlpatterns: url(r'^$', Home.as_view(), name='home') +Including another URLconf + 1. Import the include() function: from django.conf.urls import url, include + 2. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls')) +""" +from django.conf.urls import url +from django.contrib import admin +from workshop_app import views +import django + +js_info_dict = { + 'packages': ('recurrence', ), +} + + +urlpatterns = [ + url(r'^$', views.index, name='index'), + url(r'^register/$', views.user_register), + url(r'^activate_user/(?P<key>.+)$', views.activate_user), + url(r'^login/$', views.user_login), + url(r'^logout/$', views.user_logout), + url(r'^view_profile/$', views.view_profile), + url(r'^edit_profile/$', views.edit_profile), + url(r'^book/$', views.book), + url(r'^book_workshop/$', views.book_workshop), + url(r'^my_workshops/$', views.my_workshops), + url(r'^benefits/$', views.benefits), + url(r'^how_to_participate/$', views.how_to_participate), + url(r'^faq/$', views.faq), + url(r'^manage/$', views.manage), + url(r'^view_workshoptype_list/$', views.view_workshoptype_list), + url(r'^view_workshoptype_details/$', views.view_workshoptype_details), + url(r'^create_workshop/$', views.create_workshop), + url(r'^propose_workshop/$', views.propose_workshop), + url(r'^jsi18n/$', django.views.i18n.javascript_catalog, js_info_dict), + +] diff --git a/workshop_app/views.py b/workshop_app/views.py index 0557207..0efaf54 100644 --- a/workshop_app/views.py +++ b/workshop_app/views.py @@ -99,9 +99,9 @@ def activate_user(request, key): return redirect('/register/') if user.is_email_verified: - status = "Your email is already verified" + status = "2" elif timezone.now() > user.key_expiry_time: - status = "Your activation has expired please register again" + status = "1" Profile.objects.get(user_id=user.user_id).delete() User.objects.get(id=user.user_id).delete() return render(request, 'workshop_app/activation.html', @@ -109,7 +109,7 @@ def activate_user(request, key): elif key == user.activation_key: user.is_email_verified = True user.save() - status = "Your account has been activated" + status = "0" else: logout(request) return redirect('/logout/') |