239 lines
6.9 KiB
PHP
239 lines
6.9 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\Test\Package;
|
|
|
|
use Composer\Package\Locker;
|
|
|
|
class LockerTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
public function testIsLocked()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$locker = new Locker($json, $this->createRepositoryManagerMock(), 'md5');
|
|
|
|
$json
|
|
->expects($this->any())
|
|
->method('exists')
|
|
->will($this->returnValue(true));
|
|
$json
|
|
->expects($this->any())
|
|
->method('read')
|
|
->will($this->returnValue(array('packages' => array())));
|
|
|
|
$this->assertTrue($locker->isLocked());
|
|
}
|
|
|
|
public function testGetNotLockedPackages()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(false));
|
|
|
|
$this->setExpectedException('LogicException');
|
|
|
|
$locker->getLockedPackages();
|
|
}
|
|
|
|
public function testGetLockedPackages()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(true));
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue(array(
|
|
'packages' => array(
|
|
array('package' => 'pkg1', 'version' => '1.0.0-beta'),
|
|
array('package' => 'pkg2', 'version' => '0.1.10')
|
|
)
|
|
)));
|
|
|
|
$package1 = $this->createPackageMock();
|
|
$package2 = $this->createPackageMock();
|
|
|
|
$repo->getLocalRepository()
|
|
->expects($this->exactly(2))
|
|
->method('findPackage')
|
|
->with($this->logicalOr('pkg1', 'pkg2'), $this->logicalOr('1.0.0-beta', '0.1.10'))
|
|
->will($this->onConsecutiveCalls($package1, $package2));
|
|
|
|
$this->assertEquals(array($package1, $package2), $locker->getLockedPackages());
|
|
}
|
|
|
|
public function testGetPackagesWithoutRepo()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('exists')
|
|
->will($this->returnValue(true));
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue(array(
|
|
'packages' => array(
|
|
array('package' => 'pkg1', 'version' => '1.0.0-beta'),
|
|
array('package' => 'pkg2', 'version' => '0.1.10')
|
|
)
|
|
)));
|
|
|
|
$package1 = $this->createPackageMock();
|
|
$package2 = $this->createPackageMock();
|
|
|
|
$repo->getLocalRepository()
|
|
->expects($this->exactly(2))
|
|
->method('findPackage')
|
|
->with($this->logicalOr('pkg1', 'pkg2'), $this->logicalOr('1.0.0-beta', '0.1.10'))
|
|
->will($this->onConsecutiveCalls($package1, null));
|
|
|
|
$this->setExpectedException('LogicException');
|
|
|
|
$locker->getLockedPackages();
|
|
}
|
|
|
|
public function testSetLockData()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$package1 = $this->createPackageMock();
|
|
$package2 = $this->createPackageMock();
|
|
|
|
$package1
|
|
->expects($this->once())
|
|
->method('getPrettyName')
|
|
->will($this->returnValue('pkg1'));
|
|
$package1
|
|
->expects($this->once())
|
|
->method('getPrettyVersion')
|
|
->will($this->returnValue('1.0.0-beta'));
|
|
|
|
$package2
|
|
->expects($this->once())
|
|
->method('getPrettyName')
|
|
->will($this->returnValue('pkg2'));
|
|
$package2
|
|
->expects($this->once())
|
|
->method('getPrettyVersion')
|
|
->will($this->returnValue('0.1.10'));
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('write')
|
|
->with(array(
|
|
'hash' => 'md5',
|
|
'packages' => array(
|
|
array('package' => 'pkg1', 'version' => '1.0.0-beta'),
|
|
array('package' => 'pkg2', 'version' => '0.1.10')
|
|
),
|
|
'packages-dev' => array(),
|
|
'aliases' => array(),
|
|
));
|
|
|
|
$locker->setLockData(array($package1, $package2), array(), array());
|
|
}
|
|
|
|
public function testLockBadPackages()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$package1 = $this->createPackageMock();
|
|
$package1
|
|
->expects($this->once())
|
|
->method('getPrettyName')
|
|
->will($this->returnValue('pkg1'));
|
|
|
|
$this->setExpectedException('LogicException');
|
|
|
|
$locker->setLockData(array($package1), array(), array());
|
|
}
|
|
|
|
public function testIsFresh()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue(array('hash' => 'md5')));
|
|
|
|
$this->assertTrue($locker->isFresh());
|
|
}
|
|
|
|
public function testIsFreshFalse()
|
|
{
|
|
$json = $this->createJsonFileMock();
|
|
$repo = $this->createRepositoryManagerMock();
|
|
|
|
$locker = new Locker($json, $repo, 'md5');
|
|
|
|
$json
|
|
->expects($this->once())
|
|
->method('read')
|
|
->will($this->returnValue(array('hash' => 'oldmd5')));
|
|
|
|
$this->assertFalse($locker->isFresh());
|
|
}
|
|
|
|
private function createJsonFileMock()
|
|
{
|
|
return $this->getMockBuilder('Composer\Json\JsonFile')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
|
|
private function createRepositoryManagerMock()
|
|
{
|
|
$mock = $this->getMockBuilder('Composer\Repository\RepositoryManager')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$mock->expects($this->any())
|
|
->method('getLocalRepository')
|
|
->will($this->returnValue($this->getMockBuilder('Composer\Repository\ArrayRepository')->getMock()));
|
|
|
|
return $mock;
|
|
}
|
|
|
|
private function createPackageMock()
|
|
{
|
|
return $this->getMockBuilder('Composer\Package\PackageInterface')
|
|
->getMock();
|
|
}
|
|
}
|