diff options
author | mahesh | 2017-04-04 13:00:41 +0530 |
---|---|---|
committer | mahesh | 2017-04-04 13:00:41 +0530 |
commit | a9d7b48b6a5a79bf619500463d89f03e8ca1b7bb (patch) | |
tree | 0c0696c6d071efb7569e425f46c3df2cbb63f6f2 /yaksh/stdio_evaluator.py | |
parent | 734ad94d177be8ad400eb6f97e98612ce099e56a (diff) | |
download | online_test-a9d7b48b6a5a79bf619500463d89f03e8ca1b7bb.tar.gz online_test-a9d7b48b6a5a79bf619500463d89f03e8ca1b7bb.tar.bz2 online_test-a9d7b48b6a5a79bf619500463d89f03e8ca1b7bb.zip |
Kills stray processes in code, hook and stdio evaluator
Diffstat (limited to 'yaksh/stdio_evaluator.py')
-rw-r--r-- | yaksh/stdio_evaluator.py | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/yaksh/stdio_evaluator.py b/yaksh/stdio_evaluator.py index fa78a68..ec69851 100644 --- a/yaksh/stdio_evaluator.py +++ b/yaksh/stdio_evaluator.py @@ -2,6 +2,9 @@ from __future__ import unicode_literals # Local imports from .base_evaluator import BaseEvaluator +from .grader import TimeoutException +import os +import signal class StdIOEvaluator(BaseEvaluator): @@ -9,9 +12,13 @@ class StdIOEvaluator(BaseEvaluator): success = False ip = expected_input.replace(",", " ") encoded_input = '{0}\n'.format(ip).encode('utf-8') - user_output_bytes, output_err_bytes = proc.communicate(encoded_input) - user_output = user_output_bytes.decode('utf-8') - output_err = output_err_bytes.decode('utf-8') + try: + user_output_bytes, output_err_bytes = proc.communicate(encoded_input) + user_output = user_output_bytes.decode('utf-8') + output_err = output_err_bytes.decode('utf-8') + except TimeoutException: + os.killpg(os.getpgid(proc.pid), signal.SIGTERM) + raise expected_output = expected_output.replace("\r", "") if not expected_input: error_msg = "Expected Output is\n{0} ".\ |