|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Engelsystem\Test\Unit\Logger;
|
|
|
|
|
|
|
|
use Engelsystem\Helpers\Authenticator;
|
|
|
|
use Engelsystem\Logger\Logger;
|
|
|
|
use Engelsystem\Logger\UserAwareLogger;
|
|
|
|
use Engelsystem\Logger\LoggerServiceProvider;
|
|
|
|
use Engelsystem\Test\Unit\ServiceProviderTest;
|
|
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
|
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
|
|
|
|
class LoggerServiceProviderTest extends ServiceProviderTest
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @covers \Engelsystem\Logger\LoggerServiceProvider::register
|
|
|
|
*/
|
|
|
|
public function testRegister()
|
|
|
|
{
|
|
|
|
$serviceProvider = new LoggerServiceProvider($this->app);
|
|
|
|
$serviceProvider->register();
|
|
|
|
|
|
|
|
$this->assertInstanceOf(UserAwareLogger::class, $this->app->get('logger'));
|
|
|
|
$this->assertInstanceOf(UserAwareLogger::class, $this->app->get(LoggerInterface::class));
|
|
|
|
$this->assertInstanceOf(UserAwareLogger::class, $this->app->get(Logger::class));
|
|
|
|
$this->assertInstanceOf(UserAwareLogger::class, $this->app->get(UserAwareLogger::class));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \Engelsystem\Logger\LoggerServiceProvider::boot
|
|
|
|
*/
|
|
|
|
public function testBoot()
|
|
|
|
{
|
|
|
|
/** @var Authenticator|MockObject $auth */
|
|
|
|
$auth = $this->getMockBuilder(Authenticator::class)
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
/** @var UserAwareLogger|MockObject $log */
|
|
|
|
$log = $this->getMockBuilder(UserAwareLogger::class)
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
|
|
|
$this->app->instance(Authenticator::class, $auth);
|
|
|
|
$this->app->instance(UserAwareLogger::class, $log);
|
|
|
|
|
|
|
|
$log->expects($this->once())
|
|
|
|
->method('setAuth')
|
|
|
|
->with($auth);
|
|
|
|
|
|
|
|
$serviceProvider = new LoggerServiceProvider($this->app);
|
|
|
|
$serviceProvider->boot();
|
|
|
|
}
|
|
|
|
}
|