merge conflicts

This commit is contained in:
knuch 2018-12-08 11:49:49 +00:00
parent aca0b84637
commit ceb7a68efa
2 changed files with 23 additions and 8 deletions

View File

@ -94,39 +94,40 @@ class ServiceLocator implements PsrContainerInterface
$class = isset($class[2]['object']) ? \get_class($class[2]['object']) : null; $class = isset($class[2]['object']) ? \get_class($class[2]['object']) : null;
$externalId = $this->externalId ?: $class; $externalId = $this->externalId ?: $class;
$msg = sprintf('Service "%s" not found: ', $id); $msg = array();
$msg[] = sprintf('Service "%s" not found:', $id);
if (!$this->container) { if (!$this->container) {
$class = null; $class = null;
} elseif ($this->container->has($id) || isset($this->container->getRemovedIds()[$id])) { } elseif ($this->container->has($id) || isset($this->container->getRemovedIds()[$id])) {
$msg .= 'even though it exists in the app\'s container, '; $msg[] = 'even though it exists in the app\'s container,';
} else { } else {
try { try {
$this->container->get($id); $this->container->get($id);
$class = null; $class = null;
} catch (ServiceNotFoundException $e) { } catch (ServiceNotFoundException $e) {
if ($e->getAlternatives()) { if ($e->getAlternatives()) {
$msg .= sprintf(' did you mean %s? Anyway, ', $this->formatAlternatives($e->getAlternatives(), 'or')); $msg[] = sprintf('did you mean %s? Anyway,', $this->formatAlternatives($e->getAlternatives(), 'or'));
} else { } else {
$class = null; $class = null;
} }
} }
} }
if ($externalId) { if ($externalId) {
$msg .= sprintf('the container inside "%s" is a smaller service locator that %s', $externalId, $this->formatAlternatives()); $msg[] = sprintf('the container inside "%s" is a smaller service locator that %s', $externalId, $this->formatAlternatives());
} else { } else {
$msg .= sprintf('the current service locator %s', $this->formatAlternatives()); $msg[] = sprintf('the current service locator %s', $this->formatAlternatives());
} }
if (!$class) { if (!$class) {
// no-op // no-op
} elseif (is_subclass_of($class, ServiceSubscriberInterface::class)) { } elseif (is_subclass_of($class, ServiceSubscriberInterface::class)) {
$msg .= sprintf(' Unless you need extra laziness, try using dependency injection instead. Otherwise, you need to declare it using "%s::getSubscribedServices()".', preg_replace('/([^\\\\]++\\\\)++/', '', $class)); $msg[] = sprintf('Unless you need extra laziness, try using dependency injection instead. Otherwise, you need to declare it using "%s::getSubscribedServices()".', preg_replace('/([^\\\\]++\\\\)++/', '', $class));
} else { } else {
$msg .= 'Try using dependency injection instead.'; $msg[] = 'Try using dependency injection instead.';
} }
return $msg; return implode(' ', $msg);
} }
private function formatAlternatives(array $alternatives = null, $separator = 'and') private function formatAlternatives(array $alternatives = null, $separator = 'and')

View File

@ -115,6 +115,20 @@ class ServiceLocatorTest extends TestCase
$subscriber->getFoo(); $subscriber->getFoo();
} }
/**
* @expectedException \Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException
* @expectedExceptionMessage Service "foo" not found: even though it exists in the app's container, the container inside "foo" is a smaller service locator that is empty... Try using dependency injection instead.
*/
public function testGetThrowsServiceNotFoundException()
{
$container = new Container();
$container->set('foo', new \stdClass());
$locator = new ServiceLocator(array());
$locator = $locator->withContext('foo', $container);
$locator->get('foo');
}
public function testInvoke() public function testInvoke()
{ {
$locator = new ServiceLocator(array( $locator = new ServiceLocator(array(