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 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
|
<?php
declare(strict_types=1);
namespace DI\Test\UnitTest\Definition;
use DI\Definition\StringDefinition;
use DI\NotFoundException;
use PHPUnit\Framework\TestCase;
use Psr\Container\ContainerInterface;
use DI\DependencyException;
/**
* @covers \DI\Definition\StringDefinition
*/
#[\PHPUnit\Framework\Attributes\CoversClass(\DI\Definition\StringDefinition::class)]
class StringDefinitionTest extends TestCase
{
public function test_getters()
{
$definition = new StringDefinition('bar');
$definition->setName('foo');
$this->assertEquals('foo', $definition->getName());
$this->assertEquals('bar', $definition->getExpression());
}
/**
* @test
*/
#[\PHPUnit\Framework\Attributes\Test]
public function should_be_resolvable()
{
$this->markTestSkipped('Requires mnapoli/phpunit-easymock');
$container = $this->easyMock(ContainerInterface::class);
$definition = new StringDefinition('foo');
$this->assertTrue($definition->isResolvable($container));
}
/**
* @test
*/
#[\PHPUnit\Framework\Attributes\Test]
public function should_resolve_bare_strings()
{
$this->markTestSkipped('Requires mnapoli/phpunit-easymock');
$container = $this->easyMock(ContainerInterface::class);
$definition = new StringDefinition('bar');
$this->assertEquals('bar', $definition->resolve($container));
}
/**
* @test
*/
#[\PHPUnit\Framework\Attributes\Test]
public function should_resolve_references()
{
$this->markTestSkipped('Requires mnapoli/phpunit-easymock');
$container = $this->easyMock(ContainerInterface::class, [
'get' => 'bar',
]);
$definition = new StringDefinition('{test}');
$this->assertEquals('bar', $definition->resolve($container));
}
/**
* @test
*/
#[\PHPUnit\Framework\Attributes\Test]
public function should_resolve_multiple_references()
{
$this->markTestSkipped('Requires mnapoli/phpunit-easymock');
$container = $this->easySpy(ContainerInterface::class);
$container->expects($this->exactly(2))
->method('get')
->willReturnMap([
['tmp'],
['logs'],
])
->willReturnOnConsecutiveCalls('/private/tmp', 'myapp-logs');
$definition = new StringDefinition('{tmp}/{logs}/app.log');
$value = $definition->resolve($container);
$this->assertEquals('/private/tmp/myapp-logs/app.log', $value);
}
/**
* @test
*/
#[\PHPUnit\Framework\Attributes\Test]
public function should_throw_on_unknown_entry_name()
{
$this->markTestSkipped('Requires mnapoli/phpunit-easymock');
$this->expectException(DependencyException::class);
$this->expectExceptionMessage('Error while parsing string expression for entry \'foo\': No entry or class found for \'test\'');
$container = $this->easyMock(ContainerInterface::class, [
'get' => new NotFoundException("No entry or class found for 'test'"),
]);
$definition = new StringDefinition('{test}');
$definition->setName('foo');
$definition->resolve($container);
}
/**
* @test
*/
#[\PHPUnit\Framework\Attributes\Test]
public function should_cast_to_string()
{
$this->assertEquals('foo/{bar}', (string) new StringDefinition('foo/{bar}'));
}
}
|