<?php
/**
 * Copyright © Magento, Inc. All rights reserved.
 * See COPYING.txt for license details.
 */
declare(strict_types=1);

namespace Magento\Developer\Test\Unit\Model\Logger\Handler;

use Magento\Config\Setup\ConfigOptionsList;
use Magento\Developer\Model\Logger\Handler\Syslog;
use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Framework\App\DeploymentConfig;
use Magento\Framework\Logger\Monolog;
use PHPUnit\Framework\TestCase;
use PHPUnit_Framework_MockObject_MockObject as Mock;

/**
 * @inheritdoc
 */
class SyslogTest extends TestCase
{
    /**
     * @var Syslog
     */
    private $model;

    /**
     * @var ScopeConfigInterface|Mock
     */
    private $scopeConfigMock;

    /**
     * @var DeploymentConfig|Mock
     */
    private $deploymentConfigMock;

    /**
     * @inheritdoc
     */
    protected function setUp()
    {
        $this->scopeConfigMock = $this->getMockForAbstractClass(ScopeConfigInterface::class);
        $this->deploymentConfigMock = $this->createMock(DeploymentConfig::class);

        $this->model = new Syslog(
            $this->scopeConfigMock,
            $this->deploymentConfigMock,
            'Magento'
        );
    }

    /**
     * @return void
     */
    public function testIsHandling(): void
    {
        $record = [
            'level' => Monolog::DEBUG,
        ];

        $this->scopeConfigMock
            ->expects($this->never())
            ->method('getValue');
        $this->deploymentConfigMock
            ->expects($this->once())
            ->method('isDbAvailable')
            ->willReturn(true);
        $this->deploymentConfigMock
            ->expects($this->once())
            ->method('get')
            ->with(ConfigOptionsList::CONFIG_PATH_SYSLOG_LOGGING)
            ->willReturn(1);

        $this->assertTrue(
            $this->model->isHandling($record)
        );
    }

    /**
     * @return void
     */
    public function testIsHandlingNotInstalled(): void
    {
        $record = [
            'level' => Monolog::DEBUG,
        ];

        $this->scopeConfigMock
            ->expects($this->never())
            ->method('getValue');
        $this->deploymentConfigMock
            ->expects($this->once())
            ->method('isDbAvailable')
            ->willReturn(false);

        $this->assertFalse(
            $this->model->isHandling($record)
        );
    }

    /**
     * @return void
     */
    public function testIsHandlingDisabled(): void
    {
        $record = [
            'level' => Monolog::DEBUG,
        ];

        $this->scopeConfigMock
            ->expects($this->never())
            ->method('getValue');
        $this->deploymentConfigMock
            ->expects($this->once())
            ->method('isDbAvailable')
            ->willReturn(true);
        $this->deploymentConfigMock
            ->expects($this->once())
            ->method('get')
            ->with(ConfigOptionsList::CONFIG_PATH_SYSLOG_LOGGING)
            ->willReturn(0);

        $this->assertFalse(
            $this->model->isHandling($record)
        );
    }
}