summaryrefslogtreecommitdiff
path: root/tests/Unit/Logger/LoggerServiceProviderTest.php
blob: 5143d236fe3da722db81deb485fd9db7b439be20 (plain)
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
<?php

namespace Engelsystem\Test\Logger;

use Engelsystem\Application;
use Engelsystem\Logger\EngelsystemLogger;
use Engelsystem\Logger\LoggerServiceProvider;
use PHPUnit\Framework\TestCase;
use PHPUnit_Framework_MockObject_MockObject;
use Psr\Log\LoggerInterface;

class LoggerServiceProviderTest extends TestCase
{
    /**
     * @covers \Engelsystem\Logger\LoggerServiceProvider::register()
     */
    public function testRegister()
    {
        /** @var PHPUnit_Framework_MockObject_MockObject|EngelsystemLogger $logger */
        $logger = $this->getMockBuilder(EngelsystemLogger::class)
            ->getMock();

        /** @var PHPUnit_Framework_MockObject_MockObject|Application $app */
        $app = $this->getMockBuilder(Application::class)
            ->setMethods(['make', 'instance', 'bind'])
            ->getMock();

        $app->expects($this->once())
            ->method('make')
            ->with(EngelsystemLogger::class)
            ->willReturn($logger);

        $app->expects($this->once())
            ->method('instance')
            ->with('logger', $logger);

        $app->expects($this->atLeastOnce())
            ->method('bind')
            ->withConsecutive(
                [LoggerInterface::class, 'logger'],
                [EngelsystemLogger::class, 'logger']
            );

        $serviceProvider = new LoggerServiceProvider($app);
        $serviceProvider->register();
    }
}