<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\Framework\Logger\Test\Unit\Handler; use Magento\Framework\Filesystem\DriverInterface; use Magento\Framework\Logger\Handler\Exception; use Magento\Framework\Logger\Handler\System; use Monolog\Logger; use PHPUnit_Framework_MockObject_MockObject as Mock; class SystemTest extends \PHPUnit\Framework\TestCase { /** * @var System */ private $model; /** * @var DriverInterface|Mock */ private $filesystemMock; /** * @var Exception|Mock */ private $exceptionHandlerMock; /** * @inheritdoc */ protected function setUp() { $this->filesystemMock = $this->getMockBuilder(DriverInterface::class) ->getMockForAbstractClass(); $this->exceptionHandlerMock = $this->getMockBuilder(Exception::class) ->disableOriginalConstructor() ->getMock(); $this->model = new System( $this->filesystemMock, $this->exceptionHandlerMock ); } public function testWrite() { $this->filesystemMock->expects($this->once()) ->method('getParentDirectory'); $this->filesystemMock->expects($this->once()) ->method('isDirectory') ->willReturn('true'); $this->model->write($this->getRecord()); } public function testWriteException() { $record = $this->getRecord(); $record['context']['exception'] = new \Exception('Some exception'); $this->exceptionHandlerMock->expects($this->once()) ->method('handle') ->with($record); $this->filesystemMock->expects($this->never()) ->method('getParentDirectory'); $this->model->write($record); } /** * @param int $level * @param string $message * @param array $context * @return array */ private function getRecord($level = Logger::WARNING, $message = 'test', $context = []) { return [ 'message' => $message, 'context' => $context, 'level' => $level, 'level_name' => Logger::getLevelName($level), 'channel' => 'test', 'datetime' => \DateTime::createFromFormat('U.u', sprintf('%.6F', microtime(true))), 'extra' => [], ]; } }