123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308 |
- <?php
- namespace Composer\Test\Downloader;
- use Composer\Downloader\GitDownloader;
- use Composer\Config;
- class GitDownloaderTest extends \PHPUnit_Framework_TestCase
- {
- protected function getDownloaderMock($io = null, $config = null, $executor = null, $filesystem = null)
- {
- $io = $io ?: $this->getMock('Composer\IO\IOInterface');
- $executor = $executor ?: $this->getMock('Composer\Util\ProcessExecutor');
- $filesystem = $filesystem ?: $this->getMock('Composer\Util\Filesystem');
- if (!$config) {
- $config = $this->getMock('Composer\Config');
- $config->expects($this->any())
- ->method('has')
- ->will($this->returnValue(false));
- }
- return new GitDownloader($io, $config, $executor, $filesystem);
- }
-
- public function testDownloadForPackageWithoutSourceReference()
- {
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->once())
- ->method('getSourceReference')
- ->will($this->returnValue(null));
- $downloader = $this->getDownloaderMock();
- $downloader->download($packageMock, '/path');
- }
- public function testDownload()
- {
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->any())
- ->method('getSourceReference')
- ->will($this->returnValue('1234567890123456789012345678901234567890'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://example.com/composer/composer'));
- $packageMock->expects($this->any())
- ->method('getPrettyVersion')
- ->will($this->returnValue('dev-master'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $expectedGitCommand = $this->getCmd("git clone 'https://example.com/composer/composer' 'composerPath' && cd 'composerPath' && git remote add composer 'https://example.com/composer/composer' && git fetch composer");
- $processExecutor->expects($this->at(0))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(1))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("git branch -r")), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(2))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("git checkout 'master'")), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(3))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("git reset --hard '1234567890123456789012345678901234567890'")), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $downloader = $this->getDownloaderMock(null, null, $processExecutor);
- $downloader->download($packageMock, 'composerPath');
- }
- public function testDownloadUsesVariousProtocolsAndSetsPushUrlForGithub()
- {
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->any())
- ->method('getSourceReference')
- ->will($this->returnValue('ref'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://github.com/composer/composer'));
- $packageMock->expects($this->any())
- ->method('getPrettyVersion')
- ->will($this->returnValue('1.0.0'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $expectedGitCommand = $this->getCmd("git clone 'git://github.com/composer/composer' 'composerPath' && cd 'composerPath' && git remote add composer 'git://github.com/composer/composer' && git fetch composer");
- $processExecutor->expects($this->at(0))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(1));
- $expectedGitCommand = $this->getCmd("git clone 'https://github.com/composer/composer' 'composerPath' && cd 'composerPath' && git remote add composer 'https://github.com/composer/composer' && git fetch composer");
- $processExecutor->expects($this->at(2))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(1));
- $expectedGitCommand = $this->getCmd("git clone 'http://github.com/composer/composer' 'composerPath' && cd 'composerPath' && git remote add composer 'http://github.com/composer/composer' && git fetch composer");
- $processExecutor->expects($this->at(4))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(0));
- $expectedGitCommand = $this->getCmd("git remote set-url --push origin 'git@github.com:composer/composer.git'");
- $processExecutor->expects($this->at(5))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(6))
- ->method('execute')
- ->with($this->equalTo('git branch -r'))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(7))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("git checkout 'ref' && git reset --hard 'ref'")), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);
- $downloader->download($packageMock, 'composerPath');
- }
- public function testDownloadUsesCustomVariousProtocolsForGithub()
- {
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->any())
- ->method('getSourceReference')
- ->will($this->returnValue('ref'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://github.com/composer/composer'));
- $packageMock->expects($this->any())
- ->method('getPrettyVersion')
- ->will($this->returnValue('1.0.0'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $expectedGitCommand = $this->getCmd("git clone 'http://github.com/composer/composer' 'composerPath' && cd 'composerPath' && git remote add composer 'http://github.com/composer/composer' && git fetch composer");
- $processExecutor->expects($this->at(0))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->exactly(4))
- ->method('execute')
- ->will($this->returnValue(0));
- $config = new Config();
- $config->merge(array('config' => array('github-protocols' => array('http'))));
- $downloader = $this->getDownloaderMock(null, $config, $processExecutor);
- $downloader->download($packageMock, 'composerPath');
- }
-
- public function testDownloadThrowsRuntimeExceptionIfGitCommandFails()
- {
- $expectedGitCommand = $this->getCmd("git clone 'https://example.com/composer/composer' 'composerPath' && cd 'composerPath' && git remote add composer 'https://example.com/composer/composer' && git fetch composer");
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->any())
- ->method('getSourceReference')
- ->will($this->returnValue('ref'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://example.com/composer/composer'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $processExecutor->expects($this->at(0))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(1));
- $downloader = $this->getDownloaderMock(null, null, $processExecutor);
- $downloader->download($packageMock, 'composerPath');
- }
-
- public function testUpdateforPackageWithoutSourceReference()
- {
- $initialPackageMock = $this->getMock('Composer\Package\PackageInterface');
- $sourcePackageMock = $this->getMock('Composer\Package\PackageInterface');
- $sourcePackageMock->expects($this->once())
- ->method('getSourceReference')
- ->will($this->returnValue(null));
- $downloader = $this->getDownloaderMock();
- $downloader->update($initialPackageMock, $sourcePackageMock, '/path');
- }
- public function testUpdate()
- {
- $expectedGitUpdateCommand = $this->getCmd("cd 'composerPath' && git remote set-url composer 'git://github.com/composer/composer' && git fetch composer && git fetch --tags composer");
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->any())
- ->method('getSourceReference')
- ->will($this->returnValue('ref'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://github.com/composer/composer'));
- $packageMock->expects($this->any())
- ->method('getPrettyVersion')
- ->will($this->returnValue('1.0.0'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $processExecutor->expects($this->at(0))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("cd 'composerPath' && git remote -v")))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(1))
- ->method('execute')
- ->with($this->equalTo($expectedGitUpdateCommand))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(2))
- ->method('execute')
- ->with($this->equalTo('git branch -r'))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(3))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("git checkout 'ref' && git reset --hard 'ref'")), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);
- $downloader->update($packageMock, $packageMock, 'composerPath');
- }
-
- public function testUpdateThrowsRuntimeExceptionIfGitCommandFails()
- {
- $expectedGitUpdateCommand = $this->getCmd("cd 'composerPath' && git remote set-url composer 'git://github.com/composer/composer' && git fetch composer && git fetch --tags composer");
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $packageMock->expects($this->any())
- ->method('getSourceReference')
- ->will($this->returnValue('ref'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://github.com/composer/composer'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $processExecutor->expects($this->at(0))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("cd 'composerPath' && git remote -v")))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(1))
- ->method('execute')
- ->with($this->equalTo($expectedGitUpdateCommand))
- ->will($this->returnValue(1));
- $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);
- $downloader->update($packageMock, $packageMock, 'composerPath');
- }
- public function testRemove()
- {
- $expectedGitResetCommand = $this->getCmd("cd 'composerPath' && git status --porcelain --untracked-files=no");
- $packageMock = $this->getMock('Composer\Package\PackageInterface');
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $processExecutor->expects($this->any())
- ->method('execute')
- ->with($this->equalTo($expectedGitResetCommand))
- ->will($this->returnValue(0));
- $filesystem = $this->getMock('Composer\Util\Filesystem');
- $filesystem->expects($this->any())
- ->method('removeDirectory')
- ->with($this->equalTo('composerPath'))
- ->will($this->returnValue(true));
- $downloader = $this->getDownloaderMock(null, null, $processExecutor, $filesystem);
- $downloader->remove($packageMock, 'composerPath');
- }
- public function testGetInstallationSource()
- {
- $downloader = $this->getDownloaderMock();
- $this->assertEquals('source', $downloader->getInstallationSource());
- }
- private function getCmd($cmd)
- {
- if (defined('PHP_WINDOWS_VERSION_BUILD')) {
- return strtr($cmd, "'", '"');
- }
- return $cmd;
- }
- }
|