From 688c721bd31d2e27f8d6da08babf593b19a49680 Mon Sep 17 00:00:00 2001 From: daiao <358551898@qq.com> Date: Fri, 12 Apr 2019 18:17:22 +0800 Subject: [PATCH 1/7] 1 --- app/views/challenges/_edit_evaluating_page.html.erb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/views/challenges/_edit_evaluating_page.html.erb b/app/views/challenges/_edit_evaluating_page.html.erb index ae905663..6a04a07b 100644 --- a/app/views/challenges/_edit_evaluating_page.html.erb +++ b/app/views/challenges/_edit_evaluating_page.html.erb @@ -297,7 +297,7 @@ $("#test_file_name").show(); }else{ $("#challenge_shixun_update").submit(); - location.reload(); + // location.reload(); } } \ No newline at end of file From 096b9583862e585bc53a4dfbbc6dec3ea6f01ebf Mon Sep 17 00:00:00 2001 From: jingquan huang Date: Sat, 13 Apr 2019 09:19:07 +0800 Subject: [PATCH 2/7] =?UTF-8?q?=E7=BA=BF=E4=B8=8A=E7=89=88=E6=9C=AC?= =?UTF-8?q?=E6=95=B0=E6=8D=AE=E5=AF=BC=E5=85=A5=E5=88=B0=E4=B8=B4=E6=97=B6?= =?UTF-8?q?=E8=A1=A8=EF=BC=8C=E4=B8=B4=E6=97=B6=E8=A1=A8=E8=BD=AC=E5=88=B0?= =?UTF-8?q?=E7=BA=BF=E4=B8=8A=E7=89=88?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/controllers/welcome_controller.rb | 150 ++++++++++++++++++ app/models/local_challenge.rb | 3 + app/models/local_challenge_tag.rb | 3 + app/models/local_mirror_repository.rb | 3 + app/models/local_shixun.rb | 3 + app/models/local_shixun_tag_repertoire.rb | 2 + app/models/local_test_set.rb | 3 + app/models/shixun_tag_repertoire.rb | 2 +- config/routes.rb | 3 + ...70441_migrate_homework_common_end_times.rb | 14 +- ...80718_migrate_homework_common_end_time2.rb | 12 +- .../20190412012134_create_local_shixuns.rb | 47 ++++++ ...025818_create_local_mirror_repositories.rb | 10 ++ ...547_create_local_shixun_tag_repertoires.rb | 10 ++ .../20190412062718_create_local_challenges.rb | 29 ++++ .../20190412062923_create_local_test_sets.rb | 14 ++ ...90412063622_create_local_challenge_tags.rb | 10 ++ ...5_add_test_set_score_to_local_challenge.rb | 5 + ...412074140_add_shixun_id_to_local_shixun.rb | 5 + ...0412080258_add_score_to_local_test_sets.rb | 5 + lib/tasks/shixun_local.rake | 0 spec/factories/local_challenge_tags.rb | 6 + spec/factories/local_challenges.rb | 25 +++ spec/factories/local_mirror_repositories.rb | 6 + .../factories/local_shixun_tag_repertoires.rb | 6 + spec/factories/local_shixuns.rb | 37 +++++ spec/factories/local_test_sets.rb | 10 ++ spec/models/local_challenge_spec.rb | 5 + spec/models/local_challenge_tag_spec.rb | 5 + spec/models/local_mirror_repository_spec.rb | 5 + spec/models/local_shixun_spec.rb | 5 + .../local_shixun_tag_repertoire_spec.rb | 5 + spec/models/local_test_set_spec.rb | 5 + 33 files changed, 439 insertions(+), 14 deletions(-) create mode 100644 app/models/local_challenge.rb create mode 100644 app/models/local_challenge_tag.rb create mode 100644 app/models/local_mirror_repository.rb create mode 100644 app/models/local_shixun.rb create mode 100644 app/models/local_shixun_tag_repertoire.rb create mode 100644 app/models/local_test_set.rb create mode 100644 db/migrate/20190412012134_create_local_shixuns.rb create mode 100644 db/migrate/20190412025818_create_local_mirror_repositories.rb create mode 100644 db/migrate/20190412033547_create_local_shixun_tag_repertoires.rb create mode 100644 db/migrate/20190412062718_create_local_challenges.rb create mode 100644 db/migrate/20190412062923_create_local_test_sets.rb create mode 100644 db/migrate/20190412063622_create_local_challenge_tags.rb create mode 100644 db/migrate/20190412073015_add_test_set_score_to_local_challenge.rb create mode 100644 db/migrate/20190412074140_add_shixun_id_to_local_shixun.rb create mode 100644 db/migrate/20190412080258_add_score_to_local_test_sets.rb create mode 100644 lib/tasks/shixun_local.rake create mode 100644 spec/factories/local_challenge_tags.rb create mode 100644 spec/factories/local_challenges.rb create mode 100644 spec/factories/local_mirror_repositories.rb create mode 100644 spec/factories/local_shixun_tag_repertoires.rb create mode 100644 spec/factories/local_shixuns.rb create mode 100644 spec/factories/local_test_sets.rb create mode 100644 spec/models/local_challenge_spec.rb create mode 100644 spec/models/local_challenge_tag_spec.rb create mode 100644 spec/models/local_mirror_repository_spec.rb create mode 100644 spec/models/local_shixun_spec.rb create mode 100644 spec/models/local_shixun_tag_repertoire_spec.rb create mode 100644 spec/models/local_test_set_spec.rb diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb index a1e7299a..c6fa78d9 100644 --- a/app/controllers/welcome_controller.rb +++ b/app/controllers/welcome_controller.rb @@ -28,6 +28,156 @@ class WelcomeController < ApplicationController skip_before_filter :check_authentication, :only => [:index] require 'simple_xlsx_reader' + + DCODES = %W(2 3 4 5 6 7 8 9 a b c f e f g h i j k l m n o p q r s t u v w x y z) + def shixun_to_local + identifiers = params[:identifiers].split(",") + shixuns = Shixun.where(identifier: identifiers) + # 不重复导入 + ActiveRecord::Base.transaction do + begin + shixuns.each do |shixun| + if LocalShixun.where(shixun_id: shixun.id).blank? + + local_shixun = LocalShixun.create!(name: shixun.name, description: shixun.description, user_id: User.current.id, status: 0, + trainee: shixun.trainee, webssh: shixun.webssh, multi_webssh: shixun.multi_webssh, + can_copy: shixun.can_copy, identifier: generate_identifier, shixun_id: shixun.id, + use_scope: shixun.use_scope, visits: 1, evaluate_script: shixun.evaluate_script) + + # 同步镜像 + if shixun.mirror_repositories.present? + shixun.mirror_repositories.each do |mirror| + LocalMirrorRepository.create!(:local_shixun_id => local_shixun.id, :mirror_repository_id => mirror.id) + end + end + + # 同步技术标签 + shixun.shixun_tag_repertoires.each do |str| + LocalShixunTagRepertoire.create!(:tag_repertoire_id => str.tag_repertoire_id, :local_shixun_id => local_shixun.id) + end + + # 不需要同步版本库,版本库应该是从本地导入到线上的时候由线上版本创建的 + + # 同步复制关卡 + if shixun.challenges.present? + shixun.challenges.each do |challenge| + new_challenge = LocalChallenge.new + new_challenge.attributes = challenge.attributes.dup.except("id","shixun_id","user_id") + new_challenge.local_shixun_id = local_shixun.id + new_challenge.save! + # 评测题,选择题暂时不考虑 + # 同步测试集 + if challenge.test_sets.present? + challenge.test_sets.each do |test_set| + new_test_set = LocalTestSet.new + new_test_set.attributes = test_set.attributes.dup.except("id","challenge_id") + new_test_set.local_challenge_id = new_challenge.id + new_test_set.save! + end + end + # 同步关卡标签 + challenge_tags = ChallengeTag.where("challenge_id =? and challenge_choose_id is null", challenge.id) + if challenge_tags.present? + challenge_tags.each do |challenge_tag| + LocalChallengeTag.create!(:local_challenge_id => new_challenge.id, :name => challenge_tag.try(:name)) + end + end + end + end + end + end + render :json => {status: 0, message: "同步成功"} + rescue Exception => e + logger.error("shixun_local_in ##{e.message}") + render :json => {status: -1, message: "同步失败,#{e.message}"} + raise ActiveRecord::Rollback + end + + end + end + + def local_to_shixun + ActiveRecord::Base.transaction do + LocalShixun.find_each do |local_shixun| + identifier = generate_identifier + shixun = Shixun.create!(name: local_shixun.name, description: local_shixun.description, user_id: User.current.id, + trainee: local_shixun.trainee, webssh: local_shixun.webssh, multi_webssh: local_shixun.multi_webssh, + can_copy: local_shixun.can_copy, identifier: identifier, reset_time: Time.now, + modify_time: Time.now, use_scope: local_shixun.use_scope, visits: 1, evaluate_script: local_shixun.evaluate_script) + m = ShixunMember.new(:user_id => User.current.id, :role => 1) + shixun.shixun_members << m + + # 同步镜像 + local_mirrors = LocalMirrorRepository.where(local_shixun_id: local_shixun.id) + if local_mirrors.present? + local_mirrors.each do |local_mirror| + ShixunMirrorRepository.create!(:shixun_id => shixun.id, :mirror_repository_id => local_mirror.mirror_repository_id) + end + end + + # 同步技术标签 + local_shixun_tags = LocalShixunTagRepertoire.where(local_shixun_id: local_shixun.id) + if local_shixun_tags.present? + local_shixun_tags.each do |str| + ShixunTagRepertoire.create!(:tag_repertoire_id => str.tag_repertoire_id, :shixun_id => shixun.id) + end + end + + # 创建版本库 + repository = Repository.new + repository.shixun = shixun + repository.type = 'Repository::Gitlab' + repository.identifier = shixun.identifier.downcase + repository.project_id = -1 + repository.save! + s = Trustie::Gitlab::Sync.new + s.create_shixun(shixun, repository) + raise "版本库创建失败" if shixun.gpid.blank? # 若和gitlab没同步成功,则抛出异常 + g = Gitlab.client + shixun.update_column(:git_url, g.project(shixun.gpid).path_with_namespace) + + # 同步关卡信息 + local_challenges = LocalChallenge.where(local_shixun_id: local_shixun.id) + if local_challenges.present? + local_challenges.each do |local_challenge| + new_challenge = Challenge.new + new_challenge.attributes = local_challenge.attributes.dup.except("id","local_shixun_id","user_id") + new_challenge.user_id = User.current.id + new_challenge.shixun_id = shixun.id + new_challenge.save! + + # 同步测试集 + local_test_sets = LocalTestSet.where(local_challenge_id: local_challenge.id) + if local_test_sets.present? + local_test_sets.each do |local_test_set| + new_test_set = TestSet.new + new_test_set.attributes = local_test_set.attributes.dup.except("id","challenge_id") + new_test_set.challenge_id = new_challenge.id + new_test_set.save! + end + end + + # 同步关卡标签 + local_challenge_tags = LocalChallengeTag.where(local_challenge_id: local_challenge.id) + if local_challenge_tags.present? + local_challenge_tags.each do |local_challenge_tag| + ChallengeTag.create!(:challenge_id => new_challenge.id, :name => local_challenge_tag.try(:name)) + end + end + end + end + render :json => {status: 0, message: "success", identifier: shixun.identifier} + end + end + end + + + # 生成表示码 + def generate_identifier + code = DCODES.sample(8).join + return generate_identifier if Shixun.where(identifier: code).present? + code + end def index images = PortalImage.where(status: true).order("position asc") diff --git a/app/models/local_challenge.rb b/app/models/local_challenge.rb new file mode 100644 index 00000000..10cf4586 --- /dev/null +++ b/app/models/local_challenge.rb @@ -0,0 +1,3 @@ +class LocalChallenge < ActiveRecord::Base + +end diff --git a/app/models/local_challenge_tag.rb b/app/models/local_challenge_tag.rb new file mode 100644 index 00000000..9768ef30 --- /dev/null +++ b/app/models/local_challenge_tag.rb @@ -0,0 +1,3 @@ +class LocalChallengeTag < ActiveRecord::Base + +end diff --git a/app/models/local_mirror_repository.rb b/app/models/local_mirror_repository.rb new file mode 100644 index 00000000..d402a2df --- /dev/null +++ b/app/models/local_mirror_repository.rb @@ -0,0 +1,3 @@ +class LocalMirrorRepository < ActiveRecord::Base + +end diff --git a/app/models/local_shixun.rb b/app/models/local_shixun.rb new file mode 100644 index 00000000..b8480236 --- /dev/null +++ b/app/models/local_shixun.rb @@ -0,0 +1,3 @@ +class LocalShixun < ActiveRecord::Base + +end diff --git a/app/models/local_shixun_tag_repertoire.rb b/app/models/local_shixun_tag_repertoire.rb new file mode 100644 index 00000000..b3d2721b --- /dev/null +++ b/app/models/local_shixun_tag_repertoire.rb @@ -0,0 +1,2 @@ +class LocalShixunTagRepertoire < ActiveRecord::Base +end diff --git a/app/models/local_test_set.rb b/app/models/local_test_set.rb new file mode 100644 index 00000000..f4320b58 --- /dev/null +++ b/app/models/local_test_set.rb @@ -0,0 +1,3 @@ +class LocalTestSet < ActiveRecord::Base + +end diff --git a/app/models/shixun_tag_repertoire.rb b/app/models/shixun_tag_repertoire.rb index 83a52ee6..8164c98d 100644 --- a/app/models/shixun_tag_repertoire.rb +++ b/app/models/shixun_tag_repertoire.rb @@ -1,4 +1,4 @@ -class ShixunTagRepertoire < ActiveRecord::Base + class ShixunTagRepertoire < ActiveRecord::Base # attr_accessible :title, :body belongs_to :shixun belongs_to :tag_repertoire diff --git a/config/routes.rb b/config/routes.rb index 3acb9123..28319fd3 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -281,6 +281,9 @@ RedmineApp::Application.routes.draw do ## oauth相关 end get 'welcome/ccf' => 'welcome#ccf' + get 'welcome/shixun_to_local' => 'welcome#shixun_to_local' + get 'welcome/local_to_shixun' => 'welcome#local_to_shixun' + # get 'competitions/home' => 'competitions#home' # get 'competitions/hn' => 'competitions#index' # get 'competitions/db' => 'competitions#db' diff --git a/db/migrate/20190329070441_migrate_homework_common_end_times.rb b/db/migrate/20190329070441_migrate_homework_common_end_times.rb index 0fa7b6cb..ac6bb087 100644 --- a/db/migrate/20190329070441_migrate_homework_common_end_times.rb +++ b/db/migrate/20190329070441_migrate_homework_common_end_times.rb @@ -1,12 +1,12 @@ class MigrateHomeworkCommonEndTimes < ActiveRecord::Migration def up - homework_commons = HomeworkCommon.where("id < 21549") - homework_commons.find_each do |homework| - sql = "update homework_commons set end_time = (select max(end_time) from - homework_seconds where id = #{homework.id}) where id = #{homework.id}" - - ActiveRecord::Base.connection.execute(sql) - end + # homework_commons = HomeworkCommon.where("id < 21549") + # homework_commons.find_each do |homework| + # sql = "update homework_commons set end_time = (select max(end_time) from + # homework_seconds where id = #{homework.id}) where id = #{homework.id}" + # + # ActiveRecord::Base.connection.execute(sql) + # end end def down diff --git a/db/migrate/20190329080718_migrate_homework_common_end_time2.rb b/db/migrate/20190329080718_migrate_homework_common_end_time2.rb index 65d4670a..19f048fe 100644 --- a/db/migrate/20190329080718_migrate_homework_common_end_time2.rb +++ b/db/migrate/20190329080718_migrate_homework_common_end_time2.rb @@ -1,11 +1,11 @@ class MigrateHomeworkCommonEndTime2 < ActiveRecord::Migration def up - homework_commons = HomeworkCommon.where("id >= 21549") - homework_commons.each do |homework| - if homework.publish_time.nil? - homework.update_column('end_time', nil) - end - end + # homework_commons = HomeworkCommon.where("id >= 21549") + # homework_commons.each do |homework| + # if homework.publish_time.nil? + # homework.update_column('end_time', nil) + # end + # end end def down diff --git a/db/migrate/20190412012134_create_local_shixuns.rb b/db/migrate/20190412012134_create_local_shixuns.rb new file mode 100644 index 00000000..39d5adae --- /dev/null +++ b/db/migrate/20190412012134_create_local_shixuns.rb @@ -0,0 +1,47 @@ +class CreateLocalShixuns < ActiveRecord::Migration + def change + create_table :local_shixuns do |t| + t.string :name + t.text :description + t.integer :user_id + t.integer :gpid + t.integer :visits + t.integer :status + t.string :language + t.text :authentication + t.string :identifier + t.text :propaedeutics + t.integer :trainee + t.integer :major_id + t.integer :webssh + t.boolean :homepage_show + t.boolean :hidden + t.integer :fork_from + t.boolean :can_copy + t.datetime :modifiy_tim + t.datetime :reset_time + t.integer :closer_id + t.datetime :end_time + t.string :git_url + t.boolean :vnc + t.integer :myshixuns_count + t.integer :challenges_count + t.integer :use_scope + t.text :evaluate_script + t.integer :mirror_script_id + t.string :image_text + t.boolean :code_hidden + t.boolean :task_pass + t.integer :exec_time + t.string :test_set_permission + t.boolean :sigle_training + t.boolean :hide_code + t.boolean :multi_webssh + t.integer :excute_time + t.integer :averge_star + t.integer :forbid_copy + + t.timestamps + end + end +end diff --git a/db/migrate/20190412025818_create_local_mirror_repositories.rb b/db/migrate/20190412025818_create_local_mirror_repositories.rb new file mode 100644 index 00000000..a47bff50 --- /dev/null +++ b/db/migrate/20190412025818_create_local_mirror_repositories.rb @@ -0,0 +1,10 @@ +class CreateLocalMirrorRepositories < ActiveRecord::Migration + def change + create_table :local_mirror_repositories do |t| + t.integer :local_shixun_id + t.integer :mirror_repository_id + + t.timestamps + end + end +end diff --git a/db/migrate/20190412033547_create_local_shixun_tag_repertoires.rb b/db/migrate/20190412033547_create_local_shixun_tag_repertoires.rb new file mode 100644 index 00000000..d870316a --- /dev/null +++ b/db/migrate/20190412033547_create_local_shixun_tag_repertoires.rb @@ -0,0 +1,10 @@ +class CreateLocalShixunTagRepertoires < ActiveRecord::Migration + def change + create_table :local_shixun_tag_repertoires do |t| + t.integer :tag_repertoire_id + t.integer :local_shixun_id + + t.timestamps + end + end +end diff --git a/db/migrate/20190412062718_create_local_challenges.rb b/db/migrate/20190412062718_create_local_challenges.rb new file mode 100644 index 00000000..156e2a4b --- /dev/null +++ b/db/migrate/20190412062718_create_local_challenges.rb @@ -0,0 +1,29 @@ +class CreateLocalChallenges < ActiveRecord::Migration + def change + create_table :local_challenges do |t| + t.integer :local_shixun_id + t.string :subject + t.integer :status + t.integer :position + t.text :task_pass + t.text :answer + t.integer :score + t.integer :visits + t.string :path + t.integer :evaluation_way + t.integer :difficulty + t.string :exec_path + t.integer :code_line + t.integer :st + t.text :web_route + t.text :picture_path + t.text :expect_picture_path + t.integer :challenge_tags_count + t.datetime :modify_time + t.string :original_picture_path + t.integer :show_type + + t.timestamps + end + end +end diff --git a/db/migrate/20190412062923_create_local_test_sets.rb b/db/migrate/20190412062923_create_local_test_sets.rb new file mode 100644 index 00000000..1ec6e0af --- /dev/null +++ b/db/migrate/20190412062923_create_local_test_sets.rb @@ -0,0 +1,14 @@ +class CreateLocalTestSets < ActiveRecord::Migration + def change + create_table :local_test_sets do |t| + t.text :input + t.text :output + t.integer :local_challenge_id + t.integer :is_public + t.integer :result + t.integer :position + + t.timestamps + end + end +end diff --git a/db/migrate/20190412063622_create_local_challenge_tags.rb b/db/migrate/20190412063622_create_local_challenge_tags.rb new file mode 100644 index 00000000..0b35a12e --- /dev/null +++ b/db/migrate/20190412063622_create_local_challenge_tags.rb @@ -0,0 +1,10 @@ +class CreateLocalChallengeTags < ActiveRecord::Migration + def change + create_table :local_challenge_tags do |t| + t.string :name + t.integer :local_challenge_id + + t.timestamps + end + end +end diff --git a/db/migrate/20190412073015_add_test_set_score_to_local_challenge.rb b/db/migrate/20190412073015_add_test_set_score_to_local_challenge.rb new file mode 100644 index 00000000..49661522 --- /dev/null +++ b/db/migrate/20190412073015_add_test_set_score_to_local_challenge.rb @@ -0,0 +1,5 @@ +class AddTestSetScoreToLocalChallenge < ActiveRecord::Migration + def change + add_column :local_challenges, :test_set_score, :integer + end +end diff --git a/db/migrate/20190412074140_add_shixun_id_to_local_shixun.rb b/db/migrate/20190412074140_add_shixun_id_to_local_shixun.rb new file mode 100644 index 00000000..15d9853c --- /dev/null +++ b/db/migrate/20190412074140_add_shixun_id_to_local_shixun.rb @@ -0,0 +1,5 @@ +class AddShixunIdToLocalShixun < ActiveRecord::Migration + def change + add_column :local_shixuns, :shixun_id, :integer + end +end diff --git a/db/migrate/20190412080258_add_score_to_local_test_sets.rb b/db/migrate/20190412080258_add_score_to_local_test_sets.rb new file mode 100644 index 00000000..8015badd --- /dev/null +++ b/db/migrate/20190412080258_add_score_to_local_test_sets.rb @@ -0,0 +1,5 @@ +class AddScoreToLocalTestSets < ActiveRecord::Migration + def change + add_column :local_test_sets, :score, :integer + end +end diff --git a/lib/tasks/shixun_local.rake b/lib/tasks/shixun_local.rake new file mode 100644 index 00000000..e69de29b diff --git a/spec/factories/local_challenge_tags.rb b/spec/factories/local_challenge_tags.rb new file mode 100644 index 00000000..033d487b --- /dev/null +++ b/spec/factories/local_challenge_tags.rb @@ -0,0 +1,6 @@ +FactoryGirl.define do + factory :local_challenge_tag do + name "MyString" + local_challenge_id 1 + end +end diff --git a/spec/factories/local_challenges.rb b/spec/factories/local_challenges.rb new file mode 100644 index 00000000..f8094a5c --- /dev/null +++ b/spec/factories/local_challenges.rb @@ -0,0 +1,25 @@ +FactoryGirl.define do + factory :local_challenge do + local_shixun_id 1 + subject "MyString" + status 1 + position 1 + task_pass "" + answer "" + score 1 + visits 1 + path "MyString" + evaluation_way 1 + difficulty 1 + exec_path "MyString" + code_line 1 + st 1 + web_route "MyText" + picture_path "MyText" + expect_picture_path "MyText" + challenge_tags_count 1 + modify_time "2019-04-12 14:27:18" + original_picture_path "MyString" + show_type 1 + end +end diff --git a/spec/factories/local_mirror_repositories.rb b/spec/factories/local_mirror_repositories.rb new file mode 100644 index 00000000..c56d4106 --- /dev/null +++ b/spec/factories/local_mirror_repositories.rb @@ -0,0 +1,6 @@ +FactoryGirl.define do + factory :local_mirror_repository do + local_shixun_id 1 + mirror_repository_id 1 + end +end diff --git a/spec/factories/local_shixun_tag_repertoires.rb b/spec/factories/local_shixun_tag_repertoires.rb new file mode 100644 index 00000000..c0368634 --- /dev/null +++ b/spec/factories/local_shixun_tag_repertoires.rb @@ -0,0 +1,6 @@ +FactoryGirl.define do + factory :local_shixun_tag_repertoire do + tag_repertoire_id 1 + local_shixun_id 1 + end +end diff --git a/spec/factories/local_shixuns.rb b/spec/factories/local_shixuns.rb new file mode 100644 index 00000000..c0e0b736 --- /dev/null +++ b/spec/factories/local_shixuns.rb @@ -0,0 +1,37 @@ +FactoryGirl.define do + factory :local_shixun do + name "MyString" + description "MyText" + user_id 1 + gpid 1 + visits 1 + status 1 + language "MyString" + authentication false + identifier "MyString" + propaedeutics "MyText" + trainee 1 + major_id 1 + webssh 1 + homepage_show false + hidden false + fork_from 1 + can_copy false + modifiy_tim "2019-04-12 09:21:34" + reset_time "" + closer_id 1 + end_time "2019-04-12 09:21:34" + git_url "MyString" + vnc false + myshixuns_count 1 + challenges_count 1 + use_scope 1 + evaluate_script "" + mirror_script_id 1 + image_text "MyString" + code_hidden false + task_pass false + exec_time 1 + test_set "MyString" + end +end diff --git a/spec/factories/local_test_sets.rb b/spec/factories/local_test_sets.rb new file mode 100644 index 00000000..792da326 --- /dev/null +++ b/spec/factories/local_test_sets.rb @@ -0,0 +1,10 @@ +FactoryGirl.define do + factory :local_test_set do + input "" + output "" + local_challenge_id 1 + is_public 1 + result 1 + position 1 + end +end diff --git a/spec/models/local_challenge_spec.rb b/spec/models/local_challenge_spec.rb new file mode 100644 index 00000000..b123e68c --- /dev/null +++ b/spec/models/local_challenge_spec.rb @@ -0,0 +1,5 @@ +require 'rails_helper' + +RSpec.describe LocalChallenge, :type => :model do + pending "add some examples to (or delete) #{__FILE__}" +end diff --git a/spec/models/local_challenge_tag_spec.rb b/spec/models/local_challenge_tag_spec.rb new file mode 100644 index 00000000..7aac14ed --- /dev/null +++ b/spec/models/local_challenge_tag_spec.rb @@ -0,0 +1,5 @@ +require 'rails_helper' + +RSpec.describe LocalChallengeTag, :type => :model do + pending "add some examples to (or delete) #{__FILE__}" +end diff --git a/spec/models/local_mirror_repository_spec.rb b/spec/models/local_mirror_repository_spec.rb new file mode 100644 index 00000000..d88aab72 --- /dev/null +++ b/spec/models/local_mirror_repository_spec.rb @@ -0,0 +1,5 @@ +require 'rails_helper' + +RSpec.describe LocalMirrorRepository, :type => :model do + pending "add some examples to (or delete) #{__FILE__}" +end diff --git a/spec/models/local_shixun_spec.rb b/spec/models/local_shixun_spec.rb new file mode 100644 index 00000000..deff5715 --- /dev/null +++ b/spec/models/local_shixun_spec.rb @@ -0,0 +1,5 @@ +require 'rails_helper' + +RSpec.describe LocalShixun, :type => :model do + pending "add some examples to (or delete) #{__FILE__}" +end diff --git a/spec/models/local_shixun_tag_repertoire_spec.rb b/spec/models/local_shixun_tag_repertoire_spec.rb new file mode 100644 index 00000000..f3d780b0 --- /dev/null +++ b/spec/models/local_shixun_tag_repertoire_spec.rb @@ -0,0 +1,5 @@ +require 'rails_helper' + +RSpec.describe LocalShixunTagRepertoire, :type => :model do + pending "add some examples to (or delete) #{__FILE__}" +end diff --git a/spec/models/local_test_set_spec.rb b/spec/models/local_test_set_spec.rb new file mode 100644 index 00000000..117ff963 --- /dev/null +++ b/spec/models/local_test_set_spec.rb @@ -0,0 +1,5 @@ +require 'rails_helper' + +RSpec.describe LocalTestSet, :type => :model do + pending "add some examples to (or delete) #{__FILE__}" +end From 49ef49a32530bebebf96e28deb5f6d1f8eef0bbe Mon Sep 17 00:00:00 2001 From: daiao <358551898@qq.com> Date: Sat, 13 Apr 2019 10:07:27 +0800 Subject: [PATCH 3/7] 1 --- app/controllers/myshixuns_controller.rb | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/app/controllers/myshixuns_controller.rb b/app/controllers/myshixuns_controller.rb index 030f3f10..e0157b67 100644 --- a/app/controllers/myshixuns_controller.rb +++ b/app/controllers/myshixuns_controller.rb @@ -451,15 +451,12 @@ class MyshixunsController < ApplicationController # 只有评测中的game才会创建和更新代码评测中的信息 logger.info("##################game: #{game.status}") logger.info("##################retry_status: #{game.retry_status}") - if game.status == 1 || game.status == 2 && game.retry_status == 1 + if game.status == 1 || game.status == 2 if msg.blank? RunCodeMessage.create!(:game_id => game_id, :status => 1, :message => message) else msg.update_attributes(:status => (msg.status + 1), :message => message) end - else - # 评测完成,初始化评测信息的状态 - msg.update_attributes(:status => 0, :message => nil) if msg.present? end render :json => {:data => "success"} end From 59ff646a4ff4f240835ff6beead4278fe0f8cc87 Mon Sep 17 00:00:00 2001 From: jingquan huang Date: Sat, 13 Apr 2019 11:25:28 +0800 Subject: [PATCH 4/7] =?UTF-8?q?=E6=9C=AC=E5=9C=B0=E6=95=B0=E6=8D=AE?= =?UTF-8?q?=E5=88=9D=E5=A7=8B=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/controllers/welcome_controller.rb | 11 +++++++++++ config/routes.rb | 1 + 2 files changed, 12 insertions(+) diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb index c6fa78d9..06602a5c 100644 --- a/app/controllers/welcome_controller.rb +++ b/app/controllers/welcome_controller.rb @@ -30,6 +30,17 @@ class WelcomeController < ApplicationController require 'simple_xlsx_reader' DCODES = %W(2 3 4 5 6 7 8 9 a b c f e f g h i j k l m n o p q r s t u v w x y z) + def local_init + LocalShixun.delete_all + LocalMirrorRepository.delete_all + LocalShixunTagRepertoire.delete_all + LocalChallenge.delete_all + LocalTestSet.delete_all + LocalChallengeTag.delete_all + render :json => {status: 0, message: "success"} + end + + def shixun_to_local identifiers = params[:identifiers].split(",") shixuns = Shixun.where(identifier: identifiers) diff --git a/config/routes.rb b/config/routes.rb index ea70b6a2..47a052db 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -283,6 +283,7 @@ RedmineApp::Application.routes.draw do ## oauth相关 get 'welcome/ccf' => 'welcome#ccf' get 'welcome/shixun_to_local' => 'welcome#shixun_to_local' get 'welcome/local_to_shixun' => 'welcome#local_to_shixun' + get 'welcome/local_init' => 'welcome#local_init' # get 'competitions/home' => 'competitions#home' # get 'competitions/hn' => 'competitions#index' From 98c5bcca6e3b200e7901faa9c8cfe30000492753 Mon Sep 17 00:00:00 2001 From: jingquan huang Date: Sat, 13 Apr 2019 18:26:07 +0800 Subject: [PATCH 5/7] local to shixun --- app/controllers/welcome_controller.rb | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb index 06602a5c..00bab5b6 100644 --- a/app/controllers/welcome_controller.rb +++ b/app/controllers/welcome_controller.rb @@ -73,7 +73,7 @@ class WelcomeController < ApplicationController if shixun.challenges.present? shixun.challenges.each do |challenge| new_challenge = LocalChallenge.new - new_challenge.attributes = challenge.attributes.dup.except("id","shixun_id","user_id") + new_challenge.attributes = challenge.attributes.dup.except("id","shixun_id","user_id", "test_set_score") new_challenge.local_shixun_id = local_shixun.id new_challenge.save! # 评测题,选择题暂时不考虑 @@ -109,6 +109,7 @@ class WelcomeController < ApplicationController def local_to_shixun ActiveRecord::Base.transaction do + shixun_list = [] LocalShixun.find_each do |local_shixun| identifier = generate_identifier shixun = Shixun.create!(name: local_shixun.name, description: local_shixun.description, user_id: User.current.id, @@ -177,8 +178,9 @@ class WelcomeController < ApplicationController end end end - render :json => {status: 0, message: "success", identifier: shixun.identifier} + shixun_list << shixun.identifier end + render :json => {status: 0, message: "success", identifier: shixun_list} end end From a3e3fa096566e648e729a68b21b94c61b9200d79 Mon Sep 17 00:00:00 2001 From: jingquan huang Date: Sat, 13 Apr 2019 18:30:00 +0800 Subject: [PATCH 6/7] .. --- app/controllers/welcome_controller.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb index 00bab5b6..c9d41c0a 100644 --- a/app/controllers/welcome_controller.rb +++ b/app/controllers/welcome_controller.rb @@ -153,7 +153,7 @@ class WelcomeController < ApplicationController if local_challenges.present? local_challenges.each do |local_challenge| new_challenge = Challenge.new - new_challenge.attributes = local_challenge.attributes.dup.except("id","local_shixun_id","user_id") + new_challenge.attributes = local_challenge.attributes.dup.except("id","local_shixun_id","user_id", "test_set_score") new_challenge.user_id = User.current.id new_challenge.shixun_id = shixun.id new_challenge.save! From 83f0ec016b4134c2ba60189b8f8168130963adf3 Mon Sep 17 00:00:00 2001 From: huang Date: Mon, 15 Apr 2019 10:01:27 +0800 Subject: [PATCH 7/7] =?UTF-8?q?=E6=B5=8B=E8=AF=95=E7=94=A8=E6=88=B7?= =?UTF-8?q?=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/tasks/users.rake | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/tasks/users.rake b/lib/tasks/users.rake index d8ae770e..bfa0678c 100644 --- a/lib/tasks/users.rake +++ b/lib/tasks/users.rake @@ -89,7 +89,7 @@ task :add_test_users => :environment do (1..1000).each do |i| no = sprintf("%04d", i) - phone = "1560731#{no}" + phone = "5160731#{no}" us = UsersService.new user = us.register phone: phone, password: 'edu12345678' @@ -109,7 +109,7 @@ task :add_test_users => :environment do lastname: lastname, nickname: '', sex: 0, - mail: "educoder#{no}@qq.com", + mail: "00educoder#{no}@qq.com", identity: 1, te_technical_title: 0, pro_technical_title: 0,