Update phpstan, fix InstalledVersions key ordering to be more logical/consistent
parent
6b7ae1e05a
commit
06ef742a66
|
@ -1825,16 +1825,16 @@
|
||||||
"packages-dev": [
|
"packages-dev": [
|
||||||
{
|
{
|
||||||
"name": "phpstan/phpstan",
|
"name": "phpstan/phpstan",
|
||||||
"version": "1.6.2",
|
"version": "1.6.3",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/phpstan/phpstan.git",
|
"url": "https://github.com/phpstan/phpstan.git",
|
||||||
"reference": "becb9603a31d70f5007d505877a7b812598dfe46"
|
"reference": "6128620b98292e0b69ea6d799871d77163681c8e"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/phpstan/phpstan/zipball/becb9603a31d70f5007d505877a7b812598dfe46",
|
"url": "https://api.github.com/repos/phpstan/phpstan/zipball/6128620b98292e0b69ea6d799871d77163681c8e",
|
||||||
"reference": "becb9603a31d70f5007d505877a7b812598dfe46",
|
"reference": "6128620b98292e0b69ea6d799871d77163681c8e",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
|
@ -1860,7 +1860,7 @@
|
||||||
"description": "PHPStan - PHP Static Analysis Tool",
|
"description": "PHPStan - PHP Static Analysis Tool",
|
||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/phpstan/phpstan/issues",
|
"issues": "https://github.com/phpstan/phpstan/issues",
|
||||||
"source": "https://github.com/phpstan/phpstan/tree/1.6.2"
|
"source": "https://github.com/phpstan/phpstan/tree/1.6.3"
|
||||||
},
|
},
|
||||||
"funding": [
|
"funding": [
|
||||||
{
|
{
|
||||||
|
@ -1880,7 +1880,7 @@
|
||||||
"type": "tidelift"
|
"type": "tidelift"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"time": "2022-04-27T11:05:24+00:00"
|
"time": "2022-04-28T11:27:53+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "phpstan/phpstan-deprecation-rules",
|
"name": "phpstan/phpstan-deprecation-rules",
|
||||||
|
@ -1986,21 +1986,21 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "phpstan/phpstan-strict-rules",
|
"name": "phpstan/phpstan-strict-rules",
|
||||||
"version": "1.2.0",
|
"version": "1.2.1",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/phpstan/phpstan-strict-rules.git",
|
"url": "https://github.com/phpstan/phpstan-strict-rules.git",
|
||||||
"reference": "afbe1e3235c51ee3f10ba4c8b32449099016ea02"
|
"reference": "f3ca6464eae640a556c69a02b3b77a2507475d2f"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/phpstan/phpstan-strict-rules/zipball/afbe1e3235c51ee3f10ba4c8b32449099016ea02",
|
"url": "https://api.github.com/repos/phpstan/phpstan-strict-rules/zipball/f3ca6464eae640a556c69a02b3b77a2507475d2f",
|
||||||
"reference": "afbe1e3235c51ee3f10ba4c8b32449099016ea02",
|
"reference": "f3ca6464eae640a556c69a02b3b77a2507475d2f",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
"php": "^7.2 || ^8.0",
|
"php": "^7.2 || ^8.0",
|
||||||
"phpstan/phpstan": "^1.6.0"
|
"phpstan/phpstan": "^1.6.3"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"nikic/php-parser": "^4.13.0",
|
"nikic/php-parser": "^4.13.0",
|
||||||
|
@ -2028,9 +2028,9 @@
|
||||||
"description": "Extra strict and opinionated rules for PHPStan",
|
"description": "Extra strict and opinionated rules for PHPStan",
|
||||||
"support": {
|
"support": {
|
||||||
"issues": "https://github.com/phpstan/phpstan-strict-rules/issues",
|
"issues": "https://github.com/phpstan/phpstan-strict-rules/issues",
|
||||||
"source": "https://github.com/phpstan/phpstan-strict-rules/tree/1.2.0"
|
"source": "https://github.com/phpstan/phpstan-strict-rules/tree/1.2.1"
|
||||||
},
|
},
|
||||||
"time": "2022-04-21T13:07:43+00:00"
|
"time": "2022-04-28T07:20:18+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "phpstan/phpstan-symfony",
|
"name": "phpstan/phpstan-symfony",
|
||||||
|
|
|
@ -28,7 +28,7 @@ class InstalledVersions
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var mixed[]|null
|
* @var mixed[]|null
|
||||||
* @psalm-var array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}, versions: array<string, array{dev_requirement: bool, pretty_version?: string, version?: string, aliases?: string[], reference?: string, replaced?: string[], provided?: string[], install_path?: string, type?: string}>}|array{}|null
|
* @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}|array{}|null
|
||||||
*/
|
*/
|
||||||
private static $installed;
|
private static $installed;
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ class InstalledVersions
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var array[]
|
* @var array[]
|
||||||
* @psalm-var array<string, array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}, versions: array<string, array{dev_requirement: bool, pretty_version?: string, version?: string, aliases?: string[], reference?: string, replaced?: string[], provided?: string[], install_path?: string, type?: string}>}>
|
* @psalm-var array<string, array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
|
||||||
*/
|
*/
|
||||||
private static $installedByVendor = array();
|
private static $installedByVendor = array();
|
||||||
|
|
||||||
|
@ -243,7 +243,7 @@ class InstalledVersions
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
* @psalm-return array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}
|
* @psalm-return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}
|
||||||
*/
|
*/
|
||||||
public static function getRootPackage()
|
public static function getRootPackage()
|
||||||
{
|
{
|
||||||
|
@ -257,7 +257,7 @@ class InstalledVersions
|
||||||
*
|
*
|
||||||
* @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect.
|
* @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect.
|
||||||
* @return array[]
|
* @return array[]
|
||||||
* @psalm-return array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}, versions: array<string, array{dev_requirement: bool, pretty_version?: string, version?: string, aliases?: string[], reference?: string, replaced?: string[], provided?: string[], install_path?: string, type?: string}>}
|
* @psalm-return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}
|
||||||
*/
|
*/
|
||||||
public static function getRawData()
|
public static function getRawData()
|
||||||
{
|
{
|
||||||
|
@ -280,7 +280,7 @@ class InstalledVersions
|
||||||
* Returns the raw data of all installed.php which are currently loaded for custom implementations
|
* Returns the raw data of all installed.php which are currently loaded for custom implementations
|
||||||
*
|
*
|
||||||
* @return array[]
|
* @return array[]
|
||||||
* @psalm-return list<array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}, versions: array<string, array{dev_requirement: bool, pretty_version?: string, version?: string, aliases?: string[], reference?: string, replaced?: string[], provided?: string[], install_path?: string, type?: string}>}>
|
* @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
|
||||||
*/
|
*/
|
||||||
public static function getAllRawData()
|
public static function getAllRawData()
|
||||||
{
|
{
|
||||||
|
@ -303,7 +303,7 @@ class InstalledVersions
|
||||||
* @param array[] $data A vendor/composer/installed.php data set
|
* @param array[] $data A vendor/composer/installed.php data set
|
||||||
* @return void
|
* @return void
|
||||||
*
|
*
|
||||||
* @psalm-param array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}, versions: array<string, array{dev_requirement: bool, pretty_version?: string, version?: string, aliases?: string[], reference?: string, replaced?: string[], provided?: string[], install_path?: string, type?: string}>} $data
|
* @psalm-param array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $data
|
||||||
*/
|
*/
|
||||||
public static function reload($data)
|
public static function reload($data)
|
||||||
{
|
{
|
||||||
|
@ -313,7 +313,7 @@ class InstalledVersions
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array[]
|
* @return array[]
|
||||||
* @psalm-return list<array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[], dev: bool, install_path: string, type: string}, versions: array<string, array{dev_requirement: bool, pretty_version?: string, version?: string, aliases?: string[], reference?: string, replaced?: string[], provided?: string[], install_path?: string, type?: string}>}>
|
* @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
|
||||||
*/
|
*/
|
||||||
private static function getInstalled()
|
private static function getInstalled()
|
||||||
{
|
{
|
||||||
|
|
|
@ -14,6 +14,8 @@ namespace Composer\Repository;
|
||||||
|
|
||||||
use Composer\Json\JsonFile;
|
use Composer\Json\JsonFile;
|
||||||
use Composer\Package\Loader\ArrayLoader;
|
use Composer\Package\Loader\ArrayLoader;
|
||||||
|
use Composer\Package\PackageInterface;
|
||||||
|
use Composer\Package\RootAliasPackage;
|
||||||
use Composer\Package\RootPackageInterface;
|
use Composer\Package\RootPackageInterface;
|
||||||
use Composer\Package\AliasPackage;
|
use Composer\Package\AliasPackage;
|
||||||
use Composer\Package\Dumper\ArrayDumper;
|
use Composer\Package\Dumper\ArrayDumper;
|
||||||
|
@ -207,25 +209,26 @@ class FilesystemRepository extends WritableArrayRepository
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array<string, string> $installPaths
|
* @param array<string, string> $installPaths
|
||||||
* @param bool $devMode
|
|
||||||
* @param string $repoDir
|
|
||||||
*
|
*
|
||||||
* @return ?array<mixed>
|
* @return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}
|
||||||
*/
|
*/
|
||||||
private function generateInstalledVersions(InstallationManager $installationManager, array $installPaths, bool $devMode, string $repoDir): ?array
|
private function generateInstalledVersions(InstallationManager $installationManager, array $installPaths, bool $devMode, string $repoDir): array
|
||||||
{
|
{
|
||||||
if (!$this->dumpVersions) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$devPackages = array_flip($this->devPackageNames);
|
$devPackages = array_flip($this->devPackageNames);
|
||||||
$versions = array('versions' => array());
|
|
||||||
$packages = $this->getPackages();
|
$packages = $this->getPackages();
|
||||||
|
if (null === $this->rootPackage) {
|
||||||
|
throw new \LogicException('It should not be possible to dump packages if no root package is given');
|
||||||
|
}
|
||||||
$packages[] = $rootPackage = $this->rootPackage;
|
$packages[] = $rootPackage = $this->rootPackage;
|
||||||
while ($rootPackage instanceof AliasPackage) {
|
|
||||||
|
while ($rootPackage instanceof RootAliasPackage) {
|
||||||
$rootPackage = $rootPackage->getAliasOf();
|
$rootPackage = $rootPackage->getAliasOf();
|
||||||
$packages[] = $rootPackage;
|
$packages[] = $rootPackage;
|
||||||
}
|
}
|
||||||
|
$versions = [
|
||||||
|
'root' => $this->dumpRootPackage($rootPackage, $installPaths, $devMode, $repoDir, $devPackages),
|
||||||
|
'versions' => [],
|
||||||
|
];
|
||||||
|
|
||||||
// add real installed packages
|
// add real installed packages
|
||||||
foreach ($packages as $package) {
|
foreach ($packages as $package) {
|
||||||
|
@ -233,36 +236,7 @@ class FilesystemRepository extends WritableArrayRepository
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$reference = null;
|
$versions['versions'][$package->getName()] = $this->dumpInstalledPackage($package, $installPaths, $repoDir, $devPackages);
|
||||||
if ($package->getInstallationSource()) {
|
|
||||||
$reference = $package->getInstallationSource() === 'source' ? $package->getSourceReference() : $package->getDistReference();
|
|
||||||
}
|
|
||||||
if (null === $reference) {
|
|
||||||
$reference = ($package->getSourceReference() ?: $package->getDistReference()) ?: null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($package instanceof RootPackageInterface) {
|
|
||||||
$to = $this->filesystem->normalizePath(realpath(Platform::getCwd()));
|
|
||||||
$installPath = $this->filesystem->findShortestPath($repoDir, $to, true);
|
|
||||||
} else {
|
|
||||||
$installPath = $installPaths[$package->getName()];
|
|
||||||
}
|
|
||||||
|
|
||||||
$versions['versions'][$package->getName()] = array(
|
|
||||||
'pretty_version' => $package->getPrettyVersion(),
|
|
||||||
'version' => $package->getVersion(),
|
|
||||||
'type' => $package->getType(),
|
|
||||||
'install_path' => $installPath,
|
|
||||||
'aliases' => array(),
|
|
||||||
'reference' => $reference,
|
|
||||||
'dev_requirement' => isset($devPackages[$package->getName()]),
|
|
||||||
);
|
|
||||||
if ($package instanceof RootPackageInterface) {
|
|
||||||
$versions['root'] = $versions['versions'][$package->getName()];
|
|
||||||
unset($versions['root']['dev_requirement']);
|
|
||||||
$versions['root']['name'] = $package->getName();
|
|
||||||
$versions['root']['dev'] = $devMode;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// add provided/replaced packages
|
// add provided/replaced packages
|
||||||
|
@ -322,4 +296,60 @@ class FilesystemRepository extends WritableArrayRepository
|
||||||
|
|
||||||
return $versions;
|
return $versions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, string> $installPaths
|
||||||
|
* @param array<string, int> $devPackages
|
||||||
|
* @return array{pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev_requirement: bool}
|
||||||
|
*/
|
||||||
|
private function dumpInstalledPackage(PackageInterface $package, array $installPaths, string $repoDir, array $devPackages): array
|
||||||
|
{
|
||||||
|
$reference = null;
|
||||||
|
if ($package->getInstallationSource()) {
|
||||||
|
$reference = $package->getInstallationSource() === 'source' ? $package->getSourceReference() : $package->getDistReference();
|
||||||
|
}
|
||||||
|
if (null === $reference) {
|
||||||
|
$reference = ($package->getSourceReference() ?: $package->getDistReference()) ?: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($package instanceof RootPackageInterface) {
|
||||||
|
$to = $this->filesystem->normalizePath(realpath(Platform::getCwd()));
|
||||||
|
$installPath = $this->filesystem->findShortestPath($repoDir, $to, true);
|
||||||
|
} else {
|
||||||
|
$installPath = $installPaths[$package->getName()];
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'pretty_version' => $package->getPrettyVersion(),
|
||||||
|
'version' => $package->getVersion(),
|
||||||
|
'reference' => $reference,
|
||||||
|
'type' => $package->getType(),
|
||||||
|
'install_path' => $installPath,
|
||||||
|
'aliases' => array(),
|
||||||
|
'dev_requirement' => isset($devPackages[$package->getName()]),
|
||||||
|
];
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array<string, string> $installPaths
|
||||||
|
* @param array<string, int> $devPackages
|
||||||
|
* @return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}
|
||||||
|
*/
|
||||||
|
private function dumpRootPackage(RootPackageInterface $package, array $installPaths, bool $devMode, string $repoDir, array $devPackages)
|
||||||
|
{
|
||||||
|
$data = $this->dumpInstalledPackage($package, $installPaths, $repoDir, $devPackages);
|
||||||
|
|
||||||
|
return [
|
||||||
|
'name' => $package->getName(),
|
||||||
|
'pretty_version' => $data['pretty_version'],
|
||||||
|
'version' => $data['version'],
|
||||||
|
'reference' => $data['reference'],
|
||||||
|
'type' => $data['type'],
|
||||||
|
'install_path' => $data['install_path'],
|
||||||
|
'aliases' => $data['aliases'],
|
||||||
|
'dev' => $devMode,
|
||||||
|
];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ final class IgnoreNothingPlatformRequirementFilterTest extends TestCase
|
||||||
{
|
{
|
||||||
$platformRequirementFilter = new IgnoreNothingPlatformRequirementFilter();
|
$platformRequirementFilter = new IgnoreNothingPlatformRequirementFilter();
|
||||||
|
|
||||||
$this->assertFalse($platformRequirementFilter->isIgnored($req));
|
$this->assertFalse($platformRequirementFilter->isIgnored($req)); // @phpstan-ignore-line
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -215,15 +215,15 @@ class InstalledVersionsTest extends TestCase
|
||||||
public function testGetRootPackage(): void
|
public function testGetRootPackage(): void
|
||||||
{
|
{
|
||||||
$this->assertSame(array(
|
$this->assertSame(array(
|
||||||
|
'name' => '__root__',
|
||||||
'pretty_version' => 'dev-master',
|
'pretty_version' => 'dev-master',
|
||||||
'version' => 'dev-master',
|
'version' => 'dev-master',
|
||||||
|
'reference' => 'sourceref-by-default',
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
'install_path' => $this->root . '/./',
|
'install_path' => $this->root . '/./',
|
||||||
'aliases' => array(
|
'aliases' => array(
|
||||||
'1.10.x-dev',
|
'1.10.x-dev',
|
||||||
),
|
),
|
||||||
'reference' => 'sourceref-by-default',
|
|
||||||
'name' => '__root__',
|
|
||||||
'dev' => true,
|
'dev' => true,
|
||||||
), InstalledVersions::getRootPackage());
|
), InstalledVersions::getRootPackage());
|
||||||
}
|
}
|
||||||
|
|
|
@ -92,9 +92,11 @@ class JsonFileTest extends TestCase
|
||||||
|
|
||||||
public function testSchemaValidation(): void
|
public function testSchemaValidation(): void
|
||||||
{
|
{
|
||||||
|
self::expectNotToPerformAssertions();
|
||||||
|
|
||||||
$json = new JsonFile(__DIR__.'/Fixtures/composer.json');
|
$json = new JsonFile(__DIR__.'/Fixtures/composer.json');
|
||||||
$this->assertTrue($json->validateSchema());
|
$json->validateSchema();
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSchemaValidationError(): void
|
public function testSchemaValidationError(): void
|
||||||
|
@ -133,7 +135,7 @@ class JsonFileTest extends TestCase
|
||||||
$this->assertEquals(sprintf('"%s" does not match the expected JSON schema', $file), $e->getMessage());
|
$this->assertEquals(sprintf('"%s" does not match the expected JSON schema', $file), $e->getMessage());
|
||||||
$this->assertEquals(array('The property foo is not defined and the definition does not allow additional properties'), $e->getErrors());
|
$this->assertEquals(array('The property foo is not defined and the definition does not allow additional properties'), $e->getErrors());
|
||||||
}
|
}
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
unlink($file);
|
unlink($file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,7 +156,7 @@ class JsonFileTest extends TestCase
|
||||||
$this->assertContains('name : The property name is required', $errors);
|
$this->assertContains('name : The property name is required', $errors);
|
||||||
$this->assertContains('description : The property description is required', $errors);
|
$this->assertContains('description : The property description is required', $errors);
|
||||||
}
|
}
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
|
|
||||||
file_put_contents($file, '{ "name": "vendor/package" }');
|
file_put_contents($file, '{ "name": "vendor/package" }');
|
||||||
try {
|
try {
|
||||||
|
@ -164,7 +166,7 @@ class JsonFileTest extends TestCase
|
||||||
$this->assertEquals($expectedMessage, $e->getMessage());
|
$this->assertEquals($expectedMessage, $e->getMessage());
|
||||||
$this->assertEquals(array('description : The property description is required'), $e->getErrors());
|
$this->assertEquals(array('description : The property description is required'), $e->getErrors());
|
||||||
}
|
}
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
|
|
||||||
file_put_contents($file, '{ "description": "generic description" }');
|
file_put_contents($file, '{ "description": "generic description" }');
|
||||||
try {
|
try {
|
||||||
|
@ -174,7 +176,7 @@ class JsonFileTest extends TestCase
|
||||||
$this->assertEquals($expectedMessage, $e->getMessage());
|
$this->assertEquals($expectedMessage, $e->getMessage());
|
||||||
$this->assertEquals(array('name : The property name is required'), $e->getErrors());
|
$this->assertEquals(array('name : The property name is required'), $e->getErrors());
|
||||||
}
|
}
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
|
|
||||||
file_put_contents($file, '{ "type": "library" }');
|
file_put_contents($file, '{ "type": "library" }');
|
||||||
try {
|
try {
|
||||||
|
@ -186,7 +188,7 @@ class JsonFileTest extends TestCase
|
||||||
$this->assertContains('name : The property name is required', $errors);
|
$this->assertContains('name : The property name is required', $errors);
|
||||||
$this->assertContains('description : The property description is required', $errors);
|
$this->assertContains('description : The property description is required', $errors);
|
||||||
}
|
}
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
|
|
||||||
file_put_contents($file, '{ "type": "project" }');
|
file_put_contents($file, '{ "type": "project" }');
|
||||||
try {
|
try {
|
||||||
|
@ -198,17 +200,18 @@ class JsonFileTest extends TestCase
|
||||||
$this->assertContains('name : The property name is required', $errors);
|
$this->assertContains('name : The property name is required', $errors);
|
||||||
$this->assertContains('description : The property description is required', $errors);
|
$this->assertContains('description : The property description is required', $errors);
|
||||||
}
|
}
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
|
|
||||||
file_put_contents($file, '{ "name": "vendor/package", "description": "generic description" }');
|
file_put_contents($file, '{ "name": "vendor/package", "description": "generic description" }');
|
||||||
$this->assertTrue($json->validateSchema());
|
$json->validateSchema();
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA));
|
$json->validateSchema(JsonFile::LAX_SCHEMA);
|
||||||
|
|
||||||
unlink($file);
|
unlink($file);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCustomSchemaValidationLax(): void
|
public function testCustomSchemaValidationLax(): void
|
||||||
{
|
{
|
||||||
|
self::expectNotToPerformAssertions();
|
||||||
$file = $this->createTempFile();
|
$file = $this->createTempFile();
|
||||||
file_put_contents($file, '{ "custom": "property", "another custom": "property" }');
|
file_put_contents($file, '{ "custom": "property", "another custom": "property" }');
|
||||||
|
|
||||||
|
@ -217,7 +220,7 @@ class JsonFileTest extends TestCase
|
||||||
|
|
||||||
$json = new JsonFile($file);
|
$json = new JsonFile($file);
|
||||||
|
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::LAX_SCHEMA, $schema));
|
$json->validateSchema(JsonFile::LAX_SCHEMA, $schema);
|
||||||
|
|
||||||
unlink($file);
|
unlink($file);
|
||||||
unlink($schema);
|
unlink($schema);
|
||||||
|
@ -225,6 +228,7 @@ class JsonFileTest extends TestCase
|
||||||
|
|
||||||
public function testCustomSchemaValidationStrict(): void
|
public function testCustomSchemaValidationStrict(): void
|
||||||
{
|
{
|
||||||
|
self::expectNotToPerformAssertions();
|
||||||
$file = $this->createTempFile();
|
$file = $this->createTempFile();
|
||||||
file_put_contents($file, '{ "custom": "property" }');
|
file_put_contents($file, '{ "custom": "property" }');
|
||||||
|
|
||||||
|
@ -233,7 +237,7 @@ class JsonFileTest extends TestCase
|
||||||
|
|
||||||
$json = new JsonFile($file);
|
$json = new JsonFile($file);
|
||||||
|
|
||||||
$this->assertTrue($json->validateSchema(JsonFile::STRICT_SCHEMA, $schema));
|
$json->validateSchema(JsonFile::STRICT_SCHEMA, $schema);
|
||||||
|
|
||||||
unlink($file);
|
unlink($file);
|
||||||
unlink($schema);
|
unlink($schema);
|
||||||
|
|
|
@ -132,11 +132,10 @@ class FilesystemRepositoryTest extends TestCase
|
||||||
|
|
||||||
$json = new JsonFile($dir.'/installed.json');
|
$json = new JsonFile($dir.'/installed.json');
|
||||||
|
|
||||||
$rootPackage = $this->getPackage('__root__', 'dev-master', 'Composer\Package\RootPackage');
|
$rootPackage = $this->getRootPackage('__root__', 'dev-master');
|
||||||
$rootPackage->setSourceReference('sourceref-by-default');
|
$rootPackage->setSourceReference('sourceref-by-default');
|
||||||
$rootPackage->setDistReference('distref');
|
$rootPackage->setDistReference('distref');
|
||||||
$this->configureLinks($rootPackage, array('provide' => array('foo/impl' => '2.0')));
|
$this->configureLinks($rootPackage, array('provide' => array('foo/impl' => '2.0')));
|
||||||
/** @var RootAliasPackage $rootPackage */
|
|
||||||
$rootPackage = $this->getAliasPackage($rootPackage, '1.10.x-dev');
|
$rootPackage = $this->getAliasPackage($rootPackage, '1.10.x-dev');
|
||||||
|
|
||||||
$repository = new FilesystemRepository($json, true, $rootPackage);
|
$repository = new FilesystemRepository($json, true, $rootPackage);
|
||||||
|
|
|
@ -12,70 +12,70 @@
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'root' => array(
|
'root' => array(
|
||||||
|
'name' => '__root__',
|
||||||
'pretty_version' => 'dev-master',
|
'pretty_version' => 'dev-master',
|
||||||
'version' => 'dev-master',
|
'version' => 'dev-master',
|
||||||
|
'reference' => 'sourceref-by-default',
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
// @phpstan-ignore-next-line
|
// @phpstan-ignore-next-line
|
||||||
'install_path' => $dir . '/./',
|
'install_path' => $dir . '/./',
|
||||||
'aliases' => array(
|
'aliases' => array(
|
||||||
'1.10.x-dev',
|
'1.10.x-dev',
|
||||||
),
|
),
|
||||||
'reference' => 'sourceref-by-default',
|
|
||||||
'name' => '__root__',
|
|
||||||
'dev' => true,
|
'dev' => true,
|
||||||
),
|
),
|
||||||
'versions' => array(
|
'versions' => array(
|
||||||
'__root__' => array(
|
'__root__' => array(
|
||||||
'pretty_version' => 'dev-master',
|
'pretty_version' => 'dev-master',
|
||||||
'version' => 'dev-master',
|
'version' => 'dev-master',
|
||||||
|
'reference' => 'sourceref-by-default',
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
// @phpstan-ignore-next-line
|
// @phpstan-ignore-next-line
|
||||||
'install_path' => $dir . '/./',
|
'install_path' => $dir . '/./',
|
||||||
'aliases' => array(
|
'aliases' => array(
|
||||||
'1.10.x-dev',
|
'1.10.x-dev',
|
||||||
),
|
),
|
||||||
'reference' => 'sourceref-by-default',
|
|
||||||
'dev_requirement' => false,
|
'dev_requirement' => false,
|
||||||
),
|
),
|
||||||
'a/provider' => array(
|
'a/provider' => array(
|
||||||
'pretty_version' => '1.1',
|
'pretty_version' => '1.1',
|
||||||
'version' => '1.1.0.0',
|
'version' => '1.1.0.0',
|
||||||
|
'reference' => 'distref-as-no-source',
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
// @phpstan-ignore-next-line
|
// @phpstan-ignore-next-line
|
||||||
'install_path' => $dir . '/vendor/a/provider',
|
'install_path' => $dir . '/vendor/a/provider',
|
||||||
'aliases' => array(),
|
'aliases' => array(),
|
||||||
'reference' => 'distref-as-no-source',
|
|
||||||
'dev_requirement' => false,
|
'dev_requirement' => false,
|
||||||
),
|
),
|
||||||
'a/provider2' => array(
|
'a/provider2' => array(
|
||||||
'pretty_version' => '1.2',
|
'pretty_version' => '1.2',
|
||||||
'version' => '1.2.0.0',
|
'version' => '1.2.0.0',
|
||||||
|
'reference' => 'distref-as-installed-from-dist',
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
// @phpstan-ignore-next-line
|
// @phpstan-ignore-next-line
|
||||||
'install_path' => $dir . '/vendor/a/provider2',
|
'install_path' => $dir . '/vendor/a/provider2',
|
||||||
'aliases' => array(
|
'aliases' => array(
|
||||||
'1.4',
|
'1.4',
|
||||||
),
|
),
|
||||||
'reference' => 'distref-as-installed-from-dist',
|
|
||||||
'dev_requirement' => false,
|
'dev_requirement' => false,
|
||||||
),
|
),
|
||||||
'b/replacer' => array(
|
'b/replacer' => array(
|
||||||
'pretty_version' => '2.2',
|
'pretty_version' => '2.2',
|
||||||
'version' => '2.2.0.0',
|
'version' => '2.2.0.0',
|
||||||
|
'reference' => null,
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
// @phpstan-ignore-next-line
|
// @phpstan-ignore-next-line
|
||||||
'install_path' => $dir . '/vendor/b/replacer',
|
'install_path' => $dir . '/vendor/b/replacer',
|
||||||
'aliases' => array(),
|
'aliases' => array(),
|
||||||
'reference' => null,
|
|
||||||
'dev_requirement' => false,
|
'dev_requirement' => false,
|
||||||
),
|
),
|
||||||
'c/c' => array(
|
'c/c' => array(
|
||||||
'pretty_version' => '3.0',
|
'pretty_version' => '3.0',
|
||||||
'version' => '3.0.0.0',
|
'version' => '3.0.0.0',
|
||||||
|
'reference' => null,
|
||||||
'type' => 'library',
|
'type' => 'library',
|
||||||
'install_path' => '/foo/bar/vendor/c/c',
|
'install_path' => '/foo/bar/vendor/c/c',
|
||||||
'aliases' => array(),
|
'aliases' => array(),
|
||||||
'reference' => null,
|
|
||||||
'dev_requirement' => true,
|
'dev_requirement' => true,
|
||||||
),
|
),
|
||||||
'foo/impl' => array(
|
'foo/impl' => array(
|
||||||
|
@ -105,10 +105,10 @@ return array(
|
||||||
'meta/package' => array(
|
'meta/package' => array(
|
||||||
'pretty_version' => '3.0',
|
'pretty_version' => '3.0',
|
||||||
'version' => '3.0.0.0',
|
'version' => '3.0.0.0',
|
||||||
|
'reference' => null,
|
||||||
'type' => 'metapackage',
|
'type' => 'metapackage',
|
||||||
'install_path' => null,
|
'install_path' => null,
|
||||||
'aliases' => array(),
|
'aliases' => array(),
|
||||||
'reference' => null,
|
|
||||||
'dev_requirement' => false,
|
'dev_requirement' => false,
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|
|
@ -141,7 +141,7 @@ abstract class TestCase extends \PHPUnit\Framework\TestCase
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $version
|
* @param string $version
|
||||||
* @return AliasPackage|RootAliasPackage|CompleteAliasPackage
|
* @return ($package is RootPackage ? RootAliasPackage : ($package is CompletePackage ? CompleteAliasPackage : AliasPackage))
|
||||||
*/
|
*/
|
||||||
protected function getAliasPackage(Package $package, string $version): AliasPackage
|
protected function getAliasPackage(Package $package, string $version): AliasPackage
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue