diff options
author | prathamesh | 2016-12-07 13:50:33 +0530 |
---|---|---|
committer | prathamesh | 2016-12-07 13:50:33 +0530 |
commit | cb9d4c01d6287ab1288d0755d4f93d5320eb1d3a (patch) | |
tree | f93f35ae17aad6d9a071c068e8eb73406df3d7d3 /yaksh/models.py | |
parent | 7fab5de07a05cf8f84e7beb8b4c166c0398172be (diff) | |
download | online_test-cb9d4c01d6287ab1288d0755d4f93d5320eb1d3a.tar.gz online_test-cb9d4c01d6287ab1288d0755d4f93d5320eb1d3a.tar.bz2 online_test-cb9d4c01d6287ab1288d0755d4f93d5320eb1d3a.zip |
basic interface to add multiple testcases to a question
Diffstat (limited to 'yaksh/models.py')
-rw-r--r-- | yaksh/models.py | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/yaksh/models.py b/yaksh/models.py index 2018198..7a64bba 100644 --- a/yaksh/models.py +++ b/yaksh/models.py @@ -53,6 +53,7 @@ test_case_types = ( ("standardtestcase", "Standard Testcase"), ("stdiobasedtestcase", "StdIO Based Testcase"), ("mcqtestcase", "MCQ Testcase"), + ("hooktestcase", "Hook Testcase"), ) attempts = [(i, i) for i in range(1, 6)] @@ -1122,9 +1123,10 @@ class AssignmentUpload(models.Model): ################################################################################ class TestCase(models.Model): question = models.ForeignKey(Question, blank=True, null = True) + type = models.CharField(max_length=24, choices=test_case_types, null=True) class StandardTestCase(TestCase): - test_case = models.TextField(blank=True) + test_case = models.CharField(blank=True, max_length=100) weight = models.FloatField(default=0.0) def get_field_value(self): @@ -1138,8 +1140,8 @@ class StandardTestCase(TestCase): class StdioBasedTestCase(TestCase): - expected_input = models.TextField(blank=True) - expected_output = models.TextField() + expected_input = models.CharField(max_length=100, blank=True) + expected_output = models.CharField(max_length=100) weight = models.IntegerField(default=0.0) def get_field_value(self): @@ -1154,7 +1156,7 @@ class StdioBasedTestCase(TestCase): class McqTestCase(TestCase): - options = models.TextField() + options = models.CharField(max_length=100) correct = models.BooleanField(default=False) def get_field_value(self): @@ -1164,3 +1166,8 @@ class McqTestCase(TestCase): return u'Question: {0} | Correct: {1}'.format(self.question, self.correct ) + + +class HookTestCase(TestCase): + code = models.TextField() + weight = models.FloatField(default=0.0) |