on-demand release 4.5dev+
[moodle.git] / course / tests / content_item_test.php
blob95db8b36bfad27ab3821e2c4c3b11dc9e640d084
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
17 namespace core_course;
19 defined('MOODLE_INTERNAL') || die();
21 use core_course\local\entity\content_item;
22 use core_course\local\entity\lang_string_title;
23 use core_course\local\entity\string_title;
25 /**
26 * Tests for the \core_course\local\entity\content_item class.
28 * @package core
29 * @subpackage course
30 * @copyright 2020 Jake Dallimore <jrhdallimore@gmail.com>
31 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
32 * @covers \core_course\local\entity\content_item
34 class content_item_test extends \advanced_testcase {
36 /**
37 * Test the content_item class.
39 public function test_content_item(): void {
40 $this->resetAfterTest();
42 $contentitem = new content_item(22, 'Item name', new lang_string_title('modulename', 'mod_assign'),
43 new \moodle_url('mod_edit.php'), '<img src="test">', 'Description of the module', MOD_ARCHETYPE_RESOURCE, 'mod_page',
44 MOD_PURPOSE_CONTENT, true);
46 $this->assertEquals(22, $contentitem->get_id());
47 $this->assertEquals('Item name', $contentitem->get_name());
48 $this->assertEquals('Assignment', $contentitem->get_title()->get_value());
49 $this->assertEquals(new \moodle_url('mod_edit.php'), $contentitem->get_link());
50 $this->assertEquals('<img src="test">', $contentitem->get_icon());
51 $this->assertEquals('Description of the module', $contentitem->get_help());
52 $this->assertEquals(MOD_ARCHETYPE_RESOURCE, $contentitem->get_archetype());
53 $this->assertEquals('mod_page', $contentitem->get_component_name());
54 $this->assertEquals('content', $contentitem->get_purpose());
55 $this->assertTrue($contentitem->is_branded());
58 /**
59 * Test confirming that plugins can return custom titles for a content item.
61 public function test_content_item_custom_string_title(): void {
62 $this->resetAfterTest();
64 $contentitem = new content_item(22, 'Item name', new string_title('My custom string'),
65 new \moodle_url('mod_edit.php'), '<img src="test">', 'Description of the module', MOD_ARCHETYPE_RESOURCE, 'mod_page',
66 MOD_PURPOSE_CONTENT);
68 $this->assertEquals('My custom string', $contentitem->get_title()->get_value());