<?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/>.
/**
* Tests for report library functions.
*
* @package report_loglive
* @copyright 2014 onwards Ankit agarwal <ankit.agrr@gmail.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later.
*/
> namespace report_loglive;
defined('MOODLE_INTERNAL') || die();
/**
* Class report_loglive_lib_testcase
*
* @package report_loglive
* @copyright 2014 onwards Ankit agarwal <ankit.agrr@gmail.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later.
*/
< class report_loglive_lib_testcase extends advanced_testcase {
> class lib_test extends \advanced_testcase {
/**
* Test report_log_supports_logstore.
*/
public function test_report_participation_supports_logstore() {
$logmanager = get_log_manager();
$allstores = \core_component::get_plugin_list_with_class('logstore', 'log\store');
$supportedstores = array(
< 'logstore_database' => '\logstore_legacy\log\database',
< 'logstore_legacy' => '\logstore_legacy\log\store',
'logstore_standard' => '\logstore_standard\log\store'
);
// Make sure all supported stores are installed.
$expectedstores = array_keys(array_intersect($allstores, $supportedstores));
$stores = $logmanager->get_supported_logstores('report_loglive');
$stores = array_keys($stores);
foreach ($expectedstores as $expectedstore) {
$this->assertContains($expectedstore, $stores);
}
> }
}
>
}
> /**
> * Test the latest record timestamp of the report data set.
> *
> * @covers ::get_until()
> */
> public function test_report_get_until() {
> global $DB;
> $this->resetAfterTest();
> $this->preventResetByRollback();
> $now = time();
>
> // Configure log store.
> set_config('enabled_stores', 'logstore_standard', 'tool_log');
> $manager = get_log_manager();
> $stores = $manager->get_readers();
> $store = $stores['logstore_standard'];
> $DB->delete_records('logstore_standard_log');
>
> // Build the report.
> $url = new \moodle_url("/report/loglive/index.php");
> $renderable = new \report_loglive_renderable('logstore_standard', 0, $url);
> $table = $renderable->get_table();
> $table->query_db(100);
> $until = $table->get_until();
>
> // There is no record in the log table at this stage so until date is supposed to be equal to CUTOFF date.
> $this->assertLessThanOrEqual(time() - \report_loglive_renderable::CUTOFF, $until);
>
> // Create a user, store the event and re-build the report.
> $this->getDataGenerator()->create_user();
> $store->flush();
> $table->query_db(100);
> $until = $table->get_until();
>
> // Assert that until date reflects user creation event date (now).
> $this->assertGreaterThanOrEqual($now, $until);