X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/e8035f42434faf0ffcb1897f6783c64d5751ae20..b99b619fb5c4504bc8a21e5c9f92a72d84638836:/wtem/models.py diff --git a/wtem/models.py b/wtem/models.py index 69affe4..d24430d 100644 --- a/wtem/models.py +++ b/wtem/models.py @@ -27,6 +27,7 @@ class Submission(models.Model): key_sent = models.BooleanField(default = False) marks = JSONField() examiners = models.ManyToManyField(User, null = True, blank = True) + end_time = models.CharField(max_length = 5, null = True, blank = True) def __unicode__(self): return ', '.join((self.last_name, self.first_name, self.email)) @@ -97,7 +98,12 @@ class Submission(models.Model): toret = 0 for bucket_id, items in answer.items(): for item_id in items: - if int(item_id) == exercise['answer'].get(bucket_id, None): # @@ We assume only one item per bucker for now... + is_corect = False + if exercise.get('answer_mode', None) == 'possible_buckets_for_item': + is_correct = int(bucket_id) in exercise['answer'].get(item_id) + else: + is_correct = int(item_id) in exercise['answer'].get(bucket_id, []) + if is_correct: toret += exercise['points_per_hit'] return toret if t == 'edumed_wybor': @@ -108,9 +114,12 @@ class Submission(models.Model): return 0 else: toret = 0 - for id in map(int, answer): - if id in exercise['answer']: - toret += exercise['points_per_hit'] + if exercise.get('answer_mode', None) == 'all_or_nothing': + toret = exercise['points'] if map(int, answer) == exercise['answer'] else 0 + else: + for id in map(int, answer): + if id in exercise['answer']: + toret += exercise['points_per_hit'] return toret if t == 'edumed_prawdafalsz': toret = 0