/** * 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; }
/** * 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'); }