VersionSelectorTest.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <?php
  2. /*
  3. * This file is part of Composer.
  4. *
  5. * (c) Nils Adermann <naderman@naderman.de>
  6. * Jordi Boggiano <j.boggiano@seld.be>
  7. *
  8. * For the full copyright and license information, please view the LICENSE
  9. * file that was distributed with this source code.
  10. */
  11. namespace Composer\Test\Package\Version;
  12. use Composer\Package\Version\VersionSelector;
  13. use Composer\Package\Version\VersionParser;
  14. class VersionSelectorTest extends \PHPUnit_Framework_TestCase
  15. {
  16. // A) multiple versions, get the latest one
  17. // B) targetPackageVersion will pass to pool
  18. // C) No results, throw exception
  19. public function testLatestVersionIsReturned()
  20. {
  21. $packageName = 'foobar';
  22. $package1 = $this->createMockPackage('1.2.1');
  23. $package2 = $this->createMockPackage('1.2.2');
  24. $package3 = $this->createMockPackage('1.2.0');
  25. $packages = array($package1, $package2, $package3);
  26. $pool = $this->createMockPool();
  27. $pool->expects($this->once())
  28. ->method('whatProvides')
  29. ->with($packageName, null, true)
  30. ->will($this->returnValue($packages));
  31. $versionSelector = new VersionSelector($pool);
  32. $best = $versionSelector->findBestCandidate($packageName);
  33. // 1.2.2 should be returned because it's the latest of the returned versions
  34. $this->assertEquals($package2, $best, 'Latest version should be 1.2.2');
  35. }
  36. public function testFalseReturnedOnNoPackages()
  37. {
  38. $pool = $this->createMockPool();
  39. $pool->expects($this->once())
  40. ->method('whatProvides')
  41. ->will($this->returnValue(array()));
  42. $versionSelector = new VersionSelector($pool);
  43. $best = $versionSelector->findBestCandidate('foobaz');
  44. $this->assertFalse($best, 'No versions are available returns false');
  45. }
  46. /**
  47. * @dataProvider getRecommendedRequireVersionPackages
  48. */
  49. public function testFindRecommendedRequireVersion($prettyVersion, $isDev, $stability, $expectedVersion, $branchAlias = null)
  50. {
  51. $pool = $this->createMockPool();
  52. $versionSelector = new VersionSelector($pool);
  53. $versionParser = new VersionParser();
  54. $package = $this->getMock('\Composer\Package\PackageInterface');
  55. $package->expects($this->any())
  56. ->method('getPrettyVersion')
  57. ->will($this->returnValue($prettyVersion));
  58. $package->expects($this->any())
  59. ->method('getVersion')
  60. ->will($this->returnValue($versionParser->normalize($prettyVersion)));
  61. $package->expects($this->any())
  62. ->method('isDev')
  63. ->will($this->returnValue($isDev));
  64. $package->expects($this->any())
  65. ->method('getStability')
  66. ->will($this->returnValue($stability));
  67. $branchAlias = $branchAlias === null ? array() : array('branch-alias' => array($prettyVersion => $branchAlias));
  68. $package->expects($this->any())
  69. ->method('getExtra')
  70. ->will($this->returnValue($branchAlias));
  71. $recommended = $versionSelector->findRecommendedRequireVersion($package);
  72. // assert that the recommended version is what we expect
  73. $this->assertEquals($expectedVersion, $recommended);
  74. }
  75. public function getRecommendedRequireVersionPackages()
  76. {
  77. return array(
  78. // real version, is dev package, stability, expected recommendation, [branch-alias]
  79. array('1.2.1', false, 'stable', '~1.2'),
  80. array('1.2', false, 'stable', '~1.2'),
  81. array('v1.2.1', false, 'stable', '~1.2'),
  82. array('3.1.2-pl2', false, 'stable', '~3.1'),
  83. array('3.1.2-patch', false, 'stable', '~3.1'),
  84. array('2.0-beta.1', false, 'beta', '~2.0@beta'),
  85. array('3.1.2-alpha5', false, 'alpha', '~3.1@alpha'),
  86. array('3.0-RC2', false, 'RC', '~3.0@RC'),
  87. array('0.1.0', false, 'stable', '^0.1.0'),
  88. array('0.1.3', false, 'stable', '^0.1.3'),
  89. array('0.0.3', false, 'stable', '^0.0.3'),
  90. array('0.0.3-alpha', false, 'alpha', '^0.0.3@alpha'),
  91. // date-based versions are not touched at all
  92. array('v20121020', false, 'stable', 'v20121020'),
  93. array('v20121020.2', false, 'stable', 'v20121020.2'),
  94. // dev packages without alias are not touched at all
  95. array('dev-master', true, 'dev', 'dev-master'),
  96. array('3.1.2-dev', true, 'dev', '3.1.2-dev'),
  97. // dev packages with alias inherit the alias
  98. array('dev-master', true, 'dev', '~2.1@dev', '2.1.x-dev'),
  99. array('dev-master', true, 'dev', '~2.1@dev', '2.1-dev'),
  100. array('dev-master', true, 'dev', '~2.1@dev', '2.1.3.x-dev'),
  101. array('dev-master', true, 'dev', '~2.0@dev', '2.x-dev'),
  102. array('dev-master', true, 'dev', '^0.3.0@dev', '0.3.x-dev'),
  103. array('dev-master', true, 'dev', '^0.0.3@dev', '0.0.3.x-dev'),
  104. // numeric alias
  105. array('3.x-dev', true, 'dev', '~3.0@dev', '3.0.x-dev'),
  106. array('3.x-dev', true, 'dev', '~3.0@dev', '3.0-dev'),
  107. );
  108. }
  109. private function createMockPackage($version)
  110. {
  111. $package = $this->getMock('\Composer\Package\PackageInterface');
  112. $package->expects($this->any())
  113. ->method('getVersion')
  114. ->will($this->returnValue($version));
  115. return $package;
  116. }
  117. private function createMockPool()
  118. {
  119. return $this->getMock('Composer\DependencyResolver\Pool', array(), array(), '', true);
  120. }
  121. }