mirror of
https://github.com/moodle/moodle.git
synced 2025-08-06 01:16:44 +02:00
MDL-55739 course: Update get_course_module to return new data
This commit is contained in:
parent
5c6daf139d
commit
796876b0ab
5 changed files with 386 additions and 138 deletions
|
@ -1593,24 +1593,29 @@ class core_course_externallib_testcase extends externallib_advanced_testcase {
|
|||
$course = self::getDataGenerator()->create_course();
|
||||
$record = array(
|
||||
'course' => $course->id,
|
||||
'name' => 'First Chat'
|
||||
'name' => 'First Assignment'
|
||||
);
|
||||
$options = array(
|
||||
'idnumber' => 'ABC',
|
||||
'visible' => 0
|
||||
);
|
||||
// Hidden activity.
|
||||
$chat = self::getDataGenerator()->create_module('chat', $record, $options);
|
||||
$assign = self::getDataGenerator()->create_module('assign', $record, $options);
|
||||
|
||||
// Test admin user can see the complete hidden activity.
|
||||
$result = core_course_external::get_course_module($chat->cmid);
|
||||
$result = core_course_external::get_course_module($assign->cmid);
|
||||
$result = external_api::clean_returnvalue(core_course_external::get_course_module_returns(), $result);
|
||||
|
||||
$this->assertCount(0, $result['warnings']);
|
||||
// Test we retrieve all the fields.
|
||||
$this->assertCount(22, $result['cm']);
|
||||
$this->assertCount(26, $result['cm']);
|
||||
$this->assertEquals($record['name'], $result['cm']['name']);
|
||||
$this->assertEquals($options['idnumber'], $result['cm']['idnumber']);
|
||||
$this->assertEquals(100, $result['cm']['grade']);
|
||||
$this->assertEquals(0.0, $result['cm']['gradepass']);
|
||||
$this->assertEquals('submissions', $result['cm']['advancedgrading'][0]['area']);
|
||||
$this->assertEmpty($result['cm']['advancedgrading'][0]['method']);
|
||||
$this->assertArrayNotHasKey('outcomes', $result['cm']);
|
||||
|
||||
$student = $this->getDataGenerator()->create_user();
|
||||
$studentrole = $DB->get_record('role', array('shortname' => 'student'));
|
||||
|
@ -1620,26 +1625,26 @@ class core_course_externallib_testcase extends externallib_advanced_testcase {
|
|||
|
||||
// The user shouldn't be able to see the activity.
|
||||
try {
|
||||
core_course_external::get_course_module($chat->cmid);
|
||||
core_course_external::get_course_module($assign->cmid);
|
||||
$this->fail('Exception expected due to invalid permissions.');
|
||||
} catch (moodle_exception $e) {
|
||||
$this->assertEquals('requireloginerror', $e->errorcode);
|
||||
}
|
||||
|
||||
// Make module visible.
|
||||
set_coursemodule_visible($chat->cmid, 1);
|
||||
set_coursemodule_visible($assign->cmid, 1);
|
||||
|
||||
// Test student user.
|
||||
$result = core_course_external::get_course_module($chat->cmid);
|
||||
$result = core_course_external::get_course_module($assign->cmid);
|
||||
$result = external_api::clean_returnvalue(core_course_external::get_course_module_returns(), $result);
|
||||
|
||||
$this->assertCount(0, $result['warnings']);
|
||||
// Test we retrieve only the few files we can see.
|
||||
$this->assertCount(11, $result['cm']);
|
||||
$this->assertEquals($chat->cmid, $result['cm']['id']);
|
||||
$this->assertEquals($assign->cmid, $result['cm']['id']);
|
||||
$this->assertEquals($course->id, $result['cm']['course']);
|
||||
$this->assertEquals('chat', $result['cm']['modname']);
|
||||
$this->assertEquals($chat->id, $result['cm']['instance']);
|
||||
$this->assertEquals('assign', $result['cm']['modname']);
|
||||
$this->assertEquals($assign->id, $result['cm']['instance']);
|
||||
|
||||
}
|
||||
|
||||
|
|
153
course/tests/modlib_test.php
Normal file
153
course/tests/modlib_test.php
Normal file
|
@ -0,0 +1,153 @@
|
|||
<?php
|
||||
// This file is part of Moodle - http://moodle.org/
|
||||
//
|
||||
// Moodle is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// Moodle is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
/**
|
||||
* Module lib related unit tests
|
||||
*
|
||||
* @package core
|
||||
* @category phpunit
|
||||
* @copyright 2016 Juan Leyva
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
|
||||
defined('MOODLE_INTERNAL') || die();
|
||||
|
||||
global $CFG;
|
||||
require_once($CFG->dirroot . '/course/lib.php');
|
||||
require_once($CFG->dirroot . '/course/modlib.php');
|
||||
|
||||
class core_course_modlib_testcase extends advanced_testcase {
|
||||
|
||||
/**
|
||||
* Test prepare_new_moduleinfo_data
|
||||
*/
|
||||
public function test_prepare_new_moduleinfo_data() {
|
||||
global $DB;
|
||||
$this->resetAfterTest(true);
|
||||
|
||||
$this->setAdminUser();
|
||||
$course = self::getDataGenerator()->create_course();
|
||||
$coursecontext = context_course::instance($course->id);
|
||||
// Test with a complex module, like assign.
|
||||
$assignmodule = $DB->get_record('modules', array('name' => 'assign'), '*', MUST_EXIST);
|
||||
$sectionnumber = 1;
|
||||
|
||||
list($module, $context, $cw, $cm, $data) = prepare_new_moduleinfo_data($course, $assignmodule->name, $sectionnumber);
|
||||
$this->assertEquals($assignmodule, $module);
|
||||
$this->assertEquals($coursecontext, $context);
|
||||
$this->assertNull($cm); // Not cm yet.
|
||||
|
||||
$expecteddata = new stdClass();
|
||||
$expecteddata->section = $sectionnumber;
|
||||
$expecteddata->visible = 1;
|
||||
$expecteddata->course = $course->id;
|
||||
$expecteddata->module = $module->id;
|
||||
$expecteddata->modulename = $module->name;
|
||||
$expecteddata->groupmode = $course->groupmode;
|
||||
$expecteddata->groupingid = $course->defaultgroupingid;
|
||||
$expecteddata->id = '';
|
||||
$expecteddata->instance = '';
|
||||
$expecteddata->coursemodule = '';
|
||||
$expecteddata->advancedgradingmethod_submissions = ''; // Not grading methods enabled by default.
|
||||
// Unset untestable.
|
||||
unset($data->introeditor);
|
||||
unset($data->_advancedgradingdata);
|
||||
|
||||
$this->assertEquals($expecteddata, $data);
|
||||
|
||||
// Create a viewer user. Not able to edit.
|
||||
$viewer = self::getDataGenerator()->create_user();
|
||||
$this->getDataGenerator()->enrol_user($viewer->id, $course->id);
|
||||
$this->setUser($viewer);
|
||||
$this->expectException('required_capability_exception');
|
||||
prepare_new_moduleinfo_data($course, $assignmodule->name, $sectionnumber);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test get_moduleinfo_data
|
||||
*/
|
||||
public function test_get_moduleinfo_data() {
|
||||
global $DB;
|
||||
$this->resetAfterTest(true);
|
||||
$this->setAdminUser();
|
||||
$course = self::getDataGenerator()->create_course();
|
||||
$assignmodule = $DB->get_record('modules', array('name' => 'assign'), '*', MUST_EXIST);
|
||||
$assign = self::getDataGenerator()->create_module('assign', array('course' => $course->id));
|
||||
$assigncm = get_coursemodule_from_id('assign', $assign->cmid);
|
||||
$assigncontext = context_module::instance($assign->cmid);
|
||||
|
||||
list($cm, $context, $module, $data, $cw) = get_moduleinfo_data($assigncm, $course);
|
||||
$this->assertEquals($assigncm, $cm);
|
||||
$this->assertEquals($assigncontext, $context);
|
||||
$this->assertEquals($assignmodule, $module);
|
||||
|
||||
// Prepare expected data.
|
||||
$expecteddata = clone $assign;
|
||||
$expecteddata->coursemodule = $assigncm->id;
|
||||
$expecteddata->section = $cw->section;
|
||||
$expecteddata->visible = $assigncm->visible;
|
||||
$expecteddata->cmidnumber = $assigncm->idnumber;
|
||||
$expecteddata->groupmode = groups_get_activity_groupmode($cm);
|
||||
$expecteddata->groupingid = $assigncm->groupingid;
|
||||
$expecteddata->course = $course->id;
|
||||
$expecteddata->module = $module->id;
|
||||
$expecteddata->modulename = $module->name;
|
||||
$expecteddata->instance = $assigncm->instance;
|
||||
$expecteddata->completion = $assigncm->completion;
|
||||
$expecteddata->completionview = $assigncm->completionview;
|
||||
$expecteddata->completionexpected = $assigncm->completionexpected;
|
||||
$expecteddata->completionusegrade = is_null($assigncm->completiongradeitemnumber) ? 0 : 1;
|
||||
$expecteddata->showdescription = $assigncm->showdescription;
|
||||
$expecteddata->tags = core_tag_tag::get_item_tags_array('core', 'course_modules', $assigncm->id);
|
||||
$expecteddata->availabilityconditionsjson = null;
|
||||
$expecteddata->advancedgradingmethod_submissions = null;
|
||||
if ($items = grade_item::fetch_all(array('itemtype' => 'mod', 'itemmodule' => 'assign',
|
||||
'iteminstance' => $assign->id, 'courseid' => $course->id))) {
|
||||
// set category if present
|
||||
$gradecat = false;
|
||||
foreach ($items as $item) {
|
||||
if ($gradecat === false) {
|
||||
$gradecat = $item->categoryid;
|
||||
continue;
|
||||
}
|
||||
if ($gradecat != $item->categoryid) {
|
||||
//mixed categories
|
||||
$gradecat = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if ($gradecat !== false) {
|
||||
// do not set if mixed categories present
|
||||
$expecteddata->gradecat = $gradecat;
|
||||
}
|
||||
}
|
||||
$expecteddata->gradepass = '0.00';
|
||||
|
||||
// Unset untestable.
|
||||
unset($expecteddata->cmid);
|
||||
unset($data->introeditor);
|
||||
unset($data->_advancedgradingdata);
|
||||
|
||||
$this->assertEquals($expecteddata, $data);
|
||||
|
||||
// Create a viewer user. Not able to edit.
|
||||
$viewer = self::getDataGenerator()->create_user();
|
||||
$this->getDataGenerator()->enrol_user($viewer->id, $course->id);
|
||||
$this->setUser($viewer);
|
||||
$this->expectException('required_capability_exception');
|
||||
get_moduleinfo_data($assigncm, $course);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue