Browse Source

Add flag --deleteCurrent to delete current release on rollback. Issue #93

1.0
Andrés Montañez 11 years ago
parent
commit
5fb711593a
  1. 13
      Mage/Task/BuiltIn/Releases/RollbackTask.php

13
Mage/Task/BuiltIn/Releases/RollbackTask.php

@ -60,6 +60,7 @@ class RollbackTask extends AbstractTask implements IsReleaseAware
} else { } else {
rsort($releases); rsort($releases);
$deleteCurrent = $this->getConfig()->getParameter('deleteCurrent', false);
$releaseIsAvailable = false; $releaseIsAvailable = false;
if ($this->getReleaseId() == '') { if ($this->getReleaseId() == '') {
@ -86,6 +87,13 @@ class RollbackTask extends AbstractTask implements IsReleaseAware
Console::output('Rollback release on <dark_gray>' . $this->getConfig()->getHost() . '</dark_gray>'); Console::output('Rollback release on <dark_gray>' . $this->getConfig()->getHost() . '</dark_gray>');
$rollbackTo = $releasesDirectory . '/' . $releaseId; $rollbackTo = $releasesDirectory . '/' . $releaseId;
// Get Current Release
if ($deleteCurrent) {
$result = $this->runCommandRemote('ls -l ' . $symlink, $output) && $result;
$currentRelease = explode('/', $output);
$currentRelease = trim(array_pop($currentRelease));
}
// Tasks // Tasks
$tasks = 1; $tasks = 1;
$completedTasks = 0; $completedTasks = 0;
@ -132,6 +140,11 @@ class RollbackTask extends AbstractTask implements IsReleaseAware
if ($result) { if ($result) {
Console::output('<green>OK</green>', 0); Console::output('<green>OK</green>', 0);
$completedTasks++; $completedTasks++;
// Delete Old Current Release
if ($deleteCurrent && $currentRelease) {
$this->runCommandRemote('rm -rf ' . $releasesDirectory . '/' . $currentRelease, $output);
}
} else { } else {
Console::output('<red>FAIL</red>', 0); Console::output('<red>FAIL</red>', 0);
} }

Loading…
Cancel
Save