Skip to content

Commit

Permalink
improved exception messages
Browse files Browse the repository at this point in the history
  • Loading branch information
dg committed Dec 15, 2021
1 parent 18180e8 commit 6d79ebb
Show file tree
Hide file tree
Showing 6 changed files with 16 additions and 11 deletions.
11 changes: 8 additions & 3 deletions src/DI/Config/Adapters/NeonAdapter.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,9 @@ final class NeonAdapter implements Nette\DI\Config\Adapter

private const PREVENT_MERGING_SUFFIX = '!';

/** @var string */
private $file;


/**
* Reads configuration from NEON file.
Expand All @@ -36,6 +39,7 @@ public function load(string $file): array
$input = substr($input, 3);
}

$this->file = $file;
$decoder = new Neon\Decoder;
$node = $decoder->parseToNode($input);
$traverser = new Neon\Traverser;
Expand All @@ -52,8 +56,9 @@ public function process(array $arr): array
if (is_string($key) && substr($key, -1) === self::PREVENT_MERGING_SUFFIX) {
if (!is_array($val) && $val !== null) {
throw new Nette\DI\InvalidConfigurationException(sprintf(
"Replacing operator is available only for arrays, item '%s' is not array.",
$key
"Replacing operator is available only for arrays, item '%s' is not array (used in '%s')",
$key,
$this->file
));
}

Expand All @@ -78,7 +83,7 @@ public function process(array $arr): array
} else {
$tmp = $this->process([$val->value]);
if (is_string($tmp[0]) && strpos($tmp[0], '?') !== false) {
trigger_error('Operator ? is deprecated in config files.', E_USER_DEPRECATED);
trigger_error("Operator ? is deprecated in config files (used in '$this->file')", E_USER_DEPRECATED);
}

$val = new Statement($tmp[0], $this->process($val->attributes));
Expand Down
2 changes: 1 addition & 1 deletion src/DI/Container.php
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ public function addService(string $name, $service)

if ($service instanceof \Closure) {
$rt = Nette\Utils\Type::fromReflection(new \ReflectionFunction($service));
$type = $rt ? Helpers::ensureClassType($rt, 'return type of factory') : '';
$type = $rt ? Helpers::ensureClassType($rt, 'return type of closure') : '';
} else {
$type = get_class($service);
}
Expand Down
2 changes: 1 addition & 1 deletion src/DI/Definitions/ServiceDefinition.php
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ public function resolveType(Nette\DI\Resolver $resolver): void
} elseif (!$this->getType()) {
$type = $resolver->resolveEntityType($this->factory);
if (!$type) {
throw new ServiceCreationException('Unknown service type, specify it or declare return type of factory.');
throw new ServiceCreationException('Unknown service type, specify it or declare return type of factory method.');
}

$this->setType($type);
Expand Down
2 changes: 1 addition & 1 deletion tests/DI/Container.dynamic.php80.phpt
Original file line number Diff line number Diff line change
Expand Up @@ -19,4 +19,4 @@ $container = new Container;
Assert::exception(function () use ($container) {
@$container->addService('six', function (): stdClass|Closure {}); // @ triggers service should be defined as "imported"
$container->getService('six');
}, Nette\InvalidStateException::class, "Return type of factory is not expected to be nullable/union/intersection/built-in, 'stdClass|Closure' given.");
}, Nette\InvalidStateException::class, "Return type of closure is not expected to be nullable/union/intersection/built-in, 'stdClass|Closure' given.");
2 changes: 1 addition & 1 deletion tests/DI/ContainerBuilder.create.error.phpt
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ Assert::exception(function () {
$builder = new DI\ContainerBuilder;
$builder->addDefinition('one')->setFactory('Bad7::create');
$builder->complete();
}, Nette\DI\ServiceCreationException::class, "Service 'one': Unknown service type, specify it or declare return type of factory.");
}, Nette\DI\ServiceCreationException::class, "Service 'one': Unknown service type, specify it or declare return type of factory method.");


class Bad8
Expand Down
8 changes: 4 additions & 4 deletions tests/DI/ContainerBuilder.resolveTypes.phpt
Original file line number Diff line number Diff line change
Expand Up @@ -140,14 +140,14 @@ Assert::exception(function () {
$builder->addDefinition('a')
->setFactory([Factory::class, 'createObjectPhpDoc']);
$container = createContainer($builder);
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory.");
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory method.");

Assert::exception(function () {
$builder = new DI\ContainerBuilder;
$builder->addDefinition('a')
->setFactory([Factory::class, 'createObject']);
$container = createContainer($builder);
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory.");
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory method.");

Assert::exception(function () {
$builder = new DI\ContainerBuilder;
Expand All @@ -161,14 +161,14 @@ Assert::exception(function () {
$builder->addDefinition('a')
->setFactory([Factory::class, 'createMixedPhpDoc']);
$container = createContainer($builder);
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory.");
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory method.");

Assert::exception(function () {
$builder = new DI\ContainerBuilder;
$builder->addDefinition('a')
->setFactory([Factory::class, 'createMixed']);
$container = createContainer($builder);
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory.");
}, Nette\DI\ServiceCreationException::class, "Service 'a': Unknown service type, specify it or declare return type of factory method.");

Assert::exception(function () {
$builder = new DI\ContainerBuilder;
Expand Down

0 comments on commit 6d79ebb

Please sign in to comment.