Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is 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/>.

namespace mod_assign;

defined('MOODLE_INTERNAL') || die();

global $CFG;
require_once($CFG->dirroot . '/lib/accesslib.php');
require_once($CFG->dirroot . '/course/lib.php');

/**
 * 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 markerallocation_test extends \advanced_testcase {

> /** @var \stdClass course record. */ /** > private $course; * 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->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); // 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); // 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); } }