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.
   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   4  // Moodle is free software: you can redistribute it and/or modify
   5  // it under the terms of the GNU General Public License as published by
   6  // the Free Software Foundation, either version 3 of the License, or
   7  // (at your option) any later version.
   8  //
   9  // Moodle is distributed in the hope that it will be useful,
  10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  // GNU General Public License for more details.
  13  //
  14  // You should have received a copy of the GNU General Public License
  15  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  namespace core\event;
  18  
  19  defined('MOODLE_INTERNAL') || die();
  20  
  21  require_once (__DIR__.'/../fixtures/event_fixtures.php');
  22  
  23  /**
  24   * Tests for event manager, base event and observers.
  25   *
  26   * @package    core
  27   * @category   phpunit
  28   * @copyright  2014 Petr Skoda
  29   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  30   */
  31  class unknown_logged_test extends \advanced_testcase {
  32  
  33      public function test_restore_event() {
  34          $event1 = \core_tests\event\unittest_executed::create(array('context' => \context_system::instance(), 'other' => array('sample' => 1, 'xx' => 10)));
  35          $data1 = $event1->get_data();
  36  
  37          $data1['eventname'] = '\mod_xx\event\xx_yy';
  38          $data1['component'] = 'mod_xx';
  39          $data1['action'] = 'yy';
  40          $data1['target'] = 'xx';
  41          $extra1 = array('origin' => 'cli');
  42  
  43          $event2 = \core\event\base::restore($data1, $extra1);
  44          $data2 = $event2->get_data();
  45          $extra2 = $event2->get_logextra();
  46  
  47          $this->assertInstanceOf('core\event\unknown_logged', $event2);
  48          $this->assertTrue($event2->is_triggered());
  49          $this->assertTrue($event2->is_restored());
  50          $this->assertNull($event2->get_url());
  51          $this->assertEquals($data1, $data2);
  52          $this->assertEquals($extra1, $extra2);
  53      }
  54  }