icp/oer/exercise-formats/program/match-regex-parallel/controller.py

89 lines
2.2 KiB
Python
Raw Normal View History

2018-05-05 22:18:02 +00:00
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# program/match-regex
# Standardized types do not require authors to specify any control script as
# it can be generated on import. However when provided it will overwrite the
# default behaivior.
import sys
import subprocess
import re
import time
def build(ctx):
# Add filenames
allArgs = ['/usr/bin/make']
# start subprocess in with work_path as cwd
p = subprocess.Popen(allArgs, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=ctx.work_path)
msgs,errs = p.communicate()
2018-05-06 10:35:06 +00:00
retval = p.wait()
2018-05-05 22:18:02 +00:00
errs = errs.decode("utf-8")
msgs = msgs.decode("utf-8")
return retval, errs, msgs
def execute(ctx):
print("parallel execute()", file=sys.stderr)
# if build failed, return early
if ctx.build_result[0] != 0:
return
allArgs = ["/usr/bin/sbatch", ctx.work_path + "/job.slurm"]
p = subprocess.Popen(allArgs, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE, cwd=ctx.work_path)
msgs,errs = p.communicate()
2018-05-06 10:35:06 +00:00
retval = p.wait()
2018-05-05 22:18:02 +00:00
errs = errs.decode("utf-8")
msgs = msgs.decode("utf-8")
2018-05-06 12:11:47 +00:00
ctx.execute_result = (retval, errs, msgs)
2018-05-05 22:18:02 +00:00
retval = ctx.get_file_content('job.exit')
errs = ctx.get_file_content('job.err')
msgs = ctx.get_file_content('job.out')
2018-05-06 10:35:06 +00:00
2018-05-05 22:18:02 +00:00
print( (retval, errs, msgs), file=sys.stderr)
return retval, errs, msgs
def grade(ctx):
"""A function that governs the grading process when different from default.
Expected is return value that indicates if the task passed or failed."""
print("parallel grade()", file=sys.stderr)
# if build failed, return early and set grade to FAIL
if ctx.build_result[0] != 0:
return 'FAIL'
ctx.execute_result = execute(ctx)
print(ctx.data['data']['regex'], file=sys.stderr)
print(ctx.execute_result, file=sys.stderr)
if re.match(ctx.data['data']['regex'], ctx.execute_result[2]) != None:
return 'PASS'
else:
return 'FAIL'
2018-05-06 10:35:06 +00:00
2018-05-05 22:18:02 +00:00
def response(ctx):
if ctx.build_result[0] != 0:
output = ctx.build_result[1]
else:
2018-05-06 12:11:47 +00:00
output = ctx.execute_result[2] + "\n" + ctx.execute_result[1]
2018-05-05 22:18:02 +00:00
grade = ctx.grade_result
msg = ""
return {'output': output, 'grade': grade, 'msg': msg, 'data': None}