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

< /** < * Template persistent class tests. < * < * @package core_competency < * @copyright 2016 Frédéric Massart - FMCorz.net < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */ < < defined('MOODLE_INTERNAL') || die(); < global $CFG; < < use core_competency\template;
> namespace core_competency;
/** * Template persistent testcase. * * @package core_competency * @copyright 2016 Frédéric Massart - FMCorz.net * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class core_competency_template_testcase extends advanced_testcase {
> class template_test extends \advanced_testcase {
public function test_validate_duedate() { global $DB; $this->resetAfterTest(); $tpl = $this->getDataGenerator()->get_plugin_generator('core_competency')->create_template(); // No due date -> pass. $tpl->set('duedate', 0); $this->assertTrue($tpl->is_valid()); // Setting new due date in the past -> fail. $tpl->set('duedate', 1); $errors = $tpl->get_errors(); $this->assertCount(1, $errors); $this->assertArrayHasKey('duedate', $errors); // Setting new due date in very close past -> pass. $tpl->set('duedate', time() - 10); $this->assertTrue($tpl->is_valid()); // Setting new due date in future -> pass. $tpl->set('duedate', time() + 600); $this->assertTrue($tpl->is_valid()); // Save due date in the future. $tpl->update(); // Going from future date to past -> fail. $tpl->set('duedate', 1); $errors = $tpl->get_errors(); $this->assertCount(1, $errors); $this->assertArrayHasKey('duedate', $errors); // Going from future date to none -> pass. $tpl->set('duedate', 0); $this->assertTrue($tpl->is_valid()); // Going from future date to other future -> pass. $tpl->set('duedate', time() + 6000); $this->assertTrue($tpl->is_valid()); // Going from future date to close past -> pass. $tpl->set('duedate', time() - 10); $this->assertTrue($tpl->is_valid()); // Mocking past due date. $record = $tpl->to_record(); $record->duedate = 1; $DB->update_record(template::TABLE, $record); $tpl->read(); $this->assertEquals(1, $tpl->get('duedate')); // Not changing the past due date -> pass. // Note: changing visibility to force validation. $tpl->set('visible', 0); $tpl->set('visible', 1); $this->assertTrue($tpl->is_valid()); // Changing past due date to other past -> fail. $tpl->set('duedate', 10); $errors = $tpl->get_errors(); $this->assertCount(1, $errors); $this->assertArrayHasKey('duedate', $errors); // Changing past due date close past -> pass. $tpl->set('duedate', time() + 10); $this->assertTrue($tpl->is_valid()); // Changing past due date to future -> pass. $tpl->set('duedate', time() + 1000); $this->assertTrue($tpl->is_valid()); // Changing past due date to none -> pass. $tpl->set('duedate', 0); $this->assertTrue($tpl->is_valid()); } }