Refactor check-platform-reqs to use InstalledRepository and look for providers as well as platform packages, fixes #8645, closes #8676
Co-authored-by: Ellis <eantaya@nuglif.com> Co-authored-by: Jordi Boggiano <j.boggiano@seld.be>pull/8684/head
parent
d63eb8179e
commit
2445ef5e1f
|
@ -20,6 +20,7 @@ use Symfony\Component\Console\Input\InputInterface;
|
||||||
use Symfony\Component\Console\Input\InputOption;
|
use Symfony\Component\Console\Input\InputOption;
|
||||||
use Symfony\Component\Console\Output\OutputInterface;
|
use Symfony\Component\Console\Output\OutputInterface;
|
||||||
use Composer\Repository\PlatformRepository;
|
use Composer\Repository\PlatformRepository;
|
||||||
|
use Composer\Repository\InstalledRepository;
|
||||||
|
|
||||||
class CheckPlatformReqsCommand extends BaseCommand
|
class CheckPlatformReqsCommand extends BaseCommand
|
||||||
{
|
{
|
||||||
|
@ -48,12 +49,13 @@ EOT
|
||||||
|
|
||||||
$requires = $composer->getPackage()->getRequires();
|
$requires = $composer->getPackage()->getRequires();
|
||||||
if ($input->getOption('no-dev')) {
|
if ($input->getOption('no-dev')) {
|
||||||
$dependencies = $composer->getLocker()->getLockedRepository(!$input->getOption('no-dev'))->getPackages();
|
$installedRepo = $composer->getLocker()->getLockedRepository(!$input->getOption('no-dev'));
|
||||||
|
$dependencies = $installedRepo->getPackages();
|
||||||
} else {
|
} else {
|
||||||
$dependencies = $composer->getRepositoryManager()->getLocalRepository()->getPackages();
|
$installedRepo = $composer->getRepositoryManager()->getLocalRepository();
|
||||||
// fallback to lockfile if installed repo is empty
|
// fallback to lockfile if installed repo is empty
|
||||||
if (!$dependencies) {
|
if (!$installedRepo->getPackages()) {
|
||||||
$dependencies = $composer->getLocker()->getLockedRepository(true)->getPackages();
|
$installedRepo = $composer->getLocker()->getLockedRepository(true);
|
||||||
}
|
}
|
||||||
$requires += $composer->getPackage()->getDevRequires();
|
$requires += $composer->getPackage()->getDevRequires();
|
||||||
}
|
}
|
||||||
|
@ -61,7 +63,8 @@ EOT
|
||||||
$requires[$require] = array($link);
|
$requires[$require] = array($link);
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($dependencies as $package) {
|
$installedRepo = new InstalledRepository(array($installedRepo));
|
||||||
|
foreach ($installedRepo->getPackages() as $package) {
|
||||||
foreach ($package->getRequires() as $require => $link) {
|
foreach ($package->getRequires() as $require => $link) {
|
||||||
$requires[$require][] = $link;
|
$requires[$require][] = $link;
|
||||||
}
|
}
|
||||||
|
@ -69,19 +72,9 @@ EOT
|
||||||
|
|
||||||
ksort($requires);
|
ksort($requires);
|
||||||
|
|
||||||
$platformRepo = new PlatformRepository(array(), array());
|
$installedRepo->addRepository(new PlatformRepository(array(), array()));
|
||||||
$currentPlatformPackages = $platformRepo->getPackages();
|
|
||||||
$currentPlatformPackageMap = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var PackageInterface $currentPlatformPackage
|
|
||||||
*/
|
|
||||||
foreach ($currentPlatformPackages as $currentPlatformPackage) {
|
|
||||||
$currentPlatformPackageMap[$currentPlatformPackage->getName()] = $currentPlatformPackage;
|
|
||||||
}
|
|
||||||
|
|
||||||
$results = array();
|
$results = array();
|
||||||
|
|
||||||
$exitCode = 0;
|
$exitCode = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -89,33 +82,54 @@ EOT
|
||||||
*/
|
*/
|
||||||
foreach ($requires as $require => $links) {
|
foreach ($requires as $require => $links) {
|
||||||
if (preg_match(PlatformRepository::PLATFORM_PACKAGE_REGEX, $require)) {
|
if (preg_match(PlatformRepository::PLATFORM_PACKAGE_REGEX, $require)) {
|
||||||
if (isset($currentPlatformPackageMap[$require])) {
|
$candidates = $installedRepo->findPackagesWithReplacersAndProviders($require);
|
||||||
$pass = true;
|
if ($candidates) {
|
||||||
$version = $currentPlatformPackageMap[$require]->getVersion();
|
$reqResults = array();
|
||||||
|
foreach ($candidates as $candidate) {
|
||||||
|
if ($candidate->getName() === $require) {
|
||||||
|
$candidateConstraint = new Constraint('=', $candidate->getVersion());
|
||||||
|
$candidateConstraint->setPrettyString($candidate->getPrettyVersion());
|
||||||
|
} else {
|
||||||
|
foreach (array_merge($candidate->getProvides(), $candidate->getReplaces()) as $link) {
|
||||||
|
if ($link->getTarget() === $require) {
|
||||||
|
$candidateConstraint = $link->getConstraint();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($links as $link) {
|
foreach ($links as $link) {
|
||||||
if (!$link->getConstraint()->matches(new Constraint('=', $version))) {
|
if (!$link->getConstraint()->matches($candidateConstraint)) {
|
||||||
$results[] = array(
|
$reqResults[] = array(
|
||||||
$currentPlatformPackageMap[$require]->getPrettyName(),
|
$candidate->getName() === $require ? $candidate->getPrettyName() : $require,
|
||||||
$currentPlatformPackageMap[$require]->getPrettyVersion(),
|
$candidateConstraint->getPrettyString(),
|
||||||
$link,
|
$link,
|
||||||
'<error>failed</error>',
|
'<error>failed</error>'.($candidate->getName() === $require ? '' : ' <comment>provided by '.$candidate->getPrettyName().'</comment>'),
|
||||||
);
|
);
|
||||||
$pass = false;
|
|
||||||
|
|
||||||
$exitCode = max($exitCode, 1);
|
// skip to next candidate
|
||||||
|
continue 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($pass) {
|
|
||||||
$results[] = array(
|
$results[] = array(
|
||||||
$currentPlatformPackageMap[$require]->getPrettyName(),
|
$candidate->getName() === $require ? $candidate->getPrettyName() : $require,
|
||||||
$currentPlatformPackageMap[$require]->getPrettyVersion(),
|
$candidateConstraint->getPrettyString(),
|
||||||
null,
|
null,
|
||||||
'<info>success</info>',
|
'<info>success</info>'.($candidate->getName() === $require ? '' : ' <comment>provided by '.$candidate->getPrettyName().'</comment>'),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// candidate matched, skip to next requirement
|
||||||
|
continue 2;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
|
// show the first error from every failed candidate
|
||||||
|
$results = array_merge($results, $reqResults);
|
||||||
|
$exitCode = max($exitCode, 1);
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
$results[] = array(
|
$results[] = array(
|
||||||
$require,
|
$require,
|
||||||
'n/a',
|
'n/a',
|
||||||
|
@ -126,7 +140,6 @@ EOT
|
||||||
$exitCode = max($exitCode, 2);
|
$exitCode = max($exitCode, 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
$this->printTable($output, $results);
|
$this->printTable($output, $results);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue