mirror of
https://github.com/composer/composer
synced 2025-05-09 16:42:57 +00:00

any tests that use the filesystem should have their own unique directory, as we run our test suite in parallel and cleanup of tests (removing directories) should not interfere with currently running tests
110 lines
3 KiB
PHP
110 lines
3 KiB
PHP
<?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\TestCase;
|
|
|
|
class FilesystemRepositoryTest extends TestCase
|
|
{
|
|
public function testRepositoryRead()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
|
|
$repository = new FilesystemRepository($json);
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue(array(
|
|
array('name' => 'package1', 'version' => '1.0.0-beta', 'type' => 'vendor'),
|
|
)));
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(true));
|
|
|
|
$packages = $repository->getPackages();
|
|
|
|
$this->assertSame(1, count($packages));
|
|
$this->assertSame('package1', $packages[0]->getName());
|
|
$this->assertSame('1.0.0.0-beta', $packages[0]->getVersion());
|
|
$this->assertSame('vendor', $packages[0]->getType());
|
|
}
|
|
|
|
/**
|
|
* @expectedException \Composer\Repository\InvalidRepositoryException
|
|
*/
|
|
public function testCorruptedRepositoryFile()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
|
|
$repository = new FilesystemRepository($json);
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue('foo'));
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(true));
|
|
|
|
$repository->getPackages();
|
|
}
|
|
|
|
public function testUnexistentRepositoryFile()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
|
|
$repository = new FilesystemRepository($json);
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(false));
|
|
|
|
$this->assertEquals(array(), $repository->getPackages());
|
|
}
|
|
|
|
public function testRepositoryWrite()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
|
|
$repository = new FilesystemRepository($json);
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue(array()));
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(true));
|
|
$json
|
|
->expects($this->once())
|
|
->method('write')
|
|
->with(array(
|
|
array('name' => 'mypkg', 'type' => 'library', 'version' => '0.1.10', 'version_normalized' => '0.1.10.0'),
|
|
));
|
|
|
|
$repository->addPackage($this->getPackage('mypkg', '0.1.10'));
|
|
$repository->write();
|
|
}
|
|
|
|
private function createJsonFileMock()
|
|
{
|
|
return $this->getMockBuilder('Composer\Json\JsonFile')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
}
|