summaryrefslogtreecommitdiff
path: root/grades/tests/test_models.py
diff options
context:
space:
mode:
authorPrabhu Ramachandran2018-03-22 18:36:05 +0530
committerGitHub2018-03-22 18:36:05 +0530
commitd4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5 (patch)
tree8a767d224ac6a1688cd3eb301b2ccac40413fc7e /grades/tests/test_models.py
parent734b221a98745ccb6218f43923731323a265966a (diff)
parentc49550b6793c0481fae08f04c794218513894cc4 (diff)
downloadonline_test-d4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5.tar.gz
online_test-d4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5.tar.bz2
online_test-d4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5.zip
Merge pull request #438 from prathamesh920/Grades
Grades
Diffstat (limited to 'grades/tests/test_models.py')
-rw-r--r--grades/tests/test_models.py28
1 files changed, 28 insertions, 0 deletions
diff --git a/grades/tests/test_models.py b/grades/tests/test_models.py
new file mode 100644
index 0000000..f8d5c5c
--- /dev/null
+++ b/grades/tests/test_models.py
@@ -0,0 +1,28 @@
+from django.test import TestCase
+from grades.models import GradingSystem, GradeRange
+
+
+class GradingSystemTestCase(TestCase):
+ def setUp(self):
+ GradingSystem.objects.create(name='unusable')
+
+ def test_get_grade(self):
+ # Given
+ grading_system = GradingSystem.objects.get(name='default')
+ expected_grades = {0: 'F', 31: 'F', 49: 'P', 55: 'C', 60: 'B', 80: 'A',
+ 95: 'A+', 100: 'A+', 100.5: 'A+', 101: None,
+ 109: None}
+ for marks in expected_grades.keys():
+ # When
+ grade = grading_system.get_grade(marks)
+ # Then
+ self.assertEqual(expected_grades.get(marks), grade)
+
+ def test_grade_system_unusable(self):
+ # Given
+ # System with out ranges
+ grading_system = GradingSystem.objects.get(name='unusable')
+ # When
+ grade = grading_system.get_grade(29)
+ # Then
+ self.assertIsNone(grade)