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/>.

/**
 * Unit tests.
 *
 * @package filter_data
 * @category test
 * @copyright 2015 David Monllao
 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

< defined('MOODLE_INTERNAL') || die(); < < global $CFG; < require_once($CFG->dirroot . '/filter/data/filter.php');
> namespace filter_data;
/** * Tests for filter_data. * * @package filter_data * @copyright 2015 David Monllao * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class filter_data_filter_testcase extends advanced_testcase {
> class filter_test extends \advanced_testcase {
/** * Tests that the filter applies the required changes. * * @return void */ public function test_filter() { $this->resetAfterTest(true); $this->setAdminUser();
< filter_manager::reset_caches();
> \filter_manager::reset_caches();
filter_set_global_state('data', TEXTFILTER_ON); $course1 = $this->getDataGenerator()->create_course();
< $coursecontext1 = context_course::instance($course1->id);
> $coursecontext1 = \context_course::instance($course1->id);
$course2 = $this->getDataGenerator()->create_course();
< $coursecontext2 = context_course::instance($course2->id);
> $coursecontext2 = \context_course::instance($course2->id);
< $sitecontext = context_course::instance(SITEID);
> $sitecontext = \context_course::instance(SITEID);
$site = get_site(); $this->add_simple_database_instance($site, array('SiteEntry')); $this->add_simple_database_instance($course1, array('CourseEntry')); $html = '<p>I like CourseEntry and SiteEntry</p>'; // Testing at course level (both site and course). $filtered = format_text($html, FORMAT_HTML, array('context' => $coursecontext1));
< $this->assertRegExp('/title=(\'|")CourseEntry(\'|")/', $filtered); < $this->assertRegExp('/title=(\'|")SiteEntry(\'|")/', $filtered);
> $this->assertMatchesRegularExpression('/title=(\'|")CourseEntry(\'|")/', $filtered); > $this->assertMatchesRegularExpression('/title=(\'|")SiteEntry(\'|")/', $filtered);
// Testing at site level (only site). $filtered = format_text($html, FORMAT_HTML, array('context' => $sitecontext));
< $this->assertNotRegExp('/title=(\'|")CourseEntry(\'|")/', $filtered); < $this->assertRegExp('/title=(\'|")SiteEntry(\'|")/', $filtered);
> $this->assertDoesNotMatchRegularExpression('/title=(\'|")CourseEntry(\'|")/', $filtered); > $this->assertMatchesRegularExpression('/title=(\'|")SiteEntry(\'|")/', $filtered);
// Changing to another course to test the caches invalidation (only site). $filtered = format_text($html, FORMAT_HTML, array('context' => $coursecontext2));
< $this->assertNotRegExp('/title=(\'|")CourseEntry(\'|")/', $filtered); < $this->assertRegExp('/title=(\'|")SiteEntry(\'|")/', $filtered);
> $this->assertDoesNotMatchRegularExpression('/title=(\'|")CourseEntry(\'|")/', $filtered); > $this->assertMatchesRegularExpression('/title=(\'|")SiteEntry(\'|")/', $filtered);
} /** * Adds a database instance to the provided course + a text field + adds all attached entries. *
< * @param stdClass $course
> * @param \stdClass $course
* @param array $entries A list of entry names. * @return void */ protected function add_simple_database_instance($course, $entries = false) { global $DB; $database = $this->getDataGenerator()->create_module('data', array('course' => $course->id)); // A database field. $field = data_get_field_new('text', $database);
< $fielddetail = new stdClass();
> $fielddetail = new \stdClass();
$fielddetail->d = $database->id; $fielddetail->mode = 'add'; $fielddetail->type = 'text'; $fielddetail->sesskey = sesskey(); $fielddetail->name = 'Name'; $fielddetail->description = 'Some name'; $fielddetail->param1 = '1'; $field->define_field($fielddetail); $field->insert_field(); $recordid = data_add_record($database); // Database entries. foreach ($entries as $entrytext) { $datacontent = array(); $datacontent['fieldid'] = $field->field->id; $datacontent['recordid'] = $recordid; $datacontent['content'] = $entrytext; $contentid = $DB->insert_record('data_content', $datacontent); } } }