123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238 |
- <?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\Downloader;
- use Composer\Downloader\GitDownloader;
- class GitDownloaderTest extends \PHPUnit_Framework_TestCase
- {
- protected function getDownloaderMock($io = 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');
- return new GitDownloader($io, $executor, $filesystem);
- }
- /**
- * @expectedException \InvalidArgumentException
- */
- 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('ref'));
- $packageMock->expects($this->any())
- ->method('getSourceUrl')
- ->will($this->returnValue('https://example.com/composer/composer'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $expectedGitCommand = $this->getCmd("git clone 'https://example.com/composer/composer' 'composerPath' && cd 'composerPath' && git checkout 'ref' && git reset --hard 'ref' && git remote add composer 'https://example.com/composer/composer'");
- $processExecutor->expects($this->once())
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(0));
- $downloader = $this->getDownloaderMock(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'));
- $processExecutor = $this->getMock('Composer\Util\ProcessExecutor');
- $expectedGitCommand = $this->getCmd("git clone 'git://github.com/composer/composer' 'composerPath' && cd 'composerPath' && git checkout 'ref' && git reset --hard 'ref' && git remote add composer 'git://github.com/composer/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 checkout 'ref' && git reset --hard 'ref' && git remote add composer 'https://github.com/composer/composer'");
- $processExecutor->expects($this->at(1))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand))
- ->will($this->returnValue(1));
- $expectedGitCommand = $this->getCmd("git clone 'http://github.com/composer/composer' 'composerPath' && cd 'composerPath' && git checkout 'ref' && git reset --hard 'ref' && git remote add composer 'http://github.com/composer/composer'");
- $processExecutor->expects($this->at(2))
- ->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(3))
- ->method('execute')
- ->with($this->equalTo($expectedGitCommand), $this->equalTo(null), $this->equalTo('composerPath'))
- ->will($this->returnValue(0));
- $downloader = $this->getDownloaderMock(null, $processExecutor);
- $downloader->download($packageMock, 'composerPath');
- }
- /**
- * @expectedException \RuntimeException
- */
- public function testDownloadThrowsRuntimeExceptionIfGitCommandFails()
- {
- $expectedGitCommand = $this->getCmd("git clone 'https://example.com/composer/composer' 'composerPath' && cd 'composerPath' && git checkout 'ref' && git reset --hard 'ref' && git remote add composer 'https://example.com/composer/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, $processExecutor);
- $downloader->download($packageMock, 'composerPath');
- }
- /**
- * @expectedException \InvalidArgumentException
- */
- 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 && git checkout 'ref' && git reset --hard 'ref'");
- $expectedGitResetCommand = $this->getCmd("cd 'composerPath' && git status --porcelain --untracked-files=no");
- $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($expectedGitResetCommand))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(1))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("cd 'composerPath' && git remote add composer 'https://github.com/composer/composer'")))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(2))
- ->method('execute')
- ->with($this->equalTo($expectedGitUpdateCommand))
- ->will($this->returnValue(0));
- $downloader = $this->getDownloaderMock(null, $processExecutor);
- $downloader->update($packageMock, $packageMock, 'composerPath');
- }
- /**
- * @expectedException \RuntimeException
- */
- 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 && git checkout 'ref' && git reset --hard 'ref'");
- $expectedGitResetCommand = $this->getCmd("cd 'composerPath' && git status --porcelain --untracked-files=no");
- $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($expectedGitResetCommand))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(1))
- ->method('execute')
- ->with($this->equalTo($this->getCmd("cd 'composerPath' && git remote add composer 'https://github.com/composer/composer'")))
- ->will($this->returnValue(0));
- $processExecutor->expects($this->at(2))
- ->method('execute')
- ->with($this->equalTo($expectedGitUpdateCommand))
- ->will($this->returnValue(1));
- $downloader = $this->getDownloaderMock(null, $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, $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;
- }
- }
|