Skip to content

Commit

Permalink
MDL-57554 forum: Mark as read on view_forum_discussion calls
Browse files Browse the repository at this point in the history
  • Loading branch information
crazyserver committed Jan 13, 2017
1 parent d97582f commit db3c9ff
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 1 deletion.
7 changes: 6 additions & 1 deletion mod/forum/externallib.php
Original file line number Diff line number Diff line change
Expand Up @@ -678,7 +678,7 @@ public static function view_forum_discussion_parameters() {
* @throws moodle_exception
*/
public static function view_forum_discussion($discussionid) {
global $DB, $CFG;
global $DB, $CFG, $USER;
require_once($CFG->dirroot . "/mod/forum/lib.php");

$params = self::validate_parameters(self::view_forum_discussion_parameters(),
Expand All @@ -700,6 +700,11 @@ public static function view_forum_discussion($discussionid) {
// Call the forum/lib API.
forum_discussion_view($modcontext, $forum, $discussion);

// Mark as read if required.
if (!$CFG->forum_usermarksread && forum_tp_is_tracked($forum)) {
forum_tp_mark_discussion_read($USER, $discussion->id);
}

$result = array();
$result['status'] = true;
$result['warnings'] = $warnings;
Expand Down
37 changes: 37 additions & 0 deletions mod/forum/tests/externallib_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -206,6 +206,12 @@ public function test_mod_forum_get_forum_discussion_posts() {
$forum1 = self::getDataGenerator()->create_module('forum', $record);
$forum1context = context_module::instance($forum1->cmid);

// Forum with tracking enabled.
$record = new stdClass();
$record->course = $course1->id;
$forum2 = self::getDataGenerator()->create_module('forum', $record);
$forum2context = context_module::instance($forum2->cmid);

// Add discussions to the forums.
$record = new stdClass();
$record->course = $course1->id;
Expand All @@ -219,6 +225,12 @@ public function test_mod_forum_get_forum_discussion_posts() {
$record->forum = $forum1->id;
$discussion2 = self::getDataGenerator()->get_plugin_generator('mod_forum')->create_discussion($record);

$record = new stdClass();
$record->course = $course1->id;
$record->userid = $user2->id;
$record->forum = $forum2->id;
$discussion3 = self::getDataGenerator()->get_plugin_generator('mod_forum')->create_discussion($record);

// Add 2 replies to the discussion 1 from different users.
$record = new stdClass();
$record->discussion = $discussion1->id;
Expand Down Expand Up @@ -340,6 +352,31 @@ public function test_mod_forum_get_forum_discussion_posts() {
$posts = external_api::clean_returnvalue(mod_forum_external::get_forum_discussion_posts_returns(), $posts);
$this->assertEquals(1, count($posts['posts']));

// Test discussion tracking on not tracked forum.
$result = mod_forum_external::view_forum_discussion($discussion1->id);
$result = external_api::clean_returnvalue(mod_forum_external::view_forum_discussion_returns(), $result);
$this->assertTrue($result['status']);
$this->assertEmpty($result['warnings']);

// Test posts have not been marked as read.
$posts = mod_forum_external::get_forum_discussion_posts($discussion1->id, 'modified', 'DESC');
$posts = external_api::clean_returnvalue(mod_forum_external::get_forum_discussion_posts_returns(), $posts);
foreach ($posts['posts'] as $post) {
$this->assertFalse($post['postread']);
}

// Test discussion tracking on tracked forum.
$result = mod_forum_external::view_forum_discussion($discussion3->id);
$result = external_api::clean_returnvalue(mod_forum_external::view_forum_discussion_returns(), $result);
$this->assertTrue($result['status']);
$this->assertEmpty($result['warnings']);

// Test posts have been marked as read.
$posts = mod_forum_external::get_forum_discussion_posts($discussion3->id, 'modified', 'DESC');
$posts = external_api::clean_returnvalue(mod_forum_external::get_forum_discussion_posts_returns(), $posts);
foreach ($posts['posts'] as $post) {
$this->assertTrue($post['postread']);
}
}

/**
Expand Down

0 comments on commit db3c9ff

Please sign in to comment.