|
@@ -13,6 +13,7 @@
|
|
namespace Composer\Test\Package\Version;
|
|
namespace Composer\Test\Package\Version;
|
|
|
|
|
|
use Composer\Package\Version\VersionSelector;
|
|
use Composer\Package\Version\VersionSelector;
|
|
|
|
+use Composer\Package\Version\VersionParser;
|
|
|
|
|
|
class VersionSelectorTest extends \PHPUnit_Framework_TestCase
|
|
class VersionSelectorTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
{
|
|
@@ -57,15 +58,19 @@ class VersionSelectorTest extends \PHPUnit_Framework_TestCase
|
|
/**
|
|
/**
|
|
* @dataProvider getRecommendedRequireVersionPackages
|
|
* @dataProvider getRecommendedRequireVersionPackages
|
|
*/
|
|
*/
|
|
- public function testFindRecommendedRequireVersion($prettyVersion, $isDev, $stability, $expectedVersion)
|
|
|
|
|
|
+ public function testFindRecommendedRequireVersion($prettyVersion, $isDev, $stability, $expectedVersion, $branchAlias = null)
|
|
{
|
|
{
|
|
$pool = $this->createMockPool();
|
|
$pool = $this->createMockPool();
|
|
$versionSelector = new VersionSelector($pool);
|
|
$versionSelector = new VersionSelector($pool);
|
|
|
|
+ $versionParser = new VersionParser();
|
|
|
|
|
|
$package = $this->getMock('\Composer\Package\PackageInterface');
|
|
$package = $this->getMock('\Composer\Package\PackageInterface');
|
|
$package->expects($this->any())
|
|
$package->expects($this->any())
|
|
->method('getPrettyVersion')
|
|
->method('getPrettyVersion')
|
|
->will($this->returnValue($prettyVersion));
|
|
->will($this->returnValue($prettyVersion));
|
|
|
|
+ $package->expects($this->any())
|
|
|
|
+ ->method('getVersion')
|
|
|
|
+ ->will($this->returnValue($versionParser->normalize($prettyVersion)));
|
|
$package->expects($this->any())
|
|
$package->expects($this->any())
|
|
->method('isDev')
|
|
->method('isDev')
|
|
->will($this->returnValue($isDev));
|
|
->will($this->returnValue($isDev));
|
|
@@ -73,6 +78,11 @@ class VersionSelectorTest extends \PHPUnit_Framework_TestCase
|
|
->method('getStability')
|
|
->method('getStability')
|
|
->will($this->returnValue($stability));
|
|
->will($this->returnValue($stability));
|
|
|
|
|
|
|
|
+ $branchAlias = $branchAlias === null ? array() : array('branch-alias' => array($prettyVersion => $branchAlias));
|
|
|
|
+ $package->expects($this->any())
|
|
|
|
+ ->method('getExtra')
|
|
|
|
+ ->will($this->returnValue($branchAlias));
|
|
|
|
+
|
|
$recommended = $versionSelector->findRecommendedRequireVersion($package);
|
|
$recommended = $versionSelector->findRecommendedRequireVersion($package);
|
|
|
|
|
|
// assert that the recommended version is what we expect
|
|
// assert that the recommended version is what we expect
|
|
@@ -82,19 +92,26 @@ class VersionSelectorTest extends \PHPUnit_Framework_TestCase
|
|
public function getRecommendedRequireVersionPackages()
|
|
public function getRecommendedRequireVersionPackages()
|
|
{
|
|
{
|
|
return array(
|
|
return array(
|
|
- // real version, is dev package, stability, expected recommendation
|
|
|
|
|
|
+ // real version, is dev package, stability, expected recommendation, [branch-alias]
|
|
array('1.2.1', false, 'stable', '~1.2'),
|
|
array('1.2.1', false, 'stable', '~1.2'),
|
|
array('1.2', false, 'stable', '~1.2'),
|
|
array('1.2', false, 'stable', '~1.2'),
|
|
array('v1.2.1', false, 'stable', '~1.2'),
|
|
array('v1.2.1', false, 'stable', '~1.2'),
|
|
array('3.1.2-pl2', false, 'stable', '~3.1'),
|
|
array('3.1.2-pl2', false, 'stable', '~3.1'),
|
|
array('3.1.2-patch', false, 'stable', '~3.1'),
|
|
array('3.1.2-patch', false, 'stable', '~3.1'),
|
|
// for non-stable versions, we add ~, but don't try the (1.2.1 -> 1.2) transformation
|
|
// for non-stable versions, we add ~, but don't try the (1.2.1 -> 1.2) transformation
|
|
- array('2.0-beta.1', false, 'beta', '~2.0-beta.1'),
|
|
|
|
- array('3.1.2-alpha5', false, 'alpha', '~3.1.2-alpha5'),
|
|
|
|
- array('3.0-RC2', false, 'RC', '~3.0-RC2'),
|
|
|
|
- // dev packages are not touched at all
|
|
|
|
|
|
+ array('2.0-beta.1', false, 'beta', '~2.0@beta'),
|
|
|
|
+ array('3.1.2-alpha5', false, 'alpha', '~3.1@alpha'),
|
|
|
|
+ array('3.0-RC2', false, 'RC', '~3.0@RC'),
|
|
|
|
+ // date-based versions are not touched at all
|
|
|
|
+ array('v20121020', false, 'stable', 'v20121020'),
|
|
|
|
+ array('v20121020.2', false, 'stable', 'v20121020.2'),
|
|
|
|
+ // dev packages without alias are not touched at all
|
|
array('dev-master', true, 'dev', 'dev-master'),
|
|
array('dev-master', true, 'dev', 'dev-master'),
|
|
array('3.1.2-dev', true, 'dev', '3.1.2-dev'),
|
|
array('3.1.2-dev', true, 'dev', '3.1.2-dev'),
|
|
|
|
+ // dev packages with alias inherit the alias
|
|
|
|
+ array('dev-master', true, 'dev', '~2.1@dev', '2.1.x-dev'),
|
|
|
|
+ array('dev-master', true, 'dev', '~2.1@dev', '2.1.3.x-dev'),
|
|
|
|
+ array('dev-master', true, 'dev', '~2.0@dev', '2.x-dev'),
|
|
);
|
|
);
|
|
}
|
|
}
|
|
|
|
|