mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 06:18:28 +01:00
d3db4b037c
This commit defines the new /availability root folder, with /availability/classes, /availability/tests, and /availability/condition where the condition plugins will live. Condition plugin prefix is availability_, e.g. availability_date. Rationale for this organisation: 1. I was originally going to put this in /lib/availability but it has been pointed out that putting even more junk in lib is probably bad. 2. 'availability' and 'condition' are the two names used in code to refer to this system ($CFG->enableavailability). 3. The prefix has to be short enough to allow database tables (although in practice I assume that condition plugins will not normally contain database tables). The new API includes a Boolean tree structure that controls the availability of an item. AMOS BEGIN CPY [availabilityconditions,core_condition],[restrictaccess,core_availability] CPY [enableavailability,core_condition],[enableavailability,core_availability] CPY [configenableavailability,core_condition],[enableavailability_desc,core_availability] AMOS END
56 lines
2.0 KiB
PHP
56 lines
2.0 KiB
PHP
<?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 for the component and plugin definitions for availability system.
|
|
*
|
|
* @package core_availability
|
|
* @copyright 2014 The Open University
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
/**
|
|
* Unit tests for the component and plugin definitions for availability system.
|
|
*
|
|
* @package core_availability
|
|
* @copyright 2014 The Open University
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
class core_availability_component_testcase extends advanced_testcase {
|
|
/**
|
|
* Tests loading a class from /availability/classes.
|
|
*/
|
|
public function test_load_class() {
|
|
$result = get_class_methods('\core_availability\info');
|
|
$this->assertTrue(is_array($result));
|
|
}
|
|
|
|
/**
|
|
* Tests the plugininfo class is present and working.
|
|
*/
|
|
public function test_plugin_info() {
|
|
// This code will throw debugging information if the plugininfo class
|
|
// is missing. Unfortunately it doesn't actually cause the test to
|
|
// fail, but it's obvious when running test at least.
|
|
$pluginmanager = core_plugin_manager::instance();
|
|
$list = $pluginmanager->get_enabled_plugins('availability');
|
|
$this->assertEquals(array('completion', 'date', 'grade', 'group', 'grouping', 'profile'),
|
|
array_keys($list));
|
|
}
|
|
}
|