Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
51 / 51
100.00% covered (success)
100.00%
3 / 3
CRAP
100.00% covered (success)
100.00%
1 / 1
phpbb_log_add_test
100.00% covered (success)
100.00%
51 / 51
100.00% covered (success)
100.00%
3 / 3
3
100.00% covered (success)
100.00%
1 / 1
 getDataSet
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 test_log_enabled
100.00% covered (success)
100.00%
19 / 19
100.00% covered (success)
100.00%
1 / 1
1
 test_log_add
100.00% covered (success)
100.00%
31 / 31
100.00% covered (success)
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
14class 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}