Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.x is 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/>.

namespace core_course;

defined('MOODLE_INTERNAL') || die();

global $CFG;
require_once($CFG->dirroot . '/course/lib.php');
< require_once($CFG->dirroot . '/course/tests/fixtures/format_theunittest.php');
> require_once($CFG->dirroot . '/course/format/tests/fixtures/format_theunittest.php');
require_once($CFG->dirroot . '/course/format/lib.php'); /**
< * Course related unit tests
> * Course format function unit tests
* * @package core_course * @copyright 2021 Catalyst IT Pty Ltd * @author Jason den Dulk * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class course_format_function_test extends \basic_testcase {
> public function test_clean_param_if_not_null() { > /** $this->assertNull(clean_param_if_not_null(null)); > * Tests clean_param_if_not_null function $n = '3x'; > * @covers ::clean_param_if_not_null $this->assertEquals(clean_param($n, PARAM_INT), clean_param_if_not_null($n, PARAM_INT)); > */
$this->assertEquals(clean_param($n, PARAM_RAW), clean_param_if_not_null($n, PARAM_RAW)); $this->assertEquals(clean_param($n, PARAM_ALPHANUM), clean_param_if_not_null($n, PARAM_ALPHANUM)); $this->assertEquals(clean_param($n, PARAM_ALPHA), clean_param_if_not_null($n, PARAM_ALPHA)); $s = '<abc>xyz</abc>'; $this->assertEquals(clean_param($s, PARAM_ALPHANUM), clean_param_if_not_null($s, PARAM_ALPHANUM)); $this->assertEquals(clean_param($s, PARAM_RAW), clean_param_if_not_null($s, PARAM_RAW)); }
> /** public function test_contract_value() { > * Tests contract_value function $input = [ > * @covers ::contract_value 'abc' => '<p>All together Now</p>', > */
'abcformat' => '1', 'jolly' => 'Roger' ]; $expected = [ 'abc_editor' => [ 'text' => $input['abc'], 'format' => $input['abcformat'] ], 'jolly' => $input['jolly'], ]; $defs = [ 'abc_editor' => [], 'jolly' => [ 'type' => PARAM_ALPHA ], ]; $dest = []; foreach ($defs as $name => $def) { contract_value($dest, $input, $def, $name); } $this->assertEquals($expected, $dest); }
> /** public function test_expand_value() { > * Tests expand_value function $input = [ > * @covers ::expand_value 'abc_editor' => [ 'text' => '<p>All together Now</p>', 'format' => '1' ], > */
'jolly' => 'Roger', ]; $expected = [ 'abc' => $input['abc_editor']['text'], 'abcformat' => $input['abc_editor']['format'], 'jolly' => $input['jolly'], ]; $defs = [ 'abc_editor' => [], 'jolly' => [ 'type' => PARAM_ALPHA ], ]; $dest = []; foreach ($defs as $name => $def) { expand_value($dest, $input, $def, $name); } $this->assertEquals($expected, $dest); } }