Skip to content

Commit

Permalink
qa: adapt changes to CommonPluginManagerTrait
Browse files Browse the repository at this point in the history
Signed-off-by: Maximilian Bösing <[email protected]>
  • Loading branch information
boesing committed May 2, 2023
1 parent 9f7d6d7 commit 1ee6810
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 40 deletions.
50 changes: 21 additions & 29 deletions src/Test/CommonPluginManagerTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,34 +5,36 @@
namespace Laminas\ServiceManager\Test;

use Laminas\ServiceManager\AbstractPluginManager;
use Laminas\ServiceManager\AbstractSingleInstancePluginManager;
use Laminas\ServiceManager\Exception\InvalidServiceException;
use Laminas\ServiceManager\ServiceManager;
use ReflectionProperty;

use function method_exists;

/**
* Trait for testing plugin managers for v2-v3 compatibility
* Trait for testing plugin managers for compatibility
*
* To use this trait:
* * implement the `getPluginManager()` method to return your plugin manager
* * implement the `getV2InvalidPluginException()` method to return the class `validatePlugin()` throws under v2
* @psalm-import-type ServiceManagerConfiguration from ServiceManager
*/
trait CommonPluginManagerTrait
{
public function testInstanceOfMatches()
public function testInstanceOfMatches(): void
{
$manager = $this->getPluginManager();
$reflection = new ReflectionProperty($manager, 'instanceOf');
$this->assertEquals($this->getInstanceOf(), $reflection->getValue($manager), 'instanceOf does not match');
}

public function testRegisteringInvalidElementRaisesException()
public function testRegisteringInvalidElementRaisesException(): void
{
$this->expectException($this->getServiceNotFoundException());
$this->getPluginManager()->setService('test', $this);
}

public function testLoadingInvalidElementRaisesException()
public function testLoadingInvalidElementRaisesException(): void
{
$manager = $this->getPluginManager();
$manager->setInvokableClass('test', static::class);
Expand All @@ -42,55 +44,45 @@ public function testLoadingInvalidElementRaisesException()

/**
* @dataProvider aliasProvider
* @param string $alias
* @param string $expected
*/
public function testPluginAliasesResolve($alias, $expected)
public function testPluginAliasesResolve(string $alias, string $expected): void
{
$this->assertInstanceOf($expected, $this->getPluginManager()->get($alias), "Alias '$alias' does not resolve'");
}

/**
* @return array
* @return list<array{string,string}>
*/
public function aliasProvider()
public function aliasProvider(): array
{
$manager = $this->getPluginManager();
$reflection = new ReflectionProperty($manager, 'aliases');
$pluginContainer = (new ReflectionProperty(AbstractPluginManager::class, 'plugins'))
->getValue($manager);

$reflection = new ReflectionProperty($pluginContainer, 'aliases');
$data = [];
foreach ($reflection->getValue($manager) as $alias => $expected) {
foreach ($reflection->getValue($pluginContainer) as $alias => $expected) {
$data[] = [$alias, $expected];
}

return $data;
}

protected function getServiceNotFoundException(): string
{
$manager = $this->getPluginManager();
if (method_exists($manager, 'configure')) {
return InvalidServiceException::class;
}
return $this->getV2InvalidPluginException();
return InvalidServiceException::class;
}

/**
* Returns the plugin manager to test
*
* @return AbstractPluginManager
*/
abstract protected function getPluginManager();

/**
* Returns the FQCN of the exception thrown under v2 by `validatePlugin()`
*
* @return mixed
* @param ServiceManagerConfiguration $config
*/
abstract protected function getV2InvalidPluginException();
abstract protected function getPluginManager(array $config = []): AbstractSingleInstancePluginManager;

/**
* Returns the value the instanceOf property has been set to
*
* @return string
* @return class-string
*/
abstract protected function getInstanceOf();
abstract protected function getInstanceOf(): string;
}
13 changes: 2 additions & 11 deletions test/ExamplePluginManagerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,12 @@

namespace LaminasTest\ServiceManager;

use Laminas\ServiceManager\AbstractPluginManager;
use Laminas\ServiceManager\AbstractSingleInstancePluginManager;
use Laminas\ServiceManager\ServiceManager;
use Laminas\ServiceManager\Test\CommonPluginManagerTrait;
use LaminasTest\ServiceManager\TestAsset\InvokableObject;
use LaminasTest\ServiceManager\TestAsset\InvokableObjectPluginManager;
use PHPUnit\Framework\TestCase;
use RuntimeException;

/**
* Example test of using CommonPluginManagerTrait
Expand All @@ -21,19 +20,11 @@ final class ExamplePluginManagerTest extends TestCase
{
use CommonPluginManagerTrait;

/**
* @param ServiceManagerConfiguration $config
*/
protected function getPluginManager(array $config = []): AbstractPluginManager
protected function getPluginManager(array $config = []): AbstractSingleInstancePluginManager
{
return new InvokableObjectPluginManager(new ServiceManager());
}

protected function getV2InvalidPluginException(): string
{
return RuntimeException::class;
}

protected function getInstanceOf(): string
{
return InvokableObject::class;
Expand Down

0 comments on commit 1ee6810

Please sign in to comment.