1
0
mirror of https://github.com/hauke68/Magallanes.git synced 2025-10-23 21:10:17 +02:00

[Nostromo] Fixes and Tests

This commit is contained in:
Andrés Montañez 2017-01-01 03:55:09 -03:00
parent 4b7cc618b4
commit 677bf1ebd4
6 changed files with 194 additions and 17 deletions

View File

@ -32,6 +32,11 @@ use Mage\Command\AbstractCommand;
*/ */
class DeployCommand extends AbstractCommand class DeployCommand extends AbstractCommand
{ {
/**
* @var int
*/
protected $statusCode = 0;
/** /**
* @var TaskFactory * @var TaskFactory
*/ */
@ -93,7 +98,7 @@ class DeployCommand extends AbstractCommand
$output->writeln('Finished <fg=blue>Magallanes</>'); $output->writeln('Finished <fg=blue>Magallanes</>');
return 0; return $this->statusCode;
} }
/** /**
@ -133,20 +138,21 @@ class DeployCommand extends AbstractCommand
$this->runtime->setStage(Runtime::ON_DEPLOY); $this->runtime->setStage(Runtime::ON_DEPLOY);
$onDeployTasks = $this->runtime->getTasks(); $onDeployTasks = $this->runtime->getTasks();
if ($this->runtime->getEnvironmentConfig('releases', false) && !$this->runtime->inRollback()) { if (!$this->runtime->inRollback()) {
}
if ($this->runtime->getEnvironmentConfig('releases', false)) {
if (!in_array('deploy/targz/copy', $onDeployTasks)) { if (!in_array('deploy/targz/copy', $onDeployTasks)) {
array_unshift($onDeployTasks, 'deploy/targz/copy'); array_unshift($onDeployTasks, 'deploy/targz/copy');
} }
} else {
if (!in_array('deploy/rsync', $onDeployTasks) && !$this->runtime->inRollback()) {
array_unshift($onDeployTasks, 'deploy/rsync');
}
}
if ($this->runtime->getEnvironmentConfig('releases', false) && !$this->runtime->inRollback()) {
if (!in_array('deploy/release/prepare', $onDeployTasks)) { if (!in_array('deploy/release/prepare', $onDeployTasks)) {
array_unshift($onDeployTasks, 'deploy/release/prepare'); array_unshift($onDeployTasks, 'deploy/release/prepare');
} }
} else {
if (!in_array('deploy/rsync', $onDeployTasks)) {
array_unshift($onDeployTasks, 'deploy/rsync');
}
} }
foreach ($hosts as $host) { foreach ($hosts as $host) {
@ -269,6 +275,7 @@ class DeployCommand extends AbstractCommand
$this->log(sprintf('Task %s (%s) finished with OK', $task->getDescription(), $task->getName())); $this->log(sprintf('Task %s (%s) finished with OK', $task->getDescription(), $task->getName()));
} else { } else {
$output->writeln('<fg=red>FAIL</>'); $output->writeln('<fg=red>FAIL</>');
$this->statusCode = 500;
$this->log(sprintf('Task %s (%s) finished with FAIL', $task->getDescription(), $task->getName())); $this->log(sprintf('Task %s (%s) finished with FAIL', $task->getDescription(), $task->getName()));
} }
} catch (SkipException $exception) { } catch (SkipException $exception) {
@ -276,8 +283,9 @@ class DeployCommand extends AbstractCommand
$output->writeln('<fg=yellow>SKIPPED</>'); $output->writeln('<fg=yellow>SKIPPED</>');
$this->log(sprintf('Task %s (%s) finished with SKIPPED, thrown SkipException', $task->getDescription(), $task->getName())); $this->log(sprintf('Task %s (%s) finished with SKIPPED, thrown SkipException', $task->getDescription(), $task->getName()));
} catch (ErrorException $exception) { } catch (ErrorException $exception) {
$output->writeln(sprintf('<fg=red>FAIL</> [%s]', $exception->getTrimmedMessage())); $output->writeln(sprintf('<fg=red>ERROR</> [%s]', $exception->getTrimmedMessage()));
$this->log(sprintf('Task %s (%s) finished with FAIL, with Error "%s"', $task->getDescription(), $task->getName(), $exception->getMessage())); $this->log(sprintf('Task %s (%s) finished with FAIL, with Error "%s"', $task->getDescription(), $task->getName(), $exception->getMessage()));
$this->statusCode = $exception->getCode();
} }
} }
} }

View File

@ -48,17 +48,18 @@ class MageApplication extends Application
if (array_key_exists('magephp', $config)) { if (array_key_exists('magephp', $config)) {
$config = $config['magephp']; $config = $config['magephp'];
$logger = null;
if (array_key_exists('log_dir', $config)) { if (array_key_exists('log_dir', $config)) {
$logfile = sprintf('%s/%s.log', $config['log_dir'], date('Ymd_His')); $logfile = sprintf('%s/%s.log', $config['log_dir'], date('Ymd_His'));
$config['log_file'] = $logfile; $config['log_file'] = $logfile;
$logger = new Logger('magephp'); $logger = new Logger('magephp');
$logger->pushHandler(new StreamHandler($logfile)); $logger->pushHandler(new StreamHandler($logfile));
}
$this->runtime = new Runtime(); $this->runtime = new Runtime();
$this->runtime->setConfiguration($config); $this->runtime->setConfiguration($config);
$this->runtime->setLogger($logger); $this->runtime->setLogger($logger);
}
} else { } else {
throw new RuntimeException(sprintf('The file "%s" does not have a valid Magallanes configuration.', $file)); throw new RuntimeException(sprintf('The file "%s" does not have a valid Magallanes configuration.', $file));
} }

View File

@ -10,6 +10,7 @@
namespace Mage\Task\BuiltIn\Deploy; namespace Mage\Task\BuiltIn\Deploy;
use Mage\Task\ErrorException;
use Symfony\Component\Process\Process; use Symfony\Component\Process\Process;
use Mage\Task\AbstractTask; use Mage\Task\AbstractTask;
@ -38,7 +39,7 @@ class RsyncTask extends AbstractTask
$targetDir = rtrim($hostPath, '/'); $targetDir = rtrim($hostPath, '/');
if ($this->runtime->getEnvironmentConfig('releases', false)) { if ($this->runtime->getEnvironmentConfig('releases', false)) {
$targetDir = sprintf('%s/releases/%s', $hostPath, $this->runtime->getReleaseId()); throw new ErrorException('Can\'t be used with Releases, use "deploy/targz/copy"');
} }
$excludes = $this->getExcludes(); $excludes = $this->getExcludes();

View File

@ -10,7 +10,7 @@
namespace Mage\Task\BuiltIn\Deploy\TarGz; namespace Mage\Task\BuiltIn\Deploy\TarGz;
use Mage\Runtime\Exception\DeploymentException; use Mage\Task\ErrorException;
use Symfony\Component\Process\Process; use Symfony\Component\Process\Process;
use Mage\Task\AbstractTask; use Mage\Task\AbstractTask;
@ -34,7 +34,7 @@ class CleanupTask extends AbstractTask
public function execute() public function execute()
{ {
if (!$this->runtime->getEnvironmentConfig('releases', false)) { if (!$this->runtime->getEnvironmentConfig('releases', false)) {
throw new DeploymentException('This task is only available with releases enabled', 400); throw new ErrorException('This task is only available with releases enabled', 400);
} }
$tarGzLocal = $this->runtime->getVar('targz_local'); $tarGzLocal = $this->runtime->getVar('targz_local');

View File

@ -19,7 +19,7 @@ use Exception;
*/ */
class ErrorException extends Exception class ErrorException extends Exception
{ {
public function getTrimmedMessage($maxLength = 20) public function getTrimmedMessage($maxLength = 80)
{ {
$message = $this->getMessage(); $message = $this->getMessage();

View File

@ -124,6 +124,169 @@ class DeployCommandTest extends TestCase
foreach ($testCase as $index => $command) { foreach ($testCase as $index => $command) {
$this->assertEquals($ranCommands[$index], $command); $this->assertEquals($ranCommands[$index], $command);
} }
$this->assertEquals($tester->getStatusCode(), 0);
}
public function testDeploymentWithErrorTaskCommands()
{
$application = new MageTestApplication();
$application->add(new DeployCommand());
$runtime = new RuntimeMockup();
$runtime->setConfiguration(array(
'environments' =>
array(
'test' =>
array(
'user' => 'tester',
'branch' => 'test',
'host_path' => '/var/www/test',
'releases' => 4,
'exclude' =>
array(
0 => 'vendor',
1 => 'app/cache',
2 => 'app/log',
3 => 'web/app_dev.php',
),
'hosts' =>
array(
0 => 'testhost',
),
'pre-deploy' =>
array(
0 => 'git/update',
1 => 'composer/install',
2 => 'composer/generate-autoload',
),
'on-deploy' =>
array(
0 => 'deploy/rsync',
),
'on-release' => null,
'post-release' => null,
'post-deploy' => null,
),
),
)
);
$runtime->setReleaseId('20170101015120');
/** @var AbstractCommand $command */
$command = $application->find('deploy');
$command->setRuntime($runtime);
$tester = new CommandTester($command);
$tester->execute(['command' => $command->getName(), 'environment' => 'test']);
$ranCommands = $runtime->getRanCommands();
$testCase = array(
0 => 'git branch | grep "*"',
1 => 'git checkout test',
2 => 'git pull',
3 => 'composer install --dev',
4 => 'composer dumpautoload --optimize',
5 => 'tar cfz /tmp/mageXYZ --exclude=.git --exclude=vendor --exclude=app/cache --exclude=app/log --exclude=web/app_dev.php ./',
6 => 'ssh -p 22 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost sh -c \\"mkdir -p /var/www/test/releases/1234567890\\"',
7 => 'scp -P 22 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no /tmp/mageXYZ tester@testhost:/var/www/test/releases/1234567890/mageXYZ',
8 => 'ssh -p 22 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost sh -c \\"cd /var/www/test/releases/1234567890 \\&\\& tar xfz mageXYZ\\"',
9 => 'ssh -p 22 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost sh -c \\"rm /var/www/test/releases/1234567890/mageXYZ\\"',
);
// Check total of Executed Commands
$this->assertEquals(count($ranCommands), count($testCase));
// Check Generated Commands
foreach ($testCase as $index => $command) {
$this->assertEquals($ranCommands[$index], $command);
}
$this->assertTrue(strpos($tester->getDisplay(), 'ERROR') !== false);
$this->assertNotEquals($tester->getStatusCode(), 0);
}
public function testDeploymentWithFailingPostDeployTaskCommands()
{
$application = new MageTestApplication();
$application->add(new DeployCommand());
$runtime = new RuntimeMockup();
$runtime->setConfiguration(array(
'environments' =>
array(
'test' =>
array(
'user' => 'tester',
'branch' => 'test',
'host_path' => '/var/www/test',
'exclude' =>
array(
0 => 'vendor',
1 => 'app/cache',
2 => 'app/log',
3 => 'web/app_dev.php',
),
'hosts' =>
array(
0 => 'testhost',
),
'pre-deploy' =>
array(
0 => 'git/update',
1 => 'composer/install',
2 => 'composer/generate-autoload',
),
'on-deploy' =>
array(
0 => 'deploy/rsync',
),
'on-release' => null,
'post-release' => null,
'post-deploy' =>
array(
0 => 'deploy/targz/cleanup',
),
),
),
)
);
$runtime->setReleaseId('20170101015120');
/** @var AbstractCommand $command */
$command = $application->find('deploy');
$command->setRuntime($runtime);
$tester = new CommandTester($command);
$tester->execute(['command' => $command->getName(), 'environment' => 'test']);
$ranCommands = $runtime->getRanCommands();
$testCase = array(
0 => 'git branch | grep "*"',
1 => 'git checkout test',
2 => 'git pull',
3 => 'composer install --dev',
4 => 'composer dumpautoload --optimize',
5 => 'rsync -avz --exclude=.git --exclude=vendor --exclude=app/cache --exclude=app/log --exclude=web/app_dev.php ./ tester@testhost:/var/www/test',
6 => 'git checkout master',
);
// Check total of Executed Commands
$this->assertEquals(count($ranCommands), count($testCase));
// Check Generated Commands
foreach ($testCase as $index => $command) {
$this->assertEquals($ranCommands[$index], $command);
}
$this->assertTrue(strpos($tester->getDisplay(), 'ERROR') !== false);
$this->assertNotEquals($tester->getStatusCode(), 0);
} }
public function testDeploymentWithoutReleasesCommands() public function testDeploymentWithoutReleasesCommands()
@ -228,6 +391,8 @@ class DeployCommandTest extends TestCase
foreach ($testCase as $index => $command) { foreach ($testCase as $index => $command) {
$this->assertEquals($ranCommands[$index], $command); $this->assertEquals($ranCommands[$index], $command);
} }
$this->assertEquals($tester->getStatusCode(), 0);
} }
public function testDeploymentWithSkippingTask() public function testDeploymentWithSkippingTask()
@ -333,5 +498,7 @@ class DeployCommandTest extends TestCase
} }
$this->assertTrue(strpos($tester->getDisplay(), 'SKIPPED') !== false); $this->assertTrue(strpos($tester->getDisplay(), 'SKIPPED') !== false);
$this->assertEquals($tester->getStatusCode(), 0);
} }
} }