浏览代码

Fix Git failures due to tag ambiguity (issue #3417)

Colin O'Dell 10 年之前
父节点
当前提交
f304611014
共有 2 个文件被更改,包括 5 次插入5 次删除
  1. 2 2
      src/Composer/Downloader/GitDownloader.php
  2. 3 3
      tests/Composer/Test/Downloader/GitDownloaderTest.php

+ 2 - 2
src/Composer/Downloader/GitDownloader.php

@@ -215,7 +215,7 @@ class GitDownloader extends VcsDownloader
      */
      */
     protected function updateToCommit($path, $reference, $branch, $date)
     protected function updateToCommit($path, $reference, $branch, $date)
     {
     {
-        $template = 'git checkout %s && git reset --hard %1$s';
+        $template = 'git checkout %s && git reset --hard %1$s --';
         $branch = preg_replace('{(?:^dev-|(?:\.x)?-dev$)}i', '', $branch);
         $branch = preg_replace('{(?:^dev-|(?:\.x)?-dev$)}i', '', $branch);
 
 
         $branches = null;
         $branches = null;
@@ -247,7 +247,7 @@ class GitDownloader extends VcsDownloader
             if (0 === $this->process->execute($command, $output, $path)
             if (0 === $this->process->execute($command, $output, $path)
                 || 0 === $this->process->execute($fallbackCommand, $output, $path)
                 || 0 === $this->process->execute($fallbackCommand, $output, $path)
             ) {
             ) {
-                $command = sprintf('git reset --hard %s', ProcessExecutor::escape($reference));
+                $command = sprintf('git reset --hard %s --', ProcessExecutor::escape($reference));
                 if (0 === $this->process->execute($command, $output, $path)) {
                 if (0 === $this->process->execute($command, $output, $path)) {
                     return;
                     return;
                 }
                 }

+ 3 - 3
tests/Composer/Test/Downloader/GitDownloaderTest.php

@@ -79,7 +79,7 @@ class GitDownloaderTest extends \PHPUnit_Framework_TestCase
 
 
         $processExecutor->expects($this->at(3))
         $processExecutor->expects($this->at(3))
             ->method('execute')
             ->method('execute')
-            ->with($this->equalTo($this->winCompat("git reset --hard '1234567890123456789012345678901234567890'")), $this->equalTo(null), $this->equalTo($this->winCompat('composerPath')))
+            ->with($this->equalTo($this->winCompat("git reset --hard '1234567890123456789012345678901234567890' --")), $this->equalTo(null), $this->equalTo($this->winCompat('composerPath')))
             ->will($this->returnValue(0));
             ->will($this->returnValue(0));
 
 
         $downloader = $this->getDownloaderMock(null, null, $processExecutor);
         $downloader = $this->getDownloaderMock(null, null, $processExecutor);
@@ -134,7 +134,7 @@ class GitDownloaderTest extends \PHPUnit_Framework_TestCase
 
 
         $processExecutor->expects($this->at(6))
         $processExecutor->expects($this->at(6))
             ->method('execute')
             ->method('execute')
-            ->with($this->equalTo($this->winCompat("git checkout 'ref' && git reset --hard 'ref'")), $this->equalTo(null), $this->equalTo($this->winCompat('composerPath')))
+            ->with($this->equalTo($this->winCompat("git checkout 'ref' && git reset --hard 'ref' --")), $this->equalTo(null), $this->equalTo($this->winCompat('composerPath')))
             ->will($this->returnValue(0));
             ->will($this->returnValue(0));
 
 
         $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);
         $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);
@@ -266,7 +266,7 @@ class GitDownloaderTest extends \PHPUnit_Framework_TestCase
             ->will($this->returnValue(0));
             ->will($this->returnValue(0));
         $processExecutor->expects($this->at(4))
         $processExecutor->expects($this->at(4))
             ->method('execute')
             ->method('execute')
-            ->with($this->equalTo($this->winCompat("git checkout 'ref' && git reset --hard 'ref'")), $this->equalTo(null), $this->equalTo($this->winCompat($tmpDir)))
+            ->with($this->equalTo($this->winCompat("git checkout 'ref' && git reset --hard 'ref' --")), $this->equalTo(null), $this->equalTo($this->winCompat($tmpDir)))
             ->will($this->returnValue(0));
             ->will($this->returnValue(0));
 
 
         $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);
         $downloader = $this->getDownloaderMock(null, new Config(), $processExecutor);