From b13b3f92b6642414e5d432f7fa3a7c51b3966826 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Sat, 22 Jul 2017 18:13:26 -0300 Subject: [PATCH 1/8] Update to Dev version --- src/Mage.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Mage.php b/src/Mage.php index 435b2c1..4944c52 100644 --- a/src/Mage.php +++ b/src/Mage.php @@ -17,6 +17,6 @@ namespace Mage; */ class Mage { - const VERSION = '3.3.0'; + const VERSION = '3.x-dev'; const CODENAME = 'Nostromo'; } From ceb07a306f4fe84cdb0ee0269436b90f8ad9e1f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 16:48:14 -0300 Subject: [PATCH 2/8] [Issue-380] Throw exception if log_dir is defined but doesn't exists --- .gitignore | 1 + CHANGELOG.md | 4 ++++ src/MageApplication.php | 3 +++ .../Command/BuiltIn/DeployCommandMiscTest.php | 19 +++++++++++++++++++ 4 files changed, 27 insertions(+) diff --git a/.gitignore b/.gitignore index 263233c..11aaa0c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ /vendor/ /build composer.lock +.mage.yml diff --git a/CHANGELOG.md b/CHANGELOG.md index d40ac36..c81798a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,10 @@ CHANGELOG for 3.X ================= +* 3.4.0 (2018-03-29) + * [Issue#380] Throw exception if log_dir is defined but directory doesn't exists + + * 3.3.0 (2017-07-22) * [PR#386] Allow to define timeout (default 120s) for symfony/assetic-dump task. * [PR#392] Allow to define Host Port in Host configuration. diff --git a/src/MageApplication.php b/src/MageApplication.php index cb20d30..77fe4e2 100644 --- a/src/MageApplication.php +++ b/src/MageApplication.php @@ -84,6 +84,9 @@ class MageApplication extends Application $logger = new Logger('magephp'); $logger->pushHandler(new StreamHandler($logfile)); + + } elseif (array_key_exists('log_dir', $config['magephp']) && !is_dir($config['magephp']['log_dir'])) { + throw new RuntimeException(sprintf('The configured log_dir "%s" does not exists or is not a directory.', $config['magephp']['log_dir'])); } $this->runtime->setConfiguration($config['magephp']); diff --git a/tests/Command/BuiltIn/DeployCommandMiscTest.php b/tests/Command/BuiltIn/DeployCommandMiscTest.php index 9ffa09d..8df52ef 100644 --- a/tests/Command/BuiltIn/DeployCommandMiscTest.php +++ b/tests/Command/BuiltIn/DeployCommandMiscTest.php @@ -11,6 +11,7 @@ namespace Mage\Tests\Command\BuiltIn; use Mage\Command\BuiltIn\DeployCommand; +use Mage\Runtime\Exception\RuntimeException; use Mage\Tests\MageApplicationMockup; use Mage\Command\AbstractCommand; use Symfony\Component\Console\Tester\CommandTester; @@ -36,6 +37,24 @@ class DeployCommandMiscTest extends TestCase $this->assertEquals(0, $tester->getStatusCode()); } + public function testInvalidLog() + { + $application = new MageApplicationMockup(__DIR__ . '/../../Resources/invalid-log.yml'); + + /** @var AbstractCommand $command */ + $command = $application->find('deploy'); + $this->assertTrue($command instanceof DeployCommand); + + try { + $tester = new CommandTester($command); + $tester->execute(['command' => $command->getName(), 'environment' => 'test']); + } catch (RuntimeException $exception) { + $this->assertEquals('The configured log_dir "/no-temp" does not exists or is not a directory.', $exception->getMessage()); + } catch (\Exception $exception) { + $this->assertFalse(true, sprintf('Exception "%s" catched, message: "%s"', get_class($exception), $exception->getMessage())); + } + } + public function testDeploymentWithSudo() { $application = new MageApplicationMockup(__DIR__ . '/../../Resources/testhost-sudo.yml'); From bab5e164a5fd30b3a0c7e3fa7a697115da84b15b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 17:14:11 -0300 Subject: [PATCH 3/8] [Issue-380] Throw exception if log_dir is defined but doesn't exists --- tests/Resources/invalid-log.yml | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 tests/Resources/invalid-log.yml diff --git a/tests/Resources/invalid-log.yml b/tests/Resources/invalid-log.yml new file mode 100644 index 0000000..d6321c5 --- /dev/null +++ b/tests/Resources/invalid-log.yml @@ -0,0 +1,27 @@ +magephp: + log_dir: /no-temp + environments: + production: + user: app + branch: master + host_path: /var/www/myapp + releases: 4 + exclude: + - ./var/cache/* + - ./var/log/* + - ./web/app_dev.php + hosts: + - webserver1 + - webserver2 + - webserver3 + pre-deploy: + - git/update + - composer/install + - composer/dump-autoload + on-deploy: + - symfony/cache-warmup: { env: 'dev' } + - symfony/assets-install: { env: 'dev' } + - symfony/assetic-dump: { env: 'dev' } + on-release: + post-release: + post-deploy: \ No newline at end of file From 4232059d7e84be5b0b2752042f727b7be8e20e5c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 17:33:20 -0300 Subject: [PATCH 4/8] [BUGFIX] [Issue#405] Malformed ssh command when defining host:port notation --- CHANGELOG.md | 1 + src/Command/BuiltIn/DeployCommand.php | 4 +- src/Runtime/Runtime.php | 13 ++++- src/Task/BuiltIn/Deploy/RsyncTask.php | 2 +- src/Task/BuiltIn/Deploy/Tar/CopyTask.php | 2 +- src/Task/BuiltIn/FS/AbstractFileTask.php | 4 +- .../BuiltIn/DeployCommandWithReleasesTest.php | 50 +++++++++++++++++++ .../DeployCommandWithoutReleasesTest.php | 37 ++++++++++++++ tests/Resources/testhost-with-port.yml | 27 ++++++++++ .../testhost-without-releases-with-port.yml | 24 +++++++++ tests/Runtime/ProcessMockup.php | 8 +++ 11 files changed, 165 insertions(+), 7 deletions(-) create mode 100644 tests/Resources/testhost-with-port.yml create mode 100644 tests/Resources/testhost-without-releases-with-port.yml diff --git a/CHANGELOG.md b/CHANGELOG.md index c81798a..d061184 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,7 @@ CHANGELOG for 3.X * 3.4.0 (2018-03-29) * [Issue#380] Throw exception if log_dir is defined but directory doesn't exists + * [Issue#405] Malformed ssh command when defining host:port notation * 3.3.0 (2017-07-22) diff --git a/src/Command/BuiltIn/DeployCommand.php b/src/Command/BuiltIn/DeployCommand.php index dd86e4d..339f275 100644 --- a/src/Command/BuiltIn/DeployCommand.php +++ b/src/Command/BuiltIn/DeployCommand.php @@ -175,8 +175,8 @@ class DeployCommand extends AbstractCommand return true; } - if ($this->runtime->getWorkingHost() !== null) { - $output->writeln(sprintf(' Starting %s tasks on host %s:', $this->getStageName(), $this->runtime->getWorkingHost())); + if ($this->runtime->getHostName() !== null) { + $output->writeln(sprintf(' Starting %s tasks on host %s:', $this->getStageName(), $this->runtime->getHostName())); } else { $output->writeln(sprintf(' Starting %s tasks:', $this->getStageName())); } diff --git a/src/Runtime/Runtime.php b/src/Runtime/Runtime.php index f28e03f..2a4eb07 100644 --- a/src/Runtime/Runtime.php +++ b/src/Runtime/Runtime.php @@ -429,7 +429,7 @@ class Runtime { $user = $this->getEnvOption('user', $this->getCurrentUser()); $sudo = $this->getEnvOption('sudo', false); - $host = $this->getWorkingHost(); + $host = $this->getHostName(); $sshConfig = $this->getSSHConfig(); $cmdDelegate = $cmd; @@ -485,6 +485,17 @@ class Runtime return isset($info[1]) ? $info[1] : null; } + /** + * Get the current Host Name + * + * @return string + */ + public function getHostName() + { + $info = explode(':', $this->getWorkingHost()); + return $info[0]; + } + /** * Gets a Temporal File name * diff --git a/src/Task/BuiltIn/Deploy/RsyncTask.php b/src/Task/BuiltIn/Deploy/RsyncTask.php index b1ac64b..b3ce7f9 100644 --- a/src/Task/BuiltIn/Deploy/RsyncTask.php +++ b/src/Task/BuiltIn/Deploy/RsyncTask.php @@ -36,7 +36,7 @@ class RsyncTask extends AbstractTask $flags = $this->runtime->getEnvOption('rsync', '-avz'); $sshConfig = $this->runtime->getSSHConfig(); $user = $this->runtime->getEnvOption('user', $this->runtime->getCurrentUser()); - $host = $this->runtime->getWorkingHost(); + $host = $this->runtime->getHostName(); $hostPath = rtrim($this->runtime->getEnvOption('host_path'), '/'); $targetDir = rtrim($hostPath, '/'); diff --git a/src/Task/BuiltIn/Deploy/Tar/CopyTask.php b/src/Task/BuiltIn/Deploy/Tar/CopyTask.php index 294d2bc..997023d 100644 --- a/src/Task/BuiltIn/Deploy/Tar/CopyTask.php +++ b/src/Task/BuiltIn/Deploy/Tar/CopyTask.php @@ -38,7 +38,7 @@ class CopyTask extends AbstractTask } $user = $this->runtime->getEnvOption('user', $this->runtime->getCurrentUser()); - $host = $this->runtime->getWorkingHost(); + $host = $this->runtime->getHostName(); $sshConfig = $sshConfig = $this->runtime->getSSHConfig(); $hostPath = rtrim($this->runtime->getEnvOption('host_path'), '/'); $currentReleaseId = $this->runtime->getReleaseId(); diff --git a/src/Task/BuiltIn/FS/AbstractFileTask.php b/src/Task/BuiltIn/FS/AbstractFileTask.php index eb782b2..6243946 100644 --- a/src/Task/BuiltIn/FS/AbstractFileTask.php +++ b/src/Task/BuiltIn/FS/AbstractFileTask.php @@ -61,8 +61,8 @@ abstract class AbstractFileTask extends AbstractTask '%environment%' => $this->runtime->getEnvironment(), ]; - if ($this->runtime->getWorkingHost() !== null) { - $mapping['%host%'] = $this->runtime->getWorkingHost(); + if ($this->runtime->getHostName() !== null) { + $mapping['%host%'] = $this->runtime->getHostName(); } if ($this->runtime->getReleaseId() !== null) { diff --git a/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php b/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php index ead0053..b498f6b 100644 --- a/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php +++ b/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php @@ -68,6 +68,56 @@ class DeployCommandWithReleasesTest extends TestCase $this->assertEquals(0, $tester->getStatusCode()); } + public function testDeploymentWithReleasesWithPortCommands() + { + $application = new MageApplicationMockup(__DIR__ . '/../../Resources/testhost-with-port.yml'); + + $application->getRuntime()->setReleaseId('20170101015120'); + + /** @var AbstractCommand $command */ + $command = $application->find('deploy'); + $this->assertTrue($command instanceof DeployCommand); + + $tester = new CommandTester($command); + $tester->execute(['command' => $command->getName(), 'environment' => 'test']); + + $ranCommands = $application->getRuntime()->getRanCommands(); + + $testCase = array( + 0 => 'git branch | grep "*"', + 1 => 'git checkout test', + 2 => 'git pull', + 3 => 'composer install --optimize-autoloader', + 4 => 'composer dump-autoload --optimize', + 5 => 'tar cfzp /tmp/mageXYZ --exclude=".git" --exclude="./var/cache/*" --exclude="./var/log/*" --exclude="./web/app_dev.php" ./', + 6 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "mkdir -p /var/www/test/releases/1234567890"', + 7 => 'scp -P 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no /tmp/mageXYZ tester@testhost:/var/www/test/releases/1234567890/mageXYZ', + 8 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && tar xfzop mageXYZ"', + 9 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm /var/www/test/releases/1234567890/mageXYZ"', + 10 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console cache:warmup --env=dev"', + 11 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console assets:install web --env=dev --symlink --relative"', + 12 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console assetic:dump --env=dev"', + 13 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test && ln -snf releases/1234567890 current"', + 14 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "ls -1 /var/www/test/releases"', + 15 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm -rf /var/www/test/releases/20170101015110"', + 16 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm -rf /var/www/test/releases/20170101015111"', + 17 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm -rf /var/www/test/releases/20170101015112"', + 18 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm -rf /var/www/test/releases/20170101015113"', + 19 => 'rm /tmp/mageXYZ', + 20 => 'git checkout master', + ); + + // Check total of Executed Commands + $this->assertEquals(count($testCase), count($ranCommands)); + + // Check Generated Commands + foreach ($testCase as $index => $command) { + $this->assertEquals($command, $ranCommands[$index]); + } + + $this->assertEquals(0, $tester->getStatusCode()); + } + public function testDeploymentWithReleasesWithFromCommands() { $application = new MageApplicationMockup(__DIR__ . '/../../Resources/testhost-with-from.yml'); diff --git a/tests/Command/BuiltIn/DeployCommandWithoutReleasesTest.php b/tests/Command/BuiltIn/DeployCommandWithoutReleasesTest.php index 0ba490b..1e58531 100644 --- a/tests/Command/BuiltIn/DeployCommandWithoutReleasesTest.php +++ b/tests/Command/BuiltIn/DeployCommandWithoutReleasesTest.php @@ -55,6 +55,43 @@ class DeployCommandWithoutReleasesTest extends TestCase $this->assertEquals(0, $tester->getStatusCode()); } + public function testDeploymentWithoutReleasesWithPortCommands() + { + $application = new MageApplicationMockup(__DIR__ . '/../../Resources/testhost-without-releases-with-port.yml'); + + /** @var AbstractCommand $command */ + $command = $application->find('deploy'); + $this->assertTrue($command instanceof DeployCommand); + + $tester = new CommandTester($command); + $tester->execute(['command' => $command->getName(), 'environment' => 'test']); + + $ranCommands = $application->getRuntime()->getRanCommands(); + + $testCase = array( + 0 => 'git branch | grep "*"', + 1 => 'git checkout test', + 2 => 'git pull', + 3 => 'composer install --optimize-autoloader', + 4 => 'composer dump-autoload --optimize', + 5 => 'rsync -e "ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no" -avz --exclude=.git --exclude=./var/cache/* --exclude=./var/log/* --exclude=./web/app_dev.php ./ tester@testhost:/var/www/test', + 6 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test && bin/console cache:warmup --env=dev"', + 7 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test && bin/console assets:install web --env=dev --symlink --relative"', + 8 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test && bin/console assetic:dump --env=dev"', + 9 => 'git checkout master', + ); + + // Check total of Executed Commands + $this->assertEquals(count($testCase), count($ranCommands)); + + // Check Generated Commands + foreach ($testCase as $index => $command) { + $this->assertEquals($command, $ranCommands[$index]); + } + + $this->assertEquals(0, $tester->getStatusCode()); + } + public function testDeploymentWithoutReleasesWithFromCommands() { $application = new MageApplicationMockup(__DIR__ . '/../../Resources/testhost-without-releases-with-from.yml'); diff --git a/tests/Resources/testhost-with-port.yml b/tests/Resources/testhost-with-port.yml new file mode 100644 index 0000000..2c8a58d --- /dev/null +++ b/tests/Resources/testhost-with-port.yml @@ -0,0 +1,27 @@ +magephp: + log_dir: /tmp + environments: + test: + user: tester + branch: test + host_path: /var/www/test + releases: 4 + exclude: + - ./var/cache/* + - ./var/log/* + - ./web/app_dev.php + - + - + hosts: + - testhost:202 + pre-deploy: + - git/update + - composer/install + - composer/dump-autoload + on-deploy: + - symfony/cache-warmup: { env: 'dev' } + - symfony/assets-install: { env: 'dev' } + - symfony/assetic-dump: { env: 'dev' } + on-release: + post-release: + post-deploy: \ No newline at end of file diff --git a/tests/Resources/testhost-without-releases-with-port.yml b/tests/Resources/testhost-without-releases-with-port.yml new file mode 100644 index 0000000..9f4f184 --- /dev/null +++ b/tests/Resources/testhost-without-releases-with-port.yml @@ -0,0 +1,24 @@ +magephp: + log_dir: /tmp + environments: + test: + user: tester + branch: test + host_path: /var/www/test + exclude: + - ./var/cache/* + - ./var/log/* + - ./web/app_dev.php + hosts: + - testhost:202 + pre-deploy: + - git/update + - composer/install + - composer/dump-autoload + on-deploy: + - symfony/cache-warmup: { env: 'dev' } + - symfony/assets-install: { env: 'dev' } + - symfony/assetic-dump: { env: 'dev' } + on-release: + post-release: + post-deploy: \ No newline at end of file diff --git a/tests/Runtime/ProcessMockup.php b/tests/Runtime/ProcessMockup.php index 918a127..f5b862b 100644 --- a/tests/Runtime/ProcessMockup.php +++ b/tests/Runtime/ProcessMockup.php @@ -99,6 +99,14 @@ class ProcessMockup extends Process return '/var/www/test/releases/20170101015117'; } + if ($this->commandline == 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "ls -1 /var/www/test/releases"') { + return implode(PHP_EOL, ['20170101015110', '20170101015111', '20170101015112', '20170101015113', '20170101015114', '20170101015115', '20170101015116', '20170101015117']); + } + + if ($this->commandline == 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "readlink -f /var/www/test/current"') { + return '/var/www/test/releases/20170101015117'; + } + if ($this->commandline == 'ssh -p 22 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@host1 "ls -1 /var/www/test/releases"') { return implode(PHP_EOL, ['20170101015110', '20170101015111', '20170101015112', '20170101015113', '20170101015114', '20170101015115', '20170101015116', '20170101015117']); } From 50ddf081fb4d22764c99458ebadd9eed9c999799 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 17:38:28 -0300 Subject: [PATCH 5/8] [BUGFIX] [Issue#405] Malformed ssh command when defining host:port notation --- CHANGELOG.md | 2 +- src/Runtime/Runtime.php | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d061184..2f35c40 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,7 +3,7 @@ CHANGELOG for 3.X * 3.4.0 (2018-03-29) * [Issue#380] Throw exception if log_dir is defined but directory doesn't exists - * [Issue#405] Malformed ssh command when defining host:port notation + * [BUGFIX] [Issue#405] Malformed ssh command when defining host:port notation * 3.3.0 (2017-07-22) diff --git a/src/Runtime/Runtime.php b/src/Runtime/Runtime.php index 2a4eb07..5b7368d 100644 --- a/src/Runtime/Runtime.php +++ b/src/Runtime/Runtime.php @@ -492,6 +492,10 @@ class Runtime */ public function getHostName() { + if (strpos($this->getWorkingHost(), ':') === false) { + return $this->getWorkingHost(); + } + $info = explode(':', $this->getWorkingHost()); return $info[0]; } From b5f181bb18c81e7581a59ac36405eb988a6b7e25 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 17:55:54 -0300 Subject: [PATCH 6/8] Improve tests --- .travis.yml | 1 + docs/dockers/docker-compose.yml | 19 +++++++++++++++++++ docs/dockers/php5/Dockerfile | 9 +++++++++ docs/dockers/php7.0/Dockerfile | 9 +++++++++ docs/dockers/php7.1/Dockerfile | 9 +++++++++ .../BuiltIn/DeployCommandWithReleasesTest.php | 6 +++--- tests/Resources/testhost-with-port.yml | 6 +++--- 7 files changed, 53 insertions(+), 6 deletions(-) create mode 100644 docs/dockers/docker-compose.yml create mode 100644 docs/dockers/php5/Dockerfile create mode 100644 docs/dockers/php7.0/Dockerfile create mode 100644 docs/dockers/php7.1/Dockerfile diff --git a/.travis.yml b/.travis.yml index 3241d8c..51d78aa 100644 --- a/.travis.yml +++ b/.travis.yml @@ -4,6 +4,7 @@ php: - '5.6' - '7.0' - '7.1' + - '7.2' install: - composer install diff --git a/docs/dockers/docker-compose.yml b/docs/dockers/docker-compose.yml new file mode 100644 index 0000000..9bd212f --- /dev/null +++ b/docs/dockers/docker-compose.yml @@ -0,0 +1,19 @@ +version: '2' +services: + php5: + container_name: mage-php5 + build: ./php5 + volumes: + - ../../:/home/magephp + + php7.0: + container_name: mage-php7.0 + build: ./php7.0 + volumes: + - ../../:/home/magephp + + php7.1: + container_name: mage-php7.1 + build: ./php7.1 + volumes: + - ../../:/home/magephp diff --git a/docs/dockers/php5/Dockerfile b/docs/dockers/php5/Dockerfile new file mode 100644 index 0000000..c7918b4 --- /dev/null +++ b/docs/dockers/php5/Dockerfile @@ -0,0 +1,9 @@ +FROM ubuntu:14.04 + +RUN apt-get update && apt-get upgrade -y +RUN apt-get install -y vim curl git unzip +RUN apt-get install -y php5-cli php5-curl + +RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin/ --filename=composer + +WORKDIR /home/magephp diff --git a/docs/dockers/php7.0/Dockerfile b/docs/dockers/php7.0/Dockerfile new file mode 100644 index 0000000..f1da4b4 --- /dev/null +++ b/docs/dockers/php7.0/Dockerfile @@ -0,0 +1,9 @@ +FROM ubuntu:16.04 + +RUN apt-get update && apt-get upgrade -y +RUN apt-get install -y vim curl git unzip +RUN apt-get install -y php7.0-cli php-zip php7.0-curl php7.0-xml + +RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin/ --filename=composer + +WORKDIR /home/magephp diff --git a/docs/dockers/php7.1/Dockerfile b/docs/dockers/php7.1/Dockerfile new file mode 100644 index 0000000..cb63a2b --- /dev/null +++ b/docs/dockers/php7.1/Dockerfile @@ -0,0 +1,9 @@ +FROM ubuntu:17.10 + +RUN apt-get update && apt-get upgrade -y +RUN apt-get install -y vim curl git unzip +RUN apt-get install -y php7.1-cli php-zip php7.1-curl php7.1-xml + +RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin/ --filename=composer + +WORKDIR /home/magephp diff --git a/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php b/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php index b498f6b..de3e201 100644 --- a/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php +++ b/tests/Command/BuiltIn/DeployCommandWithReleasesTest.php @@ -94,9 +94,9 @@ class DeployCommandWithReleasesTest extends TestCase 7 => 'scp -P 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no /tmp/mageXYZ tester@testhost:/var/www/test/releases/1234567890/mageXYZ', 8 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && tar xfzop mageXYZ"', 9 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm /var/www/test/releases/1234567890/mageXYZ"', - 10 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console cache:warmup --env=dev"', - 11 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console assets:install web --env=dev --symlink --relative"', - 12 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console assetic:dump --env=dev"', + 10 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console cache:warmup --env=prod"', + 11 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console assets:install web --env=prod --symlink --relative"', + 12 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test/releases/1234567890 && bin/console assetic:dump --env=prod"', 13 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "cd /var/www/test && ln -snf releases/1234567890 current"', 14 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "ls -1 /var/www/test/releases"', 15 => 'ssh -p 202 -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no tester@testhost "rm -rf /var/www/test/releases/20170101015110"', diff --git a/tests/Resources/testhost-with-port.yml b/tests/Resources/testhost-with-port.yml index 2c8a58d..c6e5ff6 100644 --- a/tests/Resources/testhost-with-port.yml +++ b/tests/Resources/testhost-with-port.yml @@ -19,9 +19,9 @@ magephp: - composer/install - composer/dump-autoload on-deploy: - - symfony/cache-warmup: { env: 'dev' } - - symfony/assets-install: { env: 'dev' } - - symfony/assetic-dump: { env: 'dev' } + - symfony/cache-warmup: { env: 'prod' } + - symfony/assets-install: { env: 'prod' } + - symfony/assetic-dump: { env: 'prod' } on-release: post-release: post-deploy: \ No newline at end of file From 7860fea42591e7b1f5bb0c2b37db77d15bcb53c1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 18:09:11 -0300 Subject: [PATCH 7/8] Improve tests for php 7.2 --- src/Command/BuiltIn/DeployCommand.php | 3 +++ src/Command/BuiltIn/Releases/ListCommand.php | 3 +++ 2 files changed, 6 insertions(+) diff --git a/src/Command/BuiltIn/DeployCommand.php b/src/Command/BuiltIn/DeployCommand.php index 339f275..bb2cb5c 100644 --- a/src/Command/BuiltIn/DeployCommand.php +++ b/src/Command/BuiltIn/DeployCommand.php @@ -143,6 +143,9 @@ class DeployCommand extends AbstractCommand protected function runOnHosts(OutputInterface $output, $tasks) { $hosts = $this->runtime->getEnvOption('hosts'); + if (!is_array($hosts) && !$hosts instanceof \Countable) { + $hosts = []; + } if (count($hosts) == 0) { $output->writeln(sprintf(' No hosts defined, skipping %s tasks', $this->getStageName())); $output->writeln(''); diff --git a/src/Command/BuiltIn/Releases/ListCommand.php b/src/Command/BuiltIn/Releases/ListCommand.php index 4bee690..5d49ce2 100644 --- a/src/Command/BuiltIn/Releases/ListCommand.php +++ b/src/Command/BuiltIn/Releases/ListCommand.php @@ -74,6 +74,9 @@ class ListCommand extends AbstractCommand $output->writeln(''); $hosts = $this->runtime->getEnvOption('hosts'); + if (!is_array($hosts) && !$hosts instanceof \Countable) { + $hosts = []; + } if (count($hosts) == 0) { $output->writeln('No hosts defined'); $output->writeln(''); From 5fa99c68f579748ac206d06905dba8cf8419547d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s=20Monta=C3=B1ez?= Date: Thu, 29 Mar 2018 18:33:40 -0300 Subject: [PATCH 8/8] [Issue#415] Remove timeout on Deploy with Tar or Rsync tasks --- CHANGELOG.md | 1 + src/Task/BuiltIn/Deploy/ReleaseTask.php | 2 +- src/Task/BuiltIn/Deploy/RsyncTask.php | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2f35c40..785091b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ CHANGELOG for 3.X * 3.4.0 (2018-03-29) * [Issue#380] Throw exception if log_dir is defined but directory doesn't exists * [BUGFIX] [Issue#405] Malformed ssh command when defining host:port notation + * [Issue#415] Remove timeout on Deploy with Tar or Rsync tasks * 3.3.0 (2017-07-22) diff --git a/src/Task/BuiltIn/Deploy/ReleaseTask.php b/src/Task/BuiltIn/Deploy/ReleaseTask.php index ad0dd00..ab767f0 100644 --- a/src/Task/BuiltIn/Deploy/ReleaseTask.php +++ b/src/Task/BuiltIn/Deploy/ReleaseTask.php @@ -44,7 +44,7 @@ class ReleaseTask extends AbstractTask implements ExecuteOnRollbackInterface $cmdLinkRelease = sprintf('cd %s && ln -snf releases/%s current', $hostPath, $releaseId); /** @var Process $process */ - $process = $this->runtime->runRemoteCommand($cmdLinkRelease, false); + $process = $this->runtime->runRemoteCommand($cmdLinkRelease, false, null); return $process->isSuccessful(); } } diff --git a/src/Task/BuiltIn/Deploy/RsyncTask.php b/src/Task/BuiltIn/Deploy/RsyncTask.php index b3ce7f9..1310a5a 100644 --- a/src/Task/BuiltIn/Deploy/RsyncTask.php +++ b/src/Task/BuiltIn/Deploy/RsyncTask.php @@ -49,7 +49,7 @@ class RsyncTask extends AbstractTask $cmdRsync = sprintf('rsync -e "ssh -p %d %s" %s %s %s %s@%s:%s', $sshConfig['port'], $sshConfig['flags'], $flags, $excludes, $from, $user, $host, $targetDir); /** @var Process $process */ - $process = $this->runtime->runLocalCommand($cmdRsync, 600); + $process = $this->runtime->runLocalCommand($cmdRsync, null); return $process->isSuccessful(); }