OnlineJudge/judge/runner.py

92 lines
3.8 KiB
Python
Raw Normal View History

2015-11-28 12:32:49 +00:00
# coding=utf-8
import os
import socket
import shutil
2015-11-28 12:32:49 +00:00
2016-04-07 08:19:39 +00:00
from logger import logger
2015-11-28 12:32:49 +00:00
from client import JudgeClient
from language import languages
from compiler import compile_
from result import result
from settings import judger_workspace
2015-11-28 12:32:49 +00:00
class JudgeInstanceRunner(object):
def run(self, token, submission_id, language_code, code, time_limit, memory_limit, test_case_id,
spj, spj_language, spj_code, spj_version):
2015-11-28 12:32:49 +00:00
language = languages[language_code]
host_name = socket.gethostname()
judge_base_path = os.path.join(judger_workspace, "run", submission_id)
2015-12-07 09:35:03 +00:00
if not token or token != os.environ.get("rpc_token"):
2016-04-07 08:19:39 +00:00
if token:
logger.info("Invalid token: " + token)
2015-12-07 09:35:03 +00:00
return {"code": 2, "data": {"error": "Invalid token", "server": host_name}}
try:
os.mkdir(judge_base_path)
os.chmod(judge_base_path, 0777)
# 将代码写入文件
src_path = os.path.join(judge_base_path, language["src_name"])
f = open(src_path, "w")
f.write(code.encode("utf8"))
f.close()
except Exception as e:
shutil.rmtree(judge_base_path, ignore_errors=True)
return {"code": 2, "data": {"error": str(e), "server": host_name}}
2015-11-28 12:32:49 +00:00
# 编译
try:
exe_path = compile_(language_item=language, src_path=src_path,
exe_path=judge_base_path, judge_base_path=judge_base_path, compile_spj=False)
2015-11-28 12:32:49 +00:00
except Exception as e:
shutil.rmtree(judge_base_path, ignore_errors=True)
return {"code": 1, "data": {"error": str(e), "server": host_name}}
2015-11-28 12:32:49 +00:00
test_case_dir = os.path.join(judger_workspace, "test_case", test_case_id)
# SPJ相关
if spj:
spj_path = os.path.join(test_case_dir, "spj-" + spj_version)
if "spj-" + spj_version not in os.listdir(test_case_dir):
spj_language_item = languages[spj_language]
spj_code_path = os.path.join(test_case_dir, "spj-" + spj_language_item["src_name"])
f = open(spj_code_path, "w")
f.write(spj_code.encode("utf8"))
f.close()
try:
compile_(language_item=languages[spj_language], src_path=spj_code_path,
exe_path=spj_path,
judge_base_path=judge_base_path, compile_spj=True)
except Exception as e:
return {"code": 2, "data": {"error": "SPJ Compile error: " + str(e), "server": host_name}}
else:
spj_path = None
2015-11-28 12:32:49 +00:00
# 运行
try:
client = JudgeClient(language_code=language_code,
exe_path=exe_path,
max_cpu_time=int(time_limit),
2016-02-02 02:14:18 +00:00
max_memory=int(memory_limit) * 1024 * 1024,
test_case_dir=test_case_dir,
judge_base_path=judge_base_path, spj_path=spj_path)
judge_result = {"result": result["accepted"], "info": client.run(),
"accepted_answer_time": None, "server": host_name}
2015-11-28 12:32:49 +00:00
for item in judge_result["info"]:
2016-02-02 02:14:18 +00:00
if item["result"] != 0:
2015-11-28 12:32:49 +00:00
judge_result["result"] = item["result"]
break
else:
l = sorted(judge_result["info"], key=lambda k: k["cpu_time"])
judge_result["accepted_answer_time"] = l[-1]["cpu_time"]
return {"code": 0, "data": judge_result}
except Exception as e:
return {"code": 2, "data": {"error": str(e), "server": host_name}}
finally:
shutil.rmtree(judge_base_path, ignore_errors=True)