summaryrefslogtreecommitdiff
path: root/yaksh
diff options
context:
space:
mode:
Diffstat (limited to 'yaksh')
-rw-r--r--yaksh/evaluator_tests/test_python_evaluation.py101
1 files changed, 65 insertions, 36 deletions
diff --git a/yaksh/evaluator_tests/test_python_evaluation.py b/yaksh/evaluator_tests/test_python_evaluation.py
index 8a3ba0d..ec46b5e 100644
--- a/yaksh/evaluator_tests/test_python_evaluation.py
+++ b/yaksh/evaluator_tests/test_python_evaluation.py
@@ -2,6 +2,7 @@ import unittest
import os
from yaksh.python_code_evaluator import PythonCodeEvaluator
from yaksh.settings import SERVER_TIMEOUT
+import textwrap
class PythonEvaluationTestCases(unittest.TestCase):
def setUp(self):
@@ -15,21 +16,31 @@ class PythonEvaluationTestCases(unittest.TestCase):
}]
def test_correct_answer(self):
- user_answer = "def add(a, b):\n\treturn a + b"
+ user_answer = textwrap.dedent("""
+ def add(a, b):
+ return a + b
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertTrue(result.get("success"))
self.assertEqual(result.get("error"), "Correct answer")
def test_incorrect_answer(self):
- user_answer = "def add(a, b):\n\treturn a - b"
+ user_answer = textwrap.dedent("""
+ def add(a, b):
+ return a - b
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))
self.assertEqual(result.get("error"), "AssertionError in: assert add(3, 2) == 5")
def test_infinite_loop(self):
- user_answer = "def add(a, b):\n\twhile True:\n\t\tpass"
+ user_answer = textwrap.dedent("""
+ def add(a, b):
+ while True:
+ pass
+ """)
timeout_msg = ("Code took more than {0} seconds to run. "
"You probably have an infinite loop in your code.").format(SERVER_TIMEOUT)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
@@ -38,21 +49,34 @@ class PythonEvaluationTestCases(unittest.TestCase):
self.assertEquals(result.get("error"), timeout_msg)
def test_syntax_error(self):
- user_answer = "def add(a, b);\n\treturn a+b"
- syntax_error_msg = ('Traceback (most recent call last):\n File '
- '"<string>", line 1\n def add(a, b);\n '
- ' ^\nSyntaxError: invalid syntax\n')
+ # Do not touch any error messages as it can fail test case
+ user_answer = textwrap.dedent("""
+ def add(a, b);
+ return a + b
+ """)
+ syntax_error_msg = textwrap.dedent("""\
+ Traceback (most recent call last):
+ File "<string>", line 2
+ def add(a, b);
+ ^
+ SyntaxError: invalid syntax\n""")
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))
self.assertEquals(result.get("error"), syntax_error_msg)
def test_indent_error(self):
- user_answer = "def add(a, b):\nreturn a+b"
- indent_error_msg = ('Traceback (most recent call last):\n '
- 'File "<string>", line 2\n '
- 'return a+b\n ^\nIndentationError: '
- 'expected an indented block\n')
+ user_answer = textwrap.dedent("""
+ def add(a, b):
+ return a + b
+ """)
+ indent_error_msg = textwrap.dedent("""\
+ Traceback (most recent call last):
+ File "<string>", line 3
+ return a + b
+ ^
+ IndentationError: expected an indented block
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))
@@ -60,48 +84,53 @@ class PythonEvaluationTestCases(unittest.TestCase):
def test_name_error(self):
user_answer = ""
- name_error_msg = ("Traceback (most recent call last):\nNameError: "
- "name 'add' is not defined\n")
+ name_error_msg = textwrap.dedent("""\
+ Traceback (most recent call last):
+ NameError: name 'add' is not defined
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))
self.assertEquals(result.get("error"), name_error_msg)
def test_recursion_error(self):
- user_answer = ("def fact(a):\n\tif a == 0:\n\t\treturn fact(1)"
- "\n\telse:\n\t\treturn a * fact(a-1)")
- self.test_case_data = [{"func_name": "fact",
- "expected_answer": "24",
- "test_id": u'null',
- "pos_args": ["4"],
- "kw_args": {}
- }]
- recursion_error_msg = ('Traceback (most recent call last):\nRuntimeError: '
- 'maximum recursion depth exceeded\n')
+ user_answer = textwrap.dedent("""
+ def add(a, b):
+ return add(3, 3)
+ """)
+ recursion_error_msg = textwrap.dedent("""\
+ Traceback (most recent call last):
+ RuntimeError: maximum recursion depth exceeded
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))
self.assertEquals(result.get("error"), recursion_error_msg)
def test_type_error(self):
- user_answer = "def add(a):\n\treturn a+b"
- type_error_msg = ("Traceback (most recent call last):\nTypeError: "
- "add() takes exactly 1 argument (2 given)\n")
+ user_answer = textwrap.dedent("""
+ def add(a):
+ return a + b
+ """)
+ type_error_msg = textwrap.dedent("""\
+ Traceback (most recent call last):
+ TypeError: add() takes exactly 1 argument (2 given)
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))
self.assertEquals(result.get("error"), type_error_msg)
def test_value_error(self):
- user_answer = "def split(line):\n\t[ key, value ] = line.split()"
- value_error_msg = ("Traceback (most recent call last):\nValueError: "
- "need more than 1 value to unpack\n")
- self.test_case_data = [{"func_name": "split",
- "expected_answer": "Hello",
- "test_id": u'null',
- "pos_args": ["'Hello'"],
- "kw_args": {}
- }]
+ user_answer = textwrap.dedent("""
+ def add(a, b):
+ c = 'a'
+ return int(a) + int(b) + int(c)
+ """)
+ value_error_msg = textwrap.dedent("""\
+ Traceback (most recent call last):
+ ValueError: invalid literal for int() with base 10: 'a'
+ """)
evaluator = PythonCodeEvaluator(self.test_case_data, self.test, self.language, user_answer, ref_code_path=None, in_dir=None)
result = evaluator.evaluate()
self.assertFalse(result.get("success"))