Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 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/>.

< /** < * lock unit tests < * < * @package core < * @category lock < * @copyright 2013 Damyon Wiese < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */ < < defined('MOODLE_INTERNAL') || die(); <
> namespace core;
/** * Unit tests for our locking configuration. * * @package core
< * @category lock
> * @category test
* @copyright 2013 Damyon Wiese * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class lock_config_testcase extends advanced_testcase {
> class lock_config_test extends \advanced_testcase {
/** * Tests the static parse charset method * @return void */ public function test_lock_config() { global $CFG; $original = null; if (isset($CFG->lock_factory)) { $original = $CFG->lock_factory; } $originalfilelocking = null; if (isset($CFG->preventfilelocking)) { $originalfilelocking = $CFG->preventfilelocking; } // Test no configuration. unset($CFG->lock_factory); $CFG->preventfilelocking = 0; $factory = \core\lock\lock_config::get_lock_factory('cache'); $this->assertNotEmpty($factory, 'Get a default factory with no configuration'); // Test explicit broken lock. $CFG->lock_factory = '\core\lock\not_a_lock_factory'; try { $factory = \core\lock\lock_config::get_lock_factory('cache'); $this->fail('Exception expected');
< } catch (moodle_exception $ex) {
> } catch (\moodle_exception $ex) {
$this->assertInstanceOf('coding_exception', $ex); } // Test explicit file locks. $CFG->lock_factory = '\core\lock\file_lock_factory'; $factory = \core\lock\lock_config::get_lock_factory('cache');
> if ($factory instanceof \core\lock\timing_wrapper_lock_factory) { $this->assertTrue($factory instanceof \core\lock\file_lock_factory, > $factory = $factory->get_real_factory(); 'Get an explicit file lock factory'); > }
// Test explicit file locks but with file locks prevented. $CFG->preventfilelocking = 1; try { $factory = \core\lock\lock_config::get_lock_factory('cache'); $this->fail('Exception expected');
< } catch (moodle_exception $ex) {
> } catch (\moodle_exception $ex) {
$this->assertInstanceOf('coding_exception', $ex); } // Test explicit db locks. $CFG->lock_factory = '\core\lock\db_record_lock_factory'; $factory = \core\lock\lock_config::get_lock_factory('cache');
> if ($factory instanceof \core\lock\timing_wrapper_lock_factory) { $this->assertTrue($factory instanceof \core\lock\db_record_lock_factory, > $factory = $factory->get_real_factory(); 'Get an explicit db record lock factory'); > }
if ($original) { $CFG->lock_factory = $original; } else { unset($CFG->lock_factory); } if ($originalfilelocking) { $CFG->preventfilelocking = $originalfilelocking; } else { unset($CFG->preventfilelocking); } } }