Skip to content
This repository has been archived by the owner on Feb 6, 2020. It is now read-only.

Commit

Permalink
Merge pull request zendframework/zendframework#2997 branch 'hotfix/ab…
Browse files Browse the repository at this point in the history
…stract-factories-instantiation'
  • Loading branch information
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/ServiceManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -591,7 +591,7 @@ public function canCreateFromAbstractFactory($cName, $rName)
foreach ($this->abstractFactories as $index => $abstractFactory) {
// Support string abstract factory class names
if (is_string($abstractFactory) && class_exists($abstractFactory, true)) {
$this->abstractFactory[$index] = $abstractFactory = new $abstractFactory();
$this->abstractFactories[$index] = $abstractFactory = new $abstractFactory();
}

if (
Expand Down
16 changes: 16 additions & 0 deletions test/ServiceManagerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@
use Zend\ServiceManager\ServiceManager;
use Zend\ServiceManager\Config;

use ZendTest\ServiceManager\TestAsset\FooCounterAbstractFactory;

class ServiceManagerTest extends \PHPUnit_Framework_TestCase
{

Expand Down Expand Up @@ -599,4 +601,18 @@ public function testCanonicalizeName()
$this->assertEquals(true, $this->serviceManager->has('foo/bar'));
$this->assertEquals(true, $this->serviceManager->has('foo bar'));
}

/**
* @covers Zend\ServiceManager\ServiceManager::canCreateFromAbstractFactory
*/
public function testWanCreateFromAbstractFactoryWillNotInstantiateAbstractFactoryOnce()
{
$count = FooCounterAbstractFactory::$instantiationCount;
$this->serviceManager->addAbstractFactory(__NAMESPACE__ . '\TestAsset\FooCounterAbstractFactory');

$this->serviceManager->canCreateFromAbstractFactory('foo', 'foo');
$this->serviceManager->canCreateFromAbstractFactory('foo', 'foo');

$this->assertSame($count + 1, FooCounterAbstractFactory::$instantiationCount);
}
}
51 changes: 51 additions & 0 deletions test/TestAsset/FooCounterAbstractFactory.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @package Zend_ServiceManager
*/

namespace ZendTest\ServiceManager\TestAsset;

use Zend\ServiceManager\AbstractFactoryInterface;
use Zend\ServiceManager\ServiceLocatorInterface;

/**
* Abstract factory that keeps track of the number of times it is instantiated
*/
class FooCounterAbstractFactory implements AbstractFactoryInterface
{
/**
* @var int
*/
public static $instantiationCount = 0;

/**
* Increments instantiation count
*/
public function __construct()
{
self::$instantiationCount += 1;
}

/**
* {@inheritDoc}
*/
public function canCreateServiceWithName(ServiceLocatorInterface $serviceLocator, $name, $requestedName)
{
if ($name == 'foo') {
return true;
}
}

/**
* {@inheritDoc}
*/
public function createServiceWithName(ServiceLocatorInterface $serviceLocator, $name, $requestedName)
{
return new Foo;
}
}

0 comments on commit 2fcaf1c

Please sign in to comment.