Esempio n. 1
0
 /**
  * Sets the statuses for the Course
  *
  * @access public
  * @since  1.7.0
  * @param int $user_id
  * @param int $course_id
  * @param string $status
  * @param array $metadata
  * @return mixed false or comment_ID
  */
 public static function update_course_status($user_id, $course_id, $status = 'in-progress', $metadata = array())
 {
     $comment_id = false;
     if (!empty($status)) {
         $args = array('user_id' => $user_id, 'post_id' => $course_id, 'status' => $status, 'type' => 'sensei_course_status', 'action' => 'update', 'keep_time' => true);
         if ('in-progress' == $status) {
             unset($args['keep_time']);
             // Keep updating what's happened
         }
         $comment_id = Sensei_Utils::sensei_log_activity($args);
         if ($comment_id && !empty($metadata)) {
             foreach ($metadata as $key => $value) {
                 update_comment_meta($comment_id, $key, $value);
             }
         }
         do_action('sensei_course_status_updated', $status, $user_id, $course_id, $comment_id);
     }
     return $comment_id;
 }
Esempio n. 2
0
 /**
  * This test Sensei()->quiz->get_user_question_feedback
  */
 public function testGetUserQuestionFeedback()
 {
     // does this function add_user_data exist?
     $this->assertTrue(method_exists(Sensei()->quiz, 'get_user_question_feedback'), 'The utils class function `get_user_question_feedback` does not exist ');
     // does it return false for invalid data
     $invalid_data_message = 'This get_user_question_feedback function does not check false data correctly';
     $this->assertFalse(Sensei()->quiz->get_user_question_feedback('', '', ''), $invalid_data_message);
     $this->assertFalse(Sensei()->quiz->get_user_question_feedback(' ', ' ', ' '), $invalid_data_message);
     $this->assertFalse(Sensei()->quiz->get_user_question_feedback(-2, -3, -1), $invalid_data_message);
     $this->assertFalse(Sensei()->quiz->get_user_question_feedback(3000, 5000, 5000), $invalid_data_message);
     // setup the next assertion
     $test_user_id = wp_create_user('studentQuestionFeedback', 'studentQuestionFeedback', '*****@*****.**');
     $test_lesson_id = $this->factory->get_random_lesson_id();
     $test_quiz_id = Sensei()->lesson->lesson_quizzes($test_lesson_id);
     $test_user_answers_feedback = $this->factory->generate_user_answers_feedback($test_quiz_id);
     Sensei_Utils::sensei_start_lesson($test_lesson_id, $test_user_id);
     Sensei()->quiz->save_user_answers_feedback($test_user_answers_feedback, $test_lesson_id, $test_user_id);
     $test_question_id = array_rand($test_user_answers_feedback);
     $retrieved_grade = Sensei()->quiz->get_user_question_feedback($test_lesson_id, $test_question_id, $test_user_id);
     //test if the the question grade can be retrieved
     $this->assertEquals($test_user_answers_feedback[$test_question_id], $retrieved_grade, 'The feedback retrieved is not equal to the one that was set for this question ID');
     //setup the next assertion for backwards compatibility.
     $transient_key = 'sensei_answers_feedback_' . $test_user_id . '_' . $test_lesson_id;
     delete_transient($transient_key);
     Sensei_Utils::delete_user_data('quiz_answers_feedback', $test_lesson_id, $test_user_id);
     $random_question_id = array_rand($test_user_answers_feedback);
     $old_data_args = array('post_id' => $random_question_id, 'user_id' => $test_user_id, 'type' => 'sensei_user_answer', 'data' => 'test answer feedback');
     $old_data_activity_id = Sensei_Utils::sensei_log_activity($old_data_args);
     update_comment_meta($old_data_activity_id, 'answer_note', base64_encode('Sensei sample feedback'));
     $retrieved_feedback = Sensei()->quiz->get_user_question_feedback($test_lesson_id, $random_question_id, $test_user_id);
     // Does the fall back to 1.7.3 data work?
     $this->assertEquals('Sensei sample feedback', $retrieved_feedback, 'The get user feedback does not fall back the old data');
 }