123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474 |
- <?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.
- */
- namespace Composer\Test\Package\Loader;
- use Composer\Package\Loader\ValidatingArrayLoader;
- use Composer\Package\Loader\InvalidPackageException;
- use Composer\Test\TestCase;
- class ValidatingArrayLoaderTest extends TestCase
- {
- /**
- * @dataProvider successProvider
- */
- public function testLoadSuccess($config)
- {
- $internalLoader = $this->getMockBuilder('Composer\Package\Loader\LoaderInterface')->getMock();
- $internalLoader
- ->expects($this->once())
- ->method('load')
- ->with($config);
- $loader = new ValidatingArrayLoader($internalLoader, true, null, ValidatingArrayLoader::CHECK_ALL);
- $loader->load($config);
- }
- public function successProvider()
- {
- return array(
- array( // minimal
- array(
- 'name' => 'foo/bar',
- ),
- ),
- array( // complete
- array(
- 'name' => 'foo/bar',
- 'description' => 'Foo bar',
- 'version' => '1.0.0',
- 'type' => 'library',
- 'keywords' => array('a', 'b_c', 'D E', 'éîüø', '微信'),
- 'homepage' => 'https://foo.com',
- 'time' => '2010-10-10T10:10:10+00:00',
- 'license' => 'MIT',
- 'authors' => array(
- array(
- 'name' => 'Alice',
- 'email' => 'alice@example.org',
- 'role' => 'Lead',
- 'homepage' => 'http://example.org',
- ),
- array(
- 'name' => 'Bob',
- 'homepage' => '',
- ),
- ),
- 'support' => array(
- 'email' => 'mail@example.org',
- 'issues' => 'http://example.org/',
- 'forum' => 'http://example.org/',
- 'wiki' => 'http://example.org/',
- 'source' => 'http://example.org/',
- 'irc' => 'irc://example.org/example',
- 'rss' => 'http://example.org/rss',
- 'chat' => 'http://example.org/chat',
- ),
- 'funding' => array(
- array(
- 'type' => 'example',
- 'url' => 'https://example.org/fund'
- ),
- array(
- 'url' => 'https://example.org/fund'
- ),
- ),
- 'require' => array(
- 'a/b' => '1.*',
- 'b/c' => '~2',
- 'example' => '>2.0-dev,<2.4-dev',
- 'composer-runtime-api' => '*',
- ),
- 'require-dev' => array(
- 'a/b' => '1.*',
- 'b/c' => '*',
- 'example' => '>2.0-dev,<2.4-dev',
- ),
- 'conflict' => array(
- 'a/b' => '1.*',
- 'b/c' => '>2.7',
- 'example' => '>2.0-dev,<2.4-dev',
- ),
- 'replace' => array(
- 'a/b' => '1.*',
- 'example' => '>2.0-dev,<2.4-dev',
- ),
- 'provide' => array(
- 'a/b' => '1.*',
- 'example' => '>2.0-dev,<2.4-dev',
- ),
- 'suggest' => array(
- 'foo/bar' => 'Foo bar is very useful',
- ),
- 'autoload' => array(
- 'psr-0' => array(
- 'Foo\\Bar' => 'src/',
- '' => 'fallback/libs/',
- ),
- 'classmap' => array(
- 'dir/',
- 'dir2/file.php',
- ),
- 'files' => array(
- 'functions.php',
- ),
- ),
- 'include-path' => array(
- 'lib/',
- ),
- 'target-dir' => 'Foo/Bar',
- 'minimum-stability' => 'dev',
- 'repositories' => array(
- array(
- 'type' => 'composer',
- 'url' => 'https://repo.packagist.org/',
- ),
- ),
- 'config' => array(
- 'bin-dir' => 'bin',
- 'vendor-dir' => 'vendor',
- 'process-timeout' => 10000,
- ),
- 'archive' => array(
- 'exclude' => array('/foo/bar', 'baz', '!/foo/bar/baz'),
- ),
- 'scripts' => array(
- 'post-update-cmd' => 'Foo\\Bar\\Baz::doSomething',
- 'post-install-cmd' => array(
- 'Foo\\Bar\\Baz::doSomething',
- ),
- ),
- 'extra' => array(
- 'random' => array('stuff' => array('deeply' => 'nested')),
- 'branch-alias' => array(
- 'dev-master' => '2.0-dev',
- 'dev-old' => '1.0.x-dev',
- '3.x-dev' => '3.1.x-dev',
- ),
- ),
- 'bin' => array(
- 'bin/foo',
- 'bin/bar',
- ),
- 'transport-options' => array('ssl' => array('local_cert' => '/opt/certs/test.pem')),
- ),
- ),
- array( // test licenses as array
- array(
- 'name' => 'foo/bar',
- 'license' => array('MIT', 'WTFPL'),
- ),
- ),
- array( // test bin as string
- array(
- 'name' => 'foo/bar',
- 'bin' => 'bin1',
- ),
- ),
- array( // package name with dashes
- array(
- 'name' => 'foo/bar-baz',
- ),
- ),
- array( // package name with dashes
- array(
- 'name' => 'foo/bar--baz',
- ),
- ),
- array( // package name with dashes
- array(
- 'name' => 'foo/b-ar--ba-z',
- ),
- ),
- array( // package name with dashes
- array(
- 'name' => 'npm-asset/angular--core',
- ),
- ),
- );
- }
- /**
- * @dataProvider errorProvider
- */
- public function testLoadFailureThrowsException($config, $expectedErrors)
- {
- $internalLoader = $this->getMockBuilder('Composer\Package\Loader\LoaderInterface')->getMock();
- $loader = new ValidatingArrayLoader($internalLoader, true, null, ValidatingArrayLoader::CHECK_ALL);
- try {
- $loader->load($config);
- $this->fail('Expected exception to be thrown');
- } catch (InvalidPackageException $e) {
- $errors = $e->getErrors();
- sort($expectedErrors);
- sort($errors);
- $this->assertEquals($expectedErrors, $errors);
- }
- }
- /**
- * @dataProvider warningProvider
- */
- public function testLoadWarnings($config, $expectedWarnings)
- {
- $internalLoader = $this->getMockBuilder('Composer\Package\Loader\LoaderInterface')->getMock();
- $loader = new ValidatingArrayLoader($internalLoader, true, null, ValidatingArrayLoader::CHECK_ALL);
- $loader->load($config);
- $warnings = $loader->getWarnings();
- sort($expectedWarnings);
- sort($warnings);
- $this->assertEquals($expectedWarnings, $warnings);
- }
- /**
- * @dataProvider warningProvider
- */
- public function testLoadSkipsWarningDataWhenIgnoringErrors($config, $expectedWarnings, $mustCheck = true)
- {
- if (!$mustCheck) {
- $this->assertTrue(true);
- return;
- }
- $internalLoader = $this->getMockBuilder('Composer\Package\Loader\LoaderInterface')->getMock();
- $internalLoader
- ->expects($this->once())
- ->method('load')
- ->with(array('name' => 'a/b'));
- $loader = new ValidatingArrayLoader($internalLoader, true, null, ValidatingArrayLoader::CHECK_ALL);
- $config['name'] = 'a/b';
- $loader->load($config);
- }
- public function errorProvider()
- {
- $invalidNames = array(
- 'foo',
- 'foo/-bar-',
- 'foo/-bar',
- );
- $invalidNaming = array();
- foreach($invalidNames as $invalidName) {
- $invalidNaming[] = array(
- array(
- 'name' => $invalidName,
- ),
- array(
- "name : invalid value ($invalidName), must match [A-Za-z0-9][A-Za-z0-9_.-]*/[A-Za-z0-9][A-Za-z0-9_.-]*",
- ),
- );
- }
- return array_merge($invalidNaming, array(
- array(
- array(
- 'name' => 'foo/bar',
- 'homepage' => 43,
- ),
- array(
- 'homepage : should be a string, integer given',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'support' => array(
- 'source' => array(),
- ),
- ),
- array(
- 'support.source : invalid value, must be a string',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'autoload' => 'strings',
- ),
- array(
- 'autoload : should be an array, string given',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'autoload' => array(
- 'psr0' => array(
- 'foo' => 'src',
- ),
- ),
- ),
- array(
- 'autoload : invalid value (psr0), must be one of psr-0, psr-4, classmap, files, exclude-from-classmap',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'transport-options' => 'test',
- ),
- array(
- 'transport-options : should be an array, string given',
- ),
- ),
- ));
- }
- public function warningProvider()
- {
- $invalidNames = array(
- 'fo--oo/bar',
- 'fo-oo/bar__baz',
- 'fo-oo/bar_.baz',
- 'foo/bar---baz',
- );
- $invalidNaming = array();
- foreach($invalidNames as $invalidName) {
- $invalidNaming[] = array(
- array(
- 'name' => $invalidName,
- ),
- array(
- "Deprecation warning: Your package name $invalidName is invalid, it should have a vendor name, a forward slash, and a package name. The vendor and package name can be words separated by -, . or _. The complete name should match \"^[a-z0-9]([_.-]?[a-z0-9]+)*/[a-z0-9](([_.]?|-{0,2})[a-z0-9]+)*$\". Make sure you fix this as Composer 2.0 will error.",
- ),
- false,
- );
- }
- return array_merge($invalidNaming, array(
- array(
- array(
- 'name' => 'foo/bar',
- 'homepage' => 'foo:bar',
- ),
- array(
- 'homepage : invalid value (foo:bar), must be an http/https URL',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar.json',
- ),
- array(
- 'Deprecation warning: Your package name foo/bar.json is invalid, package names can not end in .json, consider renaming it or perhaps using a -json suffix instead. Make sure you fix this as Composer 2.0 will error.',
- ),
- ),
- array(
- array(
- 'name' => 'com1/foo',
- ),
- array(
- 'Deprecation warning: Your package name com1/foo is reserved, package and vendor names can not match any of: nul, con, prn, aux, com1, com2, com3, com4, com5, com6, com7, com8, com9, lpt1, lpt2, lpt3, lpt4, lpt5, lpt6, lpt7, lpt8, lpt9. Make sure you fix this as Composer 2.0 will error.',
- ),
- ),
- array(
- array(
- 'name' => 'Foo/Bar',
- ),
- array(
- 'Deprecation warning: Your package name Foo/Bar is invalid, it should not contain uppercase characters. We suggest using foo/bar instead. Make sure you fix this as Composer 2.0 will error.',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'support' => array(
- 'source' => 'foo:bar',
- 'forum' => 'foo:bar',
- 'issues' => 'foo:bar',
- 'wiki' => 'foo:bar',
- 'chat' => 'foo:bar',
- ),
- ),
- array(
- 'support.source : invalid value (foo:bar), must be an http/https URL',
- 'support.forum : invalid value (foo:bar), must be an http/https URL',
- 'support.issues : invalid value (foo:bar), must be an http/https URL',
- 'support.wiki : invalid value (foo:bar), must be an http/https URL',
- 'support.chat : invalid value (foo:bar), must be an http/https URL',
- ),
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'require' => array(
- 'foo/baz' => '*',
- 'bar/baz' => '>=1.0',
- 'bar/hacked' => '@stable',
- 'bar/woo' => '1.0.0',
- ),
- ),
- array(
- 'require.foo/baz : unbound version constraints (*) should be avoided',
- 'require.bar/baz : unbound version constraints (>=1.0) should be avoided',
- 'require.bar/hacked : unbound version constraints (@stable) should be avoided',
- 'require.bar/woo : exact version constraints (1.0.0) should be avoided if the package follows semantic versioning',
- ),
- false,
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'require' => array(
- 'Foo/Baz' => '^1.0',
- ),
- ),
- array(
- 'Deprecation warning: require.Foo/Baz is invalid, it should not contain uppercase characters. Please use foo/baz instead. Make sure you fix this as Composer 2.0 will error.',
- ),
- false,
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'require' => array(
- 'bar/unstable' => '0.3.0',
- ),
- ),
- array(
- // using an exact version constraint for an unstable version should not trigger a warning
- ),
- false,
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'extra' => array(
- 'branch-alias' => array(
- '5.x-dev' => '3.1.x-dev',
- ),
- ),
- ),
- array(
- 'extra.branch-alias.5.x-dev : the target branch (3.1.x-dev) is not a valid numeric alias for this version',
- ),
- false,
- ),
- array(
- array(
- 'name' => 'foo/bar',
- 'extra' => array(
- 'branch-alias' => array(
- '5.x-dev' => '3.1-dev',
- ),
- ),
- ),
- array(
- 'extra.branch-alias.5.x-dev : the target branch (3.1-dev) is not a valid numeric alias for this version',
- ),
- false,
- ),
- ));
- }
- }
|