. /** * Unit tests for lib/outputcomponents.php. * * @package core * @category phpunit * @copyright 2011 David Mudrak * @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 = <<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 = <<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('1', '2', '3', '4', '5', '6', '7', '8', ); $expectedb = array('4', '5', '6', '7', '8', ); $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); } }