|
|
|
@ -18,12 +18,12 @@ use Mage\Task\Releases\IsReleaseAware;
|
|
|
|
|
* |
|
|
|
|
* @author Oscar Reales <oreales@gmail.com> |
|
|
|
|
*/ |
|
|
|
|
class GitRebaseTask extends AbstractTask implements IsReleaseAware |
|
|
|
|
class GitRebaseTask extends BaseStrategyTaskAbstract implements IsReleaseAware |
|
|
|
|
{ |
|
|
|
|
/** |
|
|
|
|
* (non-PHPdoc) |
|
|
|
|
* @see \Mage\Task\AbstractTask::getName() |
|
|
|
|
*/ |
|
|
|
|
/** |
|
|
|
|
* (non-PHPdoc) |
|
|
|
|
* @see \Mage\Task\AbstractTask::getName() |
|
|
|
|
*/ |
|
|
|
|
public function getName() |
|
|
|
|
{ |
|
|
|
|
return 'Deploy via Git Rebase [built-in]'; |
|
|
|
@ -35,41 +35,66 @@ class GitRebaseTask extends AbstractTask implements IsReleaseAware
|
|
|
|
|
*/ |
|
|
|
|
public function run() |
|
|
|
|
{ |
|
|
|
|
$branch = $this->getParameter('branch', 'master'); |
|
|
|
|
$remote = $this->getParameter('remote', 'origin'); |
|
|
|
|
$this->checkOverrideRelease(); |
|
|
|
|
$excludes = $this->getExcludes(); |
|
|
|
|
|
|
|
|
|
// If we are working with releases |
|
|
|
|
$deployToDirectory = $this->getConfig()->deployment('to'); |
|
|
|
|
if ($this->getConfig()->release('enabled', false) == true) { |
|
|
|
|
$releasesDirectory = $this->getConfig()->release('directory', 'releases'); |
|
|
|
|
|
|
|
|
|
$deployToDirectory = rtrim($this->getConfig()->deployment('to'), '/') |
|
|
|
|
. '/' . $releasesDirectory |
|
|
|
|
. '/' . $this->getConfig()->getReleaseId(); |
|
|
|
|
$this->runCommandRemote('mkdir -p ' . $releasesDirectory . '/' . $this->getConfig()->getReleaseId()); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Fetch Remote |
|
|
|
|
$command = 'git fetch ' . $remote; |
|
|
|
|
$branch = $this->getParameter('branch', 'master'); |
|
|
|
|
$remote = $this->getParameter('remote', 'origin'); |
|
|
|
|
|
|
|
|
|
// Fetch Remote |
|
|
|
|
$command = $this->getReleasesAwareCommand('git fetch ' . $remote); |
|
|
|
|
$result = $this->runCommandRemote($command); |
|
|
|
|
|
|
|
|
|
if ($result === false) { |
|
|
|
|
$repository = $this->getConfig()->deployment('repository'); |
|
|
|
|
if ($repository) { |
|
|
|
|
$command = $this->getReleasesAwareCommand('git clone ' . $repository . ' .'); |
|
|
|
|
$result = $this->runCommandRemote($command); |
|
|
|
|
|
|
|
|
|
$command = $this->getReleasesAwareCommand('git fetch ' . $remote); |
|
|
|
|
$result = $this->runCommandRemote($command); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Checkout |
|
|
|
|
$command = 'git checkout ' . $branch; |
|
|
|
|
$command = $this->getReleasesAwareCommand('git checkout ' . $branch); |
|
|
|
|
$result = $this->runCommandRemote($command) && $result; |
|
|
|
|
|
|
|
|
|
// Check Working Copy status |
|
|
|
|
$stashed = false; |
|
|
|
|
$status = ''; |
|
|
|
|
$command = 'git checkout ' . $branch; |
|
|
|
|
$command = $this->getReleasesAwareCommand('git checkout ' . $branch); |
|
|
|
|
$result = $this->runCommandRemote($command) && $result; |
|
|
|
|
|
|
|
|
|
// Stash if Working Copy is not clean |
|
|
|
|
if(!$status) { |
|
|
|
|
$stashResult = ''; |
|
|
|
|
$command = 'git stash'; |
|
|
|
|
$result = $this->runCommandRemote($command, $stashResult) && $result; |
|
|
|
|
if($stashResult != "No local changes to save") { |
|
|
|
|
$stashResult = ''; |
|
|
|
|
$command = $this->getReleasesAwareCommand('git stash'); |
|
|
|
|
$result = $this->runCommandRemote($command, $stashResult) && $result; |
|
|
|
|
if($stashResult != "No local changes to save") { |
|
|
|
|
$stashed = true; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Rebase |
|
|
|
|
$command = 'git rebase ' . $remote . '/' . $branch; |
|
|
|
|
$command = $this->getReleasesAwareCommand('git rebase ' . $remote . '/' . $branch); |
|
|
|
|
$result = $this->runCommandRemote($command) && $result; |
|
|
|
|
|
|
|
|
|
// If Stashed, restore. |
|
|
|
|
if ($stashed) { |
|
|
|
|
$command = 'git stash pop'; |
|
|
|
|
$result = $this->runCommandRemote($command) && $result; |
|
|
|
|
$command = $this->getReleasesAwareCommand('git stash pop'); |
|
|
|
|
$result = $this->runCommandRemote($command) && $result; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
return $result; |
|
|
|
|