forked from codeigniter4/CodeIgniter4
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLogsTest.php
More file actions
71 lines (58 loc) · 1.91 KB
/
LogsTest.php
File metadata and controls
71 lines (58 loc) · 1.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?php
declare(strict_types=1);
/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <[email protected]>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
namespace CodeIgniter\Debug\Toolbar\Collectors;
use CodeIgniter\Log\Logger;
use CodeIgniter\Test\CIUnitTestCase;
use Config\Logger as LoggerConfig;
use Config\Services;
use PHPUnit\Framework\Attributes\Group;
/**
* @internal
*/
#[Group('Others')]
final class LogsTest extends CIUnitTestCase
{
private Logger $logger;
protected function setUp(): void
{
parent::setUp();
// The logs collector relies on the logger being in debug mode
// so it would populate logCache.
$this->logger = new Logger(new LoggerConfig(), debug: true);
Services::injectMock('logger', $this->logger);
}
public function testDisplay(): void
{
// log_message() always creates a new TestLogger instance while
// testing, so we need to log directly to our instance.
$this->logger->error('Test error');
$this->logger->info('Test info');
$collector = new Logs();
$result = $collector->display();
$this->assertArrayHasKey('logs', $result);
$this->assertCount(2, $result['logs']);
$this->assertSame('error', $result['logs'][0]['level']);
$this->assertSame('Test error', $result['logs'][0]['msg']);
$this->assertSame('info', $result['logs'][1]['level']);
$this->assertSame('Test info', $result['logs'][1]['msg']);
}
public function testEmpty(): void
{
$collector = new Logs();
$this->assertTrue($collector->isEmpty());
}
public function testNotEmpty(): void
{
$this->logger->warning('Test warning');
$collector = new Logs();
$this->assertFalse($collector->isEmpty());
}
}