From de1765aa486673bb6c55d414c31b1edbc5841c56 Mon Sep 17 00:00:00 2001 From: Nils Adermann Date: Mon, 20 Feb 2012 11:10:36 +0100 Subject: [PATCH 1/2] Remove workaround error detection in install command --- src/Composer/Command/InstallCommand.php | 28 ------------------------- 1 file changed, 28 deletions(-) diff --git a/src/Composer/Command/InstallCommand.php b/src/Composer/Command/InstallCommand.php index fb7531139..5885b033d 100644 --- a/src/Composer/Command/InstallCommand.php +++ b/src/Composer/Command/InstallCommand.php @@ -156,34 +156,6 @@ EOT // solve dependencies $operations = $solver->solve($request); - // check for missing deps - // TODO this belongs in the solver, but this will do for now to report top-level deps missing at least - foreach ($request->getJobs() as $job) { - if ('install' === $job['cmd']) { - foreach ($installedRepo->getPackages() as $package ) { - if ($installedRepo->hasPackage($package) && !$package->isPlatform() && !$installationManager->isPackageInstalled($package)) { - $operations[$job['packageName']] = new InstallOperation($package, Solver::RULE_PACKAGE_NOT_EXIST); - } - if (in_array($job['packageName'], $package->getNames())) { - continue 2; - } - } - foreach ($operations as $operation) { - if ('install' === $operation->getJobType() && in_array($job['packageName'], $operation->getPackage()->getNames())) { - continue 2; - } - if ('update' === $operation->getJobType() && in_array($job['packageName'], $operation->getTargetPackage()->getNames())) { - continue 2; - } - } - - if ($pool->whatProvides($job['packageName'])) { - throw new \UnexpectedValueException('Package '.$job['packageName'].' can not be installed, either because its version constraint is incorrect, or because one of its dependencies was not found.'); - } - throw new \UnexpectedValueException('Package '.$job['packageName'].' was not found in the package pool, check the name for typos.'); - } - } - // execute operations if (!$operations) { $io->write('Nothing to install/update'); From f3ff53b17cc87cc9c5d2ba7950de28b4231403c0 Mon Sep 17 00:00:00 2001 From: Nils Adermann Date: Mon, 20 Feb 2012 12:58:27 +0100 Subject: [PATCH 2/2] Create problems directly, rather than generating impossible rules --- src/Composer/DependencyResolver/Solver.php | 36 ++++--------------- .../Test/DependencyResolver/SolverTest.php | 2 -- 2 files changed, 7 insertions(+), 31 deletions(-) diff --git a/src/Composer/DependencyResolver/Solver.php b/src/Composer/DependencyResolver/Solver.php index e1d6575cd..ab85c78c2 100644 --- a/src/Composer/DependencyResolver/Solver.php +++ b/src/Composer/DependencyResolver/Solver.php @@ -147,10 +147,6 @@ class Solver */ protected function createInstallOneOfRule(array $packages, $reason, $reasonData = null) { - if (empty($packages)) { - return $this->createImpossibleRule($reason, $reasonData); - } - $literals = array(); foreach ($packages as $package) { $literals[] = new Literal($package, true); @@ -200,22 +196,6 @@ class Solver return new Rule(array(new Literal($issuer, false), new Literal($provider, false)), $reason, $reasonData); } - /** - * Intentionally creates a rule impossible to solve - * - * The rule is an empty one so it can never be satisfied. - * - * @param int $reason A RULE_* constant describing the reason for - * generating this rule - * @param mixed $reasonData Any data, e.g. the package name, that goes with - * the reason - * @return Rule An empty rule - */ - protected function createImpossibleRule($reason, $reasonData = null) - { - return new Rule(array(), $reason, $reasonData); - } - /** * Adds a rule unless it duplicates an existing one of any type * @@ -972,12 +952,6 @@ class Solver foreach ($this->jobs as $job) { - if (empty($job['packages']) && $job['cmd'] == 'install') { - $this->addRule( - RuleSet::TYPE_JOB, - $this->createImpossibleRule(static::RULE_JOB_INSTALL, $job) - ); - } foreach ($job['packages'] as $package) { switch ($job['cmd']) { case 'install': @@ -1002,9 +976,13 @@ class Solver foreach ($this->jobs as $job) { switch ($job['cmd']) { case 'install': - $rule = $this->createInstallOneOfRule($job['packages'], self::RULE_JOB_INSTALL, $job['packageName']); - $this->addRule(RuleSet::TYPE_JOB, $rule); - $this->ruleToJob[$rule->getId()] = $job; + if (empty($job['packages'])) { + $this->problems[] = array($job); + } else { + $rule = $this->createInstallOneOfRule($job['packages'], self::RULE_JOB_INSTALL, $job['packageName']); + $this->addRule(RuleSet::TYPE_JOB, $rule); + $this->ruleToJob[$rule->getId()] = $job; + } break; case 'remove': // remove all packages with this name including uninstalled diff --git a/tests/Composer/Test/DependencyResolver/SolverTest.php b/tests/Composer/Test/DependencyResolver/SolverTest.php index 70509ea0f..fe6782177 100644 --- a/tests/Composer/Test/DependencyResolver/SolverTest.php +++ b/tests/Composer/Test/DependencyResolver/SolverTest.php @@ -57,8 +57,6 @@ class SolverTest extends TestCase public function testInstallNonExistingPackageFails() { - $this->markTestIncomplete('Reporting this failure is not implemented/working yet'); - $this->repo->addPackage($this->getPackage('A', '1.0')); $this->reposComplete();