Description:
added time out check for code jom submissions
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r242:803c8843ad9b - - 3 files changed: 29 inserted, 15 deleted

@@ -159,70 +159,79
159 159 render :nothing => true
160 160 end
161 161
162 162 def error
163 163 @user = User.find(session[:user_id])
164 164 end
165 165
166 166 # announcement refreshing and hiding methods
167 167
168 168 def announcements
169 169 if params.has_key? 'recent'
170 170 prepare_announcements(params[:recent])
171 171 else
172 172 prepare_announcements
173 173 end
174 174 render(:partial => 'announcement',
175 175 :collection => @announcements,
176 176 :locals => {:announcement_effect => true})
177 177 end
178 178
179 179 #
180 180 # actions for Code Jom
181 181 #
182 182 def download_input
183 + user = User.find(session[:user_id])
184 +
185 + if Configuration.time_limit_mode? and user.contest_finished?
186 + redirect_to :action => 'list' and return
187 + end
188 +
183 189 problem = Problem.find(params[:id])
184 - user = User.find(session[:user_id])
185 190 if user.can_request_new_test_pair_for? problem
186 191 assignment = user.get_new_test_pair_assignment_for problem
187 192 assignment.save
188 193
189 194 send_data(assignment.test_pair.input,
190 195 { :filename => "#{problem.name}-#{assignment.request_number}.in",
191 196 :type => 'text/plain' })
192 197 else
193 198 recent_assignment = user.get_recent_test_pair_assignment_for problem
194 199 send_data(recent_assignment.test_pair.input,
195 200 { :filename => "#{problem.name}-#{recent_assignment.request_number}.in",
196 201 :type => 'text/plain' })
197 202 end
198 203 end
199 204
200 205 def submit_solution
201 206 problem = Problem.find(params[:id])
202 207 user = User.find(session[:user_id])
203 208 recent_assignment = user.get_recent_test_pair_assignment_for problem
204 209
210 + if Configuration.time_limit_mode? and user.contest_finished?
211 + redirect_to :action => 'list' and return
212 + end
213 +
205 214 if recent_assignment == nil
206 215 flash[:notice] = 'You have not requested for any input data for this problem. Please download an input first.'
207 216 session[:current_problem_id] = problem.id
208 217 redirect_to :action => 'list' and return
209 218 end
210 219
211 220 if recent_assignment.expired?
212 221 flash[:notice] = 'The current input is expired. Please download a new input data.'
213 222 session[:current_problem_id] = problem.id
214 223 redirect_to :action => 'list' and return
215 224 end
216 225
217 226 if recent_assignment.submitted
218 227 flash[:notice] = 'You have already submitted an incorrect solution for this input. Please download a new input data.'
219 228 session[:current_problem_id] = problem.id
220 229 redirect_to :action => 'list' and return
221 230 end
222 231
223 232 if params[:file] == nil
224 233 flash[:notice] = 'You have not submitted any output.'
225 234 session[:current_problem_id] = problem.id
226 235 redirect_to :action => 'list' and return
227 236 end
228 237
@@ -1,21 +1,26
1 1 .problem-panel{:id => "problem-panel-#{problem.id}", :style => "#{(problem.id != @current_problem_id) ? "display:none" : ""}"}
2 - .problem-form{:id => "problem-form-#{problem.id}"}
3 - - form_tag({ :action => 'download_input', :id => problem.id }, :method => :post) do
4 - %b Input:
5 - %input{:type => "submit", :value => "Download input", :onclick => "CodejomTimeout.updateTimeoutAfterDownloadClick(#{problem.id}); return true;"}
6 - %span{:id => "problem-timing-message-#{problem.id}"}
7 - = "After downloading, you have #{TEST_ASSIGNMENT_EXPIRATION_DURATION/60} minutes to submit."
8 - %div{:id => "problem-submission-form-#{problem.id}"}
9 - - form_tag({ :action => 'submit_solution', :id => problem.id }, :method => :post, :multipart => true) do
10 - %b Submit output:
11 - %input{:type => "file", :name => "file"}
12 - %input{:type => "submit", :value => "Submit solution"}
2 + - if (not Configuration.time_limit_mode?) or (not @user.contest_finished?)
3 + .problem-form{:id => "problem-form-#{problem.id}"}
4 + - form_tag({ :action => 'download_input', :id => problem.id }, :method => :post) do
5 + %b Input:
6 + %input{:type => "submit", :value => "Download input", :onclick => "CodejomTimeout.updateTimeoutAfterDownloadClick(#{problem.id}); return true;"}
7 + %span{:id => "problem-timing-message-#{problem.id}"}
8 + = "After downloading, you have #{TEST_ASSIGNMENT_EXPIRATION_DURATION/60} minutes to submit."
9 + %div{:id => "problem-submission-form-#{problem.id}"}
10 + - form_tag({ :action => 'submit_solution', :id => problem.id }, :method => :post, :multipart => true) do
11 + %b Submit output:
12 + %input{:type => "file", :name => "file"}
13 + %input{:type => "submit", :value => "Submit solution"}
14 + - else
15 + .problem-form
16 + %p
17 + The contest is over, you can view the tasks, but you can no longer submit.
13 18
14 19 .problem-description
15 20 - if problem.description!=nil
16 21 - if problem.description.markdowned
17 22 ~ markdown(problem.description.body)
18 23 - else
19 24 = problem.description.body
20 25 - else
21 26 (not available)
@@ -1,36 +1,36
1 1 # This file is auto-generated from the current state of the database. Instead of editing this file,
2 2 # please use the migrations feature of Active Record to incrementally modify your database, and
3 3 # then regenerate this schema definition.
4 4 #
5 5 # Note that this schema.rb definition is the authoritative source for your database schema. If you need
6 6 # to create the application database on another system, you should be using db:schema:load, not running
7 7 # all the migrations from scratch. The latter is a flawed and unsustainable approach (the more migrations
8 8 # you'll amass, the slower it'll run and the greater likelihood for issues).
9 9 #
10 10 # It's strongly recommended to check this file into your version control system.
11 11
12 - ActiveRecord::Schema.define(:version => 20100126170609) do
12 + ActiveRecord::Schema.define(:version => 20100129041917) do
13 13
14 14 create_table "announcements", :force => true do |t|
15 15 t.string "author"
16 16 t.text "body"
17 17 t.boolean "published"
18 18 t.datetime "created_at"
19 19 t.datetime "updated_at"
20 20 t.boolean "frontpage", :default => false
21 21 t.boolean "contest_only", :default => false
22 22 t.string "title"
23 23 end
24 24
25 25 create_table "codejom_statuses", :force => true do |t|
26 26 t.integer "user_id"
27 27 t.boolean "alive"
28 28 t.integer "num_problems_passed"
29 29 t.datetime "created_at"
30 30 t.datetime "updated_at"
31 31 end
32 32
33 33 create_table "configurations", :force => true do |t|
34 34 t.string "key"
35 35 t.string "value_type"
36 36 t.string "value"
@@ -165,50 +165,50
165 165
166 166 add_index "submissions", ["user_id", "problem_id", "number"], :name => "index_submissions_on_user_id_and_problem_id_and_number", :unique => true
167 167 add_index "submissions", ["user_id", "problem_id"], :name => "index_submissions_on_user_id_and_problem_id"
168 168
169 169 create_table "tasks", :force => true do |t|
170 170 t.integer "submission_id"
171 171 t.datetime "created_at"
172 172 t.integer "status"
173 173 t.datetime "updated_at"
174 174 end
175 175
176 176 create_table "test_pair_assignments", :force => true do |t|
177 177 t.integer "user_id"
178 178 t.integer "problem_id"
179 179 t.integer "test_pair_id"
180 180 t.integer "test_pair_number"
181 181 t.integer "request_number"
182 182 t.datetime "created_at"
183 183 t.datetime "updated_at"
184 184 t.boolean "submitted"
185 185 end
186 186
187 187 create_table "test_pairs", :force => true do |t|
188 188 t.integer "problem_id"
189 - t.text "input"
190 - t.text "solution"
189 + t.text "input", :limit => 16777215
190 + t.text "solution", :limit => 16777215
191 191 t.datetime "created_at"
192 192 t.datetime "updated_at"
193 193 t.integer "number"
194 194 end
195 195
196 196 create_table "test_requests", :force => true do |t|
197 197 t.integer "user_id"
198 198 t.integer "problem_id"
199 199 t.integer "submission_id"
200 200 t.string "input_file_name"
201 201 t.string "output_file_name"
202 202 t.string "running_stat"
203 203 t.integer "status"
204 204 t.datetime "updated_at"
205 205 t.datetime "submitted_at"
206 206 t.datetime "compiled_at"
207 207 t.text "compiler_message"
208 208 t.datetime "graded_at"
209 209 t.string "grader_comment"
210 210 t.datetime "created_at"
211 211 t.float "running_time"
212 212 t.string "exit_status"
213 213 t.integer "memory_usage"
214 214 end
You need to be logged in to leave comments. Login now