mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 06:18:28 +01:00
438 lines
19 KiB
PHP
438 lines
19 KiB
PHP
<?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 lib/outputcomponents.php.
|
|
*
|
|
* @package core
|
|
* @category phpunit
|
|
* @copyright 2011 David Mudrak <david@moodle.com>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
global $CFG;
|
|
require_once($CFG->libdir . '/outputcomponents.php');
|
|
|
|
/**
|
|
* Unit tests for the user_picture class.
|
|
*/
|
|
class core_outputcomponents_testcase extends advanced_testcase {
|
|
|
|
public function test_fields_aliasing() {
|
|
$fields = user_picture::fields();
|
|
$fields = array_map('trim', explode(',', $fields));
|
|
$this->assertTrue(in_array('id', $fields));
|
|
|
|
$aliased = array();
|
|
foreach ($fields as $field) {
|
|
if ($field === 'id') {
|
|
$aliased['id'] = 'aliasedid';
|
|
} else {
|
|
$aliased[$field] = 'prefix'.$field;
|
|
}
|
|
}
|
|
|
|
$returned = user_picture::fields('', array('custom1', 'id'), 'aliasedid', 'prefix');
|
|
$returned = array_map('trim', explode(',', $returned));
|
|
$this->assertEquals(count($returned), count($fields) + 1); // Only one extra field added.
|
|
|
|
foreach ($fields as $field) {
|
|
if ($field === 'id') {
|
|
$expected = "id AS aliasedid";
|
|
} else {
|
|
$expected = "$field AS prefix$field";
|
|
}
|
|
$this->assertContains($expected, $returned, "Expected pattern '$expected' not returned");
|
|
}
|
|
$this->assertContains("custom1 AS prefixcustom1", $returned, "Expected pattern 'custom1 AS prefixcustom1' not returned");
|
|
}
|
|
|
|
public function test_fields_unaliasing() {
|
|
$fields = user_picture::fields();
|
|
$fields = array_map('trim', explode(',', $fields));
|
|
|
|
$fakerecord = new stdClass();
|
|
$fakerecord->aliasedid = 42;
|
|
foreach ($fields as $field) {
|
|
if ($field !== 'id') {
|
|
$fakerecord->{'prefix'.$field} = "Value of $field";
|
|
}
|
|
}
|
|
$fakerecord->prefixcustom1 = 'Value of custom1';
|
|
|
|
$returned = user_picture::unalias($fakerecord, array('custom1'), 'aliasedid', 'prefix');
|
|
|
|
$this->assertEquals(42, $returned->id);
|
|
foreach ($fields as $field) {
|
|
if ($field !== 'id') {
|
|
$this->assertSame("Value of $field", $returned->{$field});
|
|
}
|
|
}
|
|
$this->assertSame('Value of custom1', $returned->custom1);
|
|
}
|
|
|
|
public function test_fields_unaliasing_null() {
|
|
$fields = user_picture::fields();
|
|
$fields = array_map('trim', explode(',', $fields));
|
|
|
|
$fakerecord = new stdClass();
|
|
$fakerecord->aliasedid = 42;
|
|
foreach ($fields as $field) {
|
|
if ($field !== 'id') {
|
|
$fakerecord->{'prefix'.$field} = "Value of $field";
|
|
}
|
|
}
|
|
$fakerecord->prefixcustom1 = 'Value of custom1';
|
|
$fakerecord->prefiximagealt = null;
|
|
|
|
$returned = user_picture::unalias($fakerecord, array('custom1'), 'aliasedid', 'prefix');
|
|
|
|
$this->assertEquals(42, $returned->id);
|
|
$this->assertNull($returned->imagealt);
|
|
foreach ($fields as $field) {
|
|
if ($field !== 'id' and $field !== 'imagealt') {
|
|
$this->assertSame("Value of $field", $returned->{$field});
|
|
}
|
|
}
|
|
$this->assertSame('Value of custom1', $returned->custom1);
|
|
}
|
|
|
|
public function test_get_url() {
|
|
global $DB, $CFG;
|
|
|
|
$this->resetAfterTest();
|
|
|
|
// Force SVG on so that we have predictable URL's.
|
|
$CFG->svgicons = true;
|
|
|
|
// Verify new install contains expected defaults.
|
|
$this->assertSame('clean', $CFG->theme);
|
|
$this->assertEquals(1, $CFG->slasharguments);
|
|
$this->assertEquals(1, $CFG->themerev);
|
|
$this->assertEquals(0, $CFG->themedesignermode);
|
|
$this->assertSame('http://www.example.com/moodle', $CFG->wwwroot);
|
|
$this->assertSame($CFG->wwwroot, $CFG->httpswwwroot);
|
|
$this->assertEquals(0, $CFG->enablegravatar);
|
|
$this->assertSame('mm', $CFG->gravatardefaulturl);
|
|
|
|
// Create some users.
|
|
$page = new moodle_page();
|
|
$page->set_url('/user/profile.php');
|
|
$page->set_context(context_system::instance());
|
|
$renderer = $page->get_renderer('core');
|
|
|
|
$user1 = $this->getDataGenerator()->create_user(array('picture'=>11, 'email'=>'user1@example.com'));
|
|
$context1 = context_user::instance($user1->id);
|
|
$user2 = $this->getDataGenerator()->create_user(array('picture'=>0, 'email'=>'user2@example.com'));
|
|
$context2 = context_user::instance($user2->id);
|
|
|
|
$user3 = $this->getDataGenerator()->create_user(array('picture'=>1, 'deleted'=>1, 'email'=>'user3@example.com'));
|
|
$context3 = context_user::instance($user3->id, IGNORE_MISSING);
|
|
$this->assertEquals(0, $user3->picture);
|
|
$this->assertNotEquals('user3@example.com', $user3->email);
|
|
$this->assertFalse($context3);
|
|
|
|
// Try legacy picture == 1.
|
|
$user1->picture = 1;
|
|
$up1 = new user_picture($user1);
|
|
$this->assertSame($CFG->wwwroot.'/pluginfile.php/'.$context1->id.'/user/icon/clean/f2?rev=1', $up1->get_url($page, $renderer)->out(false));
|
|
$user1->picture = 11;
|
|
|
|
// Try valid user with picture when user context is not cached - 1 query expected.
|
|
context_helper::reset_caches();
|
|
$reads = $DB->perf_get_reads();
|
|
$up1 = new user_picture($user1);
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
$this->assertSame($CFG->wwwroot.'/pluginfile.php/'.$context1->id.'/user/icon/clean/f2?rev=11', $up1->get_url($page, $renderer)->out(false));
|
|
$this->assertEquals($reads+1, $DB->perf_get_reads());
|
|
|
|
// Try valid user with contextid hint - no queries expected.
|
|
$user1->contextid = $context1->id;
|
|
context_helper::reset_caches();
|
|
$reads = $DB->perf_get_reads();
|
|
$up1 = new user_picture($user1);
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
$this->assertSame($CFG->wwwroot.'/pluginfile.php/'.$context1->id.'/user/icon/clean/f2?rev=11', $up1->get_url($page, $renderer)->out(false));
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
|
|
// Try valid user without image - no queries expected.
|
|
context_helper::reset_caches();
|
|
$reads = $DB->perf_get_reads();
|
|
$up2 = new user_picture($user2);
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
$this->assertSame($CFG->wwwroot.'/theme/image.php/clean/core/1/u/f2', $up2->get_url($page, $renderer)->out(false));
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
|
|
// Try guessing of deleted users - no queries expected.
|
|
unset($user3->deleted);
|
|
context_helper::reset_caches();
|
|
$reads = $DB->perf_get_reads();
|
|
$up3 = new user_picture($user3);
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
$this->assertSame($CFG->wwwroot.'/theme/image.php/clean/core/1/u/f2', $up3->get_url($page, $renderer)->out(false));
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
|
|
// Try incorrectly deleted users (with valid email and pciture flag) - some DB reads expected.
|
|
$user3->email = 'user3@example.com';
|
|
$user3->picture = 1;
|
|
$reads = $DB->perf_get_reads();
|
|
$up3 = new user_picture($user3);
|
|
$this->assertEquals($reads, $DB->perf_get_reads());
|
|
$this->assertSame($CFG->wwwroot.'/theme/image.php/clean/core/1/u/f2', $up3->get_url($page, $renderer)->out(false));
|
|
$this->assertGreaterThan($reads, $DB->perf_get_reads());
|
|
|
|
// Test gravatar.
|
|
set_config('enablegravatar', 1);
|
|
|
|
// Deleted user can not have gravatar.
|
|
$user3->email = 'deleted';
|
|
$user3->picture = 0;
|
|
$up3 = new user_picture($user3);
|
|
$this->assertSame($CFG->wwwroot.'/theme/image.php/clean/core/1/u/f2', $up3->get_url($page, $renderer)->out(false));
|
|
|
|
// Verify defaults to misteryman (mm).
|
|
$up2 = new user_picture($user2);
|
|
$this->assertSame('http://www.gravatar.com/avatar/ab53a2911ddf9b4817ac01ddcd3d975f?s=35&d=mm', $up2->get_url($page, $renderer)->out(false));
|
|
|
|
// Without gravatardefaulturl, verify we pick own file.
|
|
set_config('gravatardefaulturl', '');
|
|
$up2 = new user_picture($user2);
|
|
$this->assertSame('http://www.gravatar.com/avatar/ab53a2911ddf9b4817ac01ddcd3d975f?s=35&d=http%3A%2F%2Fwww.example.com%2Fmoodle%2Fpix%2Fu%2Ff2.png', $up2->get_url($page, $renderer)->out(false));
|
|
// Uploaded image takes precedence before gravatar.
|
|
$up1 = new user_picture($user1);
|
|
$this->assertSame($CFG->wwwroot.'/pluginfile.php/'.$context1->id.'/user/icon/clean/f2?rev=11', $up1->get_url($page, $renderer)->out(false));
|
|
|
|
// Https version.
|
|
$CFG->httpswwwroot = str_replace('http:', 'https:', $CFG->wwwroot);
|
|
|
|
$up1 = new user_picture($user1);
|
|
$this->assertSame($CFG->httpswwwroot.'/pluginfile.php/'.$context1->id.'/user/icon/clean/f2?rev=11', $up1->get_url($page, $renderer)->out(false));
|
|
|
|
$up3 = new user_picture($user3);
|
|
$this->assertSame($CFG->httpswwwroot.'/theme/image.php/clean/core/1/u/f2', $up3->get_url($page, $renderer)->out(false));
|
|
|
|
$up2 = new user_picture($user2);
|
|
$this->assertSame('https://secure.gravatar.com/avatar/ab53a2911ddf9b4817ac01ddcd3d975f?s=35&d=https%3A%2F%2Fwww.example.com%2Fmoodle%2Fpix%2Fu%2Ff2.png', $up2->get_url($page, $renderer)->out(false));
|
|
|
|
// TODO MDL-44792 Rewrite those tests to use a fixture.
|
|
// Now test gravatar with one theme having own images (afterburner).
|
|
// $CFG->httpswwwroot = $CFG->wwwroot;
|
|
// $this->assertFileExists("$CFG->dirroot/theme/afterburner/config.php");
|
|
// set_config('theme', 'afterburner');
|
|
// $page = new moodle_page();
|
|
// $page->set_url('/user/profile.php');
|
|
// $page->set_context(context_system::instance());
|
|
// $renderer = $page->get_renderer('core');
|
|
|
|
// $up2 = new user_picture($user2);
|
|
// $this->assertEquals('http://www.gravatar.com/avatar/ab53a2911ddf9b4817ac01ddcd3d975f?s=35&d=http%3A%2F%2Fwww.example.com%2Fmoodle%2Ftheme%2Fafterburner%2Fpix_core%2Fu%2Ff2.png', $up2->get_url($page, $renderer)->out(false));
|
|
|
|
// // Https version.
|
|
// $CFG->httpswwwroot = str_replace('http:', 'https:', $CFG->wwwroot);
|
|
|
|
// $up2 = new user_picture($user2);
|
|
// $this->assertSame('https://secure.gravatar.com/avatar/ab53a2911ddf9b4817ac01ddcd3d975f?s=35&d=https%3A%2F%2Fwww.example.com%2Fmoodle%2Ftheme%2Fafterburner%2Fpix_core%2Fu%2Ff2.png', $up2->get_url($page, $renderer)->out(false));
|
|
// End of gravatar tests.
|
|
|
|
// Test themed images.
|
|
// set_config('enablegravatar', 0);
|
|
// $this->assertFileExists("$CFG->dirroot/theme/formal_white/config.php"); // Use any other theme.
|
|
// set_config('theme', 'formal_white');
|
|
// $CFG->httpswwwroot = $CFG->wwwroot;
|
|
// $page = new moodle_page();
|
|
// $page->set_url('/user/profile.php');
|
|
// $page->set_context(context_system::instance());
|
|
// $renderer = $page->get_renderer('core');
|
|
|
|
// $up1 = new user_picture($user1);
|
|
// $this->assertSame($CFG->wwwroot.'/pluginfile.php/'.$context1->id.'/user/icon/formal_white/f2?rev=11', $up1->get_url($page, $renderer)->out(false));
|
|
|
|
// $up2 = new user_picture($user2);
|
|
// $this->assertSame($CFG->wwwroot.'/theme/image.php/formal_white/core/1/u/f2', $up2->get_url($page, $renderer)->out(false));
|
|
|
|
// Test non-slashargument images.
|
|
set_config('theme', 'clean');
|
|
$CFG->httpswwwroot = $CFG->wwwroot;
|
|
$CFG->slasharguments = 0;
|
|
$page = new moodle_page();
|
|
$page->set_url('/user/profile.php');
|
|
$page->set_context(context_system::instance());
|
|
$renderer = $page->get_renderer('core');
|
|
|
|
$up3 = new user_picture($user3);
|
|
$this->assertSame($CFG->wwwroot.'/theme/image.php?theme=clean&component=core&rev=1&image=u%2Ff2', $up3->get_url($page, $renderer)->out(false));
|
|
}
|
|
|
|
public function test_empty_menu() {
|
|
$emptymenu = new custom_menu();
|
|
$this->assertInstanceOf('custom_menu', $emptymenu);
|
|
$this->assertFalse($emptymenu->has_children());
|
|
}
|
|
|
|
public function test_basic_syntax() {
|
|
$definition = <<<EOF
|
|
Moodle community|http://moodle.org
|
|
-Moodle free support|http://moodle.org/support
|
|
-Moodle development|http://moodle.org/development
|
|
--Moodle Tracker|http://tracker.moodle.org
|
|
--Moodle Docs|http://docs.moodle.org
|
|
-Moodle News|http://moodle.org/news
|
|
Moodle company||Moodle trust pty
|
|
-Hosting|http://moodle.com/hosting|Commercial hosting
|
|
-Support|http://moodle.com/support|Commercial support
|
|
EOF;
|
|
|
|
$menu = new custom_menu($definition);
|
|
$this->assertInstanceOf('custom_menu', $menu);
|
|
$this->assertTrue($menu->has_children());
|
|
$firstlevel = $menu->get_children();
|
|
$this->assertTrue(is_array($firstlevel));
|
|
$this->assertCount(2, $firstlevel);
|
|
|
|
$item = array_shift($firstlevel);
|
|
$this->assertInstanceOf('custom_menu_item', $item);
|
|
$this->assertTrue($item->has_children());
|
|
$this->assertCount(3, $item->get_children());
|
|
$this->assertEquals('Moodle community', $item->get_text());
|
|
$itemurl = $item->get_url();
|
|
$this->assertTrue($itemurl instanceof moodle_url);
|
|
$this->assertEquals('http://moodle.org', $itemurl->out());
|
|
$this->assertEquals($item->get_text(), $item->get_title()); // Implicit title.
|
|
|
|
/** @var custom_menu_item $item */
|
|
$item = array_shift($firstlevel);
|
|
$this->assertTrue($item->has_children());
|
|
$this->assertCount(2, $item->get_children());
|
|
$this->assertSame('Moodle company', $item->get_text());
|
|
$this->assertNull($item->get_url());
|
|
$this->assertSame('Moodle trust pty', $item->get_title());
|
|
|
|
$children = $item->get_children();
|
|
$subitem = array_shift($children);
|
|
$this->assertFalse($subitem->has_children());
|
|
$this->assertSame('Hosting', $subitem->get_text());
|
|
$this->assertSame('Commercial hosting', $subitem->get_title());
|
|
}
|
|
|
|
public function test_custommenu_mulitlang() {
|
|
$definition = <<<EOF
|
|
Start|http://school.info
|
|
Info
|
|
-English|http://school.info/en|Information in English|en
|
|
--Nested under English
|
|
--I will be lost|||de
|
|
-Deutsch|http://school.info/de|Informationen in deutscher Sprache|de,de_du,de_kids
|
|
--Nested under Deutsch
|
|
--I will be lost|||en
|
|
kontaktieren Sie uns|contactus.php||de
|
|
Contact us|contactus.php||en
|
|
EOF;
|
|
$definitionen = <<<EOF
|
|
Start|http://school.info
|
|
Info
|
|
-English|http://school.info/en|Information in English|en
|
|
--Nested under English
|
|
Contact us|contactus.php||en
|
|
EOF;
|
|
$definitionde = <<<EOF
|
|
Start|http://school.info
|
|
Info
|
|
-Deutsch|http://school.info/de|Informationen in deutscher Sprache|de,de_du,de_kids
|
|
--Nested under Deutsch
|
|
kontaktieren Sie uns|contactus.php||de
|
|
EOF;
|
|
|
|
$definitiondedu = <<<EOF
|
|
Start|http://school.info
|
|
Info
|
|
-Deutsch|http://school.info/de|Informationen in deutscher Sprache|de,de_du,de_kids
|
|
--Nested under Deutsch
|
|
EOF;
|
|
|
|
$parsed = $this->custommenu_out(new custom_menu($definition));
|
|
$parseden = $this->custommenu_out(new custom_menu($definition, 'en'));
|
|
$parsedde = $this->custommenu_out(new custom_menu($definition, 'de'));
|
|
$parseddedu = $this->custommenu_out(new custom_menu($definition, 'de_du'));
|
|
|
|
$actualen = $this->custommenu_out(new custom_menu($definitionen, 'en'));
|
|
$actualde = $this->custommenu_out(new custom_menu($definitionde, 'de'));
|
|
$actualdedu = $this->custommenu_out(new custom_menu($definitiondedu, 'de_du'));
|
|
|
|
$this->assertSame($actualen, $parseden, 'The parsed English menu does not match the expected English menu');
|
|
$this->assertSame($actualde, $parsedde, 'The parsed German menu does not match the expected German menu');
|
|
$this->assertSame($actualdedu, $parseddedu, 'The parsed German [Du] menu does not match the expected German [Du] menu');
|
|
|
|
$this->assertNotSame($parsed, $parsedde, 'The menu without language is the same as the German menu. They should differ!');
|
|
$this->assertNotSame($parsed, $parseden, 'The menu without language is the same as the English menu. They should differ!');
|
|
$this->assertNotSame($parsed, $parseddedu, 'The menu without language is the same as the German [Du] menu. They should differ!');
|
|
$this->assertNotSame($parseden, $parsedde, 'The English menu is the same as the German menu. They should differ!');
|
|
$this->assertNotSame($parseden, $parseddedu, 'The English menu is the same as the German [Du] menu. They should differ!');
|
|
$this->assertNotSame($parseddedu, $parsedde, 'The German [Du] menu is the same as the German menu. They should differ!');
|
|
}
|
|
|
|
/**
|
|
* Support function that takes a custom_menu_item and converts it to a string.
|
|
*
|
|
* @param custom_menu_item $item
|
|
* @param int $depth
|
|
* @return string
|
|
*/
|
|
protected function custommenu_out(custom_menu_item $item, $depth = 0) {
|
|
$str = str_repeat('-', $depth);
|
|
$str .= $item->get_text();
|
|
$str .= '|' . $item->get_url();
|
|
$str .= '|' . $item->get_title();
|
|
if ($item->has_children()) {
|
|
$str .= '|' . count($item->get_children());
|
|
foreach ($item->get_children() as $child) {
|
|
$str .= "\n" . $this->custommenu_out($child, $depth + 1);
|
|
}
|
|
}
|
|
return $str;
|
|
}
|
|
|
|
public function test_prepare() {
|
|
$expecteda = array('<span class="current-page">1</span>',
|
|
'<a href="index.php?page=1">2</a>',
|
|
'<a href="index.php?page=2">3</a>',
|
|
'<a href="index.php?page=3">4</a>',
|
|
'<a href="index.php?page=4">5</a>',
|
|
'<a href="index.php?page=5">6</a>',
|
|
'<a href="index.php?page=6">7</a>',
|
|
'<a href="index.php?page=7">8</a>',
|
|
);
|
|
$expectedb = array('<a href="page?page=3">4</a>',
|
|
'<a href="page?page=4">5</a>',
|
|
'<span class="current-page">6</span>',
|
|
'<a href="page?page=6">7</a>',
|
|
'<a href="page?page=7">8</a>',
|
|
);
|
|
|
|
$mpage = new moodle_page();
|
|
$rbase = new renderer_base($mpage, "/");
|
|
$pbara = new paging_bar(40, 0, 5, 'index.php');
|
|
$pbara->prepare($rbase, $mpage, "/");
|
|
$pbarb = new paging_bar(100, 5, 5, 'page');
|
|
$pbarb->maxdisplay = 5;
|
|
$pbarb->prepare($rbase, $mpage, "/");
|
|
|
|
$this->assertEquals($expecteda, $pbara->pagelinks);
|
|
$this->assertEquals($expectedb, $pbarb->pagelinks);
|
|
}
|
|
}
|