123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- <?php
- namespace think\tests;
- use InvalidArgumentException;
- use Mockery as m;
- use Mockery\MockInterface;
- use org\bovigo\vfs\vfsStream;
- use PHPUnit\Framework\TestCase;
- use think\App;
- use think\Config;
- use think\Container;
- use think\Log;
- use think\log\ChannelSet;
- class LogTest extends TestCase
- {
- /** @var App|MockInterface */
- protected $app;
- /** @var Log|MockInterface */
- protected $log;
- /** @var Config|MockInterface */
- protected $config;
- protected function tearDown(): void
- {
- m::close();
- }
- protected function setUp()
- {
- $this->app = m::mock(App::class)->makePartial();
- Container::setInstance($this->app);
- $this->app->shouldReceive('make')->with(App::class)->andReturn($this->app);
- $this->config = m::mock(Config::class)->makePartial();
- $this->app->shouldReceive('get')->with('config')->andReturn($this->config);
- $this->app->shouldReceive('runningInConsole')->andReturn(false);
- $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($this->log->getLog(), ['info' => ['foo']]);
- $this->log->clear();
- $this->assertEmpty($this->log->getLog());
- $this->log->error('foo');
- $this->assertArrayHasKey('error', $this->log->getLog());
- $this->log->emergency('foo');
- $this->assertArrayHasKey('emergency', $this->log->getLog());
- $this->log->alert('foo');
- $this->assertArrayHasKey('alert', $this->log->getLog());
- $this->log->critical('foo');
- $this->assertArrayHasKey('critical', $this->log->getLog());
- $this->log->warning('foo');
- $this->assertArrayHasKey('warning', $this->log->getLog());
- $this->log->notice('foo');
- $this->assertArrayHasKey('notice', $this->log->getLog());
- $this->log->debug('foo');
- $this->assertArrayHasKey('debug', $this->log->getLog());
- $this->log->sql('foo');
- $this->assertArrayHasKey('sql', $this->log->getLog());
- $this->log->custom('foo');
- $this->assertArrayHasKey('custom', $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());
- }
- }
|