From 17bb4bf5a28c4d7a93eefac1ba5d7c2be63ed25f Mon Sep 17 00:00:00 2001 From: maheshgudi Date: Fri, 13 Jul 2018 15:16:32 +0530 Subject: Fix import changes for file_utils --- yaksh/file_utils.py | 66 ---------------------------------------------- yaksh/models.py | 76 ++++++++++++++++++++++++++++++++++++++++++++++++----- 2 files changed, 69 insertions(+), 73 deletions(-) (limited to 'yaksh') diff --git a/yaksh/file_utils.py b/yaksh/file_utils.py index 1dc6006..7c31c70 100644 --- a/yaksh/file_utils.py +++ b/yaksh/file_utils.py @@ -3,7 +3,6 @@ import os import zipfile import tempfile import csv -from django.template import Context, Template def copy_files(file_paths): @@ -67,68 +66,3 @@ def is_csv(document): except (csv.Error, UnicodeDecodeError): return False, None return True, dialect - - -def write_static_files_to_zip(zipfile, course_name, current_dir, static_files): - """ Write static files to zip - - Parameters - ---------- - - zipfile : Zipfile object - zip file in which the static files need to be added - - course_name : str - Create a folder with course name - - current_dir: str - Path from which the static files will be taken - - static_files: dict - Dictionary containing static folders as keys and static files as - values - """ - for folder in static_files.keys(): - folder_path = os.sep.join((current_dir, "static", "yaksh", folder)) - for file in static_files[folder]: - file_path = os.sep.join((folder_path, file)) - with open(file_path, "rb") as f: - zipfile.writestr( - os.sep.join((course_name, "static", folder, file)), - f.read() - ) - - -def write_templates_to_zip(zipfile, template_path, data, filename, filepath): - """ Write template files to zip - - Parameters - ---------- - - zipfile : Zipfile object - zip file in which the template files need to be added - - template_path : str - Path from which the template file will be loaded - - data: dict - Dictionary containing context data required for template - - filename: str - Filename with which the template file should be named - - filepath: str - File path in zip where the template will be added - """ - rendered_template = render_template(template_path, data) - zipfile.writestr(os.sep.join((filepath, "{0}.html".format(filename))), - str(rendered_template)) - - -def render_template(template_path, data): - with open(template_path) as f: - template_data = f.read() - template = Template(template_data) - context = Context(data) - render = template.render(context) - return render diff --git a/yaksh/models.py b/yaksh/models.py index 152289f..f8dac8b 100644 --- a/yaksh/models.py +++ b/yaksh/models.py @@ -28,10 +28,8 @@ import zipfile import tempfile from textwrap import dedent from ast import literal_eval -from .file_utils import ( - extract_files, delete_files, write_templates_to_zip, - write_static_files_to_zip -) +from .file_utils import extract_files, delete_files +from django.template import Context, Template from yaksh.code_server import ( submit, get_result as get_result_from_code_server ) @@ -153,6 +151,71 @@ def create_group(group_name, app_label): return group +def write_static_files_to_zip(zipfile, course_name, current_dir, static_files): + """ Write static files to zip + + Parameters + ---------- + + zipfile : Zipfile object + zip file in which the static files need to be added + + course_name : str + Create a folder with course name + + current_dir: str + Path from which the static files will be taken + + static_files: dict + Dictionary containing static folders as keys and static files as + values + """ + for folder in static_files.keys(): + folder_path = os.sep.join((current_dir, "static", "yaksh", folder)) + for file in static_files[folder]: + file_path = os.sep.join((folder_path, file)) + with open(file_path, "rb") as f: + zipfile.writestr( + os.sep.join((course_name, "static", folder, file)), + f.read() + ) + + +def write_templates_to_zip(zipfile, template_path, data, filename, filepath): + """ Write template files to zip + + Parameters + ---------- + + zipfile : Zipfile object + zip file in which the template files need to be added + + template_path : str + Path from which the template file will be loaded + + data: dict + Dictionary containing context data required for template + + filename: str + Filename with which the template file should be named + + filepath: str + File path in zip where the template will be added + """ + rendered_template = render_template(template_path, data) + zipfile.writestr(os.sep.join((filepath, "{0}.html".format(filename))), + str(rendered_template)) + + +def render_template(template_path, data): + with open(template_path) as f: + template_data = f.read() + template = Template(template_data) + context = Context(data) + render = template.render(context) + return render + + ############################################################################### class CourseManager(models.Manager): @@ -1490,8 +1553,8 @@ class QuestionPaper(models.Model): testcases_ids = ",".join([str(tc.id) for tc in testcases] ) if not TestCaseOrder.objects.filter( - answer_paper=ans_paper, question=question - ).exists(): + answer_paper=ans_paper, question=question + ).exists(): TestCaseOrder.objects.create( answer_paper=ans_paper, question=question, order=testcases_ids) @@ -2331,7 +2394,6 @@ class TestCaseOrder(models.Model): # Order of the test case for a question. order = models.TextField() - class Meta: unique_together = ("answer_paper", "question", "order") -- cgit From f3ed3db3f707e358694eee837cde6e7dd8edb241 Mon Sep 17 00:00:00 2001 From: maheshgudi Date: Fri, 13 Jul 2018 15:48:45 +0530 Subject: Modify demo questions to make them simpler - Update default timeout to 6 seconds for Java related code --- yaksh/fixtures/demo_questions.zip | Bin 3230 -> 9957 bytes yaksh/settings.py | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) (limited to 'yaksh') diff --git a/yaksh/fixtures/demo_questions.zip b/yaksh/fixtures/demo_questions.zip index 1618341..6b0f852 100644 Binary files a/yaksh/fixtures/demo_questions.zip and b/yaksh/fixtures/demo_questions.zip differ diff --git a/yaksh/settings.py b/yaksh/settings.py index 9e9597d..f687d51 100644 --- a/yaksh/settings.py +++ b/yaksh/settings.py @@ -16,7 +16,7 @@ SERVER_POOL_PORT = config('SERVER_POOL_PORT', default=55555, cast=int) SERVER_HOST_NAME = config('SERVER_HOST_NAME', default='http://localhost') # Timeout for the code to run in seconds. This is an integer! -SERVER_TIMEOUT = config('SERVER_TIMEOUT', default=4, cast=int) +SERVER_TIMEOUT = config('SERVER_TIMEOUT', default=6, cast=int) # The root of the URL, for example you might be in the situation where you # are not hosted as host.org/exam/ but as host.org/foo/exam/ for whatever -- cgit From 590dc4a5e99fc1f72287d13e5ce25d1506b4e518 Mon Sep 17 00:00:00 2001 From: maheshgudi Date: Fri, 13 Jul 2018 16:48:21 +0530 Subject: Fix unit and selenium tests for simple questions --- yaksh/live_server_tests/selenium_test.py | 8 ++++---- yaksh/models.py | 6 ++++-- yaksh/settings.py | 2 +- yaksh/test_views.py | 8 +++++--- 4 files changed, 14 insertions(+), 10 deletions(-) (limited to 'yaksh') diff --git a/yaksh/live_server_tests/selenium_test.py b/yaksh/live_server_tests/selenium_test.py index 6351f9e..a067f22 100644 --- a/yaksh/live_server_tests/selenium_test.py +++ b/yaksh/live_server_tests/selenium_test.py @@ -118,7 +118,7 @@ class SeleniumTest(): # Correct Answer loop_count = 1 - answer = '\"#!/bin/bash\\ncat $1 | cut -d: -f2 | paste -d: $3 - $2\"' + answer = '\"#!/bin/bash\\necho "Hello, World!"\"' self.submit_answer(question_label, answer, loop_count) def open_quiz(self): @@ -135,9 +135,9 @@ class SeleniumTest(): ) start_exam_elem.click() - self.test_c_question(question_label=7) - self.test_python_question(question_label=5) - self.test_bash_question(question_label=4) + self.test_c_question(question_label=6) + self.test_python_question(question_label=4) + self.test_bash_question(question_label=10) def quit_quiz(self): quit_link_elem = WebDriverWait(self.driver, 5).until( diff --git a/yaksh/models.py b/yaksh/models.py index f8dac8b..f7adfd8 100644 --- a/yaksh/models.py +++ b/yaksh/models.py @@ -1595,9 +1595,11 @@ class QuestionPaper(models.Model): question_paper = QuestionPaper.objects.create(quiz=demo_quiz, shuffle_questions=False ) - summaries = ['Roots of quadratic equation', 'Print Output', + summaries = ['Find the value of n', 'Print Output in Python2.x', 'Adding decimals', 'For Loop over String', - 'Hello World in File', 'Extract columns from files', + 'Hello World in File', + 'Arrange code to convert km to miles', + 'Print Hello, World!', "Square of two numbers", 'Check Palindrome', 'Add 3 numbers', 'Reverse a string' ] questions = Question.objects.filter(active=True, diff --git a/yaksh/settings.py b/yaksh/settings.py index f687d51..9e9597d 100644 --- a/yaksh/settings.py +++ b/yaksh/settings.py @@ -16,7 +16,7 @@ SERVER_POOL_PORT = config('SERVER_POOL_PORT', default=55555, cast=int) SERVER_HOST_NAME = config('SERVER_HOST_NAME', default='http://localhost') # Timeout for the code to run in seconds. This is an integer! -SERVER_TIMEOUT = config('SERVER_TIMEOUT', default=6, cast=int) +SERVER_TIMEOUT = config('SERVER_TIMEOUT', default=4, cast=int) # The root of the URL, for example you might be in the situation where you # are not hosted as host.org/exam/ but as host.org/foo/exam/ for whatever diff --git a/yaksh/test_views.py b/yaksh/test_views.py index 899ed31..b71bb3e 100644 --- a/yaksh/test_views.py +++ b/yaksh/test_views.py @@ -4384,9 +4384,11 @@ class TestShowQuestions(TestCase): data={'file': questions_file, 'upload': 'upload'} ) - summaries = ['Roots of quadratic equation', 'Print Output', + summaries = ['Find the value of n', 'Print Output in Python2.x', 'Adding decimals', 'For Loop over String', - 'Hello World in File', 'Extract columns from files', + 'Hello World in File', + 'Arrange code to convert km to miles', + 'Print Hello, World!', "Square of two numbers", 'Check Palindrome', 'Add 3 numbers', 'Reverse a string' ] @@ -4395,7 +4397,7 @@ class TestShowQuestions(TestCase): user=self.user).count() self.assertEqual(response.status_code, 200) self.assertTemplateUsed(response, 'yaksh/showquestions.html') - self.assertEqual(uploaded_ques, 9) + self.assertEqual(uploaded_ques, 11) f.close() dummy_file = SimpleUploadedFile("test.txt", b"test") response = self.client.post( -- cgit From e7cfaf3370cfdc135ce8c5c61abf25cf16a8daad Mon Sep 17 00:00:00 2001 From: maheshgudi Date: Fri, 13 Jul 2018 16:49:26 +0530 Subject: Add migration files for release v0.9 --- yaksh/migrations/0013_release_0_9_0.py | 48 ++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 yaksh/migrations/0013_release_0_9_0.py (limited to 'yaksh') diff --git a/yaksh/migrations/0013_release_0_9_0.py b/yaksh/migrations/0013_release_0_9_0.py new file mode 100644 index 0000000..3f7f377 --- /dev/null +++ b/yaksh/migrations/0013_release_0_9_0.py @@ -0,0 +1,48 @@ +# -*- coding: utf-8 -*- +# Generated by Django 1.10 on 2018-07-13 10:24 +from __future__ import unicode_literals + +from django.db import migrations, models +import yaksh.models + + +def set_is_moderator(apps, schema_editor): + """ Set is_moderator to True for all users that belong + to Moderator group """ + + Profile = apps.get_model('yaksh', 'Profile') + for prof in Profile.objects.all(): + user = prof.user + if user.groups.filter(name='moderator').exists(): + prof.is_moderator = True + prof.save() + + +class Migration(migrations.Migration): + + dependencies = [ + ('yaksh', '0012_release_0_8_1'), + ] + + operations = [ + migrations.AddField( + model_name='lesson', + name='video_file', + field=models.FileField(blank=True, default=None, help_text='Please upload video files in mp4, ogv, webm format', null=True, upload_to=yaksh.models.get_file_dir), + ), + migrations.AddField( + model_name='profile', + name='is_moderator', + field=models.BooleanField(default=False), + ), + migrations.AlterField( + model_name='lessonfile', + name='file', + field=models.FileField(default=None, upload_to=yaksh.models.get_file_dir), + ), + migrations.AlterUniqueTogether( + name='testcaseorder', + unique_together=set([('answer_paper', 'question', 'order')]), + ), + migrations.RunPython(set_is_moderator), + ] -- cgit From 5dce610047070dabb1ae69b1acce4ab090d4be47 Mon Sep 17 00:00:00 2001 From: maheshgudi Date: Fri, 13 Jul 2018 16:56:29 +0530 Subject: pep8 cleanup for release v0.9 --- yaksh/evaluator_tests/test_python_evaluation.py | 1 - yaksh/live_server_tests/selenium_test.py | 1 + yaksh/models.py | 1 + yaksh/test_views.py | 6 +++++- 4 files changed, 7 insertions(+), 2 deletions(-) (limited to 'yaksh') diff --git a/yaksh/evaluator_tests/test_python_evaluation.py b/yaksh/evaluator_tests/test_python_evaluation.py index 1933d17..ad9b2c2 100644 --- a/yaksh/evaluator_tests/test_python_evaluation.py +++ b/yaksh/evaluator_tests/test_python_evaluation.py @@ -173,7 +173,6 @@ class PythonAssertionEvaluationTestCases(EvaluatorBaseTest): grader = Grader(self.in_dir) result = grader.evaluate(kwargs) err = result.get("error")[0]['traceback'] - # Then self.assertFalse(result.get("success")) for msg in syntax_error_msg: diff --git a/yaksh/live_server_tests/selenium_test.py b/yaksh/live_server_tests/selenium_test.py index a067f22..229902c 100644 --- a/yaksh/live_server_tests/selenium_test.py +++ b/yaksh/live_server_tests/selenium_test.py @@ -172,6 +172,7 @@ def wrap_run_load_test(args): selenium_test = SeleniumTest(url=url, quiz_name=quiz_name) return selenium_test.run_load_test(*args) + if __name__ == '__main__': parser = argparse.ArgumentParser() parser.add_argument( diff --git a/yaksh/models.py b/yaksh/models.py index f7adfd8..60b09c5 100644 --- a/yaksh/models.py +++ b/yaksh/models.py @@ -135,6 +135,7 @@ def get_file_dir(instance, filename): upload_dir = instance.name.replace(" ", "_") return os.sep.join((upload_dir, filename)) + def create_group(group_name, app_label): try: group = Group.objects.get(name=group_name) diff --git a/yaksh/test_views.py b/yaksh/test_views.py index b71bb3e..3520c61 100644 --- a/yaksh/test_views.py +++ b/yaksh/test_views.py @@ -1345,6 +1345,7 @@ class TestAddQuiz(TestCase): self.assertEqual(response.context['quizzes'][0], self.quiz) self.assertTemplateUsed(response, "yaksh/courses.html") + class TestAddAsModerator(TestCase): def setUp(self): self.client = Client() @@ -1399,6 +1400,7 @@ class TestAddAsModerator(TestCase): with self.assertRaises(Http404): add_as_moderator(self.user, 'moderator') + class TestToggleModerator(TestCase): def setUp(self): self.client = Client() @@ -1481,6 +1483,7 @@ class TestToggleModerator(TestCase): self.assertEqual(response.status_code, 404) + class TestAddTeacher(TestCase): def setUp(self): self.client = Client() @@ -2850,7 +2853,8 @@ class TestCourseDetail(TestCase): target_status_code=301) def test_send_mail_to_course_students(self): - """ Check if bulk mail is sent to multiple students enrolled in a course + """ Check if bulk mail is sent to multiple students enrolled + in a course """ self.client.login( username=self.user1.username, -- cgit From 4346684d4ed863e5628697ccebe92bbe85fb77a4 Mon Sep 17 00:00:00 2001 From: prathamesh Date: Fri, 13 Jul 2018 17:26:15 +0530 Subject: Fix minor issue in selenium --- yaksh/live_server_tests/selenium_test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'yaksh') diff --git a/yaksh/live_server_tests/selenium_test.py b/yaksh/live_server_tests/selenium_test.py index 229902c..5bf1988 100644 --- a/yaksh/live_server_tests/selenium_test.py +++ b/yaksh/live_server_tests/selenium_test.py @@ -118,7 +118,7 @@ class SeleniumTest(): # Correct Answer loop_count = 1 - answer = '\"#!/bin/bash\\necho "Hello, World!"\"' + answer = '\"#!/bin/bash\\necho Hello, World!\"' self.submit_answer(question_label, answer, loop_count) def open_quiz(self): -- cgit