You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							350 lines
						
					
					
						
							9.4 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							350 lines
						
					
					
						
							9.4 KiB
						
					
					
				| <?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_tests\event; | |
| 
 | |
| /** | |
|  * Fixtures for new event testing. | |
|  * | |
|  * @package    core | |
|  * @category   phpunit | |
|  * @copyright  2013 Petr Skoda {@link http://skodak.org} | |
|  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
|  */ | |
| 
 | |
| defined('MOODLE_INTERNAL') || die(); | |
| 
 | |
| 
 | |
| class unittest_executed extends \core\event\base { | |
|     public $nest = false; | |
| 
 | |
|     public static function get_name() { | |
|         return 'xxx'; | |
|     } | |
| 
 | |
|     public function get_description() { | |
|         return 'yyy'; | |
|     } | |
| 
 | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         $this->data['edulevel'] = self::LEVEL_PARTICIPATING; | |
|     } | |
| 
 | |
|     public function get_url() { | |
|         return new \moodle_url('/somepath/somefile.php', array('id'=>$this->data['other']['sample'])); | |
|     } | |
| 
 | |
|     public static function get_legacy_eventname() { | |
|         return 'test_legacy'; | |
|     } | |
| 
 | |
|     protected function get_legacy_eventdata() { | |
|         return array($this->data['courseid'], $this->data['other']['sample']); | |
|     } | |
| 
 | |
|     protected function get_legacy_logdata() { | |
|         return array($this->data['courseid'], 'core_unittest', 'view', 'unittest.php?id='.$this->data['other']['sample']); | |
|     } | |
| } | |
| 
 | |
| 
 | |
| class unittest_observer { | |
|     public static $info = array(); | |
|     public static $event = array(); | |
| 
 | |
|     public static function reset() { | |
|         self::$info = array(); | |
|         self::$event = array(); | |
|     } | |
| 
 | |
|     public static function observe_one(unittest_executed $event) { | |
|         self::$info[] = 'observe_one-'.$event->other['sample']; | |
|         self::$event[] = $event; | |
|     } | |
| 
 | |
|     public static function external_observer(unittest_executed $event) { | |
|         self::$info[] = 'external_observer-'.$event->other['sample']; | |
|         self::$event[] = $event; | |
|     } | |
| 
 | |
|     public static function broken_observer(unittest_executed $event) { | |
|         self::$info[] = 'broken_observer-'.$event->other['sample']; | |
|         self::$event[] = $event; | |
|         throw new \Exception('someerror'); | |
|     } | |
| 
 | |
|     public static function observe_all(\core\event\base $event) { | |
|         if (!($event instanceof unittest_executed)) { | |
|             self::$info[] = 'observe_all-unknown'; | |
|             self::$event[] = $event; | |
|             return; | |
|         } | |
|         self::$event[] = $event; | |
|         if (!empty($event->nest)) { | |
|             self::$info[] = 'observe_all-nesting-'.$event->other['sample']; | |
|             unittest_executed::create(array('context'=>\context_system::instance(), 'other'=>array('sample'=>666, 'xx'=>666)))->trigger(); | |
|         } else { | |
|             self::$info[] = 'observe_all-'.$event->other['sample']; | |
|         } | |
|     } | |
| 
 | |
|     public static function observe_all_alt(\core\event\base $event) { | |
|         self::$info[] = 'observe_all_alt'; | |
|         self::$event[] = $event; | |
|     } | |
| 
 | |
|     public static function legacy_handler($data) { | |
|         self::$info[] = 'legacy_handler-'.$data[0]; | |
|         self::$event[] = $data; | |
|     } | |
| } | |
| 
 | |
| class bad_event1 extends \core\event\base { | |
|     protected function init() { | |
|         //$this->data['crud'] = 'u'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|     } | |
| } | |
| 
 | |
| class bad_event2 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         //$this->data['edulevel'] = 10; | |
|     } | |
| } | |
| 
 | |
| class bad_event2b extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         // Invalid level value. | |
|         $this->data['edulevel'] = -1; | |
|     } | |
| } | |
| 
 | |
| class bad_event3 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         unset($this->data['courseid']); | |
|     } | |
| } | |
| 
 | |
| class bad_event4 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->data['xxx'] = 1; | |
|     } | |
| } | |
| 
 | |
| class bad_event5 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'x'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|     } | |
| } | |
| 
 | |
| class bad_event6 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->data['objecttable'] = 'xxx_xxx_xx'; | |
|     } | |
| } | |
| 
 | |
| class bad_event7 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->data['objecttable'] = null; | |
|     } | |
| } | |
| 
 | |
| class bad_event8 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->data['objecttable'] = 'user'; | |
|     } | |
| } | |
| 
 | |
| class problematic_event1 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|     } | |
| } | |
| 
 | |
| class problematic_event2 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->context = \context_system::instance(); | |
|     } | |
| } | |
| 
 | |
| class problematic_event3 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->context = \context_system::instance(); | |
|     } | |
| 
 | |
|     protected function validate_data() { | |
|         parent::validate_data(); | |
|         if (empty($this->data['other'])) { | |
|             debugging('other is missing'); | |
|         } | |
|     } | |
| } | |
| 
 | |
| class deprecated_event1 extends \core\event\base { | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['level'] = self::LEVEL_TEACHING; // Tests edulevel hint. | |
|         $this->context = \context_system::instance(); | |
|     } | |
| } | |
| 
 | |
| class noname_event extends \core\event\base { | |
| 
 | |
|     protected function init() { | |
|         $this->data['crud'] = 'c'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->context = \context_system::instance(); | |
|     } | |
| } | |
| 
 | |
| /** | |
|  * Class course_module_viewed. | |
|  * | |
|  * Wrapper for testing \core\event\course_module_viewed. | |
|  */ | |
| class course_module_viewed extends \core\event\course_module_viewed { | |
|     protected function init() { | |
|         $this->data['crud'] = 'r'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->data['objecttable'] = 'feedback'; | |
|     } | |
| } | |
| 
 | |
| /** | |
|  * Class course_module_viewed_noinit. | |
|  * | |
|  * Wrapper for testing \core\event\course_module_viewed. | |
|  */ | |
| class course_module_viewed_noinit extends \core\event\course_module_viewed { | |
| } | |
| 
 | |
| /** | |
|  * Event for testing core\event\grade_report_viewed. | |
|  */ | |
| class grade_report_viewed extends \core\event\grade_report_viewed { | |
| } | |
| 
 | |
| /** | |
|  * Event to test context used in event functions | |
|  */ | |
| class context_used_in_event extends \core\event\base { | |
|     public function get_description() { | |
|         return $this->context->instanceid . " Description"; | |
|     } | |
| 
 | |
|     protected function init() { | |
|         $this->data['crud'] = 'u'; | |
|         $this->data['edulevel'] = self::LEVEL_PARTICIPATING; | |
|         $this->context = \context_system::instance(); | |
|     } | |
| 
 | |
|     public function get_url() { | |
|         return new \moodle_url('/somepath/somefile.php', array('id' => $this->context->instanceid)); | |
|     } | |
| 
 | |
|     protected function get_legacy_eventdata() { | |
|         return array($this->data['courseid'], $this->context->instanceid); | |
|     } | |
| 
 | |
|     protected function get_legacy_logdata() { | |
|         return array($this->data['courseid'], 'core_unittest', 'view', 'unittest.php?id=' . $this->context->instanceid); | |
|     } | |
| } | |
| 
 | |
| /** | |
|  * This is an explanation of the event. | |
|  *      - I'm making a point here. | |
|  *      - I have a second {@link something}  point here. | |
|  *      - whitespace is intentional to test it's removal. | |
|  * | |
|  * | |
|  * I have something else *Yeah* that. | |
|  * | |
|  * | |
|  * | |
|  * @package    core | |
|  * @category   phpunit | |
|  * @copyright  2014 Adrian Greeve <adrian@moodle.com> | |
|  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
|  */ | |
| class full_docblock extends \core\event\base { | |
| 
 | |
|     protected function init() { | |
| 
 | |
|     } | |
| } | |
| 
 | |
| /** | |
|  * We have only the description in the docblock | |
|  * and nothing else. | |
|  */ | |
| class docblock_test2 extends \core\event\base { | |
| 
 | |
|     protected function init() { | |
| 
 | |
|     } | |
| } | |
| 
 | |
| /** | |
|  * Calendar event created event. | |
|  * | |
|  * @property-read array $other { | |
|  *      Extra information about the event. | |
|  * | |
|  *      - int timestart: timestamp for event time start. | |
|  *      - string name: Name of the event. | |
|  *      - int repeatid: Id of the parent event if present, else 0. | |
|  * } | |
|  * | |
|  * @package    core | |
|  * @since      Moodle 2.7 | |
|  * @copyright  2014 onwards Adrian Greeve | |
|  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
|  */ | |
| class docblock_test3 extends \core\event\base { | |
| 
 | |
|     protected function init() { | |
| 
 | |
|     } | |
| } | |
| 
 | |
| class static_info_viewing extends \core\event\base { | |
| 
 | |
|     protected function init() { | |
|         $this->data['crud'] = 'r'; | |
|         $this->data['edulevel'] = self::LEVEL_OTHER; | |
|         $this->data['objecttable'] = 'mod_unittest'; | |
|     } | |
| }
 | |
| 
 |