Show More
Commit Description:
add dump submission & octave
Commit Description:
add dump submission & octave
File last commit:
Show/Diff file:
Action:
lib/runner.rb | 74 lines | 2.3 KiB | text/x-ruby | RubyLexer |
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 #
# A runner drives the engine into various tasks.
- add isolate...
r256 #
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23
module Grader
class Runner
def initialize(engine, grader_process=nil)
@engine = engine
@grader_process = grader_process
end
def grade_oldest_task
task = Task.get_inqueue_and_change_status(Task::STATUS_GRADING)
if task!=nil
@grader_process.report_active(task) if @grader_process!=nil
- add isolate...
r256
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 submission = Submission.find(task.submission_id)
@engine.grade(submission)
task.status_complete!
jittat
[grader] better status report...
r59 @grader_process.report_inactive(task) if @grader_process!=nil
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 end
return task
end
- new install script...
r254 # grade a specified problem for the latest submission of each user
# optionally, on all submission when options[:all_sub] is set
# optionally, only submission that has error (use when the problem itself has some problem)
Jittat Fakcharoenphol
added contest mode
r93 def grade_problem(problem, options={})
add --only-error to grader script
r240 user_index = 0
user_count = User.count
add options for grading all submissions of a specific problem
r163 User.find_each do |u|
add --only-error to grader script
r240 puts "user: #{u.login} (#{user_index}/#{user_count})"
user_index += 1
Jittat Fakcharoenphol
added contest mode
r93 if options[:user_conditions]!=nil
con_proc = options[:user_conditions]
next if not con_proc.call(u)
end
add options for grading all submissions of a specific problem
r163 if options[:all_sub]
Submission.where(user_id: u.id,problem_id: problem.id).find_each do |sub|
add --only-error to grader script
r240 next if options[:only_err] and sub.grader_comment != 'error during grading'
add options for grading all submissions of a specific problem
r163 @engine.grade(sub)
end
else
last_sub = Submission.find_last_by_user_and_problem(u.id,problem.id)
if last_sub!=nil
add --only-error to grader script
r240 @engine.grade(last_sub) unless options[:only_err] and last_sub.grader_comment != 'error during grading'
add options for grading all submissions of a specific problem
r163 end
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 end
end
end
jittat
[grader] +grade submission...
r61 def grade_submission(submission)
- add isolate...
r256 puts "RUNNER: grade submission: #{submission.id} by #{submission.try(:user).try(:full_name)}"
jittat
[grader] +grade submission...
r61 @engine.grade(submission)
end
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 def grade_oldest_test_request
test_request = TestRequest.get_inqueue_and_change_status(Task::STATUS_GRADING)
if test_request!=nil
@grader_process.report_active(test_request) if @grader_process!=nil
- add isolate...
r256
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 @engine.grade(test_request)
test_request.status_complete!
jittat
[grader] better status report...
r59 @grader_process.report_inactive(test_request) if @grader_process!=nil
jittat
[grader] [MERGED] Merged new-arch-branch changes 74:105 into the trunk...
r23 end
return test_request
end
end
end