Differences Between: [Versions 310 and 311] [Versions 311 and 402] [Versions 311 and 403] [Versions 39 and 311]
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 /** 18 * Tests for report library functions. 19 * 20 * @package report_loglive 21 * @copyright 2014 onwards Ankit agarwal <ankit.agrr@gmail.com> 22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later. 23 */ 24 namespace report_loglive; 25 26 defined('MOODLE_INTERNAL') || die(); 27 28 /** 29 * Class report_loglive_lib_testcase 30 * 31 * @package report_loglive 32 * @copyright 2014 onwards Ankit agarwal <ankit.agrr@gmail.com> 33 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later. 34 */ 35 class lib_test extends \advanced_testcase { 36 37 /** 38 * Test report_log_supports_logstore. 39 */ 40 public function test_report_participation_supports_logstore() { 41 $logmanager = get_log_manager(); 42 $allstores = \core_component::get_plugin_list_with_class('logstore', 'log\store'); 43 44 $supportedstores = array( 45 'logstore_database' => '\logstore_legacy\log\database', 46 'logstore_legacy' => '\logstore_legacy\log\store', 47 'logstore_standard' => '\logstore_standard\log\store' 48 ); 49 50 // Make sure all supported stores are installed. 51 $expectedstores = array_keys(array_intersect($allstores, $supportedstores)); 52 $stores = $logmanager->get_supported_logstores('report_loglive'); 53 $stores = array_keys($stores); 54 foreach ($expectedstores as $expectedstore) { 55 $this->assertContains($expectedstore, $stores); 56 } 57 } 58 59 /** 60 * Test the latest record timestamp of the report data set. 61 * 62 * @covers ::get_until() 63 */ 64 public function test_report_get_until() { 65 global $DB; 66 $this->resetAfterTest(); 67 $this->preventResetByRollback(); 68 $now = time(); 69 70 // Configure log store. 71 set_config('enabled_stores', 'logstore_standard', 'tool_log'); 72 $manager = get_log_manager(); 73 $stores = $manager->get_readers(); 74 $store = $stores['logstore_standard']; 75 $DB->delete_records('logstore_standard_log'); 76 77 // Build the report. 78 $url = new \moodle_url("/report/loglive/index.php"); 79 $renderable = new \report_loglive_renderable('logstore_standard', 0, $url); 80 $table = $renderable->get_table(); 81 $table->query_db(100); 82 $until = $table->get_until(); 83 84 // There is no record in the log table at this stage so until date is supposed to be equal to CUTOFF date. 85 $this->assertLessThanOrEqual(time() - \report_loglive_renderable::CUTOFF, $until); 86 87 // Create a user, store the event and re-build the report. 88 $this->getDataGenerator()->create_user(); 89 $store->flush(); 90 $table->query_db(100); 91 $until = $table->get_until(); 92 93 // Assert that until date reflects user creation event date (now). 94 $this->assertGreaterThanOrEqual($now, $until); 95 } 96 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body