Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.10.x will end 8 November 2021 (12 months).
  • Bug fixes for security issues in 3.10.x will end 9 May 2022 (18 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/>.

< /** < * Tests for myprofilelib apis. < * < * @package core < * @copyright 2015 onwards Ankit agarwal <ankit.agrr@gmail.com> < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later. < */
> namespace core;
defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->dirroot . '/lib/myprofilelib.php'); /** * Tests for myprofilelib apis. * * @package core * @copyright 2015 onwards Ankit agarwal <ankit.agrr@gmail.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later. */
< class core_myprofilelib_testcase extends advanced_testcase {
> class myprofilelib_test extends \advanced_testcase {
/** * @var stdClass The user. */ private $user; /** * @var stdClass The course. */ private $course; /** * @var \core_user\output\myprofile\tree The navigation tree. */ private $tree; public function setUp(): void { // Set the $PAGE->url value so core_myprofile_navigation() doesn't complain. global $PAGE; $PAGE->set_url('/test'); $this->user = $this->getDataGenerator()->create_user(); $this->user2 = $this->getDataGenerator()->create_user(); $this->course = $this->getDataGenerator()->create_course(); $this->tree = new \core_user\output\myprofile\tree(); $this->resetAfterTest(); } /** * Tests the core_myprofile_navigation() function as an admin viewing a user's course profile. */ public function test_core_myprofile_navigation_as_admin() { $this->setAdminUser(); $iscurrentuser = false; // Test tree as admin user. core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, $this->course);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$categories = $reflector->getProperty('categories'); $categories->setAccessible(true); $cats = $categories->getValue($this->tree); $this->assertArrayHasKey('contact', $cats); $this->assertArrayHasKey('coursedetails', $cats); $this->assertArrayHasKey('miscellaneous', $cats); $this->assertArrayHasKey('reports', $cats); $this->assertArrayHasKey('administration', $cats); $this->assertArrayHasKey('loginactivity', $cats); $nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayHasKey('fullprofile', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function as a user without permission to view the full * profile of another another user. */ public function test_core_myprofile_navigation_course_without_permission() { $this->setUser($this->user2); $iscurrentuser = false; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, $this->course);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayNotHasKey('fullprofile', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function as the currently logged in user. */ public function test_core_myprofile_navigation_profile_link_as_current_user() { $this->setUser($this->user); $iscurrentuser = true; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, $this->course);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayHasKey('editprofile', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function as the admin viewing another user. */ public function test_core_myprofile_navigation_profile_link_as_admin() { $this->setAdminUser(); $iscurrentuser = false; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, $this->course);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayHasKey('editprofile', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function when viewing the preference page as an admin. */ public function test_core_myprofile_navigation_preference_as_admin() { $this->setAdminUser(); $iscurrentuser = false; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, $this->course);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayHasKey('preferences', $nodes->getValue($this->tree)); $this->assertArrayHasKey('loginas', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function when viewing the preference * page as another user without the ability to use the 'loginas' functionality. */ public function test_core_myprofile_navigation_preference_without_permission() { // Login as link for a user who doesn't have the capability to login as. $this->setUser($this->user2); $iscurrentuser = false; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, $this->course);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayNotHasKey('loginas', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function as an admin viewing another user's contact details. */ public function test_core_myprofile_navigation_contact_fields_as_admin() { global $CFG; // User contact fields.
< set_config("hiddenuserfields", "country,city,webpage,icqnumber,skypeid,yahooid,aimid,msnid");
> set_config("hiddenuserfields", "country,city");
set_config("showuseridentity", "email,address,phone1,phone2,institution,department,idnumber"); $hiddenfields = explode(',', $CFG->hiddenuserfields); $identityfields = explode(',', $CFG->showuseridentity); $this->setAdminUser(); $iscurrentuser = false; // Make sure fields are not empty. $fields = array( 'country' => 'AU', 'city' => 'Silent hill',
< 'url' => 'Ghosts', < 'icq' => 'Wth is ICQ?', < 'skype' => 'derp', < 'yahoo' => 'are you living in the 90\'s?', < 'aim' => 'are you for real?', < 'msn' => '...',
'email' => 'Rulelikeaboss@example.com', 'address' => 'Didn\'t I mention silent hill already ?', 'phone1' => '123', 'phone2' => '234', 'institution' => 'strange land', 'department' => 'video game/movie', 'idnumber' => 'SLHL' ); foreach ($fields as $field => $value) { $this->user->$field = $value; } // User with proper permissions. core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, null);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); foreach ($hiddenfields as $field) { $this->assertArrayHasKey($field, $nodes->getValue($this->tree)); } foreach ($identityfields as $field) { $this->assertArrayHasKey($field, $nodes->getValue($this->tree)); } } /** * Tests the core_myprofile_navigation() function as a user viewing another user's profile * ensuring that the contact details are not shown. */ public function test_core_myprofile_navigation_contact_field_without_permission() { global $CFG; $iscurrentuser = false; $hiddenfields = explode(',', $CFG->hiddenuserfields); $identityfields = explode(',', $CFG->showuseridentity); // User without permission. $this->setUser($this->user2); core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, null);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); foreach ($hiddenfields as $field) { $this->assertArrayNotHasKey($field, $nodes->getValue($this->tree)); } foreach ($identityfields as $field) { $this->assertArrayNotHasKey($field, $nodes->getValue($this->tree)); } } /** * Tests the core_myprofile_navigation() function as an admin viewing another user's * profile ensuring the login activity links are shown. */ public function test_core_myprofile_navigation_login_activity() { // First access, last access, last ip. $this->setAdminUser(); $iscurrentuser = false; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, null);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayHasKey('firstaccess', $nodes->getValue($this->tree)); $this->assertArrayHasKey('lastaccess', $nodes->getValue($this->tree)); $this->assertArrayHasKey('lastip', $nodes->getValue($this->tree)); } /** * Tests the core_myprofile_navigation() function as a user viewing another user's profile * ensuring the login activity links are not shown. */ public function test_core_myprofile_navigationn_login_activity_without_permission() { // User without permission. set_config("hiddenuserfields", "firstaccess,lastaccess,lastip"); $this->setUser($this->user2); $iscurrentuser = false; core_myprofile_navigation($this->tree, $this->user, $iscurrentuser, null);
< $reflector = new ReflectionObject($this->tree);
> $reflector = new \ReflectionObject($this->tree);
$nodes = $reflector->getProperty('nodes'); $nodes->setAccessible(true); $this->assertArrayNotHasKey('firstaccess', $nodes->getValue($this->tree)); $this->assertArrayNotHasKey('lastaccess', $nodes->getValue($this->tree)); $this->assertArrayNotHasKey('lastip', $nodes->getValue($this->tree)); } }