Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.
<?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/>.

< /** < * Unit tests for (some of) mod/assign/markerallocaion_test.php. < * < * @package mod_assign < * @category test < * @copyright 2017 Andrés Melo <andres.torres@blackboard.com> < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */
> namespace mod_assign;
defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->dirroot . '/lib/accesslib.php'); require_once($CFG->dirroot . '/course/lib.php'); /**
< * This class tests some of marker allocation functionality.
> * Unit tests for (some of) mod/assign/markerallocaion_test.php.
* * @package mod_assign
> * @category test
* @copyright 2017 Andrés Melo <andres.torres@blackboard.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class mod_assign_markerallocation_testcase extends advanced_testcase {
> class markerallocation_test extends \advanced_testcase {
/** * Create all the needed elements to test the difference between both functions. */ public function test_markerusers() { $this->resetAfterTest(); global $DB; // Create a course, by default it is created with 5 sections. $this->course = $this->getDataGenerator()->create_course(); // Setting assing module, markingworkflow and markingallocation set to 1 to enable marker allocation.
< $record = new stdClass();
> $record = new \stdClass();
$record->course = $this->course; $modulesettings = array( 'alwaysshowdescription' => 1, 'submissiondrafts' => 1, 'requiresubmissionstatement' => 0, 'sendnotifications' => 0, 'sendstudentnotifications' => 1, 'sendlatenotifications' => 0, 'duedate' => 0, 'allowsubmissionsfromdate' => 0, 'grade' => 100, 'cutoffdate' => 0, 'teamsubmission' => 0, 'requireallteammemberssubmit' => 0, 'teamsubmissiongroupingid' => 0, 'blindmarking' => 0, 'attemptreopenmethod' => 'none', 'maxattempts' => -1, 'markingworkflow' => 1, 'markingallocation' => 1, ); $assignelement = $this->getDataGenerator()->create_module('assign', $record, $modulesettings); $coursesectionid = course_add_cm_to_section($this->course->id, $assignelement->id, 1); // Adding users to the course. $userdata = array(); $userdata['firstname'] = 'teacher1'; $userdata['lasttname'] = 'lastname_teacher1'; $user1 = $this->getDataGenerator()->create_user($userdata); $this->getDataGenerator()->enrol_user($user1->id, $this->course->id, 'teacher'); $userdata = array(); $userdata['firstname'] = 'teacher2'; $userdata['lasttname'] = 'lastname_teacher2'; $user2 = $this->getDataGenerator()->create_user($userdata); $this->getDataGenerator()->enrol_user($user2->id, $this->course->id, 'teacher'); $userdata = array(); $userdata['firstname'] = 'student'; $userdata['lasttname'] = 'lastname_student'; $user3 = $this->getDataGenerator()->create_user($userdata); $this->getDataGenerator()->enrol_user($user3->id, $this->course->id, 'student'); // Adding manager to the system. $userdata = array(); $userdata['firstname'] = 'Manager'; $userdata['lasttname'] = 'lastname_Manager'; $user4 = $this->getDataGenerator()->create_user($userdata); // Getting id of manager role. $managerrole = $DB->get_record('role', array('shortname' => 'manager')); if (!empty($managerrole)) { // By default the context of the system is assigned. $idassignment = $this->getDataGenerator()->role_assign($managerrole->id, $user4->id); } $oldusers = array($user1, $user2, $user4); $newusers = array($user1, $user2); list($sort, $params) = users_order_by_sql('u'); // Old code, it must return 3 users: teacher1, teacher2 and Manger.
< $oldmarkers = get_users_by_capability(context_course::instance($this->course->id), 'mod/assign:grade', '', $sort);
> $oldmarkers = get_users_by_capability(\context_course::instance($this->course->id), 'mod/assign:grade', '', $sort);
// New code, it must return 2 users: teacher1 and teacher2.
< $newmarkers = get_enrolled_users(context_course::instance($this->course->id), 'mod/assign:grade', 0, 'u.*', $sort);
> $newmarkers = get_enrolled_users(\context_course::instance($this->course->id), 'mod/assign:grade', 0, 'u.*', $sort);
// Test result quantity. $this->assertEquals(count($oldusers), count($oldmarkers)); $this->assertEquals(count($newusers), count($newmarkers)); $this->assertEquals(count($oldmarkers) > count($newmarkers), true); // Elements expected with new code. foreach ($newmarkers as $key => $nm) { $this->assertEquals($nm, $newusers[array_search($nm, $newusers)]); } // Elements expected with old code. foreach ($oldusers as $key => $os) { $this->assertEquals($os->id, $oldmarkers[$os->id]->id); unset($oldmarkers[$os->id]); } $this->assertEquals(count($oldmarkers), 0); } }