mirror of
https://github.com/moodle/moodle.git
synced 2025-04-25 02:16:06 +02:00
MDL-59019 course: Fix grade field type in WS get_course_module
This commit is contained in:
parent
78ab4f741b
commit
7ddb5f25b3
course
@ -2606,7 +2606,7 @@ class core_course_external extends external_api {
|
||||
'completionexpected' => new external_value(PARAM_INT, 'Completion time expected', VALUE_OPTIONAL),
|
||||
'showdescription' => new external_value(PARAM_INT, 'If the description is showed', VALUE_OPTIONAL),
|
||||
'availability' => new external_value(PARAM_RAW, 'Availability settings', VALUE_OPTIONAL),
|
||||
'grade' => new external_value(PARAM_INT, 'Grade (max value or scale id)', VALUE_OPTIONAL),
|
||||
'grade' => new external_value(PARAM_FLOAT, 'Grade (max value or scale id)', VALUE_OPTIONAL),
|
||||
'scale' => new external_value(PARAM_TEXT, 'Scale items (if used)', VALUE_OPTIONAL),
|
||||
'gradepass' => new external_value(PARAM_RAW, 'Grade to pass (float)', VALUE_OPTIONAL),
|
||||
'gradecat' => new external_value(PARAM_INT, 'Grade category', VALUE_OPTIONAL),
|
||||
|
@ -1775,23 +1775,25 @@ class core_course_externallib_testcase extends externallib_advanced_testcase {
|
||||
$course = self::getDataGenerator()->create_course();
|
||||
$record = array(
|
||||
'course' => $course->id,
|
||||
'name' => 'First Chat'
|
||||
'name' => 'First quiz',
|
||||
'grade' => 90.00
|
||||
);
|
||||
$options = array(
|
||||
'idnumber' => 'ABC',
|
||||
'visible' => 0
|
||||
);
|
||||
// Hidden activity.
|
||||
$chat = self::getDataGenerator()->create_module('chat', $record, $options);
|
||||
$quiz = self::getDataGenerator()->create_module('quiz', $record, $options);
|
||||
|
||||
// Test admin user can see the complete hidden activity.
|
||||
$result = core_course_external::get_course_module_by_instance('chat', $chat->id);
|
||||
$result = core_course_external::get_course_module_by_instance('quiz', $quiz->id);
|
||||
$result = external_api::clean_returnvalue(core_course_external::get_course_module_by_instance_returns(), $result);
|
||||
|
||||
$this->assertCount(0, $result['warnings']);
|
||||
// Test we retrieve all the fields.
|
||||
$this->assertCount(23, $result['cm']);
|
||||
$this->assertCount(26, $result['cm']);
|
||||
$this->assertEquals($record['name'], $result['cm']['name']);
|
||||
$this->assertEquals($record['grade'], $result['cm']['grade']);
|
||||
$this->assertEquals($options['idnumber'], $result['cm']['idnumber']);
|
||||
|
||||
$student = $this->getDataGenerator()->create_user();
|
||||
@ -1802,30 +1804,30 @@ 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_by_instance('chat', $chat->id);
|
||||
core_course_external::get_course_module_by_instance('quiz', $quiz->id);
|
||||
$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($quiz->cmid, 1);
|
||||
|
||||
// Test student user.
|
||||
$result = core_course_external::get_course_module_by_instance('chat', $chat->id);
|
||||
$result = core_course_external::get_course_module_by_instance('quiz', $quiz->id);
|
||||
$result = external_api::clean_returnvalue(core_course_external::get_course_module_by_instance_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($quiz->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('quiz', $result['cm']['modname']);
|
||||
$this->assertEquals($quiz->id, $result['cm']['instance']);
|
||||
|
||||
// Try with an invalid module name.
|
||||
try {
|
||||
core_course_external::get_course_module_by_instance('abc', $chat->id);
|
||||
core_course_external::get_course_module_by_instance('abc', $quiz->id);
|
||||
$this->fail('Exception expected due to invalid module name.');
|
||||
} catch (dml_read_exception $e) {
|
||||
$this->assertEquals('dmlreadexception', $e->errorcode);
|
||||
|
Loading…
x
Reference in New Issue
Block a user