Merge remote-tracking branch 'bashofmann/master'

main
Jordi Boggiano 12 years ago
commit b1eb47bdd0

@ -126,7 +126,7 @@ class PearRepository extends ArrayRepository
/**
* @param string $categoryLink
* @throws TransportException
* @throws InvalidArgumentException
* @throws \InvalidArgumentException
*/
private function fetchPearPackages($categoryLink)
{
@ -212,7 +212,7 @@ class PearRepository extends ArrayRepository
/**
* @todo Improve dependencies resolution of pear packages.
* @param array $options
* @param array $depsOptions
* @return array
*/
private function parseDependenciesOptions(array $depsOptions)
@ -257,7 +257,7 @@ class PearRepository extends ArrayRepository
/**
* @param string $deps
* @return array
* @throws InvalidArgumentException
* @throws \InvalidArgumentException
*/
private function parseDependencies($deps)
{
@ -284,7 +284,7 @@ class PearRepository extends ArrayRepository
/**
* @param string $packagesLink
* @return void
* @throws InvalidArgumentException
* @throws \InvalidArgumentException
*/
private function fetchPear2Packages($packagesLink)
{
@ -358,7 +358,7 @@ class PearRepository extends ArrayRepository
/**
* @param string $url
* @return DOMDocument
* @return \DOMDocument
*/
private function requestXml($url)
{
@ -367,7 +367,7 @@ class PearRepository extends ArrayRepository
throw new \UnexpectedValueException('The PEAR channel at '.$url.' did not respond.');
}
$dom = new \DOMDocument('1.0', 'UTF-8');
$dom->loadXML($content, LIBXML_NOERROR);
$dom->loadXML($content);
return $dom;
}

@ -0,0 +1,127 @@
<?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\Repository;
use Composer\Repository\FilesystemRepository;
use Composer\Test\TestCase;
class PearRepositoryTest extends TestCase
{
/**
* @var PearRepository
*/
private $repository;
/**
* @var \PHPUnit_Framework_MockObject_MockObject
*/
private $remoteFilesystem;
/**
* @dataProvider repositoryDataProvider
* @param string $url
* @param array $expectedPackages
*/
public function testRepositoryRead($url, array $expectedPackages)
{
$repoConfig = array(
'url' => $url
);
$this->createRepository($repoConfig);
foreach ($expectedPackages as $expectedPackage) {
$this->assertInstanceOf('Composer\Package\PackageInterface',
$this->repository->findPackage($expectedPackage['name'], $expectedPackage['version']),
'Expected package ' . $expectedPackage['name'] . ', version ' . $expectedPackage['version'] .
' not found in pear channel ' . $url
);
}
}
public function repositoryDataProvider()
{
return array(
array(
'pear.phpunit.de',
array(
array('name' => 'pear-phpunit/PHPUnit_MockObject', 'version' => '1.1.1'),
array('name' => 'pear-phpunit/PHPUnit', 'version' => '3.6.10'),
)
),
array(
'pear.php.net',
array(
array('name' => 'pear-pear/PEAR', 'version' => '1.9.4'),
)
),
array(
'pear.pdepend.org',
array(
array('name' => 'pear-pdepend/PHP_Depend', 'version' => '1.0.5'),
)
),
array(
'pear.phpmd.org',
array(
array('name' => 'pear-phpmd/PHP_PMD', 'version' => '1.3.3'),
)
),
array(
'pear.doctrine-project.org',
array(
array('name' => 'pear-doctrine/DoctrineORM', 'version' => '2.2.2'),
)
),
array(
'pear.symfony-project.com',
array(
array('name' => 'pear-symfony/YAML', 'version' => '1.0.6'),
)
),
array(
'pear.pirum-project.org',
array(
array('name' => 'pear-pirum/Pirum', 'version' => '1.1.4'),
)
),
array(
'packages.zendframework.com',
array(
array('name' => 'pear-zf2/Zend_Code', 'version' => '2.0.0.0-beta3'),
)
),
);
}
private function createRepository($repoConfig)
{
$ioInterface = $this->getMockBuilder('Composer\IO\IOInterface')
->getMock();
$config = new \Composer\Config();
$this->remoteFilesystem = $this->getMockBuilder('Composer\Util\RemoteFilesystem')
->disableOriginalConstructor()
->getMock();
$this->repository = new PearRepository($repoConfig, $ioInterface, $config, null);
}
protected function tearDown()
{
$this->repository = null;
$this->remoteFilesystem = null;
}
}
Loading…
Cancel
Save