-
Notifications
You must be signed in to change notification settings - Fork 1k
Expand file tree
/
Copy pathLogTest.php
More file actions
127 lines (92 loc) · 3.23 KB
/
LogTest.php
File metadata and controls
127 lines (92 loc) · 3.23 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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
<?php
namespace think\tests;
use InvalidArgumentException;
use Mockery as m;
use Mockery\MockInterface;
use org\bovigo\vfs\vfsStream;
use PHPUnit\Framework\TestCase;
use think\Log;
use think\log\ChannelSet;
class LogTest extends TestCase
{
use InteractsWithApp;
/** @var Log|MockInterface */
protected $log;
protected function tearDown(): void
{
m::close();
}
protected function setUp(): void
{
$this->prepareApp();
$this->log = new Log($this->app);
}
public function testGetConfig()
{
$config = [
'default' => 'file',
];
$this->config->shouldReceive('get')->with('log')->andReturn($config);
$this->assertEquals($config, $this->log->getConfig());
$this->expectException(InvalidArgumentException::class);
$this->log->getChannelConfig('foo');
}
public function testChannel()
{
$this->assertInstanceOf(ChannelSet::class, $this->log->channel(['file', 'mail']));
}
public function testLogManagerInstances()
{
$this->config->shouldReceive('get')->with("log.channels.single", null)->andReturn(['type' => 'file']);
$channel1 = $this->log->channel('single');
$channel2 = $this->log->channel('single');
$this->assertSame($channel1, $channel2);
}
public function testFileLog()
{
$root = vfsStream::setup();
$this->config->shouldReceive('get')->with("log.default", null)->andReturn('file');
$this->config->shouldReceive('get')->with("log.channels.file", null)
->andReturn(['type' => 'file', 'path' => $root->url()]);
$this->log->info('foo');
$this->assertEquals([['info', 'foo']], array_map(fn($log) => [$log->type, $log->message], $this->log->getLog()));
$this->log->clear();
$this->assertEmpty($this->log->getLog());
$this->log->error('foo');
$this->log->emergency('foo');
$this->log->alert('foo');
$this->log->critical('foo');
$this->log->warning('foo');
$this->log->notice('foo');
$this->log->debug('foo');
$this->log->sql('foo');
$this->log->custom('foo');
$this->assertEquals([
['error', 'foo'],
['emergency', 'foo'],
['alert', 'foo'],
['critical', 'foo'],
['warning', 'foo'],
['notice', 'foo'],
['debug', 'foo'],
['sql', 'foo'],
['custom', 'foo'],
], array_map(fn($log) => [$log->type, $log->message], $this->log->getLog()));
$this->log->write('foo');
$this->assertTrue($root->hasChildren());
$this->assertEmpty($this->log->getLog());
$this->log->close();
$this->log->info('foo');
$this->assertEmpty($this->log->getLog());
}
public function testSave()
{
$root = vfsStream::setup();
$this->config->shouldReceive('get')->with("log.default", null)->andReturn('file');
$this->config->shouldReceive('get')->with("log.channels.file", null)
->andReturn(['type' => 'file', 'path' => $root->url()]);
$this->log->info('foo');
$this->log->save();
$this->assertTrue($root->hasChildren());
}
}