Add tests and fixes some issues
parent
d4b7f802df
commit
b7f6cf69ab
@ -0,0 +1,18 @@
|
||||
<?php
|
||||
|
||||
namespace Installer;
|
||||
|
||||
use Composer\Installer\InstallerInterface;
|
||||
use Composer\Package\PackageInterface;
|
||||
|
||||
class Custom implements InstallerInterface
|
||||
{
|
||||
public $version = 'installer-v1';
|
||||
|
||||
public function supports($packageType) {}
|
||||
public function isInstalled(PackageInterface $package) {}
|
||||
public function install(PackageInterface $package) {}
|
||||
public function update(PackageInterface $initial, PackageInterface $target) {}
|
||||
public function uninstall(PackageInterface $package) {}
|
||||
public function getInstallPath(PackageInterface $package) {}
|
||||
}
|
@ -0,0 +1,7 @@
|
||||
<?php
|
||||
|
||||
namespace Installer;
|
||||
|
||||
class Exception extends \Exception
|
||||
{
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
{
|
||||
"name": "",
|
||||
"version": "1.0.0",
|
||||
"type": "composer-installer",
|
||||
"autoload": { "psr-0": { "Installer": "" } },
|
||||
"extra": {
|
||||
"class": "Installer\\Custom"
|
||||
}
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
<?php
|
||||
|
||||
namespace Installer;
|
||||
|
||||
use Composer\Installer\InstallerInterface;
|
||||
use Composer\Package\PackageInterface;
|
||||
|
||||
class Custom2 implements InstallerInterface
|
||||
{
|
||||
public $version = 'installer-v2';
|
||||
|
||||
public function supports($packageType) {}
|
||||
public function isInstalled(PackageInterface $package) {}
|
||||
public function install(PackageInterface $package) {}
|
||||
public function update(PackageInterface $initial, PackageInterface $target) {}
|
||||
public function uninstall(PackageInterface $package) {}
|
||||
public function getInstallPath(PackageInterface $package) {}
|
||||
}
|
@ -0,0 +1,7 @@
|
||||
<?php
|
||||
|
||||
namespace Installer;
|
||||
|
||||
class Exception extends \Exception
|
||||
{
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
{
|
||||
"name": "",
|
||||
"version": "2.0.0",
|
||||
"type": "composer-installer",
|
||||
"autoload": { "psr-0": { "Installer": "" } },
|
||||
"extra": {
|
||||
"class": "Installer\\Custom2"
|
||||
}
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
<?php
|
||||
|
||||
namespace Installer;
|
||||
|
||||
use Composer\Installer\InstallerInterface;
|
||||
use Composer\Package\PackageInterface;
|
||||
|
||||
class Custom2 implements InstallerInterface
|
||||
{
|
||||
public $version = 'installer-v3';
|
||||
|
||||
public function supports($packageType) {}
|
||||
public function isInstalled(PackageInterface $package) {}
|
||||
public function install(PackageInterface $package) {}
|
||||
public function update(PackageInterface $initial, PackageInterface $target) {}
|
||||
public function uninstall(PackageInterface $package) {}
|
||||
public function getInstallPath(PackageInterface $package) {}
|
||||
}
|
@ -0,0 +1,7 @@
|
||||
<?php
|
||||
|
||||
namespace Installer;
|
||||
|
||||
class Exception extends \Exception
|
||||
{
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
{
|
||||
"name": "",
|
||||
"version": "3.0.0",
|
||||
"type": "composer-installer",
|
||||
"autoload": { "psr-0": { "Installer": "" } },
|
||||
"extra": {
|
||||
"class": "Installer\\Custom2"
|
||||
}
|
||||
}
|
@ -0,0 +1,119 @@
|
||||
<?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\Installer;
|
||||
|
||||
use Composer\Installer\InstallerInstaller;
|
||||
use Composer\Package\Loader\JsonLoader;
|
||||
use Composer\Package\PackageInterface;
|
||||
|
||||
class InstallerInstallerTest extends \PHPUnit_Framework_TestCase
|
||||
{
|
||||
protected function setUp()
|
||||
{
|
||||
$repositoryManager = $this->getMockBuilder('Composer\Repository\RepositoryManager')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
|
||||
$loader = new JsonLoader($repositoryManager);
|
||||
$this->packages = array();
|
||||
for ($i = 1; $i <= 3; $i++) {
|
||||
$this->packages[] = $loader->load(__DIR__.'/Fixtures/installer-v'.$i.'/composer.json');
|
||||
}
|
||||
|
||||
$this->dm = $this->getMockBuilder('Composer\Downloader\DownloadManager')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
|
||||
$this->im = $this->getMockBuilder('Composer\Installer\InstallationManager')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
|
||||
$this->repository = $this->getMockBuilder('Composer\Repository\WritableRepositoryInterface')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
}
|
||||
|
||||
public function testInstallNewInstaller()
|
||||
{
|
||||
$this->repository
|
||||
->expects($this->once())
|
||||
->method('getPackages')
|
||||
->will($this->returnValue(array()));
|
||||
$installer = new InstallerInstallerMock(__DIR__.'/Fixtures/', $this->dm, $this->repository, $this->im);
|
||||
|
||||
$test = $this;
|
||||
$this->im
|
||||
->expects($this->once())
|
||||
->method('addInstaller')
|
||||
->will($this->returnCallback(function ($installer) use ($test) {
|
||||
$test->assertEquals('installer-v1', $installer->version);
|
||||
}));
|
||||
|
||||
$installer->install($this->packages[0]);
|
||||
}
|
||||
|
||||
public function testUpgradeWithNewClassName()
|
||||
{
|
||||
$this->repository
|
||||
->expects($this->once())
|
||||
->method('getPackages')
|
||||
->will($this->returnValue(array($this->packages[0])));
|
||||
$this->repository
|
||||
->expects($this->once())
|
||||
->method('hasPackage')
|
||||
->will($this->returnValue(true));
|
||||
$installer = new InstallerInstallerMock(__DIR__.'/Fixtures/', $this->dm, $this->repository, $this->im);
|
||||
|
||||
$test = $this;
|
||||
$this->im
|
||||
->expects($this->once())
|
||||
->method('addInstaller')
|
||||
->will($this->returnCallback(function ($installer) use ($test) {
|
||||
$test->assertEquals('installer-v2', $installer->version);
|
||||
}));
|
||||
|
||||
$installer->update($this->packages[0], $this->packages[1]);
|
||||
}
|
||||
|
||||
public function testUpgradeWithSameClassName()
|
||||
{
|
||||
$this->repository
|
||||
->expects($this->once())
|
||||
->method('getPackages')
|
||||
->will($this->returnValue(array($this->packages[1])));
|
||||
$this->repository
|
||||
->expects($this->once())
|
||||
->method('hasPackage')
|
||||
->will($this->returnValue(true));
|
||||
$installer = new InstallerInstallerMock(__DIR__.'/Fixtures/', $this->dm, $this->repository, $this->im);
|
||||
|
||||
$test = $this;
|
||||
$this->im
|
||||
->expects($this->once())
|
||||
->method('addInstaller')
|
||||
->will($this->returnCallback(function ($installer) use ($test) {
|
||||
$test->assertEquals('installer-v3', $installer->version);
|
||||
}));
|
||||
|
||||
$installer->update($this->packages[1], $this->packages[2]);
|
||||
}
|
||||
}
|
||||
|
||||
class InstallerInstallerMock extends InstallerInstaller
|
||||
{
|
||||
public function getInstallPath(PackageInterface $package)
|
||||
{
|
||||
$version = $package->getVersion();
|
||||
return __DIR__.'/Fixtures/installer-v'.$version[0].'/';
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue