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
|
<?php
namespace Asko\Loggr\Tests;
use DateTime;
use Asko\Loggr\Drivers\FileSystemDriver;
use Asko\Loggr\Loggr;
use Mockery;
use Mockery\Adapter\Phpunit\MockeryTestCase;
class FileSystemDriverTest extends MockeryTestCase
{
public function testEmergency(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->emergency('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.EMERGENCY: test", $data);
}
public function testAlert(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->alert('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.ALERT: test", $data);
}
public function testCritical(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->critical('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.CRITICAL: test", $data);
}
public function testError(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->error('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.ERROR: test", $data);
}
public function testWarning(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->warning('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.WARNING: test", $data);
}
public function testNotice(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->notice('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.NOTICE: test", $data);
}
public function testInfo(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->info('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.INFO: test", $data);
}
public function testDebug(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->debug('test');
$full_date = (new DateTime)->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.DEBUG: test", $data);
}
public function testMultipleEntries(): void
{
$data = '';
$logger = $this->mockLogger($data);
$logger->emergency('test1');
$logger->alert('test2');
$logger->critical('test3');
$logger->error('test4');
$logger->warning('test5');
$logger->notice('test6');
$logger->info('test7');
$logger->debug('test8');
$lines = array_filter(explode("\n", $data), fn($line) => !empty($line));
$this->assertCount(8, $lines);
$first_line = $lines[0];
$last_line = $lines[count($lines) - 1];
$full_date = (new DateTime())->format('Y-m-d H:i:s');
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.EMERGENCY: test", $first_line);
$this->assertStringContainsString("[$full_date] FileSystemDriverTest.DEBUG: test", $last_line);
}
private function mockLogger(string &$result): Loggr
{
$driver = Mockery::mock(FileSystemDriver::class, ['/tmp'])->makePartial();
$driver->shouldReceive('log')->passthru();
$driver->shouldReceive('createLogFileIfNotExist')->andReturn(true);
$driver->shouldReceive('write')->withArgs(function (string $path, string $data) use (&$result) {
$result .= $data;
return true;
});
return new Loggr($driver);
}
protected function tearDown(): void
{
Mockery::close();
}
}
|