/tests/Composer/Test/Package/LockerTest.php
PHP | 256 lines | 196 code | 51 blank | 9 comment | 0 complexity | deca9d59c295fb9b5e12dcf10513311e MD5 | raw file
- <?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(), $this->createInstallationManagerMock(), '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();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, '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();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, '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();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, '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();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, '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(),
- 'minimum-stability' => 'dev',
- 'stability-flags' => array(),
- ));
- $locker->setLockData(array($package1, $package2), array(), array(), 'dev', array());
- }
- public function testLockBadPackages()
- {
- $json = $this->createJsonFileMock();
- $repo = $this->createRepositoryManagerMock();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, 'md5');
- $package1 = $this->createPackageMock();
- $package1
- ->expects($this->once())
- ->method('getPrettyName')
- ->will($this->returnValue('pkg1'));
- $this->setExpectedException('LogicException');
- $locker->setLockData(array($package1), array(), array(), 'dev', array());
- }
- public function testIsFresh()
- {
- $json = $this->createJsonFileMock();
- $repo = $this->createRepositoryManagerMock();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, '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();
- $inst = $this->createInstallationManagerMock();
- $locker = new Locker($json, $repo, $inst, '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 createInstallationManagerMock()
- {
- $mock = $this->getMockBuilder('Composer\Installer\InstallationManager')
- ->disableOriginalConstructor()
- ->getMock();
- return $mock;
- }
- private function createPackageMock()
- {
- return $this->getMockBuilder('Composer\Package\PackageInterface')
- ->getMock();
- }
- }