This commit is contained in:
zemal 2017-05-10 17:46:59 +08:00
parent 08bd591bfb
commit 219facf185
7 changed files with 21 additions and 33 deletions

View File

@ -1,11 +1,11 @@
import hashlib
from django.utils import timezone
from django_redis import get_redis_connection
# from django_redis import get_redis_connection
from account.decorators import super_admin_required
from judge.languages import languages, spj_languages
from judge.dispatcher import process_pending_task
# from judge.dispatcher import process_pending_task
from utils.api import APIView, CSRFExemptAPIView, validate_serializer
from utils.shortcuts import rand_str
@ -129,8 +129,8 @@ class JudgeServerHeartbeatAPI(CSRFExemptAPIView):
last_heartbeat=timezone.now(),
)
# 新server上线 处理队列中的防止没有新的提交而导致一直waiting
conn = get_redis_connection("JudgeQueue")
process_pending_task(conn)
# conn = get_redis_connection("JudgeQueue")
# process_pending_task(conn)
return self.success()

View File

@ -50,7 +50,7 @@ class JudgeDispatcher(object):
def choose_judge_server():
with transaction.atomic():
# TODO: use more reasonable way
servers = JudgeServer.objects.select_for_update().all().order_by('task_number')
servers = JudgeServer.objects.select_for_update().all().order_by("task_number")
servers = [s for s in servers if s.status == "normal"]
if servers:
server = servers[0]
@ -69,13 +69,13 @@ class JudgeDispatcher(object):
def judge(self, output=False):
server = self.choose_judge_server()
if not server:
data = {'submission_id': self.submission_obj.id, 'problem_id': self.problem_obj.id}
data = {"submission_id": self.submission_obj.id, "problem_id": self.problem_obj.id}
self.redis_conn.lpush(WAITING_QUEUE, json.dumps(data))
return
language = list(filter(lambda item: self.submission_obj.language == item['name'], languages))[0]
language = list(filter(lambda item: self.submission_obj.language == item["name"], languages))[0]
data = {
"language_config": language['config'],
"language_config": language["config"],
"src": self.submission_obj.code,
"max_cpu_time": self.problem_obj.time_limit,
"max_memory": 1024 * 1024 * self.problem_obj.memory_limit,
@ -85,15 +85,15 @@ class JudgeDispatcher(object):
# TODO: try catch
resp = self._request(urljoin(server.service_url, "/judge"), data=data)
self.submission_obj.info = resp
if resp['err']:
if resp["err"]:
self.submission_obj.result = JudgeStatus.COMPILE_ERROR
else:
error_test_case = list(filter(lambda case: case['result'] != 0, resp['data']))
error_test_case = list(filter(lambda case: case["result"] != 0, resp["data"]))
# 多个测试点全部正确AC否则ACM模式下取第一个测试点状态
if not error_test_case:
self.submission_obj.result = JudgeStatus.ACCEPTED
elif self.problem_obj.rule_type == ProblemRuleType.ACM:
self.submission_obj.result = error_test_case[0]['result']
self.submission_obj.result = error_test_case[0]["result"]
else:
self.submission_obj.result = JudgeStatus.PARTIALLY_ACCEPTED
self.submission_obj.save()

View File

@ -3,4 +3,4 @@ from __future__ import absolute_import, unicode_literals
# Django starts so that shared_task will use this app.
from .celery import app as celery_app
__all__ = ['celery_app']
__all__ = ["celery_app"]

View File

@ -3,15 +3,15 @@ import os
from celery import Celery
from django.conf import settings
# set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'oj.settings')
# set the default Django settings module for the "celery" program.
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "oj.settings")
app = Celery('oj')
app = Celery("oj")
# Using a string here means the worker will not have to
# pickle the object when using Windows.
app.config_from_object('django.conf:settings')
app.config_from_object("django.conf:settings")
# load task modules from all registered Django app configs.
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)

View File

@ -64,11 +64,11 @@ class AbstractProblem(models.Model):
def add_submission_number(self):
self.total_submit_number = models.F("total_submit_number") + 1
self.save(update_fields=['total_submit_number'])
self.save(update_fields=["total_submit_number"])
def add_ac_number(self):
self.total_accepted_number = models.F("total_accepted_number") + 1
self.save(update_fields=['total_accepted_number'])
self.save(update_fields=["total_accepted_number"])
class Problem(AbstractProblem):

View File

@ -1,12 +0,0 @@
django==1.9.6
django-redis
djangorestframework==3.4.0
otpauth
pillow
python-dateutil
celery
Envelopes
pytz
jsonfield
qrcode
requests

View File

@ -30,13 +30,13 @@ class SubmissionAPI(APIView):
data = request.data
try:
problem = Problem.objects.get(id=data['problem_id'])
problem = Problem.objects.get(id=data["problem_id"])
except Problem.DoesNotExist:
return self.error("Problem not exist")
# TODO: user_id
submission = Submission.objects.create(user_id=1,
language=data['language'],
code=data['code'],
language=data["language"],
code=data["code"],
problem_id=problem.id)
judge_task.delay(submission.id, problem.id)
# JudgeDispatcher(submission.id, problem.id).judge()