class Exercise < ActiveRecord::Base #exercise_status: 1,新建;2,发布;3,关闭 include Redmine::SafeAttributes belongs_to :user belongs_to :course ,:touch => true belongs_to :exercise_bank has_many :exercise_group_settings, :dependent => :destroy has_many :exercise_questions, :dependent => :destroy has_many :exercise_users, :dependent => :destroy, :conditions => "exercise_users.is_delete = 0" has_many :users, :through => :exercise_users #该测试被哪些用户提交答案过 has_many :course_acts, :class_name => 'CourseActivity',:as =>:course_act ,:dependent => :destroy # 课程消息 has_many :tidings, as: :container, dependent: :destroy has_many :course_messages, :class_name =>'CourseMessage', :as => :course_message, :dependent => :destroy has_many :exercise_level_settings, :dependent => :destroy has_many :exercise_user_questions after_create :acts_as_course_message def acts_as_course_message if self.course if self.exercise_status == 2 #未发布 #self.course.members.each do |m| self.course_messages << CourseMessage.create(:user_id => User.current.id, :course_id => self.course_id, :viewed => false,:status=>2) #end # else # self.course_messages.destroy_all 这里的destory_all值得商榷。因为我这里是通过status来控制不同的status的 end end end def create_user_question_list exercise_user_id self.exercise_user_questions.where(exercise_user_id: exercise_user_id).destroy_all self.exercise_questions.where("question_type != 5").each do |question| ExerciseUserQuestion.create(exercise_id: self.id, exercise_user_id: exercise_user_id, exercise_question_id: question.id) end self.exercise_level_settings.each do |setting| # 每个级别中随机挑选num个实训题 setting.exercise_questions.pluck(:id).sample(setting.num).each do |question_id| ExerciseUserQuestion.create(exercise_id: self.id, exercise_user_id: exercise_user_id, exercise_question_id: question_id) end end end def user_question_list exercise_user_id if self.exercise_user_questions.where(exercise_user_id: exercise_user_id).size == 0 self.exercise_questions else self.exercise_questions.where(id: self.exercise_user_questions.where(exercise_user_id: exercise_user_id). limit(self.questions_count).pluck(:exercise_question_id)) end end def level_setting level self.exercise_level_settings.where(level: level).first end def questions_count self.exercise_questions.where("question_type != 5").size + self.shixun_question_count end def shixun_question_count self.exercise_level_settings.sum(:num) end def shixun_question_score score = 0 self.exercise_level_settings.each do |setting| score += setting.num * setting.score.to_i end score end def has_shixun_questions? self.exercise_questions.where("question_type = 5 and exercise_level_setting_id != 0").count > 0 end def exercise_question_size self.exercise_questions.where("question_type != 5").count + self.shixun_question_count end end