Proyectos de Subversion Moodle

Rev

Rev 1 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 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
     */
11 efrain 40
    public function test_report_participation_supports_logstore(): void {
1 efrain 41
        $logmanager = get_log_manager();
42
        $allstores = \core_component::get_plugin_list_with_class('logstore', 'log\store');
43
 
44
        $supportedstores = array(
45
            'logstore_standard' => '\logstore_standard\log\store'
46
        );
47
 
48
        // Make sure all supported stores are installed.
49
        $expectedstores = array_keys(array_intersect($allstores, $supportedstores));
50
        $stores = $logmanager->get_supported_logstores('report_loglive');
51
        $stores = array_keys($stores);
52
        foreach ($expectedstores as $expectedstore) {
53
            $this->assertContains($expectedstore, $stores);
54
        }
55
    }
56
 
57
    /**
58
     * Test the latest record timestamp of the report data set.
59
     *
60
     * @covers ::get_until()
61
     */
11 efrain 62
    public function test_report_get_until(): void {
1 efrain 63
        global $DB;
64
        $this->resetAfterTest();
65
        $this->preventResetByRollback();
66
        $now = time();
67
 
68
        // Configure log store.
69
        set_config('enabled_stores', 'logstore_standard', 'tool_log');
70
        $manager = get_log_manager();
71
        $stores = $manager->get_readers();
72
        $store = $stores['logstore_standard'];
73
        $DB->delete_records('logstore_standard_log');
74
 
75
        // Build the report.
76
        $url = new \moodle_url("/report/loglive/index.php");
77
        $renderable = new \report_loglive_renderable('logstore_standard', 0, $url);
78
        $table = $renderable->get_table();
79
        $table->query_db(100);
80
        $until = $table->get_until();
81
 
82
        // There is no record in the log table at this stage so until date is supposed to be equal to CUTOFF date.
83
        $this->assertLessThanOrEqual(time() - \report_loglive_renderable::CUTOFF, $until);
84
 
85
        // Create a user, store the event and re-build the report.
86
        $this->getDataGenerator()->create_user();
87
        $store->flush();
88
        $table->query_db(100);
89
        $until = $table->get_until();
90
 
91
        // Assert that until date reflects user creation event date (now).
92
        $this->assertGreaterThanOrEqual($now, $until);
93
    }
94
}