ArrayLoaderTest.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  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\Loader;
  12. use Composer\Package\Loader\ArrayLoader;
  13. use Composer\Package\Dumper\ArrayDumper;
  14. class ArrayLoaderTest extends \PHPUnit_Framework_TestCase
  15. {
  16. /**
  17. * @var ArrayLoader
  18. */
  19. private $loader;
  20. public function setUp()
  21. {
  22. $this->loader = new ArrayLoader(null);
  23. }
  24. public function testSelfVersion()
  25. {
  26. $config = array(
  27. 'name' => 'A',
  28. 'version' => '1.2.3.4',
  29. 'replace' => array(
  30. 'foo' => 'self.version',
  31. ),
  32. );
  33. $package = $this->loader->load($config);
  34. $replaces = $package->getReplaces();
  35. $this->assertEquals('== 1.2.3.4', (string) $replaces['foo']->getConstraint());
  36. }
  37. public function testTypeDefault()
  38. {
  39. $config = array(
  40. 'name' => 'A',
  41. 'version' => '1.0',
  42. );
  43. $package = $this->loader->load($config);
  44. $this->assertEquals('library', $package->getType());
  45. $config = array(
  46. 'name' => 'A',
  47. 'version' => '1.0',
  48. 'type' => 'foo',
  49. );
  50. $package = $this->loader->load($config);
  51. $this->assertEquals('foo', $package->getType());
  52. }
  53. public function testNormalizedVersionOptimization()
  54. {
  55. $config = array(
  56. 'name' => 'A',
  57. 'version' => '1.2.3',
  58. );
  59. $package = $this->loader->load($config);
  60. $this->assertEquals('1.2.3.0', $package->getVersion());
  61. $config = array(
  62. 'name' => 'A',
  63. 'version' => '1.2.3',
  64. 'version_normalized' => '1.2.3.4',
  65. );
  66. $package = $this->loader->load($config);
  67. $this->assertEquals('1.2.3.4', $package->getVersion());
  68. }
  69. public function testParseDumpProvider()
  70. {
  71. $validConfig = array(
  72. 'name' => 'A/B',
  73. 'version' => '1.2.3',
  74. 'version_normalized' => '1.2.3.0',
  75. 'description' => 'Foo bar',
  76. 'type' => 'library',
  77. 'keywords' => array('a', 'b', 'c'),
  78. 'homepage' => 'http://example.com',
  79. 'license' => array('MIT', 'GPLv3'),
  80. 'authors' => array(
  81. array('name' => 'Bob', 'email' => 'bob@example.org', 'homepage' => 'example.org', 'role' => 'Developer'),
  82. ),
  83. 'require' => array(
  84. 'foo/bar' => '1.0',
  85. ),
  86. 'require-dev' => array(
  87. 'foo/baz' => '1.0',
  88. ),
  89. 'replace' => array(
  90. 'foo/qux' => '1.0',
  91. ),
  92. 'conflict' => array(
  93. 'foo/quux' => '1.0',
  94. ),
  95. 'provide' => array(
  96. 'foo/quuux' => '1.0',
  97. ),
  98. 'autoload' => array(
  99. 'psr-0' => array('Ns\Prefix' => 'path'),
  100. 'classmap' => array('path', 'path2'),
  101. ),
  102. 'include-path' => array('path3', 'path4'),
  103. 'target-dir' => 'some/prefix',
  104. 'extra' => array('random' => array('things' => 'of', 'any' => 'shape')),
  105. 'bin' => array('bin1', 'bin/foo'),
  106. 'archive' => array(
  107. 'exclude' => array('/foo/bar', 'baz', '!/foo/bar/baz'),
  108. ),
  109. 'transport-options' => array('ssl' => array('local_cert' => '/opt/certs/test.pem')),
  110. 'abandoned' => 'foo/bar',
  111. );
  112. $validTestArguments = array($validConfig);
  113. $argumentsToProvide = array($validTestArguments);
  114. return $argumentsToProvide;
  115. }
  116. protected function fixConfigWhenLoadConfigIsFalse($config)
  117. {
  118. $expectedConfig = $config;
  119. unset($expectedConfig['transport-options']);
  120. return $expectedConfig;
  121. }
  122. /**
  123. * The default parser should default to loading the config as this
  124. * allows require-dev libraries to have transport options included.
  125. *
  126. * @dataProvider testParseDumpProvider
  127. */
  128. public function testParseDumpDefaultLoadConfig($config)
  129. {
  130. $package = $this->loader->load($config);
  131. $dumper = new ArrayDumper;
  132. $expectedConfig = $config;
  133. $expectedConfig = $this->fixConfigWhenLoadConfigIsFalse($config);
  134. $this->assertEquals($expectedConfig, $dumper->dump($package));
  135. }
  136. /**
  137. * @dataProvider testParseDumpProvider
  138. */
  139. public function testParseDumpTrueLoadConfig($config)
  140. {
  141. $loader = new ArrayLoader(null, true);
  142. $package = $loader->load($config);
  143. $dumper = new ArrayDumper;
  144. $expectedConfig = $config;
  145. $this->assertEquals($expectedConfig, $dumper->dump($package));
  146. }
  147. /**
  148. * @dataProvider testParseDumpProvider
  149. */
  150. public function testParseDumpFalseLoadConfig($config)
  151. {
  152. $loader = new ArrayLoader(null, false);
  153. $package = $loader->load($config);
  154. $dumper = new ArrayDumper;
  155. $expectedConfig = $this->fixConfigWhenLoadConfigIsFalse($config);
  156. $this->assertEquals($expectedConfig, $dumper->dump($package));
  157. }
  158. public function testPackageWithBranchAlias()
  159. {
  160. $config = array(
  161. 'name' => 'A',
  162. 'version' => 'dev-master',
  163. 'extra' => array('branch-alias' => array('dev-master' => '1.0.x-dev')),
  164. );
  165. $package = $this->loader->load($config);
  166. $this->assertInstanceOf('Composer\Package\AliasPackage', $package);
  167. $this->assertEquals('1.0.x-dev', $package->getPrettyVersion());
  168. $config = array(
  169. 'name' => 'A',
  170. 'version' => 'dev-master',
  171. 'extra' => array('branch-alias' => array('dev-master' => '1.0-dev')),
  172. );
  173. $package = $this->loader->load($config);
  174. $this->assertInstanceOf('Composer\Package\AliasPackage', $package);
  175. $this->assertEquals('1.0.x-dev', $package->getPrettyVersion());
  176. $config = array(
  177. 'name' => 'B',
  178. 'version' => '4.x-dev',
  179. 'extra' => array('branch-alias' => array('4.x-dev' => '4.0.x-dev')),
  180. );
  181. $package = $this->loader->load($config);
  182. $this->assertInstanceOf('Composer\Package\AliasPackage', $package);
  183. $this->assertEquals('4.0.x-dev', $package->getPrettyVersion());
  184. $config = array(
  185. 'name' => 'B',
  186. 'version' => '4.x-dev',
  187. 'extra' => array('branch-alias' => array('4.x-dev' => '4.0-dev')),
  188. );
  189. $package = $this->loader->load($config);
  190. $this->assertInstanceOf('Composer\Package\AliasPackage', $package);
  191. $this->assertEquals('4.0.x-dev', $package->getPrettyVersion());
  192. $config = array(
  193. 'name' => 'C',
  194. 'version' => '4.x-dev',
  195. 'extra' => array('branch-alias' => array('4.x-dev' => '3.4.x-dev')),
  196. );
  197. $package = $this->loader->load($config);
  198. $this->assertInstanceOf('Composer\Package\CompletePackage', $package);
  199. $this->assertEquals('4.x-dev', $package->getPrettyVersion());
  200. }
  201. public function testAbandoned()
  202. {
  203. $config = array(
  204. 'name' => 'A',
  205. 'version' => '1.2.3.4',
  206. 'abandoned' => 'foo/bar',
  207. );
  208. $package = $this->loader->load($config);
  209. $this->assertTrue($package->isAbandoned());
  210. $this->assertEquals('foo/bar', $package->getReplacementPackage());
  211. }
  212. public function testNotAbandoned()
  213. {
  214. $config = array(
  215. 'name' => 'A',
  216. 'version' => '1.2.3.4',
  217. );
  218. $package = $this->loader->load($config);
  219. $this->assertFalse($package->isAbandoned());
  220. }
  221. public function pluginApiVersions()
  222. {
  223. return array(
  224. array('1.0'),
  225. array('1.0.0'),
  226. array('1.0.0.0'),
  227. array('1'),
  228. array('=1.0.0'),
  229. array('==1.0'),
  230. array('~1.0.0'),
  231. array('*'),
  232. array('3.0.*'),
  233. array('@stable'),
  234. array('1.0.0@stable'),
  235. array('^5.1'),
  236. array('>=1.0.0 <2.5'),
  237. array('x'),
  238. array('1.0.0-dev'),
  239. );
  240. }
  241. /**
  242. * @dataProvider pluginApiVersions
  243. */
  244. public function testPluginApiVersionAreKeptAsDeclared($apiVersion)
  245. {
  246. $links = $this->loader->parseLinks('Plugin', '9.9.9', '', array('composer-plugin-api' => $apiVersion));
  247. $this->assertArrayHasKey('composer-plugin-api', $links);
  248. $this->assertSame($apiVersion, $links['composer-plugin-api']->getConstraint()->getPrettyString());
  249. }
  250. public function testPluginApiVersionDoesSupportSelfVersion()
  251. {
  252. $links = $this->loader->parseLinks('Plugin', '6.6.6', '', array('composer-plugin-api' => 'self.version'));
  253. $this->assertArrayHasKey('composer-plugin-api', $links);
  254. $this->assertSame('6.6.6', $links['composer-plugin-api']->getConstraint()->getPrettyString());
  255. }
  256. }