diff options
-rw-r--r-- | yaksh/models.py | 5 | ||||
-rw-r--r-- | yaksh/test_models.py | 163 |
2 files changed, 164 insertions, 4 deletions
diff --git a/yaksh/models.py b/yaksh/models.py index 3182cc8..407435e 100644 --- a/yaksh/models.py +++ b/yaksh/models.py @@ -30,7 +30,7 @@ import qrcode import hashlib # Django Imports -from django.db import models +from django.db import models, IntegrityError from django.contrib.auth.models import User, Group, Permission from django.core.exceptions import ValidationError from django.contrib.contenttypes.models import ContentType @@ -3216,8 +3216,9 @@ class QRcode(models.Model): for i in range(40): try: self.short_key = key[0:num] + self.save() break - except django.db.IntegrityError: + except IntegrityError: num = num + 1 def generate_image(self, content): diff --git a/yaksh/test_models.py b/yaksh/test_models.py index fe0d3b5..d6e5a12 100644 --- a/yaksh/test_models.py +++ b/yaksh/test_models.py @@ -6,7 +6,8 @@ from yaksh.models import User, Profile, Question, Quiz, QuestionPaper,\ QuestionSet, AnswerPaper, Answer, Course, StandardTestCase,\ StdIOBasedTestCase, FileUpload, McqTestCase, AssignmentUpload,\ LearningModule, LearningUnit, Lesson, LessonFile, CourseStatus, \ - create_group, legend_display_types, Post, Comment, MicroManager + create_group, legend_display_types, Post, Comment, MicroManager, QRcode, \ + QRcodeHandler from yaksh.code_server import ( ServerPool, get_result as get_result_from_code_server ) @@ -22,6 +23,7 @@ import zipfile import os import shutil import tempfile +import hashlib from threading import Thread from collections import defaultdict from yaksh import settings @@ -121,7 +123,6 @@ def tearDownModule(): MicroManager.objects.all().delete() Group.objects.all().delete() - ############################################################################### class GlobalMethodsTestCases(unittest.TestCase): def test_create_group_when_group_exists(self): @@ -2451,3 +2452,161 @@ class PostModelTestCases(unittest.TestCase): self.user3.delete() self.course.delete() self.post1.delete() + + +class QRcodeTestCase(unittest.TestCase): + @classmethod + def setUpClass(cls): + quiz = Quiz.objects.get(description='demo quiz 1') + cls.questionpaper = QuestionPaper.objects.create(quiz=quiz) + question = Question.objects.get(summary='Q1') + question.type = 'upload' + question.save() + cls.questionpaper.fixed_questions.add(question) + cls.questionpaper.update_total_marks() + student = User.objects.get(username='course_user') + course = Course.objects.get(name='Python Course') + attempt = 1 + ip = '127.0.0.1' + answerpaper = cls.questionpaper.make_answerpaper( + student, ip, attempt, course.id) + cls.qrcode_handler = QRcodeHandler.objects.create( + user=student, answerpaper=answerpaper, question=question) + cls.old_qrcode = cls.qrcode_handler._create_qrcode() + cls.old_qrcode.set_used() + cls.old_qrcode.save() + cls.qrcode = cls.qrcode_handler.get_qrcode() + cls.answerpaper = answerpaper + + @classmethod + def tearDownClass(cls): + cls.qrcode.image.delete() + cls.qrcode.delete() + cls.qrcode_handler.delete() + cls.answerpaper.delete() + cls.questionpaper.delete() + QRcode.objects.all().delete() + QRcodeHandler.objects.all().delete() + + def test_active(self): + # Given + qrcode = self.qrcode + + # Then + self.assertFalse(qrcode.is_active()) + + # When + qrcode.activate() + qrcode.save() + + # Then + self.assertTrue(qrcode.is_active()) + + # When + qrcode.deactivate() + qrcode.save() + + # Then + self.assertFalse(qrcode.is_active()) + + def test_used(self): + # Given + qrcode = self.qrcode + + # Then + self.assertFalse(qrcode.is_used()) + + # When + qrcode.set_used() + qrcode.save() + + # Then + self.assertTrue(qrcode.is_used()) + + # When + qrcode.used = False + qrcode.save() + + # Then + self.assertFalse(qrcode.is_used()) + + def test_random_key(self): + # Given + qrcode = self.qrcode + + # When + expect_key = hashlib.sha1('{0}'.format(qrcode.id).encode()).hexdigest() + + # Then + self.assertEqual(qrcode.random_key, expect_key) + self.assertEqual(len(qrcode.random_key), 40) + + def test_short_key(self): + # Given + qrcode = self.qrcode + + # When + expect_key = hashlib.sha1('{0}'.format(qrcode.id).encode()).hexdigest() + + # Then + self.assertEqual(qrcode.short_key, expect_key[0:5]) + self.assertEqual(len(qrcode.short_key), 5) + + # Given + old_qrcode = self.old_qrcode + old_qrcode.random_key = qrcode.random_key + old_qrcode.save() + + # When + old_qrcode.set_short_key() + + # Then + self.assertEqual(old_qrcode.short_key, expect_key[0:6]) + self.assertEqual(len(old_qrcode.short_key), 6) + + def test_generate_image(self): + # Given + qrcode = self.qrcode + image_name = 'qrcode/{0}.png'.format(qrcode.short_key) + + # When + qrcode.generate_image('test') + + # Then + self.assertTrue(qrcode.is_active()) + self.assertEqual(qrcode.image.name, image_name) + + def test_get_qrcode(self): + # Given + handler = self.qrcode_handler + self.qrcode.activate() + self.qrcode.save() + expected_qrcode = self.qrcode + + # When + qrcode = handler.get_qrcode() + + # Then + self.assertEqual(qrcode, expected_qrcode) + self.qrcode.deactivate() + self.qrcode.save() + + def test_can_use(self): + # Given + handler = self.qrcode_handler + + # When + can_use = handler.can_use() + + # Then + self.assertTrue(can_use) + + # Given + answerpaper = self.answerpaper + + # When + answerpaper.update_marks(state='complete') + can_use = handler.can_use() + + # Then + self.assertFalse(can_use) |