2012-02-19 14:54:48 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Composer.
|
|
|
|
*
|
|
|
|
* (c) Nils Adermann <naderman@naderman.de>
|
|
|
|
* Jordi Boggiano <j.boggiano@seld.be>
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
2018-11-12 14:23:32 +00:00
|
|
|
namespace Composer\Test;
|
2012-02-19 14:54:48 +00:00
|
|
|
|
2015-09-24 14:32:36 +00:00
|
|
|
use Composer\Semver\VersionParser;
|
2012-04-27 17:41:53 +00:00
|
|
|
use Composer\Package\AliasPackage;
|
2020-04-19 14:00:21 +00:00
|
|
|
use Composer\Package\RootPackageInterface;
|
|
|
|
use Composer\Package\PackageInterface;
|
2015-09-24 14:32:36 +00:00
|
|
|
use Composer\Semver\Constraint\Constraint;
|
2012-02-24 11:28:41 +00:00
|
|
|
use Composer\Util\Filesystem;
|
2016-01-26 13:03:08 +00:00
|
|
|
use Composer\Util\Silencer;
|
2017-11-04 14:52:13 +00:00
|
|
|
use PHPUnit\Framework\TestCase as BaseTestCase;
|
2016-12-22 17:14:57 +00:00
|
|
|
use Symfony\Component\Process\ExecutableFinder;
|
2020-04-19 14:00:21 +00:00
|
|
|
use Composer\Package\Loader\ArrayLoader;
|
|
|
|
use Composer\Package\BasePackage;
|
2012-02-19 14:54:48 +00:00
|
|
|
|
2017-11-04 14:52:13 +00:00
|
|
|
abstract class TestCase extends BaseTestCase
|
2012-02-19 14:54:48 +00:00
|
|
|
{
|
2012-04-29 15:28:35 +00:00
|
|
|
private static $parser;
|
2016-12-23 14:01:05 +00:00
|
|
|
private static $executableCache = array();
|
2012-04-29 15:28:35 +00:00
|
|
|
|
2016-04-01 11:07:42 +00:00
|
|
|
public static function getUniqueTmpDirectory()
|
|
|
|
{
|
|
|
|
$attempts = 5;
|
|
|
|
$root = sys_get_temp_dir();
|
|
|
|
|
|
|
|
do {
|
|
|
|
$unique = $root . DIRECTORY_SEPARATOR . uniqid('composer-test-' . rand(1000, 9000));
|
|
|
|
|
|
|
|
if (!file_exists($unique) && Silencer::call('mkdir', $unique, 0777)) {
|
|
|
|
return realpath($unique);
|
|
|
|
}
|
|
|
|
} while (--$attempts);
|
|
|
|
|
|
|
|
throw new \RuntimeException('Failed to create a unique temporary directory.');
|
|
|
|
}
|
|
|
|
|
2012-04-29 15:28:35 +00:00
|
|
|
protected static function getVersionParser()
|
|
|
|
{
|
|
|
|
if (!self::$parser) {
|
|
|
|
self::$parser = new VersionParser();
|
|
|
|
}
|
|
|
|
|
|
|
|
return self::$parser;
|
|
|
|
}
|
|
|
|
|
2012-02-19 14:55:44 +00:00
|
|
|
protected function getVersionConstraint($operator, $version)
|
|
|
|
{
|
2015-09-24 14:32:36 +00:00
|
|
|
$constraint = new Constraint(
|
2012-02-19 14:55:44 +00:00
|
|
|
$operator,
|
2012-04-29 15:28:35 +00:00
|
|
|
self::getVersionParser()->normalize($version)
|
2012-02-19 14:55:44 +00:00
|
|
|
);
|
2012-06-20 17:04:21 +00:00
|
|
|
|
|
|
|
$constraint->setPrettyString($operator.' '.$version);
|
|
|
|
|
|
|
|
return $constraint;
|
2012-02-19 14:55:44 +00:00
|
|
|
}
|
|
|
|
|
2012-08-23 13:52:40 +00:00
|
|
|
protected function getPackage($name, $version, $class = 'Composer\Package\Package')
|
2012-02-19 14:54:48 +00:00
|
|
|
{
|
2012-04-29 15:28:35 +00:00
|
|
|
$normVersion = self::getVersionParser()->normalize($version);
|
|
|
|
|
2012-08-23 13:52:40 +00:00
|
|
|
return new $class($name, $normVersion, $version);
|
2012-02-19 14:54:48 +00:00
|
|
|
}
|
2012-02-24 11:28:41 +00:00
|
|
|
|
2012-04-27 17:41:53 +00:00
|
|
|
protected function getAliasPackage($package, $version)
|
|
|
|
{
|
|
|
|
$normVersion = self::getVersionParser()->normalize($version);
|
2012-06-14 10:10:01 +00:00
|
|
|
|
2020-04-19 14:00:21 +00:00
|
|
|
$class = 'Composer\Package\AliasPackage';
|
|
|
|
if ($package instanceof RootPackageInterface) {
|
|
|
|
$class = 'Composer\Package\RootAliasPackage';
|
|
|
|
}
|
|
|
|
|
|
|
|
return new $class($package, $normVersion, $version);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function configureLinks(PackageInterface $package, array $config)
|
|
|
|
{
|
|
|
|
$arrayLoader = new ArrayLoader();
|
|
|
|
|
|
|
|
foreach (BasePackage::$supportedLinkTypes as $type => $opts) {
|
|
|
|
if (isset($config[$type])) {
|
|
|
|
$method = 'set'.ucfirst($opts['method']);
|
|
|
|
$package->{$method}(
|
|
|
|
$arrayLoader->parseLinks(
|
|
|
|
$package->getName(),
|
|
|
|
$package->getPrettyVersion(),
|
|
|
|
$opts['description'],
|
|
|
|
$config[$type]
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2012-04-27 17:41:53 +00:00
|
|
|
}
|
|
|
|
|
2016-01-21 12:01:55 +00:00
|
|
|
protected static function ensureDirectoryExistsAndClear($directory)
|
2012-02-24 11:28:41 +00:00
|
|
|
{
|
|
|
|
$fs = new Filesystem();
|
2016-01-21 12:01:55 +00:00
|
|
|
|
2012-02-24 11:28:41 +00:00
|
|
|
if (is_dir($directory)) {
|
|
|
|
$fs->removeDirectory($directory);
|
|
|
|
}
|
2016-01-21 12:01:55 +00:00
|
|
|
|
2012-02-24 11:28:41 +00:00
|
|
|
mkdir($directory, 0777, true);
|
|
|
|
}
|
2016-12-22 17:14:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check whether or not the given name is an available executable.
|
|
|
|
*
|
|
|
|
* @param string $executableName The name of the binary to test.
|
|
|
|
*
|
2017-06-22 12:33:13 +00:00
|
|
|
* @throws \PHPUnit_Framework_SkippedTestError
|
2016-12-22 17:14:57 +00:00
|
|
|
*/
|
|
|
|
protected function skipIfNotExecutable($executableName)
|
|
|
|
{
|
2016-12-23 14:01:05 +00:00
|
|
|
if (!isset(self::$executableCache[$executableName])) {
|
|
|
|
$finder = new ExecutableFinder();
|
|
|
|
self::$executableCache[$executableName] = (bool) $finder->find($executableName);
|
|
|
|
}
|
2016-12-22 17:14:57 +00:00
|
|
|
|
2016-12-23 14:01:05 +00:00
|
|
|
if (false === self::$executableCache[$executableName]) {
|
2016-12-22 17:14:57 +00:00
|
|
|
$this->markTestSkipped($executableName . ' is not found or not executable.');
|
2016-12-23 14:01:05 +00:00
|
|
|
}
|
2016-12-22 17:14:57 +00:00
|
|
|
}
|
2020-02-07 03:18:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $exception
|
|
|
|
* @param string|null $message
|
|
|
|
* @param int|null $code
|
|
|
|
*/
|
|
|
|
public function setExpectedException($exception, $message = null, $code = null)
|
|
|
|
{
|
|
|
|
if (!class_exists('PHPUnit\Framework\Error\Notice')) {
|
|
|
|
$exception = str_replace('PHPUnit\\Framework\\Error\\', 'PHPUnit_Framework_Error_', $exception);
|
|
|
|
}
|
|
|
|
if (method_exists($this, 'expectException')) {
|
|
|
|
$this->expectException($exception);
|
|
|
|
if (null !== $message) {
|
|
|
|
$this->expectExceptionMessage($message);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
parent::setExpectedException($exception, $message, $code);
|
|
|
|
}
|
|
|
|
}
|
2012-02-19 14:54:48 +00:00
|
|
|
}
|