Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
| Total | |
100.00% |
51 / 51 |
|
100.00% |
3 / 3 |
CRAP | |
100.00% |
1 / 1 |
| phpbb_log_add_test | |
100.00% |
51 / 51 |
|
100.00% |
3 / 3 |
3 | |
100.00% |
1 / 1 |
| getDataSet | |
100.00% |
1 / 1 |
|
100.00% |
1 / 1 |
1 | |||
| test_log_enabled | |
100.00% |
19 / 19 |
|
100.00% |
1 / 1 |
1 | |||
| test_log_add | |
100.00% |
31 / 31 |
|
100.00% |
1 / 1 |
1 | |||
| 1 | <?php |
| 2 | /** |
| 3 | * |
| 4 | * This file is part of the phpBB Forum Software package. |
| 5 | * |
| 6 | * @copyright (c) phpBB Limited <https://www.phpbb.com> |
| 7 | * @license GNU General Public License, version 2 (GPL-2.0) |
| 8 | * |
| 9 | * For full copyright and license information, please see |
| 10 | * the docs/CREDITS.txt file. |
| 11 | * |
| 12 | */ |
| 13 | |
| 14 | class phpbb_log_add_test extends phpbb_database_test_case |
| 15 | { |
| 16 | public function getDataSet() |
| 17 | { |
| 18 | return $this->createXMLDataSet(__DIR__ . '/fixtures/empty_log.xml'); |
| 19 | } |
| 20 | |
| 21 | public function test_log_enabled() |
| 22 | { |
| 23 | global $phpbb_root_path, $phpEx, $db, $phpbb_dispatcher; |
| 24 | |
| 25 | $db = $this->new_dbal(); |
| 26 | $phpbb_dispatcher = new phpbb_mock_event_dispatcher(); |
| 27 | $lang_loader = new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx); |
| 28 | $lang = new \phpbb\language\language($lang_loader); |
| 29 | $user = new \phpbb\user($lang, '\phpbb\datetime'); |
| 30 | $auth = $this->createMock('\phpbb\auth\auth'); |
| 31 | |
| 32 | $log = new \phpbb\log\log($db, $user, $auth, $phpbb_dispatcher, $phpbb_root_path, 'adm/', $phpEx, LOG_TABLE); |
| 33 | |
| 34 | $this->assertTrue($log->is_enabled(), 'Initialise failed'); |
| 35 | |
| 36 | $log->disable(); |
| 37 | $this->assertFalse($log->is_enabled(), 'Disable all failed'); |
| 38 | |
| 39 | $log->enable(); |
| 40 | $this->assertTrue($log->is_enabled(), 'Enable all failed'); |
| 41 | |
| 42 | $log->disable('admin'); |
| 43 | $this->assertFalse($log->is_enabled('admin'), 'Disable admin failed'); |
| 44 | $this->assertTrue($log->is_enabled('user'), 'User should be enabled, is disabled'); |
| 45 | $this->assertTrue($log->is_enabled(), 'Disable admin disabled all'); |
| 46 | |
| 47 | $log->enable('admin'); |
| 48 | $this->assertTrue($log->is_enabled('admin'), 'Enable admin failed'); |
| 49 | } |
| 50 | |
| 51 | public function test_log_add() |
| 52 | { |
| 53 | global $phpbb_root_path, $phpEx, $db, $phpbb_dispatcher; |
| 54 | |
| 55 | $db = $this->new_dbal(); |
| 56 | $phpbb_dispatcher = new phpbb_mock_event_dispatcher(); |
| 57 | $lang_loader = new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx); |
| 58 | $lang = new \phpbb\language\language($lang_loader); |
| 59 | $user = new \phpbb\user($lang, '\phpbb\datetime'); |
| 60 | $auth = $this->createMock('\phpbb\auth\auth'); |
| 61 | |
| 62 | $log = new \phpbb\log\log($db, $user, $auth, $phpbb_dispatcher, $phpbb_root_path, 'adm/', $phpEx, LOG_TABLE); |
| 63 | |
| 64 | $mode = 'critical'; |
| 65 | $user_id = ANONYMOUS; |
| 66 | $log_ip = 'user_ip'; |
| 67 | $log_time = time(); |
| 68 | $log_operation = 'LOG_OPERATION'; |
| 69 | |
| 70 | // Add an entry successful |
| 71 | $this->assertEquals(1, $log->add($mode, $user_id, $log_ip, $log_operation, $log_time)); |
| 72 | |
| 73 | // Disable logging for all types |
| 74 | $log->disable(); |
| 75 | $this->assertFalse($log->add($mode, $user_id, $log_ip, $log_operation, $log_time), 'Disable for all types failed'); |
| 76 | $log->enable(); |
| 77 | |
| 78 | // Disable logging for same type |
| 79 | $log->disable('critical'); |
| 80 | $this->assertFalse($log->add($mode, $user_id, $log_ip, $log_operation, $log_time), 'Disable for same type failed'); |
| 81 | $log->enable(); |
| 82 | |
| 83 | // Disable logging for different type |
| 84 | $log->disable('admin'); |
| 85 | $this->assertEquals(2, $log->add($mode, $user_id, $log_ip, $log_operation, $log_time), 'Disable for different types failed'); |
| 86 | $log->enable(); |
| 87 | |
| 88 | // Invalid mode specified |
| 89 | $this->assertFalse($log->add('mode_does_not_exist', $user_id, $log_ip, $log_operation, $log_time)); |
| 90 | |
| 91 | // null user and null ip given |
| 92 | $this->assertEquals(3, $log->add($mode, null, null, $log_operation, $log_time), 'Adding log with null user_id and null user_ip failed'); |
| 93 | $sql = 'SELECT user_id, log_ip FROM ' . LOG_TABLE . ' WHERE log_id = 3'; |
| 94 | $result = $db->sql_query($sql); |
| 95 | $row = $db->sql_fetchrow($result); |
| 96 | $db->sql_freeresult($result); |
| 97 | $this->assertEquals(ANONYMOUS, $row['user_id'], 'Adding log with null user_id failed'); |
| 98 | $this->assertEquals('', $row['log_ip'], 'Adding log with null user_ip failed'); |
| 99 | } |
| 100 | } |