Skip to content

Commit

Permalink
Merge branch 'MDL-49216-master' of git://github.com/andrewnicols/moodle
Browse files Browse the repository at this point in the history
  • Loading branch information
danpoltawski committed Feb 24, 2015
2 parents 5a3fe24 + 38ec3fb commit e09bd10
Show file tree
Hide file tree
Showing 2 changed files with 146 additions and 3 deletions.
5 changes: 2 additions & 3 deletions mod/forum/lib.php
Expand Up @@ -2486,9 +2486,8 @@ function forum_count_discussion_replies($forumid, $forumsort="", $limit=-1, $pag
FROM {forum_posts} p
JOIN {forum_discussions} d ON p.discussion = d.id
WHERE d.forum = ?
GROUP BY p.discussion $groupby
$orderby";
return $DB->get_records_sql("SELECT * FROM ($sql) sq", array($forumid), $limitfrom, $limitnum);
GROUP BY p.discussion $groupby $orderby";
return $DB->get_records_sql($sql, array($forumid), $limitfrom, $limitnum);
}
}

Expand Down
144 changes: 144 additions & 0 deletions mod/forum/tests/lib_test.php
Expand Up @@ -1173,4 +1173,148 @@ public function test_forum_get_neighbours_with_groups() {
$this->setExpectedException('coding_exception');
forum_get_discussion_neighbours($cm2, $disc11);
}

public function test_count_discussion_replies_basic() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);

// Count the discussion replies in the forum.
$result = forum_count_discussion_replies($forum->id);
$this->assertCount(10, $result);
}

public function test_count_discussion_replies_limited() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Adding limits shouldn't make a difference.
$result = forum_count_discussion_replies($forum->id, "", 20);
$this->assertCount(10, $result);
}

public function test_count_discussion_replies_paginated() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Adding paging shouldn't make any difference.
$result = forum_count_discussion_replies($forum->id, "", -1, 0, 100);
$this->assertCount(10, $result);
}

public function test_count_discussion_replies_paginated_sorted() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Specifying the forumsort should also give a good result. This follows a different path.
$result = forum_count_discussion_replies($forum->id, "d.id asc", -1, 0, 100);
$this->assertCount(10, $result);
foreach ($result as $row) {
// Grab the first discussionid.
$discussionid = array_shift($discussionids);
$this->assertEquals($discussionid, $row->discussion);
}
}

public function test_count_discussion_replies_limited_sorted() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Adding limits, and a forumsort shouldn't make a difference.
$result = forum_count_discussion_replies($forum->id, "d.id asc", 20);
$this->assertCount(10, $result);
foreach ($result as $row) {
// Grab the first discussionid.
$discussionid = array_shift($discussionids);
$this->assertEquals($discussionid, $row->discussion);
}
}

public function test_count_discussion_replies_paginated_sorted_small() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Grabbing a smaller subset and they should be ordered as expected.
$result = forum_count_discussion_replies($forum->id, "d.id asc", -1, 0, 5);
$this->assertCount(5, $result);
foreach ($result as $row) {
// Grab the first discussionid.
$discussionid = array_shift($discussionids);
$this->assertEquals($discussionid, $row->discussion);
}
}

public function test_count_discussion_replies_paginated_sorted_small_reverse() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Grabbing a smaller subset and they should be ordered as expected.
$result = forum_count_discussion_replies($forum->id, "d.id desc", -1, 0, 5);
$this->assertCount(5, $result);
foreach ($result as $row) {
// Grab the last discussionid.
$discussionid = array_pop($discussionids);
$this->assertEquals($discussionid, $row->discussion);
}
}

public function test_count_discussion_replies_limited_sorted_small_reverse() {
list($forum, $discussionids) = $this->create_multiple_discussions_with_replies(10, 5);
// Adding limits, and a forumsort shouldn't make a difference.
$result = forum_count_discussion_replies($forum->id, "d.id desc", 5);
$this->assertCount(5, $result);
foreach ($result as $row) {
// Grab the last discussionid.
$discussionid = array_pop($discussionids);
$this->assertEquals($discussionid, $row->discussion);
}
}

/**
* Create a new course, forum, and user with a number of discussions and replies.
*
* @param int $discussioncount The number of discussions to create
* @param int $replycount The number of replies to create in each discussion
* @return array Containing the created forum object, and the ids of the created discussions.
*/
protected function create_multiple_discussions_with_replies($discussioncount, $replycount) {
$this->resetAfterTest();

// Setup the content.
$user = $this->getDataGenerator()->create_user();
$course = $this->getDataGenerator()->create_course();
$record = new stdClass();
$record->course = $course->id;
$forum = $this->getDataGenerator()->create_module('forum', $record);

// Create 10 discussions with replies.
$discussionids = array();
for ($i = 0; $i < $discussioncount; $i++) {
$discussion = $this->create_single_discussion_with_replies($forum, $user, $replycount);
$discussionids[] = $discussion->id;
}
return array($forum, $discussionids);
}

/**
* Create a discussion with a number of replies.
*
* @param object $forum The forum which has been created
* @param object $user The user making the discussion and replies
* @param int $replycount The number of replies
* @return object $discussion
*/
protected function create_single_discussion_with_replies($forum, $user, $replycount) {
global $DB;

$generator = self::getDataGenerator()->get_plugin_generator('mod_forum');

$record = new stdClass();
$record->course = $forum->course;
$record->forum = $forum->id;
$record->userid = $user->id;
$discussion = $generator->create_discussion($record);

// Retrieve the first post.
$replyto = $DB->get_record('forum_posts', array('discussion' => $discussion->id));

// Create the replies.
$post = new stdClass();
$post->userid = $user->id;
$post->discussion = $discussion->id;
$post->parent = $replyto->id;

for ($i = 0; $i < $replycount; $i++) {
$generator->create_post($post);
}

return $discussion;
}

}

0 comments on commit e09bd10

Please sign in to comment.