Linux aries.aptans.com 4.18.0-348.20.1.lve.1.el8.x86_64 #1 SMP Wed Mar 16 08:45:39 EDT 2022 x86_64
Apache
: 135.181.142.107 | : 172.70.127.69
Cant Read [ /etc/named.conf ]
7.4.33
aja
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
README
+ Create Folder
+ Create File
/
home /
aja /
public_html /
ead.aptans /
lib /
tests /
[ HOME SHELL ]
Name
Size
Permission
Action
analytics
[ DIR ]
drwxr-xr-x
behat
[ DIR ]
drwxr-xr-x
content
[ DIR ]
drwxr-xr-x
event
[ DIR ]
drwxr-xr-x
external
[ DIR ]
drwxr-xr-x
fixtures
[ DIR ]
drwxr-xr-x
other
[ DIR ]
drwxr-xr-x
output
[ DIR ]
drwxr-xr-x
performance
[ DIR ]
drwxr-xr-x
plugininfo
[ DIR ]
drwxr-xr-x
accesslib_has_capability_test....
29.73
KB
-rw-rw-r--
accesslib_test.php
219.29
KB
-rw-rw-r--
adhoc_task_test.php
18.44
KB
-rw-rw-r--
adminlib_test.php
4.38
KB
-rw-rw-r--
admintree_test.php
17.32
KB
-rw-r--r--
ajaxlib_test.php
4.36
KB
-rw-rw-r--
analysers_test.php
12.95
KB
-rw-r--r--
antivirus_test.php
8.69
KB
-rw-rw-r--
authlib_test.php
19.91
KB
-rw-r--r--
blocklib_test.php
35.27
KB
-rw-rw-r--
calendar_cron_task_test.php
2.69
KB
-rw-rw-r--
check_test.php
1.97
KB
-rw-r--r--
client_test.php
4.34
KB
-rw-r--r--
collator_test.php
11.99
KB
-rw-r--r--
completion_daily_task_test.php
5.24
KB
-rw-r--r--
completionlib_test.php
62.1
KB
-rw-rw-r--
component_test.php
40.17
KB
-rw-rw-r--
componentlib_test.php
6.64
KB
-rw-r--r--
configonlylib_test.php
6.15
KB
-rw-r--r--
content_test.php
4.77
KB
-rw-r--r--
core_media_player_native_test....
6.54
KB
-rw-r--r--
core_renderer_template_exploit...
17.28
KB
-rw-r--r--
coverage.php
1.93
KB
-rw-rw-r--
cronlib_test.php
6.89
KB
-rw-r--r--
csslib_test.php
1.79
KB
-rw-r--r--
csvclass_test.php
5.57
KB
-rw-r--r--
curl_security_helper_test.php
14.71
KB
-rw-r--r--
customcontext_test.php
3.79
KB
-rw-r--r--
dataformat_test.php
3.74
KB
-rw-r--r--
datalib_test.php
47.8
KB
-rw-r--r--
datalib_update_with_unique_ind...
6.31
KB
-rw-r--r--
date_legacy_test.php
13.9
KB
-rw-r--r--
date_test.php
24.48
KB
-rw-rw-r--
editorlib_test.php
2.01
KB
-rw-r--r--
encryption_test.php
8.68
KB
-rw-r--r--
environment_test.php
8.54
KB
-rw-r--r--
event_context_locked_test.php
4.11
KB
-rw-r--r--
event_course_module_instance_l...
2.7
KB
-rw-r--r--
event_course_module_viewed.php
3.33
KB
-rw-r--r--
event_deprecated_test.php
1.49
KB
-rw-r--r--
event_grade_deleted_test.php
3.25
KB
-rw-r--r--
event_profile_field_test.php
12.44
KB
-rw-r--r--
event_unknown_logged_test.php
1.92
KB
-rw-r--r--
event_user_graded_test.php
10.07
KB
-rw-r--r--
event_user_password_updated_te...
2.89
KB
-rw-r--r--
exporter_test.php
11.02
KB
-rw-r--r--
externallib_test.php
29.7
KB
-rw-r--r--
filelib_test.php
70.92
KB
-rw-rw-r--
filestorage_zip_archive_test.p...
2.75
KB
-rw-r--r--
filetypes_test.php
10.2
KB
-rw-r--r--
filter_manager_test.php
3.48
KB
-rw-r--r--
filterlib_test.php
36.72
KB
-rw-r--r--
formslib_test.php
39.6
KB
-rw-r--r--
gdlib_test.php
5.92
KB
-rw-r--r--
googlelib_test.php
1.54
KB
-rw-r--r--
gradelib_test.php
9.74
KB
-rw-r--r--
grades_externallib_test.php
24.66
KB
-rw-rw-r--
grading_externallib_test.php
26.27
KB
-rw-r--r--
grouplib_test.php
84.23
KB
-rw-rw-r--
h5p_clean_orphaned_records_tas...
3.12
KB
-rw-r--r--
h5p_get_content_types_task_tes...
2.69
KB
-rw-r--r--
html2text_test.php
7.58
KB
-rw-r--r--
html_writer_test.php
8.74
KB
-rw-rw-r--
htmlpurifier_test.php
22.67
KB
-rw-r--r--
ip_utils_test.php
14.27
KB
-rw-r--r--
jquery_test.php
1.76
KB
-rw-r--r--
ldaplib_test.php
17.72
KB
-rw-r--r--
licenselib_test.php
11.58
KB
-rw-r--r--
lock_config_test.php
3.39
KB
-rw-r--r--
lock_test.php
5.5
KB
-rw-r--r--
markdown_test.php
2.45
KB
-rw-r--r--
mathslib_test.php
11.12
KB
-rw-r--r--
medialib_test.php
20.19
KB
-rw-rw-r--
message_test.php
12.46
KB
-rw-rw-r--
messageinbound_test.php
5.89
KB
-rw-r--r--
messagelib_test.php
56.39
KB
-rw-rw-r--
minify_test.php
3.14
KB
-rw-r--r--
modinfolib_test.php
44.15
KB
-rw-rw-r--
moodle_page_test.php
29.58
KB
-rw-rw-r--
moodle_url_test.php
12.85
KB
-rw-r--r--
moodlelib_test.php
216.85
KB
-rw-rw-r--
mustache_template_finder_test....
7.4
KB
-rw-r--r--
mustache_template_source_loade...
18.06
KB
-rw-r--r--
myprofilelib_test.php
10.44
KB
-rw-r--r--
navigationlib_test.php
26.28
KB
-rw-rw-r--
notification_test.php
4.61
KB
-rw-r--r--
oauth2_test.php
17.57
KB
-rw-r--r--
output_mustache_helper_collect...
8.09
KB
-rw-r--r--
outputcomponents_test.php
29.67
KB
-rw-r--r--
outputfactories_test.php
6.8
KB
-rw-r--r--
outputrequirementslib_test.php
5.38
KB
-rw-r--r--
pdflib_test.php
1.51
KB
-rw-r--r--
persistent_test.php
19.95
KB
-rw-rw-r--
plugin_manager_test.php
27.39
KB
-rw-r--r--
portfoliolib_test.php
8.4
KB
-rw-r--r--
progress_display_test.php
3.75
KB
-rw-r--r--
progress_test.php
14.48
KB
-rw-r--r--
qrcode_test.php
1.88
KB
-rw-r--r--
questionlib_test.php
96.9
KB
-rw-rw-r--
regex_test.php
1.88
KB
-rw-r--r--
report_helper_test.php
3.68
KB
-rw-rw-r--
requirejs_test.php
3.73
KB
-rw-r--r--
rsslib_test.php
6.9
KB
-rw-r--r--
rtlcss_test.php
56.86
KB
-rw-r--r--
sample_questions.ser
141.76
KB
-rw-r--r--
sample_questions.xml
102.62
KB
-rw-r--r--
sample_questions_with_old_imag...
4.85
KB
-rw-r--r--
sample_questions_with_old_imag...
4.08
KB
-rw-r--r--
sample_questions_wrong.xml
102.57
KB
-rw-r--r--
scheduled_task_test.php
29.98
KB
-rw-rw-r--
scss_test.php
4.26
KB
-rw-r--r--
session_manager_test.php
33.96
KB
-rw-r--r--
session_redis_test.php
13.27
KB
-rw-r--r--
sessionlib_test.php
11.86
KB
-rw-r--r--
setuplib_test.php
19.63
KB
-rw-r--r--
statslib_test.php
26.75
KB
-rw-r--r--
string_manager_standard_test.p...
10.05
KB
-rw-rw-r--
tablelib_test.php
23.53
KB
-rw-r--r--
task_database_logger_test.php
20.15
KB
-rw-r--r--
task_logging_test.php
17.31
KB
-rw-r--r--
task_manager_test.php
11.2
KB
-rw-r--r--
task_running_test.php
6.58
KB
-rw-r--r--
text_test.php
21.09
KB
-rw-rw-r--
theme_config_test.php
9.81
KB
-rw-rw-r--
time_splittings_test.php
15.09
KB
-rw-r--r--
update_api_test.php
6.75
KB
-rw-r--r--
update_checker_test.php
10.86
KB
-rw-r--r--
update_code_manager_test.php
9.06
KB
-rw-r--r--
update_validator_test.php
18.44
KB
-rw-r--r--
upgrade_util_test.php
5.65
KB
-rw-r--r--
upgradelib_test.php
69.1
KB
-rw-rw-r--
user_menu_test.php
3.82
KB
-rw-rw-r--
user_test.php
32.36
KB
-rw-rw-r--
useragent_test.php
83.88
KB
-rw-rw-r--
weblib_format_text_test.php
12.11
KB
-rw-r--r--
weblib_test.php
35.1
KB
-rw-rw-r--
xhprof_test.php
3.32
KB
-rw-r--r--
xhtml_container_stack_test.php
4.16
KB
-rw-r--r--
xmlize_test.php
2.72
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : task_database_logger_test.php
<?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/>. /** * This file contains the unit tests for the database task logger. * * @package core * @category phpunit * @copyright 2018 Andrew Nicols <andrew@nicols.co.uk> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); use \core\task\database_logger; /** * This file contains the unit tests for the database task logger. * * @copyright 2018 Andrew Nicols <andrew@nicols.co.uk> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class task_database_logger_testcase extends advanced_testcase { /** * @var \moodle_database The original database prior to mocking */ protected $DB; /** * Setup to backup the database before mocking. */ public function setUp(): void { global $DB; $this->DB = $DB; } /** * Tear down to unmock the database where it was mocked. */ public function tearDown(): void { global $DB; $DB = $this->DB; $this->DB = null; } /** * Ensure that store_log_for_task works with a passing scheduled task. */ public function test_store_log_for_task_scheduled() { global $DB; $this->resetAfterTest(); $endtime = microtime(true); $starttime = $endtime - 4; $logdir = make_request_directory(); $logpath = "{$logdir}/log.txt"; file_put_contents($logpath, 'Example content'); $task = new \core\task\cache_cron_task(); database_logger::store_log_for_task($task, $logpath, false, 1, 2, $starttime, $endtime); $logs = $DB->get_records('task_log'); $this->assertCount(1, $logs); $log = reset($logs); $this->assertEquals(file_get_contents($logpath), $log->output); $this->assertEquals(0, $log->result); $this->assertEquals(database_logger::TYPE_SCHEDULED, $log->type); $this->assertEquals('core\task\cache_cron_task', $log->classname); $this->assertEquals(0, $log->userid); } /** * Ensure that store_log_for_task works with a passing adhoc task. */ public function test_store_log_for_task_adhoc() { global $DB; $this->resetAfterTest(); $endtime = microtime(true); $starttime = $endtime - 4; $logdir = make_request_directory(); $logpath = "{$logdir}/log.txt"; file_put_contents($logpath, 'Example content'); $task = $this->getMockBuilder(\core\task\adhoc_task::class) ->onlyMethods(['get_component', 'execute']) ->getMock(); $task->method('get_component')->willReturn('core_test'); database_logger::store_log_for_task($task, $logpath, false, 1, 2, $starttime, $endtime); $logs = $DB->get_records('task_log'); $this->assertCount(1, $logs); $log = reset($logs); $this->assertEquals(file_get_contents($logpath), $log->output); $this->assertEquals(0, $log->result); $this->assertEquals(database_logger::TYPE_ADHOC, $log->type); } /** * Ensure that store_log_for_task works with a failing scheduled task. */ public function test_store_log_for_task_failed_scheduled() { global $DB; $this->resetAfterTest(); $endtime = microtime(true); $starttime = $endtime - 4; $logdir = make_request_directory(); $logpath = "{$logdir}/log.txt"; file_put_contents($logpath, 'Example content'); $task = new \core\task\cache_cron_task(); database_logger::store_log_for_task($task, $logpath, true, 1, 2, $starttime, $endtime); $logs = $DB->get_records('task_log'); $this->assertCount(1, $logs); $log = reset($logs); $this->assertEquals(file_get_contents($logpath), $log->output); $this->assertEquals(1, $log->result); $this->assertEquals(database_logger::TYPE_SCHEDULED, $log->type); $this->assertEquals('core\task\cache_cron_task', $log->classname); $this->assertEquals(0, $log->userid); } /** * Ensure that store_log_for_task works with a failing adhoc task. */ public function test_store_log_for_task_failed_adhoc() { global $DB; $this->resetAfterTest(); $endtime = microtime(true); $starttime = $endtime - 4; $logdir = make_request_directory(); $logpath = "{$logdir}/log.txt"; file_put_contents($logpath, 'Example content'); $task = $this->getMockBuilder(\core\task\adhoc_task::class) ->onlyMethods(['get_component', 'execute']) ->getMock(); $task->method('get_component')->willReturn('core_test'); database_logger::store_log_for_task($task, $logpath, true, 1, 2, $starttime, $endtime); $logs = $DB->get_records('task_log'); $this->assertCount(1, $logs); $log = reset($logs); $this->assertEquals(file_get_contents($logpath), $log->output); $this->assertEquals(1, $log->result); $this->assertEquals(database_logger::TYPE_ADHOC, $log->type); $this->assertEquals(0, $log->userid); } /** * Ensure that store_log_for_task works with a passing adhoc task run as a specific user. */ public function test_store_log_for_task_adhoc_userid() { global $DB; $this->resetAfterTest(); $endtime = microtime(true); $starttime = $endtime - 4; $logdir = make_request_directory(); $logpath = "{$logdir}/log.txt"; file_put_contents($logpath, 'Example content'); $task = $this->getMockBuilder(\core\task\adhoc_task::class) ->onlyMethods(['get_component', 'execute', 'get_userid']) ->getMock(); $task->method('get_component')->willReturn('core_test'); $task->method('get_userid')->willReturn(99); database_logger::store_log_for_task($task, $logpath, false, 1, 2, $starttime, $endtime); $logs = $DB->get_records('task_log'); $this->assertCount(1, $logs); $log = reset($logs); $this->assertEquals(file_get_contents($logpath), $log->output); $this->assertEquals(0, $log->result); $this->assertEquals(database_logger::TYPE_ADHOC, $log->type); $this->assertEquals(99, $log->userid); } /** * Ensure that the delete_task_logs function performs necessary deletion tasks. * * @dataProvider delete_task_logs_provider * @param mixed $ids */ public function test_delete_task_logs($ids) { $DB = $this->mock_database(); $DB->expects($this->once()) ->method('delete_records_list') ->with( $this->equalTo('task_log'), $this->equalTo('id'), $this->callback(function($deletedids) use ($ids) { sort($ids); $idvalues = array_values($deletedids); sort($idvalues); return $ids == $idvalues; }) ); database_logger::delete_task_logs($ids); } /** * Data provider for delete_task_logs tests. * * @return array */ public function delete_task_logs_provider() : array { return [ [ [0], [1], [1, 2, 3, 4, 5], ], ]; } /** * Ensure that the retention period applies correctly. */ public function test_cleanup_retention() { global $DB; $this->resetAfterTest(); // Set a high value for task_logretainruns so that it does no interfere. set_config('task_logretainruns', 1000); // Create sample log data - 1 run per hour for 3 days - round down to the start of the hour to avoid time race conditions. $date = new DateTime(); $date->setTime($date->format('G'), 0); $baselogtime = $date->getTimestamp(); for ($i = 0; $i < 3 * 24; $i++) { $task = new \core\task\cache_cron_task(); $logpath = __FILE__; database_logger::store_log_for_task($task, $logpath, false, 1, 2, $date->getTimestamp(), $date->getTimestamp() + MINSECS); $date->sub(new \DateInterval('PT1H')); } // Initially there should be 72 runs. $this->assertCount(72, $DB->get_records('task_log')); // Note: We set the retention time to a period like DAYSECS minus an adjustment. // The adjustment is to account for the time taken during setup. // With a retention period of 2 * DAYSECS, there should only be 47-48 left. set_config('task_logretention', (2 * DAYSECS) - (time() - $baselogtime)); \core\task\database_logger::cleanup(); $this->assertGreaterThanOrEqual(47, $DB->count_records('task_log')); $this->assertLessThanOrEqual(48, $DB->count_records('task_log')); // The oldest should be no more than 48 hours old. $oldest = $DB->get_records('task_log', [], 'timestart DESC', 'timestart', 0, 1); $oldest = reset($oldest); $this->assertGreaterThan(time() - (48 * DAYSECS), $oldest->timestart); // With a retention period of DAYSECS, there should only be 23 left. set_config('task_logretention', DAYSECS - (time() - $baselogtime)); \core\task\database_logger::cleanup(); $this->assertGreaterThanOrEqual(23, $DB->count_records('task_log')); $this->assertLessThanOrEqual(24, $DB->count_records('task_log')); // The oldest should be no more than 24 hours old. $oldest = $DB->get_records('task_log', [], 'timestart DESC', 'timestart', 0, 1); $oldest = reset($oldest); $this->assertGreaterThan(time() - (24 * DAYSECS), $oldest->timestart); // With a retention period of 0.5 DAYSECS, there should only be 11 left. set_config('task_logretention', (DAYSECS / 2) - (time() - $baselogtime)); \core\task\database_logger::cleanup(); $this->assertGreaterThanOrEqual(11, $DB->count_records('task_log')); $this->assertLessThanOrEqual(12, $DB->count_records('task_log')); // The oldest should be no more than 12 hours old. $oldest = $DB->get_records('task_log', [], 'timestart DESC', 'timestart', 0, 1); $oldest = reset($oldest); $this->assertGreaterThan(time() - (12 * DAYSECS), $oldest->timestart); } /** * Ensure that the run-count retention applies. */ public function test_cleanup_retainruns() { global $DB; $this->resetAfterTest(); // Set a high value for task_logretention so that it does not interfere. set_config('task_logretention', YEARSECS); // Create sample log data - 2 tasks, once per hour for 3 days. $date = new DateTime(); $date->setTime($date->format('G'), 0); $firstdate = $date->getTimestamp(); for ($i = 0; $i < 3 * 24; $i++) { $task = new \core\task\cache_cron_task(); $logpath = __FILE__; database_logger::store_log_for_task($task, $logpath, false, 1, 2, $date->getTimestamp(), $date->getTimestamp() + MINSECS); $task = new \core\task\badges_cron_task(); $logpath = __FILE__; database_logger::store_log_for_task($task, $logpath, false, 1, 2, $date->getTimestamp(), $date->getTimestamp() + MINSECS); $date->sub(new \DateInterval('PT1H')); } $lastdate = $date->getTimestamp(); // Initially there should be 144 runs - 72 for each task. $this->assertEquals(144, $DB->count_records('task_log')); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // Grab the records for comparison. $cachecronrecords = array_values($DB->get_records('task_log', ['classname' => \core\task\cache_cron_task::class], 'timestart DESC')); $badgescronrecords = array_values($DB->get_records('task_log', ['classname' => \core\task\badges_cron_task::class], 'timestart DESC')); // Configured to retain 144 should have no effect. set_config('task_logretainruns', 144); \core\task\database_logger::cleanup(); $this->assertEquals(144, $DB->count_records('task_log')); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // The list of records should be identical. $this->assertEquals($cachecronrecords, array_values($DB->get_records('task_log', ['classname' => \core\task\cache_cron_task::class], 'timestart DESC'))); $this->assertEquals($badgescronrecords, array_values($DB->get_records('task_log', ['classname' => \core\task\badges_cron_task::class], 'timestart DESC'))); // Configured to retain 72 should have no effect either. set_config('task_logretainruns', 72); \core\task\database_logger::cleanup(); $this->assertEquals(144, $DB->count_records('task_log')); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // The list of records should now only contain the first 72 of each. $this->assertEquals( array_slice($cachecronrecords, 0, 72), array_values($DB->get_records('task_log', ['classname' => \core\task\cache_cron_task::class], 'timestart DESC')) ); $this->assertEquals( array_slice($badgescronrecords, 0, 72), array_values($DB->get_records('task_log', ['classname' => \core\task\badges_cron_task::class], 'timestart DESC')) ); // Configured to only retain 24 should bring that down to a total of 48, or 24 each. set_config('task_logretainruns', 24); \core\task\database_logger::cleanup(); $this->assertEquals(48, $DB->count_records('task_log')); $this->assertEquals(24, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(24, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // The list of records should now only contain the first 24 of each. $this->assertEquals( array_slice($cachecronrecords, 0, 24), array_values($DB->get_records('task_log', ['classname' => \core\task\cache_cron_task::class], 'timestart DESC')) ); $this->assertEquals( array_slice($badgescronrecords, 0, 24), array_values($DB->get_records('task_log', ['classname' => \core\task\badges_cron_task::class], 'timestart DESC')) ); // Configured to only retain 5 should bring that down to a total of 10, or 5 each. set_config('task_logretainruns', 5); \core\task\database_logger::cleanup(); $this->assertEquals(10, $DB->count_records('task_log')); $this->assertEquals(5, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(5, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // The list of records should now only contain the first 5 of each. $this->assertEquals( array_slice($cachecronrecords, 0, 5), array_values($DB->get_records('task_log', ['classname' => \core\task\cache_cron_task::class], 'timestart DESC')) ); $this->assertEquals( array_slice($badgescronrecords, 0, 5), array_values($DB->get_records('task_log', ['classname' => \core\task\badges_cron_task::class], 'timestart DESC')) ); // Configured to only retain 0 should bring that down to none. set_config('task_logretainruns', 0); \core\task\database_logger::cleanup(); $this->assertEquals(0, $DB->count_records('task_log')); } /** * Ensure that the retention period applies correctly when combined with the run count retention. */ public function test_cleanup_combined() { global $DB; $this->resetAfterTest(); // Calculate date to be used for logs, starting from current time rounded down to nearest hour. $date = new DateTime(); $date->setTime($date->format('G'), 0); $baselogtime = $date->getTimestamp(); // Create sample log data - 2 tasks, once per hour for 3 days. for ($i = 0; $i < 3 * 24; $i++) { $task = new \core\task\cache_cron_task(); $logpath = __FILE__; database_logger::store_log_for_task($task, $logpath, false, 1, 2, $date->getTimestamp(), $date->getTimestamp() + MINSECS); $task = new \core\task\badges_cron_task(); $logpath = __FILE__; database_logger::store_log_for_task($task, $logpath, false, 1, 2, $date->getTimestamp(), $date->getTimestamp() + MINSECS); $date->sub(new \DateInterval('PT1H')); } // Initially there should be 144 runs - 72 for each task. $this->assertEquals(144, $DB->count_records('task_log')); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(72, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // Note: We set the retention time to a period like DAYSECS minus an adjustment. // The adjustment is to account for the difference between current time and baselogtime. // With a retention period of 2 * DAYSECS, there should only be 96 left. // The run count is a higher number so it will have no effect. set_config('task_logretention', time() - ($baselogtime - (2 * DAYSECS)) - 1); set_config('task_logretainruns', 50); \core\task\database_logger::cleanup(); $this->assertEquals(96, $DB->count_records('task_log')); $this->assertEquals(48, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(48, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // We should retain the most recent 48 of each task, so the oldest will be 47 hours old. $oldest = $DB->get_records('task_log', [], 'timestart ASC', 'timestart', 0, 1); $oldest = reset($oldest); $this->assertEquals($baselogtime - (47 * HOURSECS), $oldest->timestart); // Reducing the retain runs count to 10 should reduce the total logs to 20, overriding the time constraint. set_config('task_logretainruns', 10); \core\task\database_logger::cleanup(); $this->assertEquals(20, $DB->count_records('task_log')); $this->assertEquals(10, $DB->count_records('task_log', ['classname' => \core\task\cache_cron_task::class])); $this->assertEquals(10, $DB->count_records('task_log', ['classname' => \core\task\badges_cron_task::class])); // We should retain the most recent 10 of each task, so the oldest will be 9 hours old. $oldest = $DB->get_records('task_log', [], 'timestart ASC', 'timestart', 0, 1); $oldest = reset($oldest); $this->assertEquals($baselogtime - (9 * HOURSECS), $oldest->timestart); } /** * Mock the database. */ protected function mock_database() { global $DB; $DB = $this->getMockBuilder(\moodle_database::class) ->getMock(); $DB->method('get_record') ->willReturn((object) []); return $DB; } }
Close