From 9075f2ce54da660ca068c0825d08af8754f72f1b Mon Sep 17 00:00:00 2001 From: YutaAdachi Date: Fri, 21 Mar 2014 16:31:07 +0000 Subject: [PATCH 001/424] Correctly load events and tasks inside Laravel --- src/Rocketeer/Igniter.php | 55 ++++++++++++++++++++++++++------------- 1 file changed, 37 insertions(+), 18 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index ba245bce2..b3686c4b8 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -58,11 +58,8 @@ public function bindPaths() public function getConfigurationPath() { // Return path to Laravel configuration - if ($this->app->bound('path')) { + if ($this->isInsideLaravel()) { $laravel = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; - if (file_exists($laravel)) { - return $laravel; - } } return $this->app['path.rocketeer.config']; @@ -133,32 +130,35 @@ protected function bindBase() */ protected function bindConfiguration() { - $path = $this->getBasePath(); - $logs = $this->getStoragePath(); + // Bind path to the configuration directory + if ($this->isInsideLaravel()) { + $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + } else { + $path = $this->getBasePath().'.rocketeer'; + } - // Prepare the paths to bind + // Build pathes $paths = array( - 'config' => '.rocketeer', - 'events' => '.rocketeer/events', - 'tasks' => '.rocketeer/tasks', - 'logs' => $logs.'/logs', + 'config' => $path.'', + 'events' => $path.'/events', + 'tasks' => $path.'/tasks', + 'logs' => $this->getStoragePath().'logs', ); foreach ($paths as $key => $file) { - $filename = $path.$file; // Check whether we provided a file or folder - if (!is_dir($filename) and file_exists($filename.'.php')) { - $filename .= '.php'; + if (!is_dir($file) and file_exists($file.'.php')) { + $file .= '.php'; } // Use configuration in current folder if none found - $realpath = realpath('.').'/'.$file; - if (!file_exists($filename) and file_exists($realpath)) { - $filename = $realpath; + $realpath = realpath('.').'/'.basename($file); + if (!file_exists($file) and file_exists($realpath)) { + $file = $realpath; } - $this->app->instance('path.rocketeer.'.$key, $filename); + $this->app->instance('path.rocketeer.'.$key, $file); } } @@ -210,4 +210,23 @@ protected function unifySlashes($path) { return str_replace('\\', '/', $path); } + + + /** + * Check if this is in Laravel + * + * @return boolean + */ + protected function isInsideLaravel() + { + // Return path to Laravel configuration + if ($this->app->bound('path')) { + $laravel = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + if (file_exists($laravel)) { + return true; + } + } + return false; + } } + From 2531f89d87eae7d476c1467fc7584ba00bdbe93f Mon Sep 17 00:00:00 2001 From: YutaAdachi Date: Fri, 21 Mar 2014 16:53:55 +0000 Subject: [PATCH 002/424] Correctly load events and tasks --- src/Rocketeer/Igniter.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index b3686c4b8..b99d931ac 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -59,7 +59,7 @@ public function getConfigurationPath() { // Return path to Laravel configuration if ($this->isInsideLaravel()) { - $laravel = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + return $this->app['path'].'/config/packages/anahkiasen/rocketeer'; } return $this->app['path.rocketeer.config']; From 6266ff1f8ac8ddb0c4c741aa4e3a0c6b271d5e5d Mon Sep 17 00:00:00 2001 From: YutaAdachi Date: Sun, 23 Mar 2014 00:45:45 +0900 Subject: [PATCH 003/424] Remove a new line at ent of file --- src/Rocketeer/Igniter.php | 1 - 1 file changed, 1 deletion(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index b99d931ac..501bb553f 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -229,4 +229,3 @@ protected function isInsideLaravel() return false; } } - From a15ecf36c1ca3c4a9bf91362fd686fe609758ca6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 8 Jun 2014 13:11:29 +0200 Subject: [PATCH 004/424] Close #229 - Add PHPUnit to dev requirements --- composer.json | 3 +- composer.lock | 704 +++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 703 insertions(+), 4 deletions(-) diff --git a/composer.json b/composer.json index 5e91855cb..0efdd6371 100644 --- a/composer.json +++ b/composer.json @@ -22,7 +22,8 @@ "illuminate/filesystem": "~4.1", "illuminate/events": "~4.1", "illuminate/remote": "~4.1", - "illuminate/log": "~4.1" + "illuminate/log": "~4.1", + "phpunit/phpunit": "4.*" }, "require-dev": { "mockery/mockery": "~0.9", diff --git a/composer.lock b/composer.lock index 034d7f4ca..9afcc01d0 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "b3b332169ded14fb990f977dd08b7734", + "hash": "9528a4a339bed2de8aacc34c6159623d", "packages": [ { "name": "illuminate/config", @@ -538,6 +538,385 @@ ], "time": "2014-02-28 16:05:05" }, + { + "name": "phpunit/php-code-coverage", + "version": "2.0.8", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-code-coverage.git", + "reference": "58401826c8cfc8fd689b60026e91c337df374bca" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/58401826c8cfc8fd689b60026e91c337df374bca", + "reference": "58401826c8cfc8fd689b60026e91c337df374bca", + "shasum": "" + }, + "require": { + "php": ">=5.3.3", + "phpunit/php-file-iterator": "~1.3.1", + "phpunit/php-text-template": "~1.2.0", + "phpunit/php-token-stream": "~1.2.2", + "sebastian/environment": "~1.0.0", + "sebastian/version": "~1.0.3" + }, + "require-dev": { + "ext-xdebug": ">=2.1.4", + "phpunit/phpunit": "~4.0.14" + }, + "suggest": { + "ext-dom": "*", + "ext-xdebug": ">=2.2.1", + "ext-xmlwriter": "*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" + } + ], + "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", + "homepage": "https://github.com/sebastianbergmann/php-code-coverage", + "keywords": [ + "coverage", + "testing", + "xunit" + ], + "time": "2014-05-26 14:55:24" + }, + { + "name": "phpunit/php-file-iterator", + "version": "1.3.4", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-file-iterator.git", + "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/acd690379117b042d1c8af1fafd61bde001bf6bb", + "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "library", + "autoload": { + "classmap": [ + "File/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" + } + ], + "description": "FilterIterator implementation that filters files based on a list of suffixes.", + "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", + "keywords": [ + "filesystem", + "iterator" + ], + "time": "2013-10-10 15:34:57" + }, + { + "name": "phpunit/php-text-template", + "version": "1.2.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-text-template.git", + "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", + "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "library", + "autoload": { + "classmap": [ + "Text/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" + } + ], + "description": "Simple template engine.", + "homepage": "https://github.com/sebastianbergmann/php-text-template/", + "keywords": [ + "template" + ], + "time": "2014-01-30 17:20:04" + }, + { + "name": "phpunit/php-timer", + "version": "1.0.5", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-timer.git", + "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/19689d4354b295ee3d8c54b4f42c3efb69cbc17c", + "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "library", + "autoload": { + "classmap": [ + "PHP/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" + } + ], + "description": "Utility class for timing", + "homepage": "https://github.com/sebastianbergmann/php-timer/", + "keywords": [ + "timer" + ], + "time": "2013-08-02 07:42:54" + }, + { + "name": "phpunit/php-token-stream", + "version": "1.2.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-token-stream.git", + "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/ad4e1e23ae01b483c16f600ff1bebec184588e32", + "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32", + "shasum": "" + }, + "require": { + "ext-tokenizer": "*", + "php": ">=5.3.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.2-dev" + } + }, + "autoload": { + "classmap": [ + "PHP/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" + } + ], + "description": "Wrapper around PHP's tokenizer extension.", + "homepage": "https://github.com/sebastianbergmann/php-token-stream/", + "keywords": [ + "tokenizer" + ], + "time": "2014-03-03 05:10:30" + }, + { + "name": "phpunit/phpunit", + "version": "4.1.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/phpunit.git", + "reference": "be5f237df860da88a7cfe247594232cae61845df" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/be5f237df860da88a7cfe247594232cae61845df", + "reference": "be5f237df860da88a7cfe247594232cae61845df", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-json": "*", + "ext-pcre": "*", + "ext-reflection": "*", + "ext-spl": "*", + "php": ">=5.3.3", + "phpunit/php-code-coverage": "~2.0", + "phpunit/php-file-iterator": "~1.3.1", + "phpunit/php-text-template": "~1.2", + "phpunit/php-timer": "~1.0.2", + "phpunit/phpunit-mock-objects": "~2.1", + "sebastian/comparator": "~1.0", + "sebastian/diff": "~1.1", + "sebastian/environment": "~1.0", + "sebastian/exporter": "~1.0", + "sebastian/version": "~1.0", + "symfony/yaml": "~2.0" + }, + "suggest": { + "phpunit/php-invoker": "~1.1" + }, + "bin": [ + "phpunit" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "4.1.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "", + "../../symfony/yaml/" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "The PHP Unit Testing framework.", + "homepage": "http://www.phpunit.de/", + "keywords": [ + "phpunit", + "testing", + "xunit" + ], + "time": "2014-06-07 07:30:48" + }, + { + "name": "phpunit/phpunit-mock-objects", + "version": "2.1.3", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", + "reference": "92f4b49d2cd4f2537db7ef969231f3d43c8da957" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/92f4b49d2cd4f2537db7ef969231f3d43c8da957", + "reference": "92f4b49d2cd4f2537db7ef969231f3d43c8da957", + "shasum": "" + }, + "require": { + "php": ">=5.3.3", + "phpunit/php-text-template": "~1.2" + }, + "require-dev": { + "phpunit/phpunit": "~4.1" + }, + "suggest": { + "ext-soap": "*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.1.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" + } + ], + "description": "Mock Object library for PHPUnit", + "homepage": "https://github.com/sebastianbergmann/phpunit-mock-objects/", + "keywords": [ + "mock", + "xunit" + ], + "time": "2014-06-07 12:56:52" + }, { "name": "psr/log", "version": "1.0.0", @@ -576,6 +955,274 @@ ], "time": "2012-12-21 11:40:51" }, + { + "name": "sebastian/comparator", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/comparator.git", + "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", + "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", + "shasum": "" + }, + "require": { + "php": ">=5.3.3", + "sebastian/diff": "~1.1", + "sebastian/exporter": "~1.0" + }, + "require-dev": { + "phpunit/phpunit": "~4.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@2bepublished.at" + } + ], + "description": "Provides the functionality to compare PHP values for equality", + "homepage": "http://www.github.com/sebastianbergmann/comparator", + "keywords": [ + "comparator", + "compare", + "equality" + ], + "time": "2014-05-02 07:05:58" + }, + { + "name": "sebastian/diff", + "version": "1.1.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/diff.git", + "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", + "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + }, + { + "name": "Kore Nordmann", + "email": "mail@kore-nordmann.de" + } + ], + "description": "Diff implementation", + "homepage": "http://www.github.com/sebastianbergmann/diff", + "keywords": [ + "diff" + ], + "time": "2013-08-03 16:46:33" + }, + { + "name": "sebastian/environment", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/environment.git", + "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/79517609ec01139cd7e9fded0dd7ce08c952ef6a", + "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "phpunit/phpunit": "4.0.*@dev" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Provides functionality to handle HHVM/PHP environments", + "homepage": "http://www.github.com/sebastianbergmann/environment", + "keywords": [ + "Xdebug", + "environment", + "hhvm" + ], + "time": "2014-02-18 16:17:19" + }, + { + "name": "sebastian/exporter", + "version": "1.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/exporter.git", + "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", + "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "phpunit/phpunit": "4.0.*@dev" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Adam Harvey", + "email": "aharvey@php.net", + "role": "Lead" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@2bepublished.at" + } + ], + "description": "Provides the functionality to export PHP variables for visualization", + "homepage": "http://www.github.com/sebastianbergmann/exporter", + "keywords": [ + "export", + "exporter" + ], + "time": "2014-02-16 08:26:31" + }, + { + "name": "sebastian/version", + "version": "1.0.3", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/version.git", + "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", + "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", + "shasum": "" + }, + "type": "library", + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library that helps with managing the version number of Git-hosted PHP projects", + "homepage": "https://github.com/sebastianbergmann/version", + "time": "2014-03-07 15:35:33" + }, { "name": "symfony/console", "version": "v2.5.0", @@ -681,6 +1328,55 @@ "description": "Symfony Finder Component", "homepage": "http://symfony.com", "time": "2014-05-22 13:47:45" + }, + { + "name": "symfony/yaml", + "version": "v2.5.0", + "target-dir": "Symfony/Component/Yaml", + "source": { + "type": "git", + "url": "https://github.com/symfony/Yaml.git", + "reference": "b4b09c68ec2f2727574544ef0173684281a5033c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/Yaml/zipball/b4b09c68ec2f2727574544ef0173684281a5033c", + "reference": "b4b09c68ec2f2727574544ef0173684281a5033c", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.5-dev" + } + }, + "autoload": { + "psr-0": { + "Symfony\\Component\\Yaml\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com", + "homepage": "http://fabien.potencier.org", + "role": "Lead Developer" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" + } + ], + "description": "Symfony Yaml Component", + "homepage": "http://symfony.com", + "time": "2014-05-16 14:25:18" } ], "packages-dev": [ @@ -946,7 +1642,8 @@ { "name": "Kevin Herrera", "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io" + "homepage": "http://kevin.herrera.io", + "role": "Developer" } ], "description": "A PHP library for improving the use of exceptions.", @@ -996,7 +1693,8 @@ { "name": "Kevin Herrera", "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io" + "homepage": "http://kevin.herrera.io", + "role": "Developer" } ], "description": "A PHP library for improving the use of file system paths.", From 231eff8498f8841ed1ceff887cfab6efb3e2796f Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Sun, 8 Jun 2014 14:14:41 +0100 Subject: [PATCH 005/424] Update composer.json --- composer.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/composer.json b/composer.json index 0efdd6371..630e4a3b7 100644 --- a/composer.json +++ b/composer.json @@ -22,10 +22,10 @@ "illuminate/filesystem": "~4.1", "illuminate/events": "~4.1", "illuminate/remote": "~4.1", - "illuminate/log": "~4.1", - "phpunit/phpunit": "4.*" + "illuminate/log": "~4.1" }, "require-dev": { + "phpunit/phpunit": "~4.0", "mockery/mockery": "~0.9", "nesbot/carbon": "~1.4", "patchwork/utf8": "~1.1.18", From 554de2ebd08ad98440e0f8f5b21b36ccf191f301 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 9 Jun 2014 15:01:44 +0200 Subject: [PATCH 006/424] Add some plugins --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index d1a93cad1..4c2f61ec0 100644 --- a/README.md +++ b/README.md @@ -61,6 +61,8 @@ The MIT License (MIT). Please see [License File](https://github.com/anahkiasen/r - [Campfire](https://github.com/Anahkiasen/rocketeer-campfire) - [Slack](https://github.com/Anahkiasen/rocketeer-slack) +- [HipChat](https://github.com/hannesvdvreken/rocketeer-hipchat) +- [Wordpress](https://github.com/mykebates/wp-rocketeer) ## Why not Capistrano ? From a95c92082120c0fab41ea8cf0fdcf36d47885a4d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 9 Jun 2014 15:10:08 +0200 Subject: [PATCH 007/424] Update CHANGELOG.md --- CHANGELOG.md | 4 ++++ src/Rocketeer/Igniter.php | 4 ++-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 4b62dbe94..bcc8c6ec9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ ### Changelog +### 1.2.3 + +- Fixed a bug where tasks and events weren't properly loaded in Laravel + ### 1.2.2 - **The Notifier plugin module not has a hook for before and after deployment** diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 501bb553f..df7ff64bf 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -211,10 +211,9 @@ protected function unifySlashes($path) return str_replace('\\', '/', $path); } - /** * Check if this is in Laravel - * + * * @return boolean */ protected function isInsideLaravel() @@ -226,6 +225,7 @@ protected function isInsideLaravel() return true; } } + return false; } } From c0889e26c13afbe92f1b51df994358917c4dc8a2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 9 Jun 2014 14:54:33 +0200 Subject: [PATCH 008/424] Add some plugins --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 4c2f61ec0..7d0c42784 100644 --- a/README.md +++ b/README.md @@ -57,7 +57,7 @@ The MIT License (MIT). Please see [License File](https://github.com/anahkiasen/r ----- -## Available plugins +## Available plugins and integrations - [Campfire](https://github.com/Anahkiasen/rocketeer-campfire) - [Slack](https://github.com/Anahkiasen/rocketeer-slack) From 9102dfb9f88f6399b7118a23f70c2b7686fbcb27 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 9 Jun 2014 15:20:24 +0200 Subject: [PATCH 009/424] Fix path to logs --- src/Rocketeer/Igniter.php | 8 +++++--- src/Rocketeer/Rocketeer.php | 2 +- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index df7ff64bf..019bd52d2 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -132,9 +132,11 @@ protected function bindConfiguration() { // Bind path to the configuration directory if ($this->isInsideLaravel()) { - $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + $storage = $this->getStoragePath(); } else { - $path = $this->getBasePath().'.rocketeer'; + $path = $this->getBasePath().'.rocketeer'; + $storage = $path.'/'; } // Build pathes @@ -142,7 +144,7 @@ protected function bindConfiguration() 'config' => $path.'', 'events' => $path.'/events', 'tasks' => $path.'/tasks', - 'logs' => $this->getStoragePath().'logs', + 'logs' => $storage.'logs', ); foreach ($paths as $key => $file) { diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 48fc5f6f9..957a9604d 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -54,7 +54,7 @@ class Rocketeer * * @var string */ - const VERSION = '1.2.2'; + const VERSION = '1.2.3'; /** * Build a new ReleasesManager From 9858fd36c22ea73df0a6ad2a125b9887c32ac79a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 9 Jun 2014 15:52:48 +0200 Subject: [PATCH 010/424] Fix #202 - Ignition when connection is not production --- src/Rocketeer/Commands/AbstractDeployCommand.php | 1 + src/Rocketeer/Tasks/Ignite.php | 1 + src/config/config.php | 2 +- tests/Tasks/IgniteTest.php | 2 ++ 4 files changed, 5 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 7ee250e88..3c3901f86 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -206,6 +206,7 @@ protected function storeServerCredentials($connections, $connectionName) // Save credentials $credentials = compact(array_keys($credentials)); $this->laravel['rocketeer.rocketeer']->syncConnectionCredentials($connectionName, $credentials); + $this->laravel['rocketeer.rocketeer']->setConnection($connectionName); } /** diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index 52481ac51..bae4083df 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -84,6 +84,7 @@ protected function getConfigurationInformations() return array_merge( $this->rocketeer->getConnectionCredentials(), array( + 'connection' => $this->rocketeer->getConnection(), 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], diff --git a/src/config/config.php b/src/config/config.php index a9642da73..b60c38618 100644 --- a/src/config/config.php +++ b/src/config/config.php @@ -19,7 +19,7 @@ //////////////////////////////////////////////////////////////////// // The default remote connection(s) to execute tasks on - 'default' => array('production'), + 'default' => array('{connection}'), // The various connections you defined // You can leave all of this empty or remove it entirely if you don't want diff --git a/tests/Tasks/IgniteTest.php b/tests/Tasks/IgniteTest.php index f53b00879..49242c182 100644 --- a/tests/Tasks/IgniteTest.php +++ b/tests/Tasks/IgniteTest.php @@ -15,6 +15,7 @@ public function testCanIgniteConfigurationOutsideLaravel() ->shouldReceive('getConfigurationPath')->twice() ->shouldReceive('exportConfiguration')->once()->andReturn($server) ->shouldReceive('updateConfiguration')->once()->with($server, array( + 'connection' => 'production', 'scm_repository' => '', 'scm_username' => '', 'scm_password' => '', @@ -36,6 +37,7 @@ public function testCanIgniteConfigurationInLaravel() ->shouldReceive('getConfigurationPath')->twice() ->shouldReceive('exportConfiguration')->never() ->shouldReceive('updateConfiguration')->once()->with($path, array( + 'connection' => 'production', 'scm_repository' => '', 'scm_username' => '', 'scm_password' => '', From f8a42bf5c71f61a03b1ae050bd43066f4b62ab67 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 9 Jun 2014 16:12:10 +0200 Subject: [PATCH 011/424] Close #232 - Fix CurrentRelease task --- src/Rocketeer/Tasks/CurrentRelease.php | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index bd81e3a70..95ffc05ff 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -19,6 +19,13 @@ */ class CurrentRelease extends Task { + /** + * The slug of the task + * + * @var string + */ + protected $name = 'current'; + /** * A description of what the Task does * From 844ec9c619bdb7e2ce0a604187d59c04a0a90fc4 Mon Sep 17 00:00:00 2001 From: tnarik Date: Mon, 9 Jun 2014 19:37:02 +0100 Subject: [PATCH 012/424] Reimplement fix for #233 on the develop branch. --- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index ebaa31f6c..46be41d8a 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -47,7 +47,7 @@ public function php($command = null) */ public function artisan($command = null, $flags = array()) { - $artisan = $this->which('artisan') ?: 'artisan'; + $artisan = $this->which('artisan', $this->releasesManager->getCurrentReleasePath()."/artisan") ?: 'artisan'; foreach ($flags as $name => $value) { $command .= ' --'.$name; $command .= $value ? '="' .$value. '"' : ''; From 222aa3c09544640a3031cbb591f48d5706f31c9c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 11 Jun 2014 18:18:45 +0200 Subject: [PATCH 013/424] Fix storagelogs bug --- src/Rocketeer/Igniter.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 019bd52d2..76d377cc8 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -136,7 +136,7 @@ protected function bindConfiguration() $storage = $this->getStoragePath(); } else { $path = $this->getBasePath().'.rocketeer'; - $storage = $path.'/'; + $storage = $path; } // Build pathes @@ -144,7 +144,7 @@ protected function bindConfiguration() 'config' => $path.'', 'events' => $path.'/events', 'tasks' => $path.'/tasks', - 'logs' => $storage.'logs', + 'logs' => $storage.'/logs', ); foreach ($paths as $key => $file) { From 61b56b0a80b0ca10277d9daeaa34ea11ce68bcb7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 16 Jun 2014 23:55:33 +0200 Subject: [PATCH 014/424] Fix some typos --- .gitignore | 5 +++-- src/Rocketeer/Commands/AbstractDeployCommand.php | 2 +- src/Rocketeer/Commands/TestCommand.php | 2 +- src/Rocketeer/Igniter.php | 4 ++-- src/Rocketeer/LogsHandler.php | 6 +++--- src/Rocketeer/ReleasesManager.php | 2 +- src/Rocketeer/Rocketeer.php | 2 +- src/Rocketeer/Tasks/Closure.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- src/config/remote.php | 2 +- 10 files changed, 15 insertions(+), 14 deletions(-) diff --git a/.gitignore b/.gitignore index a68b5f971..a5de3e44c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,8 +1,9 @@ # Cache and compiled -bin/rocketeer.phar +.idea +.rocketeer bin/phar +bin/rocketeer.phar storage -.rocketeer # Plugins rocketeer-campfire diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 3c3901f86..0f4efcbce 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -99,7 +99,7 @@ protected function fireTasksQueue($tasks) $this->laravel['rocketeer.tasks']->run($tasks, $this); $this->line('Execution time: '.round(microtime(true) - $timerStart, 4). 's'); - // Remove commmand instance + // Remove command instance unset($this->laravel['rocketeer.command']); } diff --git a/src/Rocketeer/Commands/TestCommand.php b/src/Rocketeer/Commands/TestCommand.php index 8c1edfeac..17137c9c5 100644 --- a/src/Rocketeer/Commands/TestCommand.php +++ b/src/Rocketeer/Commands/TestCommand.php @@ -10,7 +10,7 @@ namespace Rocketeer\Commands; /** - * Run the tests on the server and displays the ouput + * Run the tests on the server and displays the output * * @author Maxime Fabre */ diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 76d377cc8..afcfa2acc 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -68,7 +68,7 @@ public function getConfigurationPath() /** * Export the configuration files * - * @return void + * @return string */ public function exportConfiguration() { @@ -139,7 +139,7 @@ protected function bindConfiguration() $storage = $path; } - // Build pathes + // Build paths $paths = array( 'config' => $path.'', 'events' => $path.'/events', diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/LogsHandler.php index 65766c2c8..1e34e65e3 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/LogsHandler.php @@ -50,7 +50,7 @@ public function __construct(Container $app) */ public function __call($method, $parameters) { - return $this->log($parameters[0], $method); + $this->log($parameters[0], $method); } /** @@ -64,7 +64,7 @@ public function __call($method, $parameters) public function log($informations, $level = 'info') { if ($file = $this->getCurrentLogsFile()) { - return $this->getLogger($file)->$level($informations); + $this->getLogger($file)->$level($informations); } } @@ -77,7 +77,7 @@ public function getCurrentLogsFile() { $logs = $this->app['config']->get('rocketeer::logs'); if (!$logs) { - return; + return false; } $file = $logs($this->app['rocketeer.rocketeer']); diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index aa34406c0..ea1843251 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -202,7 +202,7 @@ public function markReleaseAsValid($release) $validation = $this->getValidationFile(); $validation[$release] = true; - return $this->saveValidationFile($validation); + $this->saveValidationFile($validation); } /** diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 957a9604d..090bf3595 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -316,7 +316,7 @@ public function setConnections($connections) } /** - * Set the curent connection + * Set the current connection * * @param string $connection */ diff --git a/src/Rocketeer/Tasks/Closure.php b/src/Rocketeer/Tasks/Closure.php index a181dd784..b182f2747 100644 --- a/src/Rocketeer/Tasks/Closure.php +++ b/src/Rocketeer/Tasks/Closure.php @@ -22,7 +22,7 @@ class Closure extends Task /** * A Closure to execute at runtime * - * @var Closure + * @var AnonymousFunction */ protected $closure; diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index e2b1ed9ec..30b8f4070 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -39,7 +39,7 @@ class Setup extends Task */ public function execute() { - // Check if requirments are met + // Check if requirements are met if ($this->executeTask('Check') === false and !$this->getOption('pretend')) { return false; } diff --git a/src/config/remote.php b/src/config/remote.php index 0e4c61756..ee9b05fc3 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -1,6 +1,6 @@ Date: Tue, 17 Jun 2014 00:16:09 +0200 Subject: [PATCH 015/424] Code tweaks --- src/Rocketeer/Commands/BaseTaskCommand.php | 2 +- src/Rocketeer/Commands/RollbackCommand.php | 2 +- src/Rocketeer/Console/Console.php | 2 +- src/Rocketeer/Facades/Console.php | 2 +- src/Rocketeer/Facades/Rocketeer.php | 2 +- src/Rocketeer/Facades/StandaloneFacade.php | 2 +- src/Rocketeer/Igniter.php | 2 +- src/Rocketeer/Plugins/Notifier.php | 3 +- src/Rocketeer/ReleasesManager.php | 2 +- src/Rocketeer/Rocketeer.php | 21 +++++------ src/Rocketeer/Scm/Svn.php | 6 +-- src/Rocketeer/Server.php | 10 +++-- src/Rocketeer/Tasks/Check.php | 6 +-- src/Rocketeer/Tasks/Cleanup.php | 2 +- src/Rocketeer/Tasks/CurrentRelease.php | 4 +- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Tasks/Ignite.php | 6 +-- src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Tasks/Teardown.php | 2 +- src/Rocketeer/Tasks/Test.php | 2 +- src/Rocketeer/Tasks/Update.php | 2 +- src/Rocketeer/TasksHandler.php | 14 +++---- src/Rocketeer/TasksQueue.php | 11 +++--- src/Rocketeer/Traits/AbstractLocatorClass.php | 6 +-- src/Rocketeer/Traits/BashModules/Binaries.php | 16 ++++---- src/Rocketeer/Traits/BashModules/Core.php | 37 +++++++++---------- .../Traits/BashModules/Filesystem.php | 10 ++--- src/Rocketeer/Traits/BashModules/Scm.php | 6 +-- src/Rocketeer/Traits/Scm.php | 4 +- src/Rocketeer/Traits/Task.php | 2 +- 30 files changed, 95 insertions(+), 95 deletions(-) diff --git a/src/Rocketeer/Commands/BaseTaskCommand.php b/src/Rocketeer/Commands/BaseTaskCommand.php index 573458729..627375120 100644 --- a/src/Rocketeer/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Commands/BaseTaskCommand.php @@ -37,7 +37,7 @@ class BaseTaskCommand extends AbstractDeployCommand * Build a new custom command * * @param Task $task - * @param string $name A name for the command + * @param string $name A name for the command */ public function __construct(Task $task, $name = null) { diff --git a/src/Rocketeer/Commands/RollbackCommand.php b/src/Rocketeer/Commands/RollbackCommand.php index c3ae0ad40..bdee7f2c2 100644 --- a/src/Rocketeer/Commands/RollbackCommand.php +++ b/src/Rocketeer/Commands/RollbackCommand.php @@ -9,8 +9,8 @@ */ namespace Rocketeer\Commands; -use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputOption; /** * Rollback to the previous release, or to a specific one diff --git a/src/Rocketeer/Console/Console.php b/src/Rocketeer/Console/Console.php index 2e17e9f6a..cb1f8f284 100644 --- a/src/Rocketeer/Console/Console.php +++ b/src/Rocketeer/Console/Console.php @@ -44,7 +44,7 @@ public function getHelp() */ protected function buildBlock($title, $informations) { - $message = '' .$title. ''; + $message = ''.$title.''; foreach ($informations as $name => $info) { $message .= PHP_EOL.sprintf(' %-15s %s', $name, $info); } diff --git a/src/Rocketeer/Facades/Console.php b/src/Rocketeer/Facades/Console.php index 3a5ba9927..69a4e01a8 100644 --- a/src/Rocketeer/Facades/Console.php +++ b/src/Rocketeer/Facades/Console.php @@ -14,7 +14,7 @@ * * @author Maxime Fabre * - * @see Rocketeer\Console\Console + * @see Rocketeer\Console\Console */ class Console extends StandaloneFacade { diff --git a/src/Rocketeer/Facades/Rocketeer.php b/src/Rocketeer/Facades/Rocketeer.php index aaa672ebd..ec528e36f 100644 --- a/src/Rocketeer/Facades/Rocketeer.php +++ b/src/Rocketeer/Facades/Rocketeer.php @@ -14,7 +14,7 @@ * * @author Maxime Fabre * - * @see Rocketeer\TasksQueue + * @see Rocketeer\TasksQueue */ class Rocketeer extends StandaloneFacade { diff --git a/src/Rocketeer/Facades/StandaloneFacade.php b/src/Rocketeer/Facades/StandaloneFacade.php index 84a476ce4..3fdbe554c 100644 --- a/src/Rocketeer/Facades/StandaloneFacade.php +++ b/src/Rocketeer/Facades/StandaloneFacade.php @@ -17,7 +17,7 @@ * * @author Maxime Fabre * - * @see Rocketeer\Console\Console + * @see Rocketeer\Console\Console */ abstract class StandaloneFacade extends Facade { diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index afcfa2acc..852627500 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -95,7 +95,7 @@ public function updateConfiguration($folder, array $values = array()) $files = $this->app['files']->files($folder); foreach ($files as $file) { foreach ($values as $name => $value) { - $contents = str_replace('{' .$name. '}', $value, file_get_contents($file)); + $contents = str_replace('{'.$name.'}', $value, file_get_contents($file)); $this->app['files']->put($file, $contents); } } diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 39dcc1777..fcc74f3a4 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -9,8 +9,8 @@ */ namespace Rocketeer\Plugins; -use Rocketeer\Traits\Plugin; use Rocketeer\TasksHandler; +use Rocketeer\Traits\Plugin; /** * A base class for notification services to extends @@ -40,7 +40,6 @@ public function onQueue(TasksHandler $queue) /** * Send a given message * - * @param Task $task * @param string $message * * @return void diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index ea1843251..2771cff2b 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -199,7 +199,7 @@ public function saveValidationFile(array $validation) */ public function markReleaseAsValid($release) { - $validation = $this->getValidationFile(); + $validation = $this->getValidationFile(); $validation[$release] = true; $this->saveValidationFile($validation); diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 090bf3595..0c97cc79a 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -92,7 +92,7 @@ public function getOption($option) * Get a contextual option * * @param string $option - * @param string $type [stage,connection] + * @param string $type [stage,connection] * @param string|array $original * * @return mixed @@ -203,7 +203,7 @@ public function getAvailableConnections() /** * Check if a connection has credentials related to it * - * @param string $connection + * @param string $connection * * @return boolean */ @@ -231,7 +231,7 @@ public function getConnections() $default = $this->app['config']->get('remote.default'); // Remove invalid connections - $instance = $this; + $instance = $this; $connections = array_filter($connections, function ($value) use ($instance) { return $instance->isValidConnection($value); }); @@ -259,7 +259,7 @@ public function getConnection() return $this->connection; } - $connection = array_get($this->getConnections(), 0); + $connection = array_get($this->getConnections(), 0); $this->connection = $connection; return $this->connection; @@ -378,9 +378,6 @@ public function getCredentials() /** * Get the URL to the Git repository * - * @param string $username - * @param string $password - * * @return string */ public function getRepository() @@ -395,7 +392,7 @@ public function getRepository() if ($username or $password) { // Build credentials chain - $credentials = $password ? $username.':'.$password : $username; + $credentials = $password ? $username.':'.$password : $username; $credentials .= '@'; // Add them in chain @@ -500,12 +497,14 @@ public function getHomeFolder() */ public function getRocketeerConfigFolder() { - return $this->getUserHomeFolder() . '/.rocketeer'; + return $this->getUserHomeFolder().'/.rocketeer'; } /** * Get the path to the users home folder * + * @throws Exception + * * @return string */ public function getUserHomeFolder() @@ -514,9 +513,9 @@ public function getUserHomeFolder() if (!empty($_SERVER['HOME'])) { return $_SERVER['HOME']; - // Else use the homedrive (Windows) + // Else use the home drive (Windows) } elseif (!empty($_SERVER['HOMEDRIVE']) && !empty($_SERVER['HOMEPATH'])) { - return $_SERVER['HOMEDRIVE'] . $_SERVER['HOMEPATH']; + return $_SERVER['HOMEDRIVE'].$_SERVER['HOMEPATH']; } else { throw new Exception('Cannot determine user home directory.'); diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index a8bf092f3..2f627b69f 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -75,7 +75,7 @@ public function checkout($destination) { $branch = $this->app['rocketeer.rocketeer']->getRepositoryBranch(); $repository = $this->app['rocketeer.rocketeer']->getRepository(); - $repository = rtrim($repository, '/') . '/' . ltrim($branch, '/'); + $repository = rtrim($repository, '/').'/'.ltrim($branch, '/'); return $this->getCommand('co %s %s %s', $this->getCredentials(), $repository, $destination); } @@ -112,10 +112,10 @@ protected function getCredentials() // Build command if ($user = array_get($credentials, 'username')) { - $options[] = '--username=' . $user; + $options[] = '--username='.$user; } if ($pass = array_get($credentials, 'password')) { - $options[] = '--password=' . $pass; + $options[] = '--password='.$pass; } return implode(' ', $options); diff --git a/src/Rocketeer/Server.php b/src/Rocketeer/Server.php index dd62e82e4..029fca877 100644 --- a/src/Rocketeer/Server.php +++ b/src/Rocketeer/Server.php @@ -43,9 +43,9 @@ class Server /** * Build a new ReleasesManager * - * @param Container $app - * @param string $filename - * @param string $storage + * @param Container $app + * @param string $filename + * @param string $storage */ public function __construct(Container $app, $filename = 'deployments', $storage = null) { @@ -94,7 +94,7 @@ public function getHash() // Compute the salts foreach ($files as $file) { - $file = $this->app['files']->getRequire($file); + $file = $this->app['files']->getRequire($file); $salt .= json_encode($file); } @@ -158,6 +158,7 @@ public function getSeparator() } $bash = $this->app['rocketeer.bash']; + return $this->getValue('directory_separator', function ($server) use ($bash) { $separator = $bash->runLast('php -r "echo DIRECTORY_SEPARATOR;"'); @@ -190,6 +191,7 @@ public function getLineEndings() } $bash = $this->app['rocketeer.bash']; + return $this->getValue('line_endings', function ($server) use ($bash) { $endings = $bash->runRaw('php -r "echo PHP_EOL;"'); $server->setValue('line_endings', $endings); diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 7d1baf657..63f5ad45d 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -25,7 +25,7 @@ class Check extends Task */ protected $extensions = array(); - /** + /** * A description of what the Task does * * @var string @@ -210,13 +210,13 @@ public function checkCacheDriver($cache) /** * Check the presence of a PHP extension * - * @param string $extension The extension + * @param string $extension The extension * * @return boolean */ public function checkPhpExtension($extension) { - $this->command->comment('Checking presence of '.$extension. ' extension'); + $this->command->comment('Checking presence of '.$extension.' extension'); // Get the PHP extensions available if (!$this->extensions) { diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index a7e42896a..a0203613f 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -19,7 +19,7 @@ */ class Cleanup extends Task { - /** + /** * A description of what the Task does * * @var string diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index 95ffc05ff..f1e4f89ac 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -26,7 +26,7 @@ class CurrentRelease extends Task */ protected $name = 'current'; - /** + /** * A description of what the Task does * * @var string @@ -53,7 +53,7 @@ public function execute() // Create state message $date = DateTime::createFromFormat('YmdHis', $currentRelease)->format('Y-m-d H:i:s'); $state = $this->runForCurrentRelease($this->scm->currentState()); - $message = sprintf('The current release' .$stage. ' is %s (%s deployed at %s)', $currentRelease, $state, $date); + $message = sprintf('The current release'.$stage.' is %s (%s deployed at %s)', $currentRelease, $state, $date); // Display current and past releases $this->command->line($message); diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index b7a4e20e7..128026985 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -123,7 +123,7 @@ protected function runMigrationsAndSeed() */ protected function createEvents() { - $strategy = $this->rocketeer->getOption('remote.strategy'); + $strategy = $this->rocketeer->getOption('remote.strategy'); $this->halting = array( $strategy.'Repository', 'runComposer', diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index bae4083df..af9535d3e 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -18,7 +18,7 @@ */ class Ignite extends Task { - /** + /** * A description of what the Task does * * @var string @@ -79,7 +79,7 @@ protected function getConfigurationInformations() { // Replace credentials $repositoryCredentials = $this->rocketeer->getCredentials(); - $name = basename($this->app['path.base']); + $name = basename($this->app['path.base']); return array_merge( $this->rocketeer->getConnectionCredentials(), @@ -88,7 +88,7 @@ protected function getConfigurationInformations() 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], - 'application_name' => $this->command->ask("What is your application's name ? (" .$name. ")", $name), + 'application_name' => $this->command->ask("What is your application's name ? (".$name.")", $name), ) ); } diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 30b8f4070..5970479e0 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -18,7 +18,7 @@ */ class Setup extends Task { - /** + /** * A description of what the Task does * * @var string diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 870221123..3827813ec 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -18,7 +18,7 @@ */ class Teardown extends Task { - /** + /** * A description of what the Task does * * @var string diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index 7d8f632b7..18b5288d3 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -18,7 +18,7 @@ */ class Test extends Task { - /** + /** * A description of what the Task does * * @var string diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 3242322e2..8e9167675 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -16,7 +16,7 @@ */ class Update extends Deploy { - /** + /** * A description of what the Task does * * @var string diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index 4637e4d38..1f6d623de 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -30,7 +30,7 @@ class TasksHandler extends AbstractLocatorClass /** * Build a new TasksQueue Instance * - * @param Container $app + * @param Container $app */ public function __construct(Container $app) { @@ -102,9 +102,9 @@ public function task($name, $task) /** * Execute a Task before another one * - * @param string $task - * @param string|Closure|Task $listeners - * @param integer $priority + * @param string $task + * @param string|Closure|Task $listeners + * @param integer $priority * * @return void */ @@ -116,9 +116,9 @@ public function before($task, $listeners, $priority = 0) /** * Execute a Task after another one * - * @param string $task - * @param string|Closure|Task $listeners - * @param integer $priority + * @param string $task + * @param string|Closure|Task $listeners + * @param integer $priority * * @return void */ diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index 0217a1184..828c5e2b3 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -88,7 +88,7 @@ public function on($connections, $queue) * Run an array of Tasks instances on the various * connections and stages provided * - * @param array $tasks An array of tasks + * @param array $tasks An array of tasks * * @return array An array of output */ @@ -138,10 +138,11 @@ protected function runQueue($tasks, $stage = null) // Here we fire the task and if it was halted // at any point, we cancel the whole queue - $state = $task->fire(); + $state = $task->fire(); $this->output[] = $state; if ($task->wasHalted() or $state === false) { - $this->command->error('Deployment was canceled by task "'.$task->getName(). '"'); + $this->command->error('Deployment was canceled by task "'.$task->getName().'"'); + return false; } } @@ -159,7 +160,7 @@ protected function runQueue($tasks, $stage = null) * Here we will take the various Tasks names, closures and string tasks * and unify all of those to actual Task instances * - * @param array $tasks + * @param array $tasks * * @return array */ @@ -223,7 +224,7 @@ public function buildTaskFromClosure($task) // We'll build a closure from it if ($this->isStringCommand($task)) { $stringTask = $task; - $closure = function ($task) use ($stringTask) { + $closure = function ($task) use ($stringTask) { return $task->runForCurrentRelease($stringTask); }; diff --git a/src/Rocketeer/Traits/AbstractLocatorClass.php b/src/Rocketeer/Traits/AbstractLocatorClass.php index 7e85d5a7f..0b0b0078f 100644 --- a/src/Rocketeer/Traits/AbstractLocatorClass.php +++ b/src/Rocketeer/Traits/AbstractLocatorClass.php @@ -15,10 +15,11 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * + * @property Illuminate\Console\Command $command + * @property Illuminate\Remote\Connection $remote * @property ReleasesManager $releasesManager * @property Rocketeer $rocketeer * @property Server $server - * @property Illuminate\Remote\Connection $remote * @property Traits\Scm $scm * * @author Maxime Fabre @@ -35,8 +36,7 @@ abstract class AbstractLocatorClass /** * Build a new Task * - * @param Container $app - * @param Command|null $command + * @param Container $app */ public function __construct(Container $app) { diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 46be41d8a..1306d898c 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -10,7 +10,7 @@ namespace Rocketeer\Traits\BashModules; /** - * Handles findingand calling binaries + * Handles finding and calling binaries * * @author Maxime Fabre */ @@ -31,7 +31,7 @@ public function php($command = null) { $php = $this->which('php'); - return trim($php. ' ' .$command); + return trim($php.' '.$command); } // Artisan @@ -50,10 +50,10 @@ public function artisan($command = null, $flags = array()) $artisan = $this->which('artisan', $this->releasesManager->getCurrentReleasePath()."/artisan") ?: 'artisan'; foreach ($flags as $name => $value) { $command .= ' --'.$name; - $command .= $value ? '="' .$value. '"' : ''; + $command .= $value ? '="'.$value.'"' : ''; } - return $this->php($artisan. ' ' .$command); + return $this->php($artisan.' '.$command); } /** @@ -154,7 +154,7 @@ public function composer($command = null) $composer = $this->php($composer); } - return trim($composer. ' ' .$command); + return trim($composer.' '.$command); } /** @@ -202,8 +202,8 @@ public function runComposer($force = false) /** * Get a binary * - * @param string $binary The name of the binary - * @param string $fallback A fallback location + * @param string $binary The name of the binary + * @param string $fallback A fallback location * * @return string */ @@ -223,7 +223,7 @@ public function which($binary, $fallback = null) // Add command prompt if possible if ($this->hasCommand()) { - $prompt = $binary. ' could not be found, please enter the path to it'; + $prompt = $binary.' could not be found, please enter the path to it'; $locations[] = array($this->command, 'ask', $prompt); } diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 639952f51..93e963758 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -47,9 +47,9 @@ public function getHistory() /** * Run actions on the remote server and gather the ouput * - * @param string|array $commands One or more commands - * @param boolean $silent Whether the command should stay silent no matter what - * @param boolean $array Whether the output should be returned as an array + * @param string|array $commands One or more commands + * @param boolean $silent Whether the command should stay silent no matter what + * @param boolean $array Whether the output should be returned as an array * * @return string|array */ @@ -91,7 +91,7 @@ public function run($commands, $silent = false, $array = false) * Run a command get the last line output to * prevent noise * - * @param string|array $commands + * @param string|array $commands * * @return string */ @@ -108,8 +108,8 @@ public function runLast($commands) * get its output as a string or array * * @param string|array $commands - * @param boolean $array Whether the output should be returned as an array - * @param boolean $trim Whether the output should be trimmed + * @param boolean $array Whether the output should be returned as an array + * @param boolean $trim Whether the output should be trimmed * * @return string */ @@ -130,8 +130,8 @@ public function runRaw($commands, $array = false, $trim = false) /** * Run commands silently * - * @param string|array $commands - * @param boolean $array + * @param string|array $commands + * @param boolean $array * * @return string */ @@ -143,8 +143,8 @@ public function runSilently($commands, $array = false) /** * Run commands in a folder * - * @param string $folder - * @param string|array $tasks + * @param string $folder + * @param string|array $tasks * * @return string */ @@ -164,9 +164,9 @@ public function runInFolder($folder = null, $tasks = array()) /** * Check the status of the last run command, return an error if any * - * @param string $error The message to display on error - * @param string $output The command's output - * @param string $success The message to display on success + * @param string $error The message to display on error + * @param string $output The command's output + * @param string $success The message to display on success * * @return boolean|string */ @@ -226,7 +226,7 @@ protected function getOption($option) protected function addCommandsToHistory($commands) { $this->command->line(implode(PHP_EOL, $commands)); - $commands = (sizeof($commands) == 1) ? $commands[0] : $commands; + $commands = (sizeof($commands) == 1) ? $commands[0] : $commands; $this->history[] = $commands; return $commands; @@ -239,7 +239,7 @@ protected function addCommandsToHistory($commands) /** * Process an array of commands * - * @param string|array $commands + * @param string|array $commands * * @return array */ @@ -265,7 +265,6 @@ protected function processCommands($commands) if (Str::contains($command, 'artisan') and $stage) { $command .= ' --env='.$stage; } - } return $commands; @@ -274,9 +273,9 @@ protected function processCommands($commands) /** * Process the output of a command * - * @param string|array $output - * @param boolean $array Whether to return an array or a string - * @param boolean $trim Whether to trim the output or not + * @param string|array $output + * @param boolean $array Whether to return an array or a string + * @param boolean $trim Whether to trim the output or not * * @return string|array */ diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index e5f176222..095823667 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -23,8 +23,8 @@ class Filesystem extends Core /** * Symlinks two folders * - * @param string $folder The folder in shared/ - * @param string $symlink The folder that will symlink to it + * @param string $folder The folder in shared/ + * @param string $symlink The folder that will symlink to it * * @return string */ @@ -91,7 +91,7 @@ public function listContents($directory) */ public function fileExists($file) { - $exists = $this->runRaw('[ -e ' .$file. ' ] && echo "true"'); + $exists = $this->runRaw('[ -e '.$file.' ] && echo "true"'); return trim($exists) == 'true'; } @@ -157,7 +157,7 @@ public function putFile($file, $contents) /** * Create a folder in the application's folder * - * @param string $folder The folder to create + * @param string $folder The folder to create * @param boolean $recursive * * @return string The task @@ -172,7 +172,7 @@ public function createFolder($folder = null, $recursive = false) /** * Remove a folder in the application's folder * - * @param string $folder The folder to remove + * @param string $folder The folder to remove * * @return string The task */ diff --git a/src/Rocketeer/Traits/BashModules/Scm.php b/src/Rocketeer/Traits/BashModules/Scm.php index 04ce66994..5d216e91a 100644 --- a/src/Rocketeer/Traits/BashModules/Scm.php +++ b/src/Rocketeer/Traits/BashModules/Scm.php @@ -38,7 +38,7 @@ public function copyRepository($destination = null) } // Copy old release into new one - $this->command->info('Copying previous release "' .$previous. '" in "' .$destination. '"'); + $this->command->info('Copying previous release "'.$previous.'" in "'.$destination.'"'); $this->copy($previous, $destination); // Update repository @@ -59,8 +59,8 @@ public function cloneRepository($destination = null) } // Executing checkout - $this->command->info('Cloning repository in "' .$destination. '"'); - $output = $this->scm->execute('checkout', $destination); + $this->command->info('Cloning repository in "'.$destination.'"'); + $output = $this->scm->execute('checkout', $destination); $this->history[] = $output; // Cancel if failed and forget credentials diff --git a/src/Rocketeer/Traits/Scm.php b/src/Rocketeer/Traits/Scm.php index 649538ab2..66293e968 100644 --- a/src/Rocketeer/Traits/Scm.php +++ b/src/Rocketeer/Traits/Scm.php @@ -40,14 +40,14 @@ public function __construct($app) /** * Returns a command with the SCM's binary * - * @param string $commands... + * @param string $commands,... * * @return string */ public function getCommand() { $arguments = func_get_args(); - $arguments[0] = $this->binary. ' ' .$arguments[0]; + $arguments[0] = $this->binary.' '.$arguments[0]; return call_user_func_array('sprintf', $arguments); } diff --git a/src/Rocketeer/Traits/Task.php b/src/Rocketeer/Traits/Task.php index 055a94949..6cd607a8b 100644 --- a/src/Rocketeer/Traits/Task.php +++ b/src/Rocketeer/Traits/Task.php @@ -123,7 +123,7 @@ public function fire() /** * Cancel the task * - * @param string $errors Potential errors to display + * @param string $errors Potential errors to display * * @return boolean */ From 8c3cdf37f4ab90b0847336f042cd01050221e191 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 17 Jun 2014 00:16:14 +0200 Subject: [PATCH 016/424] Fix property PHPdoc --- src/Rocketeer/Traits/AbstractLocatorClass.php | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Traits/AbstractLocatorClass.php b/src/Rocketeer/Traits/AbstractLocatorClass.php index 0b0b0078f..51c375102 100644 --- a/src/Rocketeer/Traits/AbstractLocatorClass.php +++ b/src/Rocketeer/Traits/AbstractLocatorClass.php @@ -15,12 +15,12 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * - * @property Illuminate\Console\Command $command - * @property Illuminate\Remote\Connection $remote - * @property ReleasesManager $releasesManager - * @property Rocketeer $rocketeer - * @property Server $server - * @property Traits\Scm $scm + * @property Illuminate\Console\Command command + * @property Illuminate\Remote\Connection remote + * @property ReleasesManager releasesManager + * @property Rocketeer rocketeer + * @property Server server + * @property Traits\Scm scm * * @author Maxime Fabre */ From 85c3b97c9596a1ca94dc96601f8f5a8558351b54 Mon Sep 17 00:00:00 2001 From: Julius Beckmann Date: Thu, 19 Jun 2014 14:54:52 +0200 Subject: [PATCH 017/424] Added HHVM support badge. --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index 7d0c42784..52658d1e8 100644 --- a/README.md +++ b/README.md @@ -5,6 +5,7 @@ [![Total Downloads](https://poser.pugx.org/anahkiasen/rocketeer/downloads.png)](https://packagist.org/packages/anahkiasen/rocketeer) [![Scrutinizer Quality Score](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/badges/quality-score.png?s=20d9a4be6695b7677c427eab73151c1a9d803044)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) [![Code Coverage](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/badges/coverage.png?s=f6e022cbcf1a51f82b5d9e6fb30bd1643fc70e76)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) +[![HHVM Status](http://hhvm.h4cc.de/badge/anahkiasen/rocketeer.png)](http://hhvm.h4cc.de/package/anahkiasen/rocketeer) [![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg)](https://www.gittip.com/Anahkiasen/) **Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. From b276ee3131e14ac711ea74c30896f6ece4d61b46 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 24 Jun 2014 18:26:12 +0200 Subject: [PATCH 018/424] Code tweaks --- composer.lock | 1248 ++++++++--------- .../Commands/AbstractDeployCommand.php | 16 +- src/Rocketeer/Commands/CleanupCommand.php | 2 +- src/Rocketeer/RocketeerServiceProvider.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- tests/Dummies/DummyNotifier.php | 42 +- tests/ReleasesManagerTest.php | 12 +- tests/RocketeerTest.php | 4 +- tests/Scm/GitTest.php | 4 +- tests/ServerTest.php | 2 +- tests/Tasks/DeployTest.php | 10 +- tests/TasksHandlerTest.php | 4 +- tests/TasksQueueTest.php | 9 +- tests/TestCases/ContainerTestCase.php | 9 +- tests/TestCases/RocketeerTestCase.php | 8 +- tests/Traits/BashModules/BinariesTest.php | 4 +- tests/Traits/BashModules/CoreTest.php | 4 +- tests/Traits/BashModules/FilesystemTest.php | 6 +- tests/Traits/BashModules/ScmTest.php | 2 +- tests/Traits/TaskTest.php | 4 +- 20 files changed, 698 insertions(+), 696 deletions(-) diff --git a/composer.lock b/composer.lock index 9afcc01d0..b5a2e478b 100644 --- a/composer.lock +++ b/composer.lock @@ -4,21 +4,21 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "9528a4a339bed2de8aacc34c6159623d", + "hash": "6eb01d88d5864a31f00cae46f75f3366", "packages": [ { "name": "illuminate/config", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Config", "source": { "type": "git", "url": "https://github.com/illuminate/config.git", - "reference": "cd99d3dc2ca192b7b4003b5f6b31a4b1dd3c8167" + "reference": "33396894a35428074e8c41583bf308a7c019610a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/config/zipball/cd99d3dc2ca192b7b4003b5f6b31a4b1dd3c8167", - "reference": "cd99d3dc2ca192b7b4003b5f6b31a4b1dd3c8167", + "url": "https://api.github.com/repos/illuminate/config/zipball/33396894a35428074e8c41583bf308a7c019610a", + "reference": "33396894a35428074e8c41583bf308a7c019610a", "shasum": "" }, "require": { @@ -49,11 +49,11 @@ "role": "Creator of Laravel" } ], - "time": "2014-05-23 16:40:19" + "time": "2014-06-08 19:09:40" }, { "name": "illuminate/console", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Console", "source": { "type": "git", @@ -97,7 +97,7 @@ }, { "name": "illuminate/container", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Container", "source": { "type": "git", @@ -140,17 +140,17 @@ }, { "name": "illuminate/events", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Events", "source": { "type": "git", "url": "https://github.com/illuminate/events.git", - "reference": "eb23d436806893b6b05d7ad3b6f52212830c7e4e" + "reference": "c95614873f4e437ed7a723c1734197b51feaf991" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/events/zipball/eb23d436806893b6b05d7ad3b6f52212830c7e4e", - "reference": "eb23d436806893b6b05d7ad3b6f52212830c7e4e", + "url": "https://api.github.com/repos/illuminate/events/zipball/c95614873f4e437ed7a723c1734197b51feaf991", + "reference": "c95614873f4e437ed7a723c1734197b51feaf991", "shasum": "" }, "require": { @@ -181,11 +181,11 @@ "role": "Creator of Laravel" } ], - "time": "2014-05-23 16:40:19" + "time": "2014-06-06 13:58:46" }, { "name": "illuminate/filesystem", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Filesystem", "source": { "type": "git", @@ -230,7 +230,7 @@ }, { "name": "illuminate/log", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Log", "source": { "type": "git", @@ -278,7 +278,7 @@ }, { "name": "illuminate/remote", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Remote", "source": { "type": "git", @@ -327,17 +327,17 @@ }, { "name": "illuminate/support", - "version": "v4.2.1", + "version": "v4.2.4", "target-dir": "Illuminate/Support", "source": { "type": "git", "url": "https://github.com/illuminate/support.git", - "reference": "f1dd716598f99ff18b455da3e073a8324d65252e" + "reference": "976bdc0f42e9efd3dfa2e0eba11aba48a97113ac" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/support/zipball/f1dd716598f99ff18b455da3e073a8324d65252e", - "reference": "f1dd716598f99ff18b455da3e073a8324d65252e", + "url": "https://api.github.com/repos/illuminate/support/zipball/976bdc0f42e9efd3dfa2e0eba11aba48a97113ac", + "reference": "976bdc0f42e9efd3dfa2e0eba11aba48a97113ac", "shasum": "" }, "require": { @@ -373,7 +373,7 @@ "role": "Creator of Laravel" } ], - "time": "2014-05-30 16:22:28" + "time": "2014-06-13 20:42:27" }, { "name": "monolog/monolog", @@ -539,402 +539,403 @@ "time": "2014-02-28 16:05:05" }, { - "name": "phpunit/php-code-coverage", - "version": "2.0.8", + "name": "psr/log", + "version": "1.0.0", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/php-code-coverage.git", - "reference": "58401826c8cfc8fd689b60026e91c337df374bca" + "url": "https://github.com/php-fig/log.git", + "reference": "fe0936ee26643249e916849d48e3a51d5f5e278b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/58401826c8cfc8fd689b60026e91c337df374bca", - "reference": "58401826c8cfc8fd689b60026e91c337df374bca", + "url": "https://api.github.com/repos/php-fig/log/zipball/fe0936ee26643249e916849d48e3a51d5f5e278b", + "reference": "fe0936ee26643249e916849d48e3a51d5f5e278b", "shasum": "" }, - "require": { - "php": ">=5.3.3", - "phpunit/php-file-iterator": "~1.3.1", - "phpunit/php-text-template": "~1.2.0", - "phpunit/php-token-stream": "~1.2.2", - "sebastian/environment": "~1.0.0", - "sebastian/version": "~1.0.3" - }, - "require-dev": { - "ext-xdebug": ">=2.1.4", - "phpunit/phpunit": "~4.0.14" - }, - "suggest": { - "ext-dom": "*", - "ext-xdebug": ">=2.2.1", - "ext-xmlwriter": "*" - }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0.x-dev" - } - }, "autoload": { - "classmap": [ - "src/" - ] + "psr-0": { + "Psr\\Log\\": "" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" } ], - "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", - "homepage": "https://github.com/sebastianbergmann/php-code-coverage", + "description": "Common interface for logging libraries", "keywords": [ - "coverage", - "testing", - "xunit" + "log", + "psr", + "psr-3" ], - "time": "2014-05-26 14:55:24" + "time": "2012-12-21 11:40:51" }, { - "name": "phpunit/php-file-iterator", - "version": "1.3.4", + "name": "symfony/console", + "version": "v2.5.0", + "target-dir": "Symfony/Component/Console", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/php-file-iterator.git", - "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb" + "url": "https://github.com/symfony/Console.git", + "reference": "ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/acd690379117b042d1c8af1fafd61bde001bf6bb", - "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb", + "url": "https://api.github.com/repos/symfony/Console/zipball/ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c", + "reference": "ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c", "shasum": "" }, "require": { "php": ">=5.3.3" }, + "require-dev": { + "psr/log": "~1.0", + "symfony/event-dispatcher": "~2.1" + }, + "suggest": { + "psr/log": "For using the console logger", + "symfony/event-dispatcher": "" + }, "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.5-dev" + } + }, "autoload": { - "classmap": [ - "File/" - ] + "psr-0": { + "Symfony\\Component\\Console\\": "" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" + "name": "Fabien Potencier", + "email": "fabien@symfony.com", + "homepage": "http://fabien.potencier.org", + "role": "Lead Developer" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" } ], - "description": "FilterIterator implementation that filters files based on a list of suffixes.", - "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", - "keywords": [ - "filesystem", - "iterator" - ], - "time": "2013-10-10 15:34:57" + "description": "Symfony Console Component", + "homepage": "http://symfony.com", + "time": "2014-05-22 08:54:24" }, { - "name": "phpunit/php-text-template", - "version": "1.2.0", + "name": "symfony/finder", + "version": "v2.5.0", + "target-dir": "Symfony/Component/Finder", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/php-text-template.git", - "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a" + "url": "https://github.com/symfony/Finder.git", + "reference": "307aad2c541bbdf43183043645e186ef2cd6b973" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", - "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", + "url": "https://api.github.com/repos/symfony/Finder/zipball/307aad2c541bbdf43183043645e186ef2cd6b973", + "reference": "307aad2c541bbdf43183043645e186ef2cd6b973", "shasum": "" }, "require": { "php": ">=5.3.3" }, "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.5-dev" + } + }, "autoload": { - "classmap": [ - "Text/" - ] + "psr-0": { + "Symfony\\Component\\Finder\\": "" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" + "name": "Fabien Potencier", + "email": "fabien@symfony.com", + "homepage": "http://fabien.potencier.org", + "role": "Lead Developer" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" } ], - "description": "Simple template engine.", - "homepage": "https://github.com/sebastianbergmann/php-text-template/", - "keywords": [ - "template" - ], - "time": "2014-01-30 17:20:04" - }, + "description": "Symfony Finder Component", + "homepage": "http://symfony.com", + "time": "2014-05-22 13:47:45" + } + ], + "packages-dev": [ { - "name": "phpunit/php-timer", - "version": "1.0.5", + "name": "herrera-io/box", + "version": "1.5.3", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/php-timer.git", - "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c" + "url": "https://github.com/herrera-io/php-box.git", + "reference": "b5432951f85a56df6012f503881174e7aeec6611" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/19689d4354b295ee3d8c54b4f42c3efb69cbc17c", - "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c", + "url": "https://api.github.com/repos/herrera-io/php-box/zipball/b5432951f85a56df6012f503881174e7aeec6611", + "reference": "b5432951f85a56df6012f503881174e7aeec6611", "shasum": "" }, "require": { + "ext-phar": "*", + "phine/path": "~1.0", "php": ">=5.3.3" }, + "require-dev": { + "herrera-io/annotations": "~1.0", + "herrera-io/phpunit-test-case": "1.*", + "mikey179/vfsstream": "1.1.0", + "phpseclib/phpseclib": "~0.3", + "phpunit/phpunit": "3.7.*" + }, + "suggest": { + "herrera-io/annotations": "For compacting annotated docblocks.", + "phpseclib/phpseclib": "For verifying OpenSSL signed phars without the phar extension." + }, "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0-dev" + } + }, "autoload": { - "classmap": [ - "PHP/" - ] + "psr-0": { + "Herrera\\Box": "src/lib" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" + "name": "Kevin Herrera", + "email": "kevin@herrera.io", + "homepage": "http://kevin.herrera.io", + "role": "Developer" } ], - "description": "Utility class for timing", - "homepage": "https://github.com/sebastianbergmann/php-timer/", + "description": "A library for simplifying the PHAR build process.", + "homepage": "http://herrera-io.github.com/php-box", "keywords": [ - "timer" + "phar" ], - "time": "2013-08-02 07:42:54" + "time": "2014-02-07 15:48:46" }, { - "name": "phpunit/php-token-stream", - "version": "1.2.2", + "name": "mockery/mockery", + "version": "0.9.1", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/php-token-stream.git", - "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32" + "url": "https://github.com/padraic/mockery.git", + "reference": "17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/ad4e1e23ae01b483c16f600ff1bebec184588e32", - "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32", + "url": "https://api.github.com/repos/padraic/mockery/zipball/17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1", + "reference": "17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1", "shasum": "" }, "require": { - "ext-tokenizer": "*", - "php": ">=5.3.3" + "lib-pcre": ">=7.0", + "php": ">=5.3.2" + }, + "require-dev": { + "hamcrest/hamcrest-php": "~1.1", + "phpunit/phpunit": "~4.0", + "satooshi/php-coveralls": "~0.7@dev" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.2-dev" + "dev-master": "0.9.x-dev" } }, "autoload": { - "classmap": [ - "PHP/" - ] + "psr-0": { + "Mockery": "library/" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], "license": [ "BSD-3-Clause" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" + "name": "Pádraic Brady", + "email": "padraic.brady@gmail.com", + "homepage": "http://blog.astrumfutura.com" + }, + { + "name": "Dave Marshall", + "email": "dave.marshall@atstsolutions.co.uk", + "homepage": "http://davedevelopment.co.uk" } ], - "description": "Wrapper around PHP's tokenizer extension.", - "homepage": "https://github.com/sebastianbergmann/php-token-stream/", + "description": "Mockery is a simple yet flexible PHP mock object framework for use in unit testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a test double framework with a succint API capable of clearly defining all possible object operations and interactions using a human readable Domain Specific Language (DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with PHPUnit and can operate alongside phpunit-mock-objects without the World ending.", + "homepage": "http://github.com/padraic/mockery", "keywords": [ - "tokenizer" + "BDD", + "TDD", + "library", + "mock", + "mock objects", + "mockery", + "stub", + "test", + "test double", + "testing" ], - "time": "2014-03-03 05:10:30" + "time": "2014-05-02 12:16:45" }, { - "name": "phpunit/phpunit", - "version": "4.1.2", + "name": "nesbot/carbon", + "version": "1.9.0", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "be5f237df860da88a7cfe247594232cae61845df" + "url": "https://github.com/briannesbitt/Carbon.git", + "reference": "b94de7192b01d0e80794eae984dcc773220ab0dc" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/be5f237df860da88a7cfe247594232cae61845df", - "reference": "be5f237df860da88a7cfe247594232cae61845df", + "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/b94de7192b01d0e80794eae984dcc773220ab0dc", + "reference": "b94de7192b01d0e80794eae984dcc773220ab0dc", "shasum": "" }, "require": { - "ext-dom": "*", - "ext-json": "*", - "ext-pcre": "*", - "ext-reflection": "*", - "ext-spl": "*", - "php": ">=5.3.3", - "phpunit/php-code-coverage": "~2.0", - "phpunit/php-file-iterator": "~1.3.1", - "phpunit/php-text-template": "~1.2", - "phpunit/php-timer": "~1.0.2", - "phpunit/phpunit-mock-objects": "~2.1", - "sebastian/comparator": "~1.0", - "sebastian/diff": "~1.1", - "sebastian/environment": "~1.0", - "sebastian/exporter": "~1.0", - "sebastian/version": "~1.0", - "symfony/yaml": "~2.0" + "php": ">=5.3.0" }, - "suggest": { - "phpunit/php-invoker": "~1.1" + "require-dev": { + "phpunit/phpunit": "3.7.*" }, - "bin": [ - "phpunit" - ], "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.1.x-dev" - } - }, "autoload": { - "classmap": [ - "src/" - ] + "psr-0": { + "Carbon": "src" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "", - "../../symfony/yaml/" - ], "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" + "name": "Brian Nesbitt", + "email": "brian@nesbot.com", + "homepage": "http://nesbot.com" } ], - "description": "The PHP Unit Testing framework.", - "homepage": "http://www.phpunit.de/", + "description": "A simple API extension for DateTime.", + "homepage": "https://github.com/briannesbitt/Carbon", "keywords": [ - "phpunit", - "testing", - "xunit" + "date", + "datetime", + "time" ], - "time": "2014-06-07 07:30:48" + "time": "2014-05-13 02:29:30" }, { - "name": "phpunit/phpunit-mock-objects", - "version": "2.1.3", + "name": "patchwork/utf8", + "version": "v1.1.24", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", - "reference": "92f4b49d2cd4f2537db7ef969231f3d43c8da957" + "url": "https://github.com/nicolas-grekas/Patchwork-UTF8.git", + "reference": "40f552c019956f446553b19f7de2da2f9c74d730" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/92f4b49d2cd4f2537db7ef969231f3d43c8da957", - "reference": "92f4b49d2cd4f2537db7ef969231f3d43c8da957", + "url": "https://api.github.com/repos/nicolas-grekas/Patchwork-UTF8/zipball/40f552c019956f446553b19f7de2da2f9c74d730", + "reference": "40f552c019956f446553b19f7de2da2f9c74d730", "shasum": "" }, "require": { - "php": ">=5.3.3", - "phpunit/php-text-template": "~1.2" - }, - "require-dev": { - "phpunit/phpunit": "~4.1" + "lib-pcre": ">=7.3", + "php": ">=5.3.0" }, "suggest": { - "ext-soap": "*" + "ext-iconv": "Use iconv for best performance", + "ext-intl": "Use Intl for best performance", + "ext-mbstring": "Use Mbstring for best performance" }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.1.x-dev" - } - }, "autoload": { - "classmap": [ - "src/" - ] + "psr-0": { + "Patchwork": "class/", + "Normalizer": "class/" + } }, "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], "license": [ - "BSD-3-Clause" + "(Apache-2.0 or GPL-2.0)" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" + "name": "Nicolas Grekas", + "email": "p@tchwork.com", + "role": "Developer" } ], - "description": "Mock Object library for PHPUnit", - "homepage": "https://github.com/sebastianbergmann/phpunit-mock-objects/", + "description": "Extensive, portable and performant handling of UTF-8 and grapheme clusters for PHP", + "homepage": "https://github.com/nicolas-grekas/Patchwork-UTF8", "keywords": [ - "mock", - "xunit" + "i18n", + "unicode", + "utf-8", + "utf8" ], - "time": "2014-06-07 12:56:52" + "time": "2014-06-17 08:23:06" }, { - "name": "psr/log", + "name": "phine/exception", "version": "1.0.0", "source": { "type": "git", - "url": "https://github.com/php-fig/log.git", - "reference": "fe0936ee26643249e916849d48e3a51d5f5e278b" + "url": "https://github.com/phine/lib-exception.git", + "reference": "150c6b6090b2ebc53c60e87cb20c7f1287b7b68a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-fig/log/zipball/fe0936ee26643249e916849d48e3a51d5f5e278b", - "reference": "fe0936ee26643249e916849d48e3a51d5f5e278b", + "url": "https://api.github.com/repos/phine/lib-exception/zipball/150c6b6090b2ebc53c60e87cb20c7f1287b7b68a", + "reference": "150c6b6090b2ebc53c60e87cb20c7f1287b7b68a", "shasum": "" }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "league/phpunit-coverage-listener": "~1.0" + }, "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0-dev" + } + }, "autoload": { "psr-0": { - "Psr\\Log\\": "" + "Phine\\Exception": "src/lib" } }, "notification-url": "https://packagist.org/downloads/", @@ -943,104 +944,107 @@ ], "authors": [ { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" + "name": "Kevin Herrera", + "email": "kevin@herrera.io", + "homepage": "http://kevin.herrera.io", + "role": "Developer" } ], - "description": "Common interface for logging libraries", + "description": "A PHP library for improving the use of exceptions.", + "homepage": "https://github.com/phine/lib-exception", "keywords": [ - "log", - "psr", - "psr-3" + "exception" ], - "time": "2012-12-21 11:40:51" + "time": "2013-08-27 17:43:25" }, { - "name": "sebastian/comparator", - "version": "1.0.0", + "name": "phine/path", + "version": "1.1.0", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/comparator.git", - "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2" + "url": "https://github.com/phine/lib-path.git", + "reference": "cbe1a5eb6cf22958394db2469af9b773508abddd" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", - "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", + "url": "https://api.github.com/repos/phine/lib-path/zipball/cbe1a5eb6cf22958394db2469af9b773508abddd", + "reference": "cbe1a5eb6cf22958394db2469af9b773508abddd", "shasum": "" }, "require": { - "php": ">=5.3.3", - "sebastian/diff": "~1.1", - "sebastian/exporter": "~1.0" + "phine/exception": "~1.0", + "php": ">=5.3.3" }, "require-dev": { - "phpunit/phpunit": "~4.1" + "league/phpunit-coverage-listener": "~1.0" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.0.x-dev" + "dev-master": "1.0-dev" } }, "autoload": { - "classmap": [ - "src/" - ] + "psr-0": { + "Phine\\Path": "src/lib" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Volker Dusch", - "email": "github@wallbash.com" - }, - { - "name": "Bernhard Schussek", - "email": "bschussek@2bepublished.at" + "name": "Kevin Herrera", + "email": "kevin@herrera.io", + "homepage": "http://kevin.herrera.io", + "role": "Developer" } ], - "description": "Provides the functionality to compare PHP values for equality", - "homepage": "http://www.github.com/sebastianbergmann/comparator", + "description": "A PHP library for improving the use of file system paths.", + "homepage": "https://github.com/phine/lib-path", "keywords": [ - "comparator", - "compare", - "equality" + "file", + "path", + "system" ], - "time": "2014-05-02 07:05:58" + "time": "2013-10-15 22:58:04" }, { - "name": "sebastian/diff", - "version": "1.1.0", + "name": "phpunit/php-code-coverage", + "version": "2.0.8", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/diff.git", - "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d" + "url": "https://github.com/sebastianbergmann/php-code-coverage.git", + "reference": "58401826c8cfc8fd689b60026e91c337df374bca" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", - "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", + "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/58401826c8cfc8fd689b60026e91c337df374bca", + "reference": "58401826c8cfc8fd689b60026e91c337df374bca", "shasum": "" }, "require": { - "php": ">=5.3.3" + "php": ">=5.3.3", + "phpunit/php-file-iterator": "~1.3.1", + "phpunit/php-text-template": "~1.2.0", + "phpunit/php-token-stream": "~1.2.2", + "sebastian/environment": "~1.0.0", + "sebastian/version": "~1.0.3" + }, + "require-dev": { + "ext-xdebug": ">=2.1.4", + "phpunit/phpunit": "~4.0.14" + }, + "suggest": { + "ext-dom": "*", + "ext-xdebug": ">=2.2.1", + "ext-xmlwriter": "*" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.1-dev" + "dev-master": "2.0.x-dev" } }, "autoload": { @@ -1049,430 +1053,434 @@ ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], "license": [ "BSD-3-Clause" ], "authors": [ { "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", + "email": "sb@sebastian-bergmann.de", "role": "lead" - }, - { - "name": "Kore Nordmann", - "email": "mail@kore-nordmann.de" } ], - "description": "Diff implementation", - "homepage": "http://www.github.com/sebastianbergmann/diff", + "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", + "homepage": "https://github.com/sebastianbergmann/php-code-coverage", "keywords": [ - "diff" + "coverage", + "testing", + "xunit" ], - "time": "2013-08-03 16:46:33" + "time": "2014-05-26 14:55:24" }, { - "name": "sebastian/environment", - "version": "1.0.0", + "name": "phpunit/php-file-iterator", + "version": "1.3.4", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/environment.git", - "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a" + "url": "https://github.com/sebastianbergmann/php-file-iterator.git", + "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/79517609ec01139cd7e9fded0dd7ce08c952ef6a", - "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a", + "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/acd690379117b042d1c8af1fafd61bde001bf6bb", + "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb", "shasum": "" }, "require": { "php": ">=5.3.3" }, - "require-dev": { - "phpunit/phpunit": "4.0.*@dev" - }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, "autoload": { "classmap": [ - "src/" + "File/" ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], "license": [ "BSD-3-Clause" ], "authors": [ { "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", + "email": "sb@sebastian-bergmann.de", "role": "lead" } ], - "description": "Provides functionality to handle HHVM/PHP environments", - "homepage": "http://www.github.com/sebastianbergmann/environment", + "description": "FilterIterator implementation that filters files based on a list of suffixes.", + "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", "keywords": [ - "Xdebug", - "environment", - "hhvm" + "filesystem", + "iterator" ], - "time": "2014-02-18 16:17:19" + "time": "2013-10-10 15:34:57" }, { - "name": "sebastian/exporter", - "version": "1.0.1", + "name": "phpunit/php-text-template", + "version": "1.2.0", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/exporter.git", - "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529" + "url": "https://github.com/sebastianbergmann/php-text-template.git", + "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", - "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", + "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", + "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", "shasum": "" }, "require": { "php": ">=5.3.3" }, - "require-dev": { - "phpunit/phpunit": "4.0.*@dev" - }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, "autoload": { "classmap": [ - "src/" + "Text/" ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], "license": [ "BSD-3-Clause" ], "authors": [ { "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", + "email": "sb@sebastian-bergmann.de", "role": "lead" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Volker Dusch", - "email": "github@wallbash.com" - }, - { - "name": "Adam Harvey", - "email": "aharvey@php.net", - "role": "Lead" - }, - { - "name": "Bernhard Schussek", - "email": "bschussek@2bepublished.at" } ], - "description": "Provides the functionality to export PHP variables for visualization", - "homepage": "http://www.github.com/sebastianbergmann/exporter", + "description": "Simple template engine.", + "homepage": "https://github.com/sebastianbergmann/php-text-template/", "keywords": [ - "export", - "exporter" + "template" ], - "time": "2014-02-16 08:26:31" + "time": "2014-01-30 17:20:04" }, { - "name": "sebastian/version", - "version": "1.0.3", + "name": "phpunit/php-timer", + "version": "1.0.5", "source": { "type": "git", - "url": "https://github.com/sebastianbergmann/version.git", - "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43" + "url": "https://github.com/sebastianbergmann/php-timer.git", + "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", - "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", + "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/19689d4354b295ee3d8c54b4f42c3efb69cbc17c", + "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c", "shasum": "" }, + "require": { + "php": ">=5.3.3" + }, "type": "library", "autoload": { "classmap": [ - "src/" + "PHP/" ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], "license": [ "BSD-3-Clause" ], "authors": [ { "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", + "email": "sb@sebastian-bergmann.de", "role": "lead" } ], - "description": "Library that helps with managing the version number of Git-hosted PHP projects", - "homepage": "https://github.com/sebastianbergmann/version", - "time": "2014-03-07 15:35:33" + "description": "Utility class for timing", + "homepage": "https://github.com/sebastianbergmann/php-timer/", + "keywords": [ + "timer" + ], + "time": "2013-08-02 07:42:54" }, { - "name": "symfony/console", - "version": "v2.5.0", - "target-dir": "Symfony/Component/Console", + "name": "phpunit/php-token-stream", + "version": "1.2.2", "source": { "type": "git", - "url": "https://github.com/symfony/Console.git", - "reference": "ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c" + "url": "https://github.com/sebastianbergmann/php-token-stream.git", + "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Console/zipball/ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c", - "reference": "ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c", + "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/ad4e1e23ae01b483c16f600ff1bebec184588e32", + "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32", "shasum": "" }, "require": { + "ext-tokenizer": "*", "php": ">=5.3.3" }, - "require-dev": { - "psr/log": "~1.0", - "symfony/event-dispatcher": "~2.1" - }, - "suggest": { - "psr/log": "For using the console logger", - "symfony/event-dispatcher": "" - }, "type": "library", "extra": { "branch-alias": { - "dev-master": "2.5-dev" + "dev-master": "1.2-dev" } }, "autoload": { - "psr-0": { - "Symfony\\Component\\Console\\": "" - } + "classmap": [ + "PHP/" + ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], "license": [ - "MIT" + "BSD-3-Clause" ], "authors": [ { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" - }, - { - "name": "Symfony Community", - "homepage": "http://symfony.com/contributors" + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" } ], - "description": "Symfony Console Component", - "homepage": "http://symfony.com", - "time": "2014-05-22 08:54:24" + "description": "Wrapper around PHP's tokenizer extension.", + "homepage": "https://github.com/sebastianbergmann/php-token-stream/", + "keywords": [ + "tokenizer" + ], + "time": "2014-03-03 05:10:30" }, { - "name": "symfony/finder", - "version": "v2.5.0", - "target-dir": "Symfony/Component/Finder", + "name": "phpunit/phpunit", + "version": "4.1.3", "source": { "type": "git", - "url": "https://github.com/symfony/Finder.git", - "reference": "307aad2c541bbdf43183043645e186ef2cd6b973" + "url": "https://github.com/sebastianbergmann/phpunit.git", + "reference": "939cb801b3b2aa253aedd0b279f40bb8f35cec91" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Finder/zipball/307aad2c541bbdf43183043645e186ef2cd6b973", - "reference": "307aad2c541bbdf43183043645e186ef2cd6b973", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/939cb801b3b2aa253aedd0b279f40bb8f35cec91", + "reference": "939cb801b3b2aa253aedd0b279f40bb8f35cec91", "shasum": "" }, "require": { - "php": ">=5.3.3" + "ext-dom": "*", + "ext-json": "*", + "ext-pcre": "*", + "ext-reflection": "*", + "ext-spl": "*", + "php": ">=5.3.3", + "phpunit/php-code-coverage": "~2.0", + "phpunit/php-file-iterator": "~1.3.1", + "phpunit/php-text-template": "~1.2", + "phpunit/php-timer": "~1.0.2", + "phpunit/phpunit-mock-objects": "~2.1", + "sebastian/comparator": "~1.0", + "sebastian/diff": "~1.1", + "sebastian/environment": "~1.0", + "sebastian/exporter": "~1.0", + "sebastian/version": "~1.0", + "symfony/yaml": "~2.0" }, + "suggest": { + "phpunit/php-invoker": "~1.1" + }, + "bin": [ + "phpunit" + ], "type": "library", "extra": { "branch-alias": { - "dev-master": "2.5-dev" + "dev-master": "4.1.x-dev" } }, "autoload": { - "psr-0": { - "Symfony\\Component\\Finder\\": "" - } + "classmap": [ + "src/" + ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "", + "../../symfony/yaml/" + ], "license": [ - "MIT" + "BSD-3-Clause" ], "authors": [ { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" - }, - { - "name": "Symfony Community", - "homepage": "http://symfony.com/contributors" + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" } ], - "description": "Symfony Finder Component", - "homepage": "http://symfony.com", - "time": "2014-05-22 13:47:45" + "description": "The PHP Unit Testing framework.", + "homepage": "http://www.phpunit.de/", + "keywords": [ + "phpunit", + "testing", + "xunit" + ], + "time": "2014-06-11 14:15:47" }, { - "name": "symfony/yaml", - "version": "v2.5.0", - "target-dir": "Symfony/Component/Yaml", + "name": "phpunit/phpunit-mock-objects", + "version": "2.1.4", "source": { "type": "git", - "url": "https://github.com/symfony/Yaml.git", - "reference": "b4b09c68ec2f2727574544ef0173684281a5033c" + "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", + "reference": "1a894a16b6c15fcdc5ef2b110f0e6233952c9b0f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Yaml/zipball/b4b09c68ec2f2727574544ef0173684281a5033c", - "reference": "b4b09c68ec2f2727574544ef0173684281a5033c", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/1a894a16b6c15fcdc5ef2b110f0e6233952c9b0f", + "reference": "1a894a16b6c15fcdc5ef2b110f0e6233952c9b0f", "shasum": "" }, "require": { - "php": ">=5.3.3" + "php": ">=5.3.3", + "phpunit/php-text-template": "~1.2" + }, + "require-dev": { + "phpunit/phpunit": "~4.1" + }, + "suggest": { + "ext-soap": "*" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "2.5-dev" + "dev-master": "2.1.x-dev" } }, "autoload": { - "psr-0": { - "Symfony\\Component\\Yaml\\": "" - } + "classmap": [ + "src/" + ] }, "notification-url": "https://packagist.org/downloads/", + "include-path": [ + "" + ], "license": [ - "MIT" + "BSD-3-Clause" ], "authors": [ { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" - }, - { - "name": "Symfony Community", - "homepage": "http://symfony.com/contributors" + "name": "Sebastian Bergmann", + "email": "sb@sebastian-bergmann.de", + "role": "lead" } ], - "description": "Symfony Yaml Component", - "homepage": "http://symfony.com", - "time": "2014-05-16 14:25:18" - } - ], - "packages-dev": [ + "description": "Mock Object library for PHPUnit", + "homepage": "https://github.com/sebastianbergmann/phpunit-mock-objects/", + "keywords": [ + "mock", + "xunit" + ], + "time": "2014-06-07 16:22:57" + }, { - "name": "herrera-io/box", - "version": "1.5.3", + "name": "sebastian/comparator", + "version": "1.0.0", "source": { "type": "git", - "url": "https://github.com/herrera-io/php-box.git", - "reference": "b5432951f85a56df6012f503881174e7aeec6611" + "url": "https://github.com/sebastianbergmann/comparator.git", + "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/herrera-io/php-box/zipball/b5432951f85a56df6012f503881174e7aeec6611", - "reference": "b5432951f85a56df6012f503881174e7aeec6611", + "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", + "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", "shasum": "" }, "require": { - "ext-phar": "*", - "phine/path": "~1.0", - "php": ">=5.3.3" + "php": ">=5.3.3", + "sebastian/diff": "~1.1", + "sebastian/exporter": "~1.0" }, "require-dev": { - "herrera-io/annotations": "~1.0", - "herrera-io/phpunit-test-case": "1.*", - "mikey179/vfsstream": "1.1.0", - "phpseclib/phpseclib": "~0.3", - "phpunit/phpunit": "3.7.*" - }, - "suggest": { - "herrera-io/annotations": "For compacting annotated docblocks.", - "phpseclib/phpseclib": "For verifying OpenSSL signed phars without the phar extension." + "phpunit/phpunit": "~4.1" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.0-dev" + "dev-master": "1.0.x-dev" } }, "autoload": { - "psr-0": { - "Herrera\\Box": "src/lib" - } + "classmap": [ + "src/" + ] }, "notification-url": "https://packagist.org/downloads/", "license": [ - "MIT" + "BSD-3-Clause" ], "authors": [ { - "name": "Kevin Herrera", - "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io", - "role": "Developer" + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@2bepublished.at" } ], - "description": "A library for simplifying the PHAR build process.", - "homepage": "http://herrera-io.github.com/php-box", + "description": "Provides the functionality to compare PHP values for equality", + "homepage": "http://www.github.com/sebastianbergmann/comparator", "keywords": [ - "phar" + "comparator", + "compare", + "equality" ], - "time": "2014-02-07 15:48:46" + "time": "2014-05-02 07:05:58" }, { - "name": "mockery/mockery", - "version": "0.9.1", + "name": "sebastian/diff", + "version": "1.1.0", "source": { "type": "git", - "url": "https://github.com/padraic/mockery.git", - "reference": "17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1" + "url": "https://github.com/sebastianbergmann/diff.git", + "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/padraic/mockery/zipball/17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1", - "reference": "17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1", + "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", + "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", "shasum": "" }, "require": { - "lib-pcre": ">=7.0", - "php": ">=5.3.2" - }, - "require-dev": { - "hamcrest/hamcrest-php": "~1.1", - "phpunit/phpunit": "~4.0", - "satooshi/php-coveralls": "~0.7@dev" + "php": ">=5.3.3" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "0.9.x-dev" + "dev-master": "1.1-dev" } }, "autoload": { - "psr-0": { - "Mockery": "library/" - } + "classmap": [ + "src/" + ] }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -1480,209 +1488,202 @@ ], "authors": [ { - "name": "Pádraic Brady", - "email": "padraic.brady@gmail.com", - "homepage": "http://blog.astrumfutura.com" + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" }, { - "name": "Dave Marshall", - "email": "dave.marshall@atstsolutions.co.uk", - "homepage": "http://davedevelopment.co.uk" + "name": "Kore Nordmann", + "email": "mail@kore-nordmann.de" } ], - "description": "Mockery is a simple yet flexible PHP mock object framework for use in unit testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a test double framework with a succint API capable of clearly defining all possible object operations and interactions using a human readable Domain Specific Language (DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with PHPUnit and can operate alongside phpunit-mock-objects without the World ending.", - "homepage": "http://github.com/padraic/mockery", + "description": "Diff implementation", + "homepage": "http://www.github.com/sebastianbergmann/diff", "keywords": [ - "BDD", - "TDD", - "library", - "mock", - "mock objects", - "mockery", - "stub", - "test", - "test double", - "testing" + "diff" ], - "time": "2014-05-02 12:16:45" + "time": "2013-08-03 16:46:33" }, { - "name": "nesbot/carbon", - "version": "1.9.0", + "name": "sebastian/environment", + "version": "1.0.0", "source": { "type": "git", - "url": "https://github.com/briannesbitt/Carbon.git", - "reference": "b94de7192b01d0e80794eae984dcc773220ab0dc" + "url": "https://github.com/sebastianbergmann/environment.git", + "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/b94de7192b01d0e80794eae984dcc773220ab0dc", - "reference": "b94de7192b01d0e80794eae984dcc773220ab0dc", + "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/79517609ec01139cd7e9fded0dd7ce08c952ef6a", + "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a", "shasum": "" }, "require": { - "php": ">=5.3.0" + "php": ">=5.3.3" }, "require-dev": { - "phpunit/phpunit": "3.7.*" + "phpunit/phpunit": "4.0.*@dev" }, "type": "library", - "autoload": { - "psr-0": { - "Carbon": "src" + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" } }, + "autoload": { + "classmap": [ + "src/" + ] + }, "notification-url": "https://packagist.org/downloads/", "license": [ - "MIT" + "BSD-3-Clause" ], "authors": [ { - "name": "Brian Nesbitt", - "email": "brian@nesbot.com", - "homepage": "http://nesbot.com" + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" } ], - "description": "A simple API extension for DateTime.", - "homepage": "https://github.com/briannesbitt/Carbon", + "description": "Provides functionality to handle HHVM/PHP environments", + "homepage": "http://www.github.com/sebastianbergmann/environment", "keywords": [ - "date", - "datetime", - "time" + "Xdebug", + "environment", + "hhvm" ], - "time": "2014-05-13 02:29:30" + "time": "2014-02-18 16:17:19" }, { - "name": "patchwork/utf8", - "version": "v1.1.23", + "name": "sebastian/exporter", + "version": "1.0.1", "source": { "type": "git", - "url": "https://github.com/nicolas-grekas/Patchwork-UTF8.git", - "reference": "c1edbc82aed49ff2bdef0a0f659bf69e3f7b14cc" + "url": "https://github.com/sebastianbergmann/exporter.git", + "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/nicolas-grekas/Patchwork-UTF8/zipball/c1edbc82aed49ff2bdef0a0f659bf69e3f7b14cc", - "reference": "c1edbc82aed49ff2bdef0a0f659bf69e3f7b14cc", + "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", + "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", "shasum": "" }, "require": { - "lib-pcre": ">=7.3", - "php": ">=5.3.0" + "php": ">=5.3.3" }, - "suggest": { - "ext-iconv": "Use iconv for best performance", - "ext-intl": "Use Intl for best performance", - "ext-mbstring": "Use Mbstring for best performance" + "require-dev": { + "phpunit/phpunit": "4.0.*@dev" }, "type": "library", - "autoload": { - "psr-0": { - "Patchwork": "class/", - "Normalizer": "class/" + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" } }, + "autoload": { + "classmap": [ + "src/" + ] + }, "notification-url": "https://packagist.org/downloads/", "license": [ - "(Apache-2.0 or GPL-2.0)" + "BSD-3-Clause" ], "authors": [ { - "name": "Nicolas Grekas", - "email": "p@tchwork.com", - "role": "Developer" + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Adam Harvey", + "email": "aharvey@php.net", + "role": "Lead" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@2bepublished.at" } ], - "description": "Extensive, portable and performant handling of UTF-8 and grapheme clusters for PHP", - "homepage": "https://github.com/nicolas-grekas/Patchwork-UTF8", + "description": "Provides the functionality to export PHP variables for visualization", + "homepage": "http://www.github.com/sebastianbergmann/exporter", "keywords": [ - "i18n", - "unicode", - "utf-8", - "utf8" + "export", + "exporter" ], - "time": "2014-05-22 13:59:09" + "time": "2014-02-16 08:26:31" }, { - "name": "phine/exception", - "version": "1.0.0", + "name": "sebastian/version", + "version": "1.0.3", "source": { "type": "git", - "url": "https://github.com/phine/lib-exception.git", - "reference": "150c6b6090b2ebc53c60e87cb20c7f1287b7b68a" + "url": "https://github.com/sebastianbergmann/version.git", + "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phine/lib-exception/zipball/150c6b6090b2ebc53c60e87cb20c7f1287b7b68a", - "reference": "150c6b6090b2ebc53c60e87cb20c7f1287b7b68a", + "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", + "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", "shasum": "" }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "league/phpunit-coverage-listener": "~1.0" - }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, "autoload": { - "psr-0": { - "Phine\\Exception": "src/lib" - } + "classmap": [ + "src/" + ] }, "notification-url": "https://packagist.org/downloads/", "license": [ - "MIT" + "BSD-3-Clause" ], "authors": [ { - "name": "Kevin Herrera", - "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io", - "role": "Developer" + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" } ], - "description": "A PHP library for improving the use of exceptions.", - "homepage": "https://github.com/phine/lib-exception", - "keywords": [ - "exception" - ], - "time": "2013-08-27 17:43:25" + "description": "Library that helps with managing the version number of Git-hosted PHP projects", + "homepage": "https://github.com/sebastianbergmann/version", + "time": "2014-03-07 15:35:33" }, { - "name": "phine/path", - "version": "1.1.0", + "name": "symfony/yaml", + "version": "v2.5.0", + "target-dir": "Symfony/Component/Yaml", "source": { "type": "git", - "url": "https://github.com/phine/lib-path.git", - "reference": "cbe1a5eb6cf22958394db2469af9b773508abddd" + "url": "https://github.com/symfony/Yaml.git", + "reference": "b4b09c68ec2f2727574544ef0173684281a5033c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phine/lib-path/zipball/cbe1a5eb6cf22958394db2469af9b773508abddd", - "reference": "cbe1a5eb6cf22958394db2469af9b773508abddd", + "url": "https://api.github.com/repos/symfony/Yaml/zipball/b4b09c68ec2f2727574544ef0173684281a5033c", + "reference": "b4b09c68ec2f2727574544ef0173684281a5033c", "shasum": "" }, "require": { - "phine/exception": "~1.0", "php": ">=5.3.3" }, - "require-dev": { - "league/phpunit-coverage-listener": "~1.0" - }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.0-dev" + "dev-master": "2.5-dev" } }, "autoload": { "psr-0": { - "Phine\\Path": "src/lib" + "Symfony\\Component\\Yaml\\": "" } }, "notification-url": "https://packagist.org/downloads/", @@ -1691,20 +1692,19 @@ ], "authors": [ { - "name": "Kevin Herrera", - "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io", - "role": "Developer" + "name": "Fabien Potencier", + "email": "fabien@symfony.com", + "homepage": "http://fabien.potencier.org", + "role": "Lead Developer" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" } ], - "description": "A PHP library for improving the use of file system paths.", - "homepage": "https://github.com/phine/lib-path", - "keywords": [ - "file", - "path", - "system" - ], - "time": "2013-10-15 22:58:04" + "description": "Symfony Yaml Component", + "homepage": "http://symfony.com", + "time": "2014-05-16 14:25:18" } ], "aliases": [], diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 0f4efcbce..66cf4751d 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -97,7 +97,7 @@ protected function fireTasksQueue($tasks) // Run tasks and display timer $this->laravel['rocketeer.tasks']->run($tasks, $this); - $this->line('Execution time: '.round(microtime(true) - $timerStart, 4). 's'); + $this->line('Execution time: '.round(microtime(true) - $timerStart, 4).'s'); // Remove command instance unset($this->laravel['rocketeer.command']); @@ -116,7 +116,7 @@ protected function getRepositoryCredentials() { // Check for repository credentials $repositoryInfos = $this->laravel['rocketeer.rocketeer']->getCredentials(); - $credentials = array('repository'); + $credentials = array('repository'); if (!array_get($repositoryInfos, 'repository') or $this->laravel['rocketeer.rocketeer']->needsCredentials()) { $credentials = array('repository', 'username', 'password'); } @@ -125,7 +125,7 @@ protected function getRepositoryCredentials() foreach ($credentials as $credential) { ${$credential} = $this->getCredential($repositoryInfos, $credential); if (!${$credential}) { - ${$credential} = $this->ask('No '.$credential. ' is set for the repository, please provide one :'); + ${$credential} = $this->ask('No '.$credential.' is set for the repository, please provide one :'); } } @@ -187,16 +187,16 @@ protected function storeServerCredentials($connections, $connectionName) foreach ($credentials as $credential => $required) { ${$credential} = $this->getCredential($connection, $credential); if ($required and !${$credential}) { - ${$credential} = $this->ask('No '.$credential. ' is set for [' .$connectionName. '], please provide one :'); + ${$credential} = $this->ask('No '.$credential.' is set for ['.$connectionName.'], please provide one :'); } } // Get password or key if (!$password and !$key) { - $type = $this->ask('No password or SSH key is set for [' .$connectionName. '], which would you use ? [key/password]', 'key'); + $type = $this->ask('No password or SSH key is set for ['.$connectionName.'], which would you use ? [key/password]', 'key'); if ($type == 'key') { $default = $this->laravel['rocketeer.rocketeer']->getUserHomeFolder().'/.ssh/id_rsa'; - $key = $this->ask('Please enter the full path to your key (' .$default. ')', $default); + $key = $this->ask('Please enter the full path to your key ('.$default.')', $default); $keyphrase = $this->ask('If a keyphrase is required, provide it'); } else { $password = $this->ask('Please enter your password'); @@ -212,8 +212,8 @@ protected function storeServerCredentials($connections, $connectionName) /** * Check if a credential needs to be filled * - * @param array $credentials - * @param string $credential + * @param array $credentials + * @param string $credential * * @return string */ diff --git a/src/Rocketeer/Commands/CleanupCommand.php b/src/Rocketeer/Commands/CleanupCommand.php index c098cc88b..538a84c7b 100644 --- a/src/Rocketeer/Commands/CleanupCommand.php +++ b/src/Rocketeer/Commands/CleanupCommand.php @@ -50,7 +50,7 @@ public function fire() protected function getOptions() { return array_merge(parent::getOptions(), array( - array('clean-all', null, InputOption::VALUE_NONE, 'Cleans up all non-current releases'), + array('clean-all', null, InputOption::VALUE_NONE, 'Cleans up all non-current releases'), )); } } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 807dfc4ce..d1d27230d 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -283,7 +283,7 @@ public function bindCommands(Container $app) }); // Add command to array - $command = trim('deploy.'.$slug, '.'); + $command = trim('deploy.'.$slug, '.'); $this->commands[] = $command; // Look for an existing command diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 1306d898c..982ecf36e 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -129,7 +129,7 @@ public function runTests($arguments = null) // Run PHPUnit $this->command->info('Running tests...'); $output = $this->runForCurrentRelease(array( - $phpunit. ' --stop-on-failure '.$arguments, + $phpunit.' --stop-on-failure '.$arguments, )); return $this->checkStatus('Tests failed', $output, 'Tests passed successfully'); diff --git a/tests/Dummies/DummyNotifier.php b/tests/Dummies/DummyNotifier.php index 74717bf82..21b5fa53d 100644 --- a/tests/Dummies/DummyNotifier.php +++ b/tests/Dummies/DummyNotifier.php @@ -5,27 +5,27 @@ class DummyNotifier extends Notifier { - /** - * Get the default message format - * - * @return string - */ - protected function getMessageFormat($message) - { - return '{1} finished deploying branch "{2}" on "{3}" ({4})'; - } + /** + * Get the default message format + * + * @return string + */ + protected function getMessageFormat($message) + { + return '{1} finished deploying branch "{2}" on "{3}" ({4})'; + } - /** - * Send a given message - * - * @param string $message - * - * @return void - */ - public function send($message) - { - print $message; + /** + * Send a given message + * + * @param string $message + * + * @return void + */ + public function send($message) + { + print $message; - return $message; - } + return $message; + } } diff --git a/tests/ReleasesManagerTest.php b/tests/ReleasesManagerTest.php index 4f1dc89f6..7d4357afa 100644 --- a/tests/ReleasesManagerTest.php +++ b/tests/ReleasesManagerTest.php @@ -17,9 +17,9 @@ public function testCanGetStateOfReleases() $validation = $this->app['rocketeer.releases']->getValidationFile(); $this->assertEquals(array( - 10000000000000 => true, - 15000000000000 => false, - 20000000000000 => true, + 10000000000000 => true, + 15000000000000 => false, + 20000000000000 => true, ), $validation); } @@ -36,9 +36,9 @@ public function testCanUpdateStateOfReleases() $validation = $this->app['rocketeer.releases']->getValidationFile(); $this->assertEquals(array( - 10000000000000 => true, - 15000000000000 => true, - 20000000000000 => true, + 10000000000000 => true, + 15000000000000 => true, + 20000000000000 => true, ), $validation); } diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 9ea59f0f9..a1ba2fa96 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -147,14 +147,14 @@ public function testCanUseRecursiveStageConfiguration() public function testCanUseRecursiveConnectionConfiguration() { $this->swapConfig(array( - 'rocketeer::default' => 'production', + 'rocketeer::default' => 'production', 'rocketeer::scm.branch' => 'master', 'rocketeer::on.connections.staging.scm.branch' => 'staging', )); $this->assertEquals('master', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); $this->swapConfig(array( - 'rocketeer::default' => 'staging', + 'rocketeer::default' => 'staging', 'rocketeer::scm.branch' => 'master', 'rocketeer::on.connections.staging.scm.branch' => 'staging', )); diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index c4039ba60..36bad97b0 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -55,7 +55,7 @@ public function testCanGetCheckout() $command = $this->scm->checkout($this->server); - $this->assertEquals('git clone --depth 1 -b develop "http://github.com/my/repository" ' .$this->server, $command); + $this->assertEquals('git clone --depth 1 -b develop "http://github.com/my/repository" '.$this->server, $command); } public function testCanGetDeepClone() @@ -69,7 +69,7 @@ public function testCanGetDeepClone() $command = $this->scm->checkout($this->server); - $this->assertEquals('git clone -b develop "http://github.com/my/repository" ' .$this->server, $command); + $this->assertEquals('git clone -b develop "http://github.com/my/repository" '.$this->server, $command); } public function testCanGetReset() diff --git a/tests/ServerTest.php b/tests/ServerTest.php index 24d269dc3..44c649af2 100644 --- a/tests/ServerTest.php +++ b/tests/ServerTest.php @@ -17,7 +17,7 @@ public function testCanCreateDeploymentsFileAnywhere() new Server($this->app); $storage = $this->app['rocketeer.rocketeer']->getRocketeerConfigFolder(); - $exists = file_exists($storage); + $exists = file_exists($storage); $this->app['files']->deleteDirectory($storage); $this->assertTrue($exists); } diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 062703b1f..1d796c442 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -52,7 +52,7 @@ public function testCanDisableGitOptions() $this->swapConfig(array( 'rocketeer::scm.shallow' => false, 'rocketeer::scm.submodules' => false, - 'rocketeer::scm' => array( + 'rocketeer::scm' => array( 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', @@ -92,7 +92,7 @@ public function testCanDisableGitOptions() public function testCanConfigureComposerCommands() { $this->swapConfig(array( - 'rocketeer::scm' => array( + 'rocketeer::scm' => array( 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', @@ -108,8 +108,8 @@ public function testCanConfigureComposerCommands() $matcher = array( array( "cd {server}/releases/{release}", - "{composer} self-update", - "{composer} install --prefer-source", + "{composer} self-update", + "{composer} install --prefer-source", ), ); @@ -127,7 +127,7 @@ public function testCanUseCopyStrategy() { $this->swapConfig(array( 'rocketeer::remote.strategy' => 'copy', - 'rocketeer::scm' => array( + 'rocketeer::scm' => array( 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index 15c82fe1b..d46e83dde 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -42,7 +42,7 @@ public function testCanAddTasksViaFacade() public function testCanAddMultipleTasksViaFacade() { - $task = $this->task('Deploy'); + $task = $this->task('Deploy'); $after = $this->tasksQueue()->getTasksListeners($task, 'after', true); $this->tasksQueue()->after('deploy', array( @@ -56,7 +56,7 @@ public function testCanAddMultipleTasksViaFacade() public function testCanAddSurroundTasksToNonExistingTasks() { - $task = $this->task('Setup'); + $task = $this->task('Setup'); $this->tasksQueue()->after('setup', 'composer install'); $after = array('composer install'); diff --git a/tests/TasksQueueTest.php b/tests/TasksQueueTest.php index 9cbceacdd..cdf955258 100644 --- a/tests/TasksQueueTest.php +++ b/tests/TasksQueueTest.php @@ -2,7 +2,6 @@ namespace Rocketeer; use ReflectionFunction; -use Rocketeer\Facades\Rocketeer; use Rocketeer\TestCases\RocketeerTestCase; class TasksQueueTest extends RocketeerTestCase @@ -63,7 +62,7 @@ function ($task) { $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[0]); $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[1]); - $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $queue[2]); + $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $queue[2]); } public function testCanRunQueue() @@ -88,9 +87,9 @@ public function testCanRunQueueOnDifferentConnectionsAndStages() )); $output = array(); - $queue = array( + $queue = array( function ($task) use (&$output) { - $output[] = $task->rocketeer->getConnection(). ' - ' .$task->rocketeer->getStage(); + $output[] = $task->rocketeer->getConnection().' - '.$task->rocketeer->getStage(); } ); @@ -131,7 +130,7 @@ public function testCanRunOnMultipleConnectionsViaOn() )); $output = $this->tasksQueue()->on(array('staging', 'production'), function ($task) { - return $task->rocketeer->getConnection(). ' - ' .$task->rocketeer->getStage(); + return $task->rocketeer->getConnection().' - '.$task->rocketeer->getStage(); }); $this->assertEquals(array( diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 7b1ad0eda..6c2e252fe 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -149,7 +149,10 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('cache.driver')->andReturn('file'); $config->shouldReceive('get')->with('database.default')->andReturn('mysql'); $config->shouldReceive('get')->with('remote.default')->andReturn('production'); - $config->shouldReceive('get')->with('remote.connections')->andReturn(array('production' => array(), 'staging' => array())); + $config->shouldReceive('get')->with('remote.connections')->andReturn(array( + 'production' => array(), + 'staging' => array() + )); $config->shouldReceive('get')->with('session.driver')->andReturn('file'); // Rocketeer @@ -199,8 +202,8 @@ protected function getConfig($expectations = array()) 'foobar' ), ), - 'after' => array( - 'check' => array( + 'after' => array( + 'check' => array( 'Rocketeer\Dummies\MyCustomTask', ), 'deploy' => array( diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index a5a8fcf89..d1786eb25 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -68,7 +68,7 @@ protected function recreateVirtualServer() 'current_release' => array('production' => 20000000000000), 'directory_separator' => '/', 'is_setup' => true, - 'webuser' => array('username' => 'www-data','group' => 'www-data'), + 'webuser' => array('username' => 'www-data', 'group' => 'www-data'), 'line_endings' => "\n", ))); @@ -118,9 +118,9 @@ protected function assertTaskOutput($task, $output, $command = null) /** * Assert a task's history matches an array * - * @param string|Task $task - * @param array $history - * @param array $options + * @param string|Task $task + * @param array $history + * @param array $options * * @return string */ diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index a64361831..87a969d07 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -34,7 +34,7 @@ public function testFetchesBinaryIfNotSpecifiedOrNull() public function testCanGetBinary() { $whichGrep = exec('which grep'); - $grep = $this->task->which('grep'); + $grep = $this->task->which('grep'); $this->assertEquals($whichGrep, $grep); } @@ -42,7 +42,7 @@ public function testCanGetBinary() public function testCanGetFallbackForBinary() { $whichGrep = exec('which grep'); - $grep = $this->task->which('foobar', $whichGrep); + $grep = $this->task->which('foobar', $whichGrep); $this->assertEquals($whichGrep, $grep); $this->assertFalse($this->task->which('fdsf')); diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 40be091bd..932f8b648 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -16,7 +16,7 @@ public function testCanCheckStatusOfACommand() { $this->task->remote = clone $this->getRemote()->shouldReceive('status')->andReturn(1)->mock(); ob_start(); - $status = $this->task->checkStatus(null, 'error'); + $status = $this->task->checkStatus(null, 'error'); $output = ob_get_clean(); $this->assertEquals('error'.PHP_EOL, $output); $this->assertFalse($status); @@ -31,7 +31,7 @@ public function testCanGetTimestampOffServer() public function testCanGetLocalTimestampIfError() { $this->app['remote'] = $this->getRemote('NOPE'); - $timestamp = $this->task->getTimestamp(); + $timestamp = $this->task->getTimestamp(); $this->assertEquals(date('YmdHis'), $timestamp); } diff --git a/tests/Traits/BashModules/FilesystemTest.php b/tests/Traits/BashModules/FilesystemTest.php index ec06b5684..afed9c49a 100644 --- a/tests/Traits/BashModules/FilesystemTest.php +++ b/tests/Traits/BashModules/FilesystemTest.php @@ -7,9 +7,9 @@ class FilesystemTest extends RocketeerTestCase { public function testCancelsSymlinkForUnexistingFolders() { - $task = $this->pretendTask(); - $folder = '{path.storage}/logs'; - $share = $task->share($folder); + $task = $this->pretendTask(); + $folder = '{path.storage}/logs'; + $share = $task->share($folder); $this->assertFalse($share); } diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index a71adcaa9..c1b52817b 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -16,7 +16,7 @@ public function testCanForgetCredentialsIfInvalid() // Create fake remote $remote = clone $this->getRemote(); $remote->shouldReceive('status')->andReturn(1); - $task = $this->pretendTask(); + $task = $this->pretendTask(); $task->remote = $remote; $task->cloneRepository($this->server.'/test'); diff --git a/tests/Traits/TaskTest.php b/tests/Traits/TaskTest.php index ba9c98df4..08dc6a3f0 100644 --- a/tests/Traits/TaskTest.php +++ b/tests/Traits/TaskTest.php @@ -29,7 +29,7 @@ public function testCanDisplayOutputOfCommandsIfVerbose() )); ob_start(); - $task->run('ls'); + $task->run('ls'); $output = ob_get_clean(); $this->assertContains('tests', $output); @@ -53,7 +53,7 @@ public function testCanGetDescription() public function testCanRunMigrations() { $task = $this->pretendTask(); - $php = exec('which php'); + $php = exec('which php'); $commands = $task->runMigrations(); $this->assertEquals($php.' artisan migrate', $commands[1]); From 64ec5c5b5482d88211a6090590f8211e5914b454 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 24 Jun 2014 18:53:10 +0200 Subject: [PATCH 019/424] PHPDoc fixes --- phpunit.xml | 72 +++++++++++------------ src/Rocketeer/Plugins/Notifier.php | 3 +- src/Rocketeer/Server.php | 2 +- src/Rocketeer/TasksHandler.php | 2 + src/Rocketeer/Traits/BashModules/Core.php | 2 + src/Rocketeer/Traits/Task.php | 2 +- tests/TestCases/ContainerTestCase.php | 3 +- 7 files changed, 43 insertions(+), 43 deletions(-) diff --git a/phpunit.xml b/phpunit.xml index 18ef14b9f..93129fcc9 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -1,39 +1,33 @@ - - - - - - - src/Rocketeer - - src/Rocketeer/RocketeerServiceProvider.php - src/Rocketeer/Console/WhitespaceCompactor.php - src/Rocketeer/Console/Compiler.php - src/Rocketeer/Console - src/Rocketeer/Commands - src/Rocketeer/Facades - - - - - - - tests - - - \ No newline at end of file + + + + + + src/Rocketeer + + src/Rocketeer/RocketeerServiceProvider.php + src/Rocketeer/Console/WhitespaceCompactor.php + src/Rocketeer/Console/Compiler.php + src/Rocketeer/Console + src/Rocketeer/Commands + src/Rocketeer/Facades + + + + + + + tests + + + diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index fcc74f3a4..77f77ddad 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -11,6 +11,7 @@ use Rocketeer\TasksHandler; use Rocketeer\Traits\Plugin; +use Rocketeer\Traits\Task; /** * A base class for notification services to extends @@ -96,7 +97,7 @@ abstract protected function getMessageFormat($message); * * @return void */ - public function prepareThenSend($task, $message) + public function prepareThenSend(Task $task, $message) { // Don't send a notification if pretending to deploy if ($task->command->option('pretend')) { diff --git a/src/Rocketeer/Server.php b/src/Rocketeer/Server.php index 029fca877..ce69a9be7 100644 --- a/src/Rocketeer/Server.php +++ b/src/Rocketeer/Server.php @@ -111,7 +111,7 @@ public function getHash() /** * Flushes the repository if required * - * @return void + * @return boolean */ public function shouldFlush() { diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index 1f6d623de..6d0f9d721 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -180,6 +180,8 @@ public function listenTo($event, $listeners, $priority = 0) * @param string $event * @param mixed $listeners * @param integer $priority + * + * @return string */ public function addTaskListeners($task, $event, $listeners, $priority = 0) { diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 93e963758..7e677eac9 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -222,6 +222,8 @@ protected function getOption($option) * Add an array/command to the history * * @param string|array $commands + * + * @return array|string */ protected function addCommandsToHistory($commands) { diff --git a/src/Rocketeer/Traits/Task.php b/src/Rocketeer/Traits/Task.php index 6cd607a8b..5831ef280 100644 --- a/src/Rocketeer/Traits/Task.php +++ b/src/Rocketeer/Traits/Task.php @@ -98,7 +98,7 @@ public function getDescription() /** * Run the Task * - * @return void + * @return string */ abstract public function execute(); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 6c2e252fe..149fcb6a4 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -1,6 +1,7 @@ mock(); From 3e40162900cd6689bebca724683478d33376cad1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 25 Jun 2014 22:15:03 +0200 Subject: [PATCH 020/424] Codeblock tweaks --- src/Rocketeer/Igniter.php | 6 ------ src/Rocketeer/LogsHandler.php | 6 ------ src/Rocketeer/ReleasesManager.php | 4 ---- src/Rocketeer/TasksQueue.php | 2 +- src/Rocketeer/Traits/AbstractLocatorClass.php | 8 ++++---- tests/TasksHandlerTest.php | 17 +++++++++++++++++ tests/TestCases/RocketeerTestCase.php | 7 ++++--- 7 files changed, 26 insertions(+), 24 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 852627500..e1bb6b5e7 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -86,8 +86,6 @@ public function exportConfiguration() * * @param string $folder * @param array $values - * - * @return void */ public function updateConfiguration($folder, array $values = array()) { @@ -111,8 +109,6 @@ public function updateConfiguration($folder, array $values = array()) /** * Bind the base path to the Container - * - * @return void */ protected function bindBase() { @@ -125,8 +121,6 @@ protected function bindBase() /** * Bind paths to the configuration files - * - * @return void */ protected function bindConfiguration() { diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/LogsHandler.php index 1e34e65e3..348517ab0 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/LogsHandler.php @@ -45,8 +45,6 @@ public function __construct(Container $app) * * @param string $method * @param array $parameters - * - * @return void */ public function __call($method, $parameters) { @@ -58,8 +56,6 @@ public function __call($method, $parameters) * * @param string $informations * @param string $level - * - * @return void */ public function log($informations, $level = 'info') { @@ -112,8 +108,6 @@ protected function getLogger($file) * Create a logs file if it doesn't exist * * @param string $file - * - * @return void */ protected function createLogsFile($file) { diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index 2771cff2b..b876dafdd 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -179,8 +179,6 @@ public function getValidationFile() * Update the contents of the validation file * * @param array $validation - * - * @return void */ public function saveValidationFile(array $validation) { @@ -194,8 +192,6 @@ public function saveValidationFile(array $validation) * Mark a release as valid * * @param integer $release - * - * @return void */ public function markReleaseAsValid($release) { diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index 828c5e2b3..10105fbac 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -252,7 +252,7 @@ public function buildTaskFromClosure($task) * * @param string $task * - * @return Task + * @return \Rocketeer\Traits\Task */ public function buildTaskFromClass($task) { diff --git a/src/Rocketeer/Traits/AbstractLocatorClass.php b/src/Rocketeer/Traits/AbstractLocatorClass.php index 51c375102..cb9d54e60 100644 --- a/src/Rocketeer/Traits/AbstractLocatorClass.php +++ b/src/Rocketeer/Traits/AbstractLocatorClass.php @@ -17,10 +17,10 @@ * * @property Illuminate\Console\Command command * @property Illuminate\Remote\Connection remote - * @property ReleasesManager releasesManager - * @property Rocketeer rocketeer - * @property Server server - * @property Traits\Scm scm + * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Server server + * @property \Rocketeer\Traits\Scm scm * * @author Maxime Fabre */ diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index d46e83dde..e34f092b3 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -101,4 +101,21 @@ public function testCanExecuteContextualEvents() $this->app['rocketeer.rocketeer']->setStage('noEvent'); $this->assertEquals(array(), $this->tasksQueue()->getTasksListeners('check', 'before', true)); } + + public function testCanBuildQueueFromConfigHook() + { + $tasks = array( + 'npm install', + 'bower install', + ); + + $this->swapConfig(array( + 'rocketeer::hooks' => ['after' => ['deploy' => $tasks]], + )); + + $this->tasksQueue()->registerConfiguredEvents(); + $listeners = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + + $this->assertEquals($tasks, $listeners); + } } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index d1786eb25..4b4bcc802 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -243,9 +243,10 @@ protected function pretendTask($task = 'Deploy', $options = array(), array $expe /** * Get Task instance * - * @param string $task + * @param string $task + * @param null $command * - * @return Task + * @return \Rocketeer\Traits\Task */ protected function task($task = null, $command = null) { @@ -263,7 +264,7 @@ protected function task($task = null, $command = null) /** * Get TasksQueue instance * - * @return TasksQueue + * @return \Rocketeer\TasksQueue */ protected function tasksQueue() { From 862b0ced77102c3d05302ab4e58196e7dd9c0e41 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 25 Jun 2014 22:19:15 +0200 Subject: [PATCH 021/424] Close #169 - Specify default path for local artisan --- src/config/paths.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/config/paths.php b/src/config/paths.php index f366b416a..a5cbcf753 100644 --- a/src/config/paths.php +++ b/src/config/paths.php @@ -17,6 +17,6 @@ 'composer' => '', // Path to the Artisan CLI - 'artisan' => '', + 'artisan' => 'artisan', ); From 94eb7180c88299860162dd3d31df2b1c060f70ed Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 25 Jun 2014 22:54:37 +0200 Subject: [PATCH 022/424] Update CHANGELOG --- CHANGELOG.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index bcc8c6ec9..fbea54de4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,10 @@ ### 1.2.3 +- Fixed a bug where `rocketeer current` would fail to find the related task +- Fixed a bug where Artisan wouldn't be found even if at the default location +- Fixed a bug where ignition would fail when the default connection isn't `production` +- Fixed a bug where logs would be misplaced - Fixed a bug where tasks and events weren't properly loaded in Laravel ### 1.2.2 From 31eeb1693a9c1693bb4cd1311e1b54b067ade8a3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 25 Jun 2014 22:54:44 +0200 Subject: [PATCH 023/424] Quote environment flag --- src/Rocketeer/Traits/AbstractLocatorClass.php | 12 ++++++------ src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- tests/TestCases/ContainerTestCase.php | 2 ++ tests/TestCases/RocketeerTestCase.php | 13 +++++++++---- tests/Traits/BashModules/CoreTest.php | 16 ++++++++++++++++ 5 files changed, 35 insertions(+), 12 deletions(-) diff --git a/src/Rocketeer/Traits/AbstractLocatorClass.php b/src/Rocketeer/Traits/AbstractLocatorClass.php index cb9d54e60..4e859ee9b 100644 --- a/src/Rocketeer/Traits/AbstractLocatorClass.php +++ b/src/Rocketeer/Traits/AbstractLocatorClass.php @@ -15,12 +15,12 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * - * @property Illuminate\Console\Command command - * @property Illuminate\Remote\Connection remote - * @property \Rocketeer\ReleasesManager releasesManager - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Server server - * @property \Rocketeer\Traits\Scm scm + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Server server + * @property \Rocketeer\Traits\Scm scm * * @author Maxime Fabre */ diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 7e677eac9..06762aec3 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -245,7 +245,7 @@ protected function addCommandsToHistory($commands) * * @return array */ - protected function processCommands($commands) + public function processCommands($commands) { $stage = $this->rocketeer->getStage(); $separator = $this->server->getSeparator(); @@ -265,7 +265,7 @@ protected function processCommands($commands) // Add stage flag to Artisan commands if (Str::contains($command, 'artisan') and $stage) { - $command .= ' --env='.$stage; + $command .= ' --env="'.$stage.'"'; } } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 149fcb6a4..5905b5d0b 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -233,6 +233,8 @@ protected function swapConfig($config) /** * Mock the Remote component * + * @param null $mockedOutput + * * @return Mockery */ protected function getRemote($mockedOutput = null) diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 4b4bcc802..e4fea24e2 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -1,6 +1,7 @@ mock('rocketeer.releases', 'ReleasesManager', $expectations); } @@ -224,6 +225,10 @@ protected function usesComposer($uses = true) /** * Get a pretend Task to run bogus commands * + * @param string $task + * @param array $options + * @param array $expectations + * * @return Task */ protected function pretendTask($task = 'Deploy', $options = array(), array $expectations = array()) diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 932f8b648..25b5e18da 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -18,6 +18,7 @@ public function testCanCheckStatusOfACommand() ob_start(); $status = $this->task->checkStatus(null, 'error'); $output = ob_get_clean(); + $this->assertEquals('error'.PHP_EOL, $output); $this->assertFalse($status); } @@ -25,6 +26,7 @@ public function testCanCheckStatusOfACommand() public function testCanGetTimestampOffServer() { $timestamp = $this->task->getTimestamp(); + $this->assertEquals(date('YmdHis'), $timestamp); } @@ -35,4 +37,18 @@ public function testCanGetLocalTimestampIfError() $this->assertEquals(date('YmdHis'), $timestamp); } + + public function testDoesntAppendEnvironmentToStandardTasks() + { + $this->app['rocketeer.rocketeer']->setStage('staging'); + $commands = $this->pretendTask()->processCommands(array( + 'artisan something', + 'rm readme*', + )); + + $this->assertEquals(array( + 'artisan something --env="staging"', + 'rm readme*', + ), $commands); + } } From 50144bab616e05fc44f997691173eccd3939f91f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 25 Jun 2014 23:20:16 +0200 Subject: [PATCH 024/424] Close #221 - Add Rocketeer::getDetectedStage --- src/Rocketeer/Rocketeer.php | 14 ++++++++++++++ tests/RocketeerTest.php | 15 +++++++++++++++ 2 files changed, 29 insertions(+) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 0c97cc79a..82eaec019 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -164,6 +164,20 @@ public function getStages() return $this->getOption('stages.stages'); } + /** + * Returns what stage Rocketeer thinks he's in + * + * @return string + */ + public function getDetectedStage() + { + $application = $this->getApplicationName(); + $current = $this->app['path.base']; + preg_match('/'.$application.'\/([a-zA-Z0-9_-]+)\/releases\/([0-9]{14})/', $current, $matches); + + return isset($matches[1]) ? $matches[1] : $this->getStage(); + } + //////////////////////////////////////////////////////////////////// ///////////////////////////// APPLICATION ////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index a1ba2fa96..48cff8a6d 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -184,4 +184,19 @@ protected function expectRepositoryConfig($repository, $username, $password) ), )); } + + public function testRocketeerCanGuessWhichStageHesIn() + { + $this->app['path.base'] = '/home/www/foobar/production/releases/12345678901234/app'; + $stage = $this->app['rocketeer.rocketeer']->getDetectedStage(); + $this->assertEquals('production', $stage); + + $this->app['path.base'] = '/home/www/foobar/staging/releases/12345678901234/app'; + $stage = $this->app['rocketeer.rocketeer']->getDetectedStage(); + $this->assertEquals('staging', $stage); + + $this->app['path.base'] = '/home/www/foobar/releases/12345678901234/app'; + $stage = $this->app['rocketeer.rocketeer']->getDetectedStage(); + $this->assertEquals(false, $stage); + } } From 9eb1d2380b4963c8662e1104d6ebbd69c5586461 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 25 Jun 2014 23:43:35 +0200 Subject: [PATCH 025/424] Make detectedStage into a static --- src/Rocketeer/Rocketeer.php | 10 ++++++---- tests/RocketeerTest.php | 12 ++++++------ 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 82eaec019..2bb07851a 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -167,15 +167,17 @@ public function getStages() /** * Returns what stage Rocketeer thinks he's in * + * @param string $application + * @param string $path + * * @return string */ - public function getDetectedStage() + public static function getDetectedStage($application = 'application', $path = null) { - $application = $this->getApplicationName(); - $current = $this->app['path.base']; + $current = $path ?: realpath(__DIR__); preg_match('/'.$application.'\/([a-zA-Z0-9_-]+)\/releases\/([0-9]{14})/', $current, $matches); - return isset($matches[1]) ? $matches[1] : $this->getStage(); + return isset($matches[1]) ? $matches[1] : false; } //////////////////////////////////////////////////////////////////// diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 48cff8a6d..013a70fca 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -187,16 +187,16 @@ protected function expectRepositoryConfig($repository, $username, $password) public function testRocketeerCanGuessWhichStageHesIn() { - $this->app['path.base'] = '/home/www/foobar/production/releases/12345678901234/app'; - $stage = $this->app['rocketeer.rocketeer']->getDetectedStage(); + $path = '/home/www/foobar/production/releases/12345678901234/app'; + $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals('production', $stage); - $this->app['path.base'] = '/home/www/foobar/staging/releases/12345678901234/app'; - $stage = $this->app['rocketeer.rocketeer']->getDetectedStage(); + $path = '/home/www/foobar/staging/releases/12345678901234/app'; + $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals('staging', $stage); - $this->app['path.base'] = '/home/www/foobar/releases/12345678901234/app'; - $stage = $this->app['rocketeer.rocketeer']->getDetectedStage(); + $path = '/home/www/foobar/releases/12345678901234/app'; + $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals(false, $stage); } } From 1c21021f261ab814f20ab668596079bd4b4f75fc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 26 Jun 2014 00:36:19 +0200 Subject: [PATCH 026/424] Correctly check for HHVM extensions --- src/Rocketeer/Tasks/Check.php | 57 +++++++++++++++++++++++++++++++++++ tests/Tasks/CheckTest.php | 16 ++++++++++ 2 files changed, 73 insertions(+) diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 63f5ad45d..3491b1c5c 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -218,6 +218,50 @@ public function checkPhpExtension($extension) { $this->command->comment('Checking presence of '.$extension.' extension'); + // Check for HHVM and built-in extensions + if ($this->usesHhvm()) { + $this->extensions = array( + '_hhvm', + 'apache', + 'asio', + 'bcmath', + 'bz2', + 'ctype', + 'curl', + 'debugger', + 'fileinfo', + 'filter', + 'gd', + 'hash', + 'hh', + 'iconv', + 'icu', + 'imagick', + 'imap', + 'json', + 'mailparse', + 'mcrypt', + 'memcache', + 'memcached', + 'mysql', + 'odbc', + 'openssl', + 'pcre', + 'phar', + 'reflection', + 'session', + 'soap', + 'std', + 'stream', + 'thrift', + 'url', + 'wddx', + 'xdebug', + 'zip', + 'zlib', + ); + } + // Get the PHP extensions available if (!$this->extensions) { $this->extensions = (array) $this->run($this->php('-m'), false, true); @@ -225,4 +269,17 @@ public function checkPhpExtension($extension) return in_array($extension, $this->extensions); } + + /** + * Check if we're using HHVM in production + * + * @return bool + */ + public function usesHhvm() + { + $defined = $this->php('-r "echo defined(\'HHVM_VERSION\') ? \'true\' : \'false\';"'); + $defined = $this->runLast($defined); + + return $defined == 'true'; + } } diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index b0fdbbce9..4e75df39c 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -50,4 +50,20 @@ public function testCanCheckPhpExtensions() '{php} -m', )); } + + public function testCanCheckForHhvmExtensions() + { + $this->app['remote'] = $this->getRemote('true'); + $exists = $this->task('Check')->checkPhpExtension('_hhvm'); + + $this->assertTrue($exists); + } + + public function testCanCheckIfUsesHhvm() + { + $hhvm = $this->task('Check')->usesHhvm(); + $defined = defined('HHVM_VERSION'); + + $this->assertEquals($defined, $hhvm); + } } From 9ed8654272bcfc27a26fa4f9bc15d8067361e80e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 26 Jun 2014 00:43:32 +0200 Subject: [PATCH 027/424] Update CHANGELOG.md --- CHANGELOG.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index fbea54de4..e45a5217f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ ### 1.2.3 +- Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) +- Added support for checking of HHVM extensions - Fixed a bug where `rocketeer current` would fail to find the related task - Fixed a bug where Artisan wouldn't be found even if at the default location - Fixed a bug where ignition would fail when the default connection isn't `production` @@ -10,7 +12,7 @@ ### 1.2.2 -- **The Notifier plugin module not has a hook for before and after deployment** +- **The Notifier plugin module now has a hook for before and after deployment** - Add ability to disable composer completely - Add support for ssh-agent for secure connections - Fixed a bug that prevented the `--seed` option from working From 3ca9d5e3e7c7ac534b9c22ec493cacff52d5b1b6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 26 Jun 2014 00:53:21 +0200 Subject: [PATCH 028/424] Change my check --- src/Rocketeer/Tasks/Check.php | 7 ++++--- tests/Tasks/CheckTest.php | 2 +- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 3491b1c5c..399b20e54 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -277,9 +277,10 @@ public function checkPhpExtension($extension) */ public function usesHhvm() { - $defined = $this->php('-r "echo defined(\'HHVM_VERSION\') ? \'true\' : \'false\';"'); - $defined = $this->runLast($defined); + $version = $this->php('--version'); + $version = $this->runLast($version); + $version = strtolower($version); - return $defined == 'true'; + return strpos($version, 'hiphop') !== false; } } diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index 4e75df39c..90894bb05 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -53,7 +53,7 @@ public function testCanCheckPhpExtensions() public function testCanCheckForHhvmExtensions() { - $this->app['remote'] = $this->getRemote('true'); + $this->app['remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'); $exists = $this->task('Check')->checkPhpExtension('_hhvm'); $this->assertTrue($exists); From 02daa0f3b0d740ec39358f206e192640bbfbb79b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 20:38:25 +0200 Subject: [PATCH 029/424] Bump minimum requirement --- CHANGELOG.md | 3 +- composer.json | 18 ++--- composer.lock | 206 ++++++++++++++++++++++++-------------------------- 3 files changed, 110 insertions(+), 117 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e45a5217f..16b28cef7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,7 +1,8 @@ ### Changelog -### 1.2.3 +### 2.0.0 +- Minimum requirement is now PHP 5.4+ - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions - Fixed a bug where `rocketeer current` would fail to find the related task diff --git a/composer.json b/composer.json index 630e4a3b7..6ed463cfe 100644 --- a/composer.json +++ b/composer.json @@ -14,15 +14,15 @@ } ], "require": { - "php": ">=5.3.0", - "illuminate/support": "~4.1", - "illuminate/config": "~4.1", - "illuminate/console": "~4.1", - "illuminate/container": "~4.1", - "illuminate/filesystem": "~4.1", - "illuminate/events": "~4.1", - "illuminate/remote": "~4.1", - "illuminate/log": "~4.1" + "php": ">=5.4.0", + "illuminate/support": "~4.2", + "illuminate/config": "~4.2", + "illuminate/console": "~4.2", + "illuminate/container": "~4.2", + "illuminate/filesystem": "~4.2", + "illuminate/events": "~4.2", + "illuminate/remote": "~4.2", + "illuminate/log": "~4.2" }, "require-dev": { "phpunit/phpunit": "~4.0", diff --git a/composer.lock b/composer.lock index b5a2e478b..2131b7e49 100644 --- a/composer.lock +++ b/composer.lock @@ -4,21 +4,21 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "6eb01d88d5864a31f00cae46f75f3366", + "hash": "e8764dc76959a981db6664c1eb87c737", "packages": [ { "name": "illuminate/config", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Config", "source": { "type": "git", "url": "https://github.com/illuminate/config.git", - "reference": "33396894a35428074e8c41583bf308a7c019610a" + "reference": "03de040d413800bd3c672a484202bc8b355b6f9b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/config/zipball/33396894a35428074e8c41583bf308a7c019610a", - "reference": "33396894a35428074e8c41583bf308a7c019610a", + "url": "https://api.github.com/repos/illuminate/config/zipball/03de040d413800bd3c672a484202bc8b355b6f9b", + "reference": "03de040d413800bd3c672a484202bc8b355b6f9b", "shasum": "" }, "require": { @@ -44,26 +44,24 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], - "time": "2014-06-08 19:09:40" + "time": "2014-07-15 11:11:21" }, { "name": "illuminate/console", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Console", "source": { "type": "git", "url": "https://github.com/illuminate/console.git", - "reference": "de40c341eeccb1619106e8e8b954eea239aceb68" + "reference": "2cfb8c65ea03c44d27ee02acf367de5b9b62f1c9" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/console/zipball/de40c341eeccb1619106e8e8b954eea239aceb68", - "reference": "de40c341eeccb1619106e8e8b954eea239aceb68", + "url": "https://api.github.com/repos/illuminate/console/zipball/2cfb8c65ea03c44d27ee02acf367de5b9b62f1c9", + "reference": "2cfb8c65ea03c44d27ee02acf367de5b9b62f1c9", "shasum": "" }, "require": { @@ -88,26 +86,24 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], - "time": "2014-05-23 16:40:19" + "time": "2014-07-16 03:00:55" }, { "name": "illuminate/container", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Container", "source": { "type": "git", "url": "https://github.com/illuminate/container.git", - "reference": "15d85ddb8b56fef54db5941c9b112cae069606ae" + "reference": "33f3dbfc21eafa2a71f64c156955e618142afc3c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/container/zipball/15d85ddb8b56fef54db5941c9b112cae069606ae", - "reference": "15d85ddb8b56fef54db5941c9b112cae069606ae", + "url": "https://api.github.com/repos/illuminate/container/zipball/33f3dbfc21eafa2a71f64c156955e618142afc3c", + "reference": "33f3dbfc21eafa2a71f64c156955e618142afc3c", "shasum": "" }, "require": { @@ -131,16 +127,14 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], - "time": "2014-05-23 16:40:19" + "time": "2014-07-18 22:26:34" }, { "name": "illuminate/events", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Events", "source": { "type": "git", @@ -176,16 +170,14 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], "time": "2014-06-06 13:58:46" }, { "name": "illuminate/filesystem", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Filesystem", "source": { "type": "git", @@ -221,26 +213,24 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], "time": "2014-05-23 16:40:19" }, { "name": "illuminate/log", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Log", "source": { "type": "git", "url": "https://github.com/illuminate/log.git", - "reference": "9b3ae8d7159ae45f3db03bf2a83684c7f2b88474" + "reference": "6f317b78f316862a21e386ca63dd9a55873a81f4" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/log/zipball/9b3ae8d7159ae45f3db03bf2a83684c7f2b88474", - "reference": "9b3ae8d7159ae45f3db03bf2a83684c7f2b88474", + "url": "https://api.github.com/repos/illuminate/log/zipball/6f317b78f316862a21e386ca63dd9a55873a81f4", + "reference": "6f317b78f316862a21e386ca63dd9a55873a81f4", "shasum": "" }, "require": { @@ -269,26 +259,24 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], - "time": "2014-05-23 16:40:19" + "time": "2014-07-21 19:47:50" }, { "name": "illuminate/remote", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Remote", "source": { "type": "git", "url": "https://github.com/illuminate/remote.git", - "reference": "7ba42ea5f526e665062b889632195b947da03d32" + "reference": "2d170349d127e85aac08d850c823c2029e60af36" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/remote/zipball/7ba42ea5f526e665062b889632195b947da03d32", - "reference": "7ba42ea5f526e665062b889632195b947da03d32", + "url": "https://api.github.com/repos/illuminate/remote/zipball/2d170349d127e85aac08d850c823c2029e60af36", + "reference": "2d170349d127e85aac08d850c823c2029e60af36", "shasum": "" }, "require": { @@ -318,26 +306,24 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], - "time": "2014-05-25 01:46:11" + "time": "2014-07-17 20:08:16" }, { "name": "illuminate/support", - "version": "v4.2.4", + "version": "v4.2.7", "target-dir": "Illuminate/Support", "source": { "type": "git", "url": "https://github.com/illuminate/support.git", - "reference": "976bdc0f42e9efd3dfa2e0eba11aba48a97113ac" + "reference": "b3d84fa93aa3f2081a935158f860de8308d62d5a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/support/zipball/976bdc0f42e9efd3dfa2e0eba11aba48a97113ac", - "reference": "976bdc0f42e9efd3dfa2e0eba11aba48a97113ac", + "url": "https://api.github.com/repos/illuminate/support/zipball/b3d84fa93aa3f2081a935158f860de8308d62d5a", + "reference": "b3d84fa93aa3f2081a935158f860de8308d62d5a", "shasum": "" }, "require": { @@ -368,12 +354,10 @@ "authors": [ { "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com", - "homepage": "https://github.com/taylorotwell", - "role": "Creator of Laravel" + "email": "taylorotwell@gmail.com" } ], - "time": "2014-06-13 20:42:27" + "time": "2014-07-21 21:14:59" }, { "name": "monolog/monolog", @@ -445,22 +429,24 @@ }, { "name": "phpseclib/phpseclib", - "version": "0.3.6", + "version": "0.3.7", "source": { "type": "git", "url": "https://github.com/phpseclib/phpseclib.git", - "reference": "0ea31d9b65d49a8661e93bec19f44e989bd34c69" + "reference": "8b8c62f278e363b75ddcacaf5803710232fbd3e4" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpseclib/phpseclib/zipball/0ea31d9b65d49a8661e93bec19f44e989bd34c69", - "reference": "0ea31d9b65d49a8661e93bec19f44e989bd34c69", + "url": "https://api.github.com/repos/phpseclib/phpseclib/zipball/8b8c62f278e363b75ddcacaf5803710232fbd3e4", + "reference": "8b8c62f278e363b75ddcacaf5803710232fbd3e4", "shasum": "" }, "require": { "php": ">=5.0.0" }, "require-dev": { + "phing/phing": "2.7.*", + "phpunit/phpunit": "4.0.*", "squizlabs/php_codesniffer": "1.*" }, "suggest": { @@ -536,7 +522,7 @@ "x.509", "x509" ], - "time": "2014-02-28 16:05:05" + "time": "2014-07-05 16:36:21" }, { "name": "psr/log", @@ -578,17 +564,17 @@ }, { "name": "symfony/console", - "version": "v2.5.0", + "version": "v2.5.2", "target-dir": "Symfony/Component/Console", "source": { "type": "git", "url": "https://github.com/symfony/Console.git", - "reference": "ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c" + "reference": "386fa63407805959bd2c5fe540294721ad4224c8" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Console/zipball/ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c", - "reference": "ef4ca73b0b3a10cbac653d3ca482d0cdd4502b2c", + "url": "https://api.github.com/repos/symfony/Console/zipball/386fa63407805959bd2c5fe540294721ad4224c8", + "reference": "386fa63407805959bd2c5fe540294721ad4224c8", "shasum": "" }, "require": { @@ -631,21 +617,21 @@ ], "description": "Symfony Console Component", "homepage": "http://symfony.com", - "time": "2014-05-22 08:54:24" + "time": "2014-07-15 14:15:12" }, { "name": "symfony/finder", - "version": "v2.5.0", + "version": "v2.5.2", "target-dir": "Symfony/Component/Finder", "source": { "type": "git", "url": "https://github.com/symfony/Finder.git", - "reference": "307aad2c541bbdf43183043645e186ef2cd6b973" + "reference": "576d8f69feec477067e91b6bd0367c113e76a1a0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Finder/zipball/307aad2c541bbdf43183043645e186ef2cd6b973", - "reference": "307aad2c541bbdf43183043645e186ef2cd6b973", + "url": "https://api.github.com/repos/symfony/Finder/zipball/576d8f69feec477067e91b6bd0367c113e76a1a0", + "reference": "576d8f69feec477067e91b6bd0367c113e76a1a0", "shasum": "" }, "require": { @@ -680,7 +666,7 @@ ], "description": "Symfony Finder Component", "homepage": "http://symfony.com", - "time": "2014-05-22 13:47:45" + "time": "2014-07-15 14:15:12" } ], "packages-dev": [ @@ -733,7 +719,7 @@ { "name": "Kevin Herrera", "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io", + "homepage": "http://kevin.herrera.io/", "role": "Developer" } ], @@ -812,23 +798,23 @@ }, { "name": "nesbot/carbon", - "version": "1.9.0", + "version": "1.10.0", "source": { "type": "git", "url": "https://github.com/briannesbitt/Carbon.git", - "reference": "b94de7192b01d0e80794eae984dcc773220ab0dc" + "reference": "9b42a1aec56011c2ac4d75c0ddad0794762344fc" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/b94de7192b01d0e80794eae984dcc773220ab0dc", - "reference": "b94de7192b01d0e80794eae984dcc773220ab0dc", + "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/9b42a1aec56011c2ac4d75c0ddad0794762344fc", + "reference": "9b42a1aec56011c2ac4d75c0ddad0794762344fc", "shasum": "" }, "require": { "php": ">=5.3.0" }, "require-dev": { - "phpunit/phpunit": "3.7.*" + "phpunit/phpunit": "~4.0" }, "type": "library", "autoload": { @@ -854,20 +840,20 @@ "datetime", "time" ], - "time": "2014-05-13 02:29:30" + "time": "2014-07-18 03:44:47" }, { "name": "patchwork/utf8", - "version": "v1.1.24", + "version": "v1.1.25", "source": { "type": "git", "url": "https://github.com/nicolas-grekas/Patchwork-UTF8.git", - "reference": "40f552c019956f446553b19f7de2da2f9c74d730" + "reference": "2d43bd047b120279511d45e76e61c5a9812d9a83" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/nicolas-grekas/Patchwork-UTF8/zipball/40f552c019956f446553b19f7de2da2f9c74d730", - "reference": "40f552c019956f446553b19f7de2da2f9c74d730", + "url": "https://api.github.com/repos/nicolas-grekas/Patchwork-UTF8/zipball/2d43bd047b120279511d45e76e61c5a9812d9a83", + "reference": "2d43bd047b120279511d45e76e61c5a9812d9a83", "shasum": "" }, "require": { @@ -880,6 +866,11 @@ "ext-mbstring": "Use Mbstring for best performance" }, "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.1-dev" + } + }, "autoload": { "psr-0": { "Patchwork": "class/", @@ -905,7 +896,7 @@ "utf-8", "utf8" ], - "time": "2014-06-17 08:23:06" + "time": "2014-08-05 08:00:32" }, { "name": "phine/exception", @@ -946,7 +937,7 @@ { "name": "Kevin Herrera", "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io", + "homepage": "http://kevin.herrera.io/", "role": "Developer" } ], @@ -997,7 +988,7 @@ { "name": "Kevin Herrera", "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io", + "homepage": "http://kevin.herrera.io/", "role": "Developer" } ], @@ -1012,16 +1003,16 @@ }, { "name": "phpunit/php-code-coverage", - "version": "2.0.8", + "version": "2.0.9", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/php-code-coverage.git", - "reference": "58401826c8cfc8fd689b60026e91c337df374bca" + "reference": "ed8ac99ce38c3fd134128c898f7ca74665abef7f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/58401826c8cfc8fd689b60026e91c337df374bca", - "reference": "58401826c8cfc8fd689b60026e91c337df374bca", + "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/ed8ac99ce38c3fd134128c898f7ca74665abef7f", + "reference": "ed8ac99ce38c3fd134128c898f7ca74665abef7f", "shasum": "" }, "require": { @@ -1073,7 +1064,7 @@ "testing", "xunit" ], - "time": "2014-05-26 14:55:24" + "time": "2014-06-29 08:14:40" }, { "name": "phpunit/php-file-iterator", @@ -1260,16 +1251,16 @@ }, { "name": "phpunit/phpunit", - "version": "4.1.3", + "version": "4.1.4", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "939cb801b3b2aa253aedd0b279f40bb8f35cec91" + "reference": "a71c4842c5fb836d8b200624583b859ec34e8a26" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/939cb801b3b2aa253aedd0b279f40bb8f35cec91", - "reference": "939cb801b3b2aa253aedd0b279f40bb8f35cec91", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/a71c4842c5fb836d8b200624583b859ec34e8a26", + "reference": "a71c4842c5fb836d8b200624583b859ec34e8a26", "shasum": "" }, "require": { @@ -1330,20 +1321,20 @@ "testing", "xunit" ], - "time": "2014-06-11 14:15:47" + "time": "2014-07-18 07:15:58" }, { "name": "phpunit/phpunit-mock-objects", - "version": "2.1.4", + "version": "2.1.5", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", - "reference": "1a894a16b6c15fcdc5ef2b110f0e6233952c9b0f" + "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/1a894a16b6c15fcdc5ef2b110f0e6233952c9b0f", - "reference": "1a894a16b6c15fcdc5ef2b110f0e6233952c9b0f", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/7878b9c41edb3afab92b85edf5f0981014a2713a", + "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a", "shasum": "" }, "require": { @@ -1387,7 +1378,7 @@ "mock", "xunit" ], - "time": "2014-06-07 16:22:57" + "time": "2014-06-12 07:22:15" }, { "name": "sebastian/comparator", @@ -1659,17 +1650,17 @@ }, { "name": "symfony/yaml", - "version": "v2.5.0", + "version": "v2.5.2", "target-dir": "Symfony/Component/Yaml", "source": { "type": "git", "url": "https://github.com/symfony/Yaml.git", - "reference": "b4b09c68ec2f2727574544ef0173684281a5033c" + "reference": "f868ecdbcc0276b6158dfbf08b9e98ce07f014e1" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Yaml/zipball/b4b09c68ec2f2727574544ef0173684281a5033c", - "reference": "b4b09c68ec2f2727574544ef0173684281a5033c", + "url": "https://api.github.com/repos/symfony/Yaml/zipball/f868ecdbcc0276b6158dfbf08b9e98ce07f014e1", + "reference": "f868ecdbcc0276b6158dfbf08b9e98ce07f014e1", "shasum": "" }, "require": { @@ -1704,14 +1695,15 @@ ], "description": "Symfony Yaml Component", "homepage": "http://symfony.com", - "time": "2014-05-16 14:25:18" + "time": "2014-07-09 09:05:48" } ], "aliases": [], "minimum-stability": "stable", "stability-flags": [], + "prefer-stable": false, "platform": { - "php": ">=5.3.0" + "php": ">=5.4.0" }, "platform-dev": [] } From 0b678ea0a557d370d63d5ba872f58096f9d303ce Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 21:46:30 +0200 Subject: [PATCH 030/424] Update version constant --- composer.json | 2 +- src/Rocketeer/Rocketeer.php | 2 +- src/Rocketeer/TasksQueue.php | 11 ++++------- 3 files changed, 6 insertions(+), 9 deletions(-) diff --git a/composer.json b/composer.json index 6ed463cfe..abb6bea60 100644 --- a/composer.json +++ b/composer.json @@ -46,7 +46,7 @@ }, "extra": { "branch-alias": { - "dev-develop": "1.3-dev" + "dev-develop": "2.0-dev" } } } diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 2bb07851a..a6f30cba8 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -54,7 +54,7 @@ class Rocketeer * * @var string */ - const VERSION = '1.2.3'; + const VERSION = '2.0.0'; /** * Build a new ReleasesManager diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index 10105fbac..3e86ead98 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -125,8 +125,8 @@ public function run(array $tasks) /** * Run the queue, taking into account the stage * - * @param array $tasks - * @param string $stage + * @param \Rocketeer\Traits\Task[] $tasks + * @param string $stage * * @return boolean */ @@ -191,9 +191,7 @@ public function buildTask($task, $name = null) // If we provided a Closure or a string command, build it if ($task instanceof Closure or $this->isStringCommand($task)) { $task = $this->buildTaskFromClosure($task); - } - - // Check for an existing container binding + } // Check for an existing container binding elseif (isset($handle) and $this->app->bound($handle)) { return $this->app[$handle]; } @@ -227,8 +225,7 @@ public function buildTaskFromClosure($task) $closure = function ($task) use ($stringTask) { return $task->runForCurrentRelease($stringTask); }; - - // If the User provided a Closure + // If the User provided a Closure } elseif ($task instanceof Closure) { $closure = $task; } From f7fe7ee778eb9bf04175d5014fa5ddcdf8850744 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 21:51:25 +0200 Subject: [PATCH 031/424] Close #253 - Cache the fetched releases for faster deploys --- src/Rocketeer/ReleasesManager.php | 20 ++++++++++++++++---- src/Rocketeer/RocketeerServiceProvider.php | 2 +- tests/Console/ConsoleTest.php | 2 +- tests/ReleasesManagerTest.php | 14 ++++++++++++++ 4 files changed, 32 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index b876dafdd..931de9f37 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -32,6 +32,13 @@ class ReleasesManager */ protected $state = array(); + /** + * Cache of the releases + * + * @type array + */ + public $releases = array(); + /** * Build a new ReleasesManager * @@ -55,12 +62,17 @@ public function __construct(Container $app) public function getReleases() { // Get releases on server - $releases = $this->app['rocketeer.bash']->listContents($this->getReleasesPath()); - if (is_array($releases)) { - rsort($releases); + if (!$this->releases) { + $releases = $this->getReleasesPath(); + $releases = $this->app['rocketeer.bash']->listContents($releases); + if (is_array($releases)) { + rsort($releases); + } + + $this->releases = $releases; } - return $releases; + return $this->releases; } /** diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index d1d27230d..0ef06001e 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -177,7 +177,7 @@ public function bindClasses(Container $app) return new Rocketeer($app); }); - $app->bind('rocketeer.releases', function ($app) { + $app->singleton('rocketeer.releases', function ($app) { return new ReleasesManager($app); }); diff --git a/tests/Console/ConsoleTest.php b/tests/Console/ConsoleTest.php index 60f6d2d18..d818f5fab 100644 --- a/tests/Console/ConsoleTest.php +++ b/tests/Console/ConsoleTest.php @@ -7,7 +7,7 @@ class ConsoleTest extends RocketeerTestCase { public function testCanRunStandaloneConsole() { - $console = exec('php bin/rocketeer --version'); + $console = exec('php bin/rocketeer --version --no-ansi'); $this->assertContains('Rocketeer version', $console); } diff --git a/tests/ReleasesManagerTest.php b/tests/ReleasesManagerTest.php index 7d4357afa..927dcfaf1 100644 --- a/tests/ReleasesManagerTest.php +++ b/tests/ReleasesManagerTest.php @@ -131,4 +131,18 @@ public function testCanGetFolderInRelease() $this->assertEquals($this->server.'/releases/20000000000000/app/storage', $folder); } + + public function testDoesntPingForReleasesAllTheFuckingTime() + { + $this->mock('rocketeer.bash', 'Rocketeer\Bash', function ($mock) { + return $mock + ->shouldReceive('getFile')->times(1) + ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([1, 2, 3]); + }); + + $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->app['rocketeer.releases']->getNonCurrentReleases(); + } } From eef283260a595e40cc3dad21f7435d50d47c73c4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 21:56:07 +0200 Subject: [PATCH 032/424] Trim output from polluting strings --- src/Rocketeer/Traits/BashModules/Core.php | 3 +++ tests/Traits/BashModules/CoreTest.php | 8 ++++++++ 2 files changed, 11 insertions(+) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 06762aec3..a68b28fd5 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -283,6 +283,9 @@ public function processCommands($commands) */ protected function processOutput($output, $array = false, $trim = true) { + // Remove polluting strings + $output = str_replace('stdin: is not a tty', null, $output); + // Explode output if necessary if ($array) { $output = explode($this->server->getLineEndings(), $output); diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 25b5e18da..819a2eeac 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -51,4 +51,12 @@ public function testDoesntAppendEnvironmentToStandardTasks() 'rm readme*', ), $commands); } + + public function testCanRemoveCommonPollutingOutput() + { + $this->app['remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); + $result = $this->app['rocketeer.bash']->run('ls'); + + $this->assertEquals('something', $result); + } } From 3f880c8b5f88d199549323ab0b795a9c6ecea16f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 22:08:53 +0200 Subject: [PATCH 033/424] Close #247 - Reboot events when switching connection --- src/Rocketeer/Rocketeer.php | 17 ++++++++------- src/Rocketeer/TasksHandler.php | 6 +++--- tests/RocketeerTest.php | 30 +++++++++++++-------------- tests/TasksHandlerTest.php | 24 +++++++++++++++++++++ tests/TestCases/RocketeerTestCase.php | 2 +- 5 files changed, 53 insertions(+), 26 deletions(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index a6f30cba8..2cbe7d6cc 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -174,7 +174,7 @@ public function getStages() */ public static function getDetectedStage($application = 'application', $path = null) { - $current = $path ?: realpath(__DIR__); + $current = $path ?: realpath(__DIR__); preg_match('/'.$application.'\/([a-zA-Z0-9_-]+)\/releases\/([0-9]{14})/', $current, $matches); return isset($matches[1]) ? $matches[1] : false; @@ -338,10 +338,16 @@ public function setConnections($connections) */ public function setConnection($connection) { - if ($this->isValidConnection($connection)) { - $this->connection = $connection; - $this->app['config']->set('remote.default', $connection); + if (!$this->isValidConnection($connection)) { + return; } + + // Set the connection + $this->connection = $connection; + $this->app['config']->set('remote.default', $connection); + + // Update events + $this->app['rocketeer.tasks']->registerConfiguredEvents(); } /** @@ -520,7 +526,6 @@ public function getRocketeerConfigFolder() * Get the path to the users home folder * * @throws Exception - * * @return string */ public function getUserHomeFolder() @@ -528,11 +533,9 @@ public function getUserHomeFolder() // Get home folder if available (Unix) if (!empty($_SERVER['HOME'])) { return $_SERVER['HOME']; - // Else use the home drive (Windows) } elseif (!empty($_SERVER['HOMEDRIVE']) && !empty($_SERVER['HOMEPATH'])) { return $_SERVER['HOMEDRIVE'].$_SERVER['HOMEPATH']; - } else { throw new Exception('Cannot determine user home directory.'); } diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index 6d0f9d721..bb30520d1 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -204,9 +204,9 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) /** * Get all of a task's listeners * - * @param Task $task - * @param string $event - * @param boolean $flatten + * @param string|Task $task + * @param string $event + * @param boolean $flatten * * @return array */ diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 013a70fca..e0a519558 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -161,6 +161,21 @@ public function testCanUseRecursiveConnectionConfiguration() $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); } + public function testRocketeerCanGuessWhichStageHesIn() + { + $path = '/home/www/foobar/production/releases/12345678901234/app'; + $stage = Rocketeer::getDetectedStage('foobar', $path); + $this->assertEquals('production', $stage); + + $path = '/home/www/foobar/staging/releases/12345678901234/app'; + $stage = Rocketeer::getDetectedStage('foobar', $path); + $this->assertEquals('staging', $stage); + + $path = '/home/www/foobar/releases/12345678901234/app'; + $stage = Rocketeer::getDetectedStage('foobar', $path); + $this->assertEquals(false, $stage); + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// //////////////////////////////////////////////////////////////////// @@ -184,19 +199,4 @@ protected function expectRepositoryConfig($repository, $username, $password) ), )); } - - public function testRocketeerCanGuessWhichStageHesIn() - { - $path = '/home/www/foobar/production/releases/12345678901234/app'; - $stage = Rocketeer::getDetectedStage('foobar', $path); - $this->assertEquals('production', $stage); - - $path = '/home/www/foobar/staging/releases/12345678901234/app'; - $stage = Rocketeer::getDetectedStage('foobar', $path); - $this->assertEquals('staging', $stage); - - $path = '/home/www/foobar/releases/12345678901234/app'; - $stage = Rocketeer::getDetectedStage('foobar', $path); - $this->assertEquals(false, $stage); - } } diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index e34f092b3..d6c54bc2a 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -118,4 +118,28 @@ public function testCanBuildQueueFromConfigHook() $this->assertEquals($tasks, $listeners); } + + public function testCanHaveCustomConnectionHooks() + { + $tasks = array( + 'npm install', + 'bower install', + ); + + $this->swapConfig(array( + 'rocketeer::default' => 'production', + 'rocketeer::hooks' => [], + 'rocketeer::on.connections.staging.hooks' => ['after' => ['deploy' => $tasks]], + )); + $this->tasksQueue()->registerConfiguredEvents(); + + $this->app['rocketeer.rocketeer']->setConnection('production'); + $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + $this->assertEmpty($events); + + $this->app['rocketeer.rocketeer']->setConnection('staging'); + $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + + $this->assertEquals($tasks, $events); + } } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index e4fea24e2..bfe0444d5 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -269,7 +269,7 @@ protected function task($task = null, $command = null) /** * Get TasksQueue instance * - * @return \Rocketeer\TasksQueue + * @return \Rocketeer\TasksHandler */ protected function tasksQueue() { From bb2a64e9c36564bbd36c0554ae1f9f9729ec24d6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 23:28:29 +0200 Subject: [PATCH 034/424] Close #250 - Ensure storage doesn't forget config connections --- src/Rocketeer/Plugins/Notifier.php | 2 +- src/Rocketeer/Rocketeer.php | 24 +++++++++++++----------- tests/RocketeerTest.php | 21 ++++++++++++++++++++- 3 files changed, 34 insertions(+), 13 deletions(-) diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 77f77ddad..26830f969 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -71,7 +71,7 @@ protected function getComponents() $connection = $this->rocketeer->getConnection(); // Get hostname - $credentials = array_get($this->rocketeer->getAvailableConnections(), $connection); + $credentials = $this->rocketeer->getAvailableConnections($connection); $host = array_get($credentials, 'host'); if ($stage) { $connection = $stage.'@'.$connection; diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 2cbe7d6cc..fd3cb1c93 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -197,23 +197,25 @@ public function needsCredentials() /** * Get the available connections * + * @param string|null $connection A connection to fetch from the resulting array + * * @return array */ - public function getAvailableConnections() + public function getAvailableConnections($connection = null) { - $connections = $this->app['rocketeer.server']->getValue('connections'); + // Fetch stored credentials + $storage = (array) $this->app['rocketeer.server']->getValue('connections'); - // Fetch from config file - if (!$connections) { - $connections = $this->app['config']->get('rocketeer::connections'); - } + // Merge with defaults from config file + $configuration = (array) $this->app['config']->get('rocketeer::connections'); // Fetch from remote file - if (!$connections or array_get($connections, 'production.host') == '{host}') { - $connections = $this->app['config']->get('remote.connections'); - } + $remote = (array) $this->app['config']->get('remote.connections'); - return $connections; + // Merge configurations + $storage = array_replace_recursive($remote, $configuration, $storage); + + return $connection ? array_get($storage, $connection) : $storage; } /** @@ -292,7 +294,7 @@ public function getConnectionCredentials($connection = null) { $connection = $connection ?: $this->getConnection(); - return array_get($this->getAvailableConnections(), $connection, array()); + return $this->getAvailableConnections($connection); } /** diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index e0a519558..6f0312e82 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -16,7 +16,7 @@ public function testCanGetAvailableConnections() $this->app['rocketeer.server']->setValue('connections.custom.username', 'foobar'); $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); - $this->assertEquals(array('custom'), array_keys($connections)); + $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); } public function testCanGetCurrentConnection() @@ -176,6 +176,25 @@ public function testRocketeerCanGuessWhichStageHesIn() $this->assertEquals(false, $stage); } + public function testFillsConnectionCredentialsHoles() + { + $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); + $this->assertArrayHasKey('production', $connections); + + $this->app['rocketeer.server']->setValue('connections', array( + 'staging' => array( + 'host' => 'foobar', + 'username' => 'user', + 'password' => '', + 'keyphrase' => '', + 'key' => '/Users/user/.ssh/id_rsa', + 'agent' => '' + ), + )); + $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); + $this->assertArrayHasKey('production', $connections); + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// //////////////////////////////////////////////////////////////////// From c94da01fe2aeed94d6909c6e487785aeb0c87da3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 23:48:54 +0200 Subject: [PATCH 035/424] Move handling of connections and stages to a dedicated class --- CHANGELOG.md | 3 + src/Rocketeer/ConnectionsHandler.php | 353 ++++++++++++++++++ src/Rocketeer/LogsHandler.php | 2 +- src/Rocketeer/Plugins/Notifier.php | 8 +- src/Rocketeer/ReleasesManager.php | 4 +- src/Rocketeer/Rocketeer.php | 342 +---------------- src/Rocketeer/RocketeerServiceProvider.php | 6 +- src/Rocketeer/Scm/Git.php | 4 +- src/Rocketeer/Scm/Svn.php | 2 +- src/Rocketeer/Tasks/CurrentRelease.php | 2 +- src/Rocketeer/Tasks/Ignite.php | 6 +- src/Rocketeer/Tasks/Setup.php | 8 +- src/Rocketeer/TasksQueue.php | 10 +- src/Rocketeer/Traits/AbstractLocatorClass.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 2 +- src/Rocketeer/Traits/BashModules/Flow.php | 2 +- tests/LogsHandlerTest.php | 4 +- tests/Plugins/NotifierTest.php | 2 +- tests/RocketeerTest.php | 44 +-- tests/Scm/GitTest.php | 9 +- tests/Tasks/SetupTest.php | 6 +- tests/TasksHandlerTest.php | 8 +- tests/TasksQueueTest.php | 4 +- tests/TestCases/ContainerTestCase.php | 2 +- tests/Traits/BashModules/CoreTest.php | 2 +- 25 files changed, 445 insertions(+), 392 deletions(-) create mode 100644 src/Rocketeer/ConnectionsHandler.php diff --git a/CHANGELOG.md b/CHANGELOG.md index 16b28cef7..de84e81cc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,9 @@ - Fixed a bug where ignition would fail when the default connection isn't `production` - Fixed a bug where logs would be misplaced - Fixed a bug where tasks and events weren't properly loaded in Laravel +- Fixed a bug where releases would be asked to the server at each command, slowing down deployments +- Fixed a bug where events wouldn't be properly rebooted when using connections other than the default ones +- Fixed a bug where Rocketeer would ask for credentials again after switching connection ### 1.2.2 diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php new file mode 100644 index 000000000..2d3ff5615 --- /dev/null +++ b/src/Rocketeer/ConnectionsHandler.php @@ -0,0 +1,353 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer; + +use Exception; +use Illuminate\Container\Container; +use Illuminate\Support\Str; + +/** + * Handles, get and return, the various connections/stages + * and their credentials + * + * @author Maxime Fabre + */ +class ConnectionsHandler +{ + /** + * The IoC Container + * + * @var Container + */ + protected $app; + + /** + * The current stage + * + * @var string + */ + protected $stage; + + /** + * The connections to use + * + * @var array + */ + protected $connections; + + /** + * The current connection + * + * @var string + */ + protected $connection; + + /** + * Build a new ReleasesManager + * + * @param Container $app + */ + public function __construct(Container $app) + { + $this->app = $app; + } + + //////////////////////////////////////////////////////////////////// + //////////////////////////////// STAGES //////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Set the stage Tasks will execute on + * + * @param string $stage + * + * @return void + */ + public function setStage($stage) + { + $this->stage = $stage; + + // If we do have a stage, cleanup previous events + if ($stage) { + $this->app['rocketeer.tasks']->registerConfiguredEvents(); + } + } + + /** + * Get the current stage + * + * @return string + */ + public function getStage() + { + return $this->stage; + } + + /** + * Get the various stages provided by the User + * + * @return array + */ + public function getStages() + { + return $this->app['rocketeer.rocketeer']->getOption('stages.stages'); + } + + //////////////////////////////////////////////////////////////////// + ///////////////////////////// APPLICATION ////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Whether the repository used is using SSH or HTTPS + * + * @return boolean + */ + public function needsCredentials() + { + return Str::contains($this->getRepository(), 'https://'); + } + + /** + * Get the available connections + * + * @param string|null $connection A connection to fetch from the resulting array + * + * @return array + */ + public function getAvailableConnections($connection = null) + { + // Fetch stored credentials + $storage = (array) $this->app['rocketeer.server']->getValue('connections'); + + // Merge with defaults from config file + $configuration = (array) $this->app['config']->get('rocketeer::connections'); + + // Fetch from remote file + $remote = (array) $this->app['config']->get('remote.connections'); + + // Merge configurations + $storage = array_replace_recursive($remote, $configuration, $storage); + + return $connection ? array_get($storage, $connection) : $storage; + } + + /** + * Check if a connection has credentials related to it + * + * @param string $connection + * + * @return boolean + */ + public function isValidConnection($connection) + { + $available = (array) $this->getAvailableConnections(); + + return array_key_exists($connection, $available); + } + + /** + * Get the connection in use + * + * @return string + */ + public function getConnections() + { + // Get cached resolved connections + if ($this->connections) { + return $this->connections; + } + + // Get all and defaults + $connections = (array) $this->app['config']->get('rocketeer::default'); + $default = $this->app['config']->get('remote.default'); + + // Remove invalid connections + $instance = $this; + $connections = array_filter($connections, function ($value) use ($instance) { + return $instance->isValidConnection($value); + }); + + // Return default if no active connection(s) set + if (empty($connections) and $default) { + return array($default); + } + + // Set current connection as default + $this->connections = $connections; + + return $connections; + } + + /** + * Get the active connection + * + * @return string + */ + public function getConnection() + { + // Get cached resolved connection + if ($this->connection) { + return $this->connection; + } + + $connection = array_get($this->getConnections(), 0); + $this->connection = $connection; + + return $this->connection; + } + + /** + * Get the credentials for a particular connection + * + * @param string $connection + * + * @return array + */ + public function getConnectionCredentials($connection = null) + { + $connection = $connection ?: $this->getConnection(); + + return $this->getAvailableConnections($connection); + } + + /** + * Sync Rocketeer's credentials with Laravel's + * + * @param string $connection + * @param array $credentials + * + * @return void + */ + public function syncConnectionCredentials($connection = null, array $credentials = array()) + { + // Store credentials if any + if ($credentials) { + $this->app['rocketeer.server']->setValue('connections.'.$connection, $credentials); + } + + // Get connection + $connection = $connection ?: $this->getConnection(); + $credentials = $this->getConnectionCredentials($connection); + + $this->app['config']->set('remote.connections.'.$connection, $credentials); + } + + /** + * Set the active connections + * + * @param string|array $connections + */ + public function setConnections($connections) + { + if (!is_array($connections)) { + $connections = explode(',', $connections); + } + + $this->connections = $connections; + } + + /** + * Set the current connection + * + * @param string $connection + */ + public function setConnection($connection) + { + if (!$this->isValidConnection($connection)) { + return; + } + + // Set the connection + $this->connection = $connection; + $this->app['config']->set('remote.default', $connection); + + // Update events + $this->app['rocketeer.tasks']->registerConfiguredEvents(); + } + + /** + * Flush active connection(s) + * + * @return void + */ + public function disconnect() + { + $this->connection = null; + $this->connections = null; + } + + //////////////////////////////////////////////////////////////////// + /////////////////////////// GIT REPOSITORY ///////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Get the credentials for the repository + * + * @return array + */ + public function getCredentials() + { + $credentials = $this->app['rocketeer.server']->getValue('credentials'); + if (!$credentials) { + $credentials = $this->app['rocketeer.rocketeer']->getOption('scm'); + } + + // Cast to array + $credentials = (array) $credentials; + + return array_merge(array( + 'repository' => '', + 'username' => '', + 'password' => '', + ), $credentials); + } + + /** + * Get the URL to the Git repository + * + * @return string + */ + public function getRepository() + { + // Get credentials + $repository = $this->getCredentials(); + $username = array_get($repository, 'username'); + $password = array_get($repository, 'password'); + $repository = array_get($repository, 'repository'); + + // Add credentials if possible + if ($username or $password) { + + // Build credentials chain + $credentials = $password ? $username.':'.$password : $username; + $credentials .= '@'; + + // Add them in chain + $repository = preg_replace('#https://(.+)@#', 'https://', $repository); + $repository = str_replace('https://', 'https://'.$credentials, $repository); + } + + return $repository; + } + + /** + * Get the Git branch + * + * @return string + */ + public function getRepositoryBranch() + { + exec($this->app['rocketeer.scm']->currentBranch(), $fallback); + $fallback = trim($fallback[0]) ?: 'master'; + $branch = $this->app['rocketeer.rocketeer']->getOption('scm.branch') ?: $fallback; + + return $branch; + } +} diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/LogsHandler.php index 348517ab0..244a273dc 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/LogsHandler.php @@ -76,7 +76,7 @@ public function getCurrentLogsFile() return false; } - $file = $logs($this->app['rocketeer.rocketeer']); + $file = $logs($this->app['rocketeer.connections']); $file = $this->app['path.rocketeer.logs'].'/'.$file; return $file; diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 26830f969..b8786209f 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -66,12 +66,12 @@ protected function getComponents() } // Get what was deployed - $branch = $this->rocketeer->getRepositoryBranch(); - $stage = $this->rocketeer->getStage(); - $connection = $this->rocketeer->getConnection(); + $branch = $this->connections->getRepositoryBranch(); + $stage = $this->connections->getStage(); + $connection = $this->connections->getConnection(); // Get hostname - $credentials = $this->rocketeer->getAvailableConnections($connection); + $credentials = $this->connections->getAvailableConnections($connection); $host = array_get($credentials, 'host'); if ($stage) { $connection = $stage.'@'.$connection; diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index 931de9f37..032d82608 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -251,8 +251,8 @@ protected function getCurrentReleaseKey() $key = 'current_release'; // Get the scopes - $connection = $this->app['rocketeer.rocketeer']->getConnection(); - $stage = $this->app['rocketeer.rocketeer']->getStage(); + $connection = $this->app['rocketeer.connections']->getConnection(); + $stage = $this->app['rocketeer.connections']->getStage(); $scopes = array($connection, $stage); foreach ($scopes as $scope) { $key .= $scope ? '.'.$scope : ''; diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index fd3cb1c93..7ce1d343d 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -28,27 +28,6 @@ class Rocketeer */ protected $app; - /** - * The current stage - * - * @var string - */ - protected $stage; - - /** - * The connections to use - * - * @var array - */ - protected $connections; - - /** - * The current connection - * - * @var string - */ - protected $connection; - /** * The Rocketeer version * @@ -66,6 +45,16 @@ public function __construct(Container $app) $this->app = $app; } + /** + * Get the name of the application to deploy + * + * @return string + */ + public function getApplicationName() + { + return $this->app['config']->get('rocketeer::application_name'); + } + /** * Get an option from Rocketeer's config file * @@ -102,11 +91,11 @@ protected function getContextualOption($option, $type, $original = null) // Switch context switch ($type) { case 'stages': - $contextual = sprintf('rocketeer::on.stages.%s.%s', $this->stage, $option); + $contextual = sprintf('rocketeer::on.stages.%s.%s', $this->app['rocketeer.connections']->getStage(), $option); break; case 'connections': - $contextual = sprintf('rocketeer::on.connections.%s.%s', $this->getConnection(), $option); + $contextual = sprintf('rocketeer::on.connections.%s.%s', $this->app['rocketeer.connections']->getConnection(), $option); break; default: @@ -123,47 +112,6 @@ protected function getContextualOption($option, $type, $original = null) return $value; } - //////////////////////////////////////////////////////////////////// - //////////////////////////////// STAGES //////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Set the stage Tasks will execute on - * - * @param string $stage - * - * @return void - */ - public function setStage($stage) - { - $this->stage = $stage; - - // If we do have a stage, cleanup previous events - if ($stage) { - $this->app['rocketeer.tasks']->registerConfiguredEvents(); - } - } - - /** - * Get the current stage - * - * @return string - */ - public function getStage() - { - return $this->stage; - } - - /** - * Get the various stages provided by the User - * - * @return array - */ - public function getStages() - { - return $this->getOption('stages.stages'); - } - /** * Returns what stage Rocketeer thinks he's in * @@ -180,267 +128,6 @@ public static function getDetectedStage($application = 'application', $path = nu return isset($matches[1]) ? $matches[1] : false; } - //////////////////////////////////////////////////////////////////// - ///////////////////////////// APPLICATION ////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Whether the repository used is using SSH or HTTPS - * - * @return boolean - */ - public function needsCredentials() - { - return Str::contains($this->getRepository(), 'https://'); - } - - /** - * Get the available connections - * - * @param string|null $connection A connection to fetch from the resulting array - * - * @return array - */ - public function getAvailableConnections($connection = null) - { - // Fetch stored credentials - $storage = (array) $this->app['rocketeer.server']->getValue('connections'); - - // Merge with defaults from config file - $configuration = (array) $this->app['config']->get('rocketeer::connections'); - - // Fetch from remote file - $remote = (array) $this->app['config']->get('remote.connections'); - - // Merge configurations - $storage = array_replace_recursive($remote, $configuration, $storage); - - return $connection ? array_get($storage, $connection) : $storage; - } - - /** - * Check if a connection has credentials related to it - * - * @param string $connection - * - * @return boolean - */ - public function isValidConnection($connection) - { - $available = (array) $this->getAvailableConnections(); - - return array_key_exists($connection, $available); - } - - /** - * Get the connection in use - * - * @return string - */ - public function getConnections() - { - // Get cached resolved connections - if ($this->connections) { - return $this->connections; - } - - // Get all and defaults - $connections = (array) $this->app['config']->get('rocketeer::default'); - $default = $this->app['config']->get('remote.default'); - - // Remove invalid connections - $instance = $this; - $connections = array_filter($connections, function ($value) use ($instance) { - return $instance->isValidConnection($value); - }); - - // Return default if no active connection(s) set - if (empty($connections) and $default) { - return array($default); - } - - // Set current connection as default - $this->connections = $connections; - - return $connections; - } - - /** - * Get the active connection - * - * @return string - */ - public function getConnection() - { - // Get cached resolved connection - if ($this->connection) { - return $this->connection; - } - - $connection = array_get($this->getConnections(), 0); - $this->connection = $connection; - - return $this->connection; - } - - /** - * Get the credentials for a particular connection - * - * @param string $connection - * - * @return array - */ - public function getConnectionCredentials($connection = null) - { - $connection = $connection ?: $this->getConnection(); - - return $this->getAvailableConnections($connection); - } - - /** - * Sync Rocketeer's credentials with Laravel's - * - * @param string $connection - * @param array $credentials - * - * @return void - */ - public function syncConnectionCredentials($connection = null, array $credentials = array()) - { - // Store credentials if any - if ($credentials) { - $this->app['rocketeer.server']->setValue('connections.'.$connection, $credentials); - } - - // Get connection - $connection = $connection ?: $this->getConnection(); - $credentials = $this->getConnectionCredentials($connection); - - $this->app['config']->set('remote.connections.'.$connection, $credentials); - } - - /** - * Set the active connections - * - * @param string|array $connections - */ - public function setConnections($connections) - { - if (!is_array($connections)) { - $connections = explode(',', $connections); - } - - $this->connections = $connections; - } - - /** - * Set the current connection - * - * @param string $connection - */ - public function setConnection($connection) - { - if (!$this->isValidConnection($connection)) { - return; - } - - // Set the connection - $this->connection = $connection; - $this->app['config']->set('remote.default', $connection); - - // Update events - $this->app['rocketeer.tasks']->registerConfiguredEvents(); - } - - /** - * Flush active connection(s) - * - * @return void - */ - public function disconnect() - { - $this->connection = null; - $this->connections = null; - } - - /** - * Get the name of the application to deploy - * - * @return string - */ - public function getApplicationName() - { - return $this->app['config']->get('rocketeer::application_name'); - } - - //////////////////////////////////////////////////////////////////// - /////////////////////////// GIT REPOSITORY ///////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Get the credentials for the repository - * - * @return array - */ - public function getCredentials() - { - $credentials = $this->app['rocketeer.server']->getValue('credentials'); - if (!$credentials) { - $credentials = $this->getOption('scm'); - } - - // Cast to array - $credentials = (array) $credentials; - - return array_merge(array( - 'repository' => '', - 'username' => '', - 'password' => '', - ), $credentials); - } - - /** - * Get the URL to the Git repository - * - * @return string - */ - public function getRepository() - { - // Get credentials - $repository = $this->getCredentials(); - $username = array_get($repository, 'username'); - $password = array_get($repository, 'password'); - $repository = array_get($repository, 'repository'); - - // Add credentials if possible - if ($username or $password) { - - // Build credentials chain - $credentials = $password ? $username.':'.$password : $username; - $credentials .= '@'; - - // Add them in chain - $repository = preg_replace('#https://(.+)@#', 'https://', $repository); - $repository = str_replace('https://', 'https://'.$credentials, $repository); - } - - return $repository; - } - - /** - * Get the Git branch - * - * @return string - */ - public function getRepositoryBranch() - { - exec($this->app['rocketeer.scm']->currentBranch(), $fallback); - $fallback = trim($fallback[0]) ?: 'master'; - $branch = $this->getOption('scm.branch') ?: $fallback; - - return $branch; - } - //////////////////////////////////////////////////////////////////// //////////////////////////////// PATHS ///////////////////////////// //////////////////////////////////////////////////////////////////// @@ -492,8 +179,9 @@ public function getFolder($folder = null) $folder = $this->replacePatterns($folder); $base = $this->getHomeFolder().'/'; - if ($folder and $this->stage) { - $base .= $this->stage.'/'; + $stage = $this->app['rocketeer.connections']->getStage(); + if ($folder and $stage) { + $base .= $stage.'/'; } $folder = str_replace($base, null, $folder); diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 0ef06001e..dbb627a02 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -177,6 +177,10 @@ public function bindClasses(Container $app) return new Rocketeer($app); }); + $app->singleton('rocketeer.connections', function ($app) { + return new ConnectionsHandler($app); + }); + $app->singleton('rocketeer.releases', function ($app) { return new ReleasesManager($app); }); @@ -209,7 +213,7 @@ public function bindClasses(Container $app) }); $app['rocketeer.console']->setLaravel($app); - $app['rocketeer.rocketeer']->syncConnectionCredentials(); + $app['rocketeer.connections']->syncConnectionCredentials(); return $app; } diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index b90ab7f82..cdbf685a4 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -72,8 +72,8 @@ public function currentBranch() */ public function checkout($destination) { - $branch = $this->app['rocketeer.rocketeer']->getRepositoryBranch(); - $repository = $this->app['rocketeer.rocketeer']->getRepository(); + $branch = $this->app['rocketeer.connections']->getRepositoryBranch(); + $repository = $this->app['rocketeer.connections']->getRepository(); $shallow = $this->app['rocketeer.rocketeer']->getOption('scm.shallow') ? ' --depth 1' : ''; return $this->getCommand('clone%s -b %s "%s" %s', $shallow, $branch, $repository, $destination); diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index 2f627b69f..82b01a917 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -74,7 +74,7 @@ public function currentBranch() public function checkout($destination) { $branch = $this->app['rocketeer.rocketeer']->getRepositoryBranch(); - $repository = $this->app['rocketeer.rocketeer']->getRepository(); + $repository = $this->app['rocketeer.connections']->getRepository(); $repository = rtrim($repository, '/').'/'.ltrim($branch, '/'); return $this->getCommand('co %s %s %s', $this->getCredentials(), $repository, $destination); diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index f1e4f89ac..e2a5ec83e 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -41,7 +41,7 @@ class CurrentRelease extends Task public function execute() { // Get the current stage - $stage = $this->rocketeer->getStage(); + $stage = $this->connections->getStage(); $stage = $stage ? ' for stage '.$stage : ''; // Check if a release has been deployed already diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index af9535d3e..309d2b979 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -78,13 +78,13 @@ protected function createOutsideConfiguration() protected function getConfigurationInformations() { // Replace credentials - $repositoryCredentials = $this->rocketeer->getCredentials(); + $repositoryCredentials = $this->connections->getCredentials(); $name = basename($this->app['path.base']); return array_merge( - $this->rocketeer->getConnectionCredentials(), + $this->connections->getConnectionCredentials(), array( - 'connection' => $this->rocketeer->getConnection(), + 'connection' => $this->connections->getConnection(), 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 5970479e0..41ac6d395 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -76,22 +76,22 @@ public function execute() protected function createStages() { // Get stages - $availableStages = $this->rocketeer->getStages(); - $originalStage = $this->rocketeer->getStage(); + $availableStages = $this->connections->getStages(); + $originalStage = $this->connections->getStage(); if (empty($availableStages)) { $availableStages = array(null); } // Create folders foreach ($availableStages as $stage) { - $this->rocketeer->setStage($stage); + $this->connections->setStage($stage); $this->createFolder('releases', true); $this->createFolder('current', true); $this->createFolder('shared', true); } if ($originalStage) { - $this->rocketeer->setStage($originalStage); + $this->connections->setStage($originalStage); } } } diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index 3e86ead98..83060dc1a 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -56,7 +56,7 @@ class TasksQueue extends AbstractLocatorClass public function execute($queue, $connections = null) { if ($connections) { - $this->rocketeer->setConnections($connections); + $this->connections->setConnections($connections); } $queue = (array) $queue; @@ -98,13 +98,13 @@ public function run(array $tasks) $queue = $this->buildQueue($tasks); // Get the connections to execute the tasks on - $connections = (array) $this->rocketeer->getConnections(); + $connections = (array) $this->connections->getConnections(); foreach ($connections as $connection) { - $this->rocketeer->setConnection($connection); + $this->connections->setConnection($connection); // Check if we provided a stage $stage = $this->getStage(); - $stages = $this->rocketeer->getStages(); + $stages = $this->connections->getStages(); if ($stage and in_array($stage, $stages)) { $stages = array($stage); } @@ -134,7 +134,7 @@ protected function runQueue($tasks, $stage = null) { foreach ($tasks as $task) { $currentStage = $task->usesStages() ? $stage : null; - $this->rocketeer->setStage($currentStage); + $this->connections->setStage($currentStage); // Here we fire the task and if it was halted // at any point, we cancel the whole queue diff --git a/src/Rocketeer/Traits/AbstractLocatorClass.php b/src/Rocketeer/Traits/AbstractLocatorClass.php index 4e859ee9b..584b2bdea 100644 --- a/src/Rocketeer/Traits/AbstractLocatorClass.php +++ b/src/Rocketeer/Traits/AbstractLocatorClass.php @@ -21,7 +21,6 @@ * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Server server * @property \Rocketeer\Traits\Scm scm - * * @author Maxime Fabre */ abstract class AbstractLocatorClass @@ -53,6 +52,7 @@ public function __construct(Container $app) public function __get($key) { $shortcuts = array( + 'connections' => 'rocketeer.connections', 'command' => 'rocketeer.command', 'console' => 'rocketeer.console', 'logs' => 'rocketeer.logs', diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index a68b28fd5..d981e5de2 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -247,7 +247,7 @@ protected function addCommandsToHistory($commands) */ public function processCommands($commands) { - $stage = $this->rocketeer->getStage(); + $stage = $this->connections->getStage(); $separator = $this->server->getSeparator(); // Cast commands to array diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index d1cee0c67..bcd0c3e55 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -33,7 +33,7 @@ public function isSetup() */ public function usesStages() { - $stages = $this->rocketeer->getStages(); + $stages = $this->connections->getStages(); return $this->usesStages and !empty($stages); } diff --git a/tests/LogsHandlerTest.php b/tests/LogsHandlerTest.php index 884ac1d10..924abac37 100644 --- a/tests/LogsHandlerTest.php +++ b/tests/LogsHandlerTest.php @@ -22,8 +22,8 @@ public function testCanGetCurrentLogsFile() $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); $this->assertEquals($this->server.'/logs/production-.log', $logs); - $this->app['rocketeer.rocketeer']->setConnection('staging'); - $this->app['rocketeer.rocketeer']->setStage('foobar'); + $this->app['rocketeer.connections']->setConnection('staging'); + $this->app['rocketeer.connections']->setStage('foobar'); $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); $this->assertEquals($this->server.'/logs/staging-foobar.log', $logs); } diff --git a/tests/Plugins/NotifierTest.php b/tests/Plugins/NotifierTest.php index 2c898a6b6..b86286ad6 100644 --- a/tests/Plugins/NotifierTest.php +++ b/tests/Plugins/NotifierTest.php @@ -29,7 +29,7 @@ public function testCanAppendStageToDetails() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "staging@production" (foo.bar.com)'); $this->app['rocketeer.server']->setValue('notifier.name', 'Jean Eude'); - $this->app['rocketeer.rocketeer']->setStage('staging'); + $this->app['rocketeer.connections']->setStage('staging'); $this->notifier = new DummyNotifier($this->app); $this->app['rocketeer.tasks']->plugin($this->notifier); diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 6f0312e82..8991ea639 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -11,35 +11,35 @@ class RocketeerTest extends RocketeerTestCase public function testCanGetAvailableConnections() { - $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); $this->assertEquals(array('production', 'staging'), array_keys($connections)); $this->app['rocketeer.server']->setValue('connections.custom.username', 'foobar'); - $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); } public function testCanGetCurrentConnection() { $this->swapConfig(array('rocketeer::default' => 'foobar')); - $this->assertEquals('production', $this->app['rocketeer.rocketeer']->getConnection()); + $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); $this->swapConfig(array('rocketeer::default' => 'production')); - $this->assertEquals('production', $this->app['rocketeer.rocketeer']->getConnection()); + $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); $this->swapConfig(array('rocketeer::default' => 'staging')); - $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getConnection()); + $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); } public function testCanChangeConnection() { - $this->assertEquals('production', $this->app['rocketeer.rocketeer']->getConnection()); + $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); - $this->app['rocketeer.rocketeer']->setConnection('staging'); - $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getConnection()); + $this->app['rocketeer.connections']->setConnection('staging'); + $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); - $this->app['rocketeer.rocketeer']->setConnections('staging,production'); - $this->assertEquals(array('staging', 'production'), $this->app['rocketeer.rocketeer']->getConnections()); + $this->app['rocketeer.connections']->setConnections('staging,production'); + $this->assertEquals(array('staging', 'production'), $this->app['rocketeer.connections']->getConnections()); } public function testCanUseSshRepository() @@ -47,53 +47,53 @@ public function testCanUseSshRepository() $repository = 'git@github.com:'.$this->repository; $this->expectRepositoryConfig($repository, '', ''); - $this->assertEquals($repository, $this->app['rocketeer.rocketeer']->getRepository()); + $this->assertEquals($repository, $this->app['rocketeer.connections']->getRepository()); } public function testCanUseHttpsRepository() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, 'foobar', 'bar'); - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.rocketeer']->getRepository()); + $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); } public function testCanUseHttpsRepositoryWithUsernameProvided() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', 'bar'); - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.rocketeer']->getRepository()); + $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); } public function testCanUseHttpsRepositoryWithOnlyUsernameProvided() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', ''); - $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->app['rocketeer.rocketeer']->getRepository()); + $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); } public function testCanCleanupProvidedRepositoryFromCredentials() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'Anahkiasen', ''); - $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->app['rocketeer.rocketeer']->getRepository()); + $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); } public function testCanUseHttpsRepositoryWithoutCredentials() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - $this->assertEquals('https://github.com/'.$this->repository, $this->app['rocketeer.rocketeer']->getRepository()); + $this->assertEquals('https://github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); } public function testCanCheckIfRepositoryNeedsCredentials() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - $this->assertTrue($this->app['rocketeer.rocketeer']->needsCredentials()); + $this->assertTrue($this->app['rocketeer.connections']->needsCredentials()); } public function testCangetRepositoryBranch() { - $this->assertEquals('master', $this->app['rocketeer.rocketeer']->getRepositoryBranch()); + $this->assertEquals('master', $this->app['rocketeer.connections']->getRepositoryBranch()); } public function testCanGetApplicationName() @@ -108,7 +108,7 @@ public function testCanGetHomeFolder() public function testCanGetFolderWithStage() { - $this->app['rocketeer.rocketeer']->setStage('test'); + $this->app['rocketeer.connections']->setStage('test'); $this->assertEquals($this->server.'/test/current', $this->app['rocketeer.rocketeer']->getFolder('current')); } @@ -140,7 +140,7 @@ public function testCanUseRecursiveStageConfiguration() )); $this->assertEquals('master', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); - $this->app['rocketeer.rocketeer']->setStage('staging'); + $this->app['rocketeer.connections']->setStage('staging'); $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); } @@ -178,7 +178,7 @@ public function testRocketeerCanGuessWhichStageHesIn() public function testFillsConnectionCredentialsHoles() { - $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); $this->assertArrayHasKey('production', $connections); $this->app['rocketeer.server']->setValue('connections', array( @@ -191,7 +191,7 @@ public function testFillsConnectionCredentialsHoles() 'agent' => '' ), )); - $connections = $this->app['rocketeer.rocketeer']->getAvailableConnections(); + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); $this->assertArrayHasKey('production', $connections); } diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index 36bad97b0..e8f7a7e41 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -47,8 +47,10 @@ public function testCanGetCurrentBranch() public function testCanGetCheckout() { $this->mock('rocketeer.rocketeer', 'Rocketeer', function ($mock) { + return $mock->shouldReceive('getOption')->once()->with('scm.shallow')->andReturn(true); + }); + $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { return $mock - ->shouldReceive('getOption')->once()->with('scm.shallow')->andReturn(true) ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); @@ -61,12 +63,15 @@ public function testCanGetCheckout() public function testCanGetDeepClone() { $this->mock('rocketeer.rocketeer', 'Rocketeer', function ($mock) { + return $mock->shouldReceive('getOption')->once()->with('scm.shallow')->andReturn(false); + }); + $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { return $mock - ->shouldReceive('getOption')->once()->with('scm.shallow')->andReturn(false) ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); + $command = $this->scm->checkout($this->server); $this->assertEquals('git clone -b develop "http://github.com/my/repository" '.$this->server, $command); diff --git a/tests/Tasks/SetupTest.php b/tests/Tasks/SetupTest.php index 88a0fed76..ef8425a24 100644 --- a/tests/Tasks/SetupTest.php +++ b/tests/Tasks/SetupTest.php @@ -54,8 +54,8 @@ public function testRunningSetupKeepsCurrentCongiguredStage() 'rocketeer::stages.stages' => array('staging', 'production'), )); - $this->app['rocketeer.rocketeer']->setStage('staging'); - $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getStage()); + $this->app['rocketeer.connections']->setStage('staging'); + $this->assertEquals('staging', $this->app['rocketeer.connections']->getStage()); $this->assertTaskHistory('Setup', array( "mkdir {server}/", "mkdir -p {server}/staging/releases", @@ -67,6 +67,6 @@ public function testRunningSetupKeepsCurrentCongiguredStage() ), array( 'stage' => 'staging', )); - $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getStage()); + $this->assertEquals('staging', $this->app['rocketeer.connections']->getStage()); } } diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index d6c54bc2a..c530a9ffd 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -95,10 +95,10 @@ public function testCanExecuteContextualEvents() 'rocketeer::on.stages.hasEvent.hooks' => array('before' => array('check' => 'ls')), )); - $this->app['rocketeer.rocketeer']->setStage('hasEvent'); + $this->app['rocketeer.connections']->setStage('hasEvent'); $this->assertEquals(array('ls'), $this->tasksQueue()->getTasksListeners('check', 'before', true)); - $this->app['rocketeer.rocketeer']->setStage('noEvent'); + $this->app['rocketeer.connections']->setStage('noEvent'); $this->assertEquals(array(), $this->tasksQueue()->getTasksListeners('check', 'before', true)); } @@ -133,11 +133,11 @@ public function testCanHaveCustomConnectionHooks() )); $this->tasksQueue()->registerConfiguredEvents(); - $this->app['rocketeer.rocketeer']->setConnection('production'); + $this->app['rocketeer.connections']->setConnection('production'); $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); $this->assertEmpty($events); - $this->app['rocketeer.rocketeer']->setConnection('staging'); + $this->app['rocketeer.connections']->setConnection('staging'); $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); $this->assertEquals($tasks, $events); diff --git a/tests/TasksQueueTest.php b/tests/TasksQueueTest.php index cdf955258..e78893938 100644 --- a/tests/TasksQueueTest.php +++ b/tests/TasksQueueTest.php @@ -89,7 +89,7 @@ public function testCanRunQueueOnDifferentConnectionsAndStages() $output = array(); $queue = array( function ($task) use (&$output) { - $output[] = $task->rocketeer->getConnection().' - '.$task->rocketeer->getStage(); + $output[] = $task->connections->getConnection().' - '.$task->connections->getStage(); } ); @@ -130,7 +130,7 @@ public function testCanRunOnMultipleConnectionsViaOn() )); $output = $this->tasksQueue()->on(array('staging', 'production'), function ($task) { - return $task->rocketeer->getConnection().' - '.$task->rocketeer->getStage(); + return $task->connections->getConnection().' - '.$task->connections->getStage(); }); $this->assertEquals(array( diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 5905b5d0b..345087c19 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -226,7 +226,7 @@ protected function getConfig($expectations = array()) */ protected function swapConfig($config) { - $this->app['rocketeer.rocketeer']->disconnect(); + $this->app['rocketeer.connections']->disconnect(); $this->app['config'] = $this->getConfig($config); } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 819a2eeac..0bad9e381 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -40,7 +40,7 @@ public function testCanGetLocalTimestampIfError() public function testDoesntAppendEnvironmentToStandardTasks() { - $this->app['rocketeer.rocketeer']->setStage('staging'); + $this->app['rocketeer.connections']->setStage('staging'); $commands = $this->pretendTask()->processCommands(array( 'artisan something', 'rm readme*', From 543c2ca18c38556911a80a4aac694700b0298dbf Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 5 Aug 2014 23:54:40 +0200 Subject: [PATCH 036/424] Rename Traits folder to Abstracts --- .../AbstractLocatorClass.php | 14 ++++----- .../BashModules/Binaries.php | 2 +- .../BashModules/Core.php | 4 +-- .../BashModules/Filesystem.php | 2 +- .../BashModules/Flow.php | 2 +- .../{Traits => Abstracts}/BashModules/Scm.php | 2 +- .../{Traits => Abstracts}/Plugin.php | 2 +- src/Rocketeer/{Traits => Abstracts}/Scm.php | 2 +- src/Rocketeer/{Traits => Abstracts}/Task.php | 2 +- src/Rocketeer/Bash.php | 2 +- src/Rocketeer/Commands/BaseTaskCommand.php | 2 +- src/Rocketeer/ConnectionsHandler.php | 1 - src/Rocketeer/Console/Compiler.php | 10 +++---- src/Rocketeer/Facades/Console.php | 1 - src/Rocketeer/Facades/Rocketeer.php | 1 - src/Rocketeer/Facades/StandaloneFacade.php | 1 - src/Rocketeer/Plugins/Notifier.php | 4 +-- src/Rocketeer/Rocketeer.php | 2 +- src/Rocketeer/RocketeerServiceProvider.php | 8 ++--- src/Rocketeer/Scm/Git.php | 2 +- src/Rocketeer/Scm/Svn.php | 2 +- src/Rocketeer/Tasks/Check.php | 2 +- src/Rocketeer/Tasks/Cleanup.php | 2 +- src/Rocketeer/Tasks/Closure.php | 2 +- src/Rocketeer/Tasks/CurrentRelease.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Tasks/Ignite.php | 2 +- src/Rocketeer/Tasks/Rollback.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Tasks/Teardown.php | 2 +- src/Rocketeer/Tasks/Test.php | 2 +- src/Rocketeer/TasksHandler.php | 2 +- src/Rocketeer/TasksQueue.php | 12 ++++---- src/config/hooks.php | 2 +- tests/Dummies/MyCustomTask.php | 2 +- tests/TestCases/RocketeerTestCase.php | 9 ++++-- tests/Traits/BashModules/BinariesTest.php | 2 +- tests/Traits/BashModules/CoreTest.php | 2 +- tests/Traits/BashModules/FilesystemTest.php | 2 +- tests/Traits/BashModules/ScmTest.php | 2 +- tests/Traits/ScmTest.php | 2 +- tests/Traits/TaskTest.php | 2 +- tests/_meta/coverage.txt | 30 +++++++++---------- 43 files changed, 75 insertions(+), 82 deletions(-) rename src/Rocketeer/{Traits => Abstracts}/AbstractLocatorClass.php (82%) rename src/Rocketeer/{Traits => Abstracts}/BashModules/Binaries.php (99%) rename src/Rocketeer/{Traits => Abstracts}/BashModules/Core.php (98%) rename src/Rocketeer/{Traits => Abstracts}/BashModules/Filesystem.php (99%) rename src/Rocketeer/{Traits => Abstracts}/BashModules/Flow.php (98%) rename src/Rocketeer/{Traits => Abstracts}/BashModules/Scm.php (98%) rename src/Rocketeer/{Traits => Abstracts}/Plugin.php (97%) rename src/Rocketeer/{Traits => Abstracts}/Scm.php (97%) rename src/Rocketeer/{Traits => Abstracts}/Task.php (99%) diff --git a/src/Rocketeer/Traits/AbstractLocatorClass.php b/src/Rocketeer/Abstracts/AbstractLocatorClass.php similarity index 82% rename from src/Rocketeer/Traits/AbstractLocatorClass.php rename to src/Rocketeer/Abstracts/AbstractLocatorClass.php index 584b2bdea..97d7ce354 100644 --- a/src/Rocketeer/Traits/AbstractLocatorClass.php +++ b/src/Rocketeer/Abstracts/AbstractLocatorClass.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits; +namespace Rocketeer\Abstracts; use Illuminate\Container\Container; @@ -15,12 +15,12 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Console\Command command - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\ReleasesManager releasesManager - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Server server - * @property \Rocketeer\Traits\Scm scm + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Server server + * @property \Rocketeer\Abstracts\Scm scm * @author Maxime Fabre */ abstract class AbstractLocatorClass diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Abstracts/BashModules/Binaries.php similarity index 99% rename from src/Rocketeer/Traits/BashModules/Binaries.php rename to src/Rocketeer/Abstracts/BashModules/Binaries.php index 982ecf36e..1b4aecf2d 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Abstracts/BashModules/Binaries.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits\BashModules; +namespace Rocketeer\Abstracts\BashModules; /** * Handles finding and calling binaries diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Abstracts/BashModules/Core.php similarity index 98% rename from src/Rocketeer/Traits/BashModules/Core.php rename to src/Rocketeer/Abstracts/BashModules/Core.php index d981e5de2..d6725d143 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Abstracts/BashModules/Core.php @@ -7,10 +7,10 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits\BashModules; +namespace Rocketeer\Abstracts\BashModules; use Illuminate\Support\Str; -use Rocketeer\Traits\AbstractLocatorClass; +use Rocketeer\Abstracts\AbstractLocatorClass; /** * Core handling of running commands and returning output diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Abstracts/BashModules/Filesystem.php similarity index 99% rename from src/Rocketeer/Traits/BashModules/Filesystem.php rename to src/Rocketeer/Abstracts/BashModules/Filesystem.php index 095823667..fc7c0c2b1 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Abstracts/BashModules/Filesystem.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits\BashModules; +namespace Rocketeer\Abstracts\BashModules; /** * Files and folders handling diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Abstracts/BashModules/Flow.php similarity index 98% rename from src/Rocketeer/Traits/BashModules/Flow.php rename to src/Rocketeer/Abstracts/BashModules/Flow.php index bcd0c3e55..e9ec80fd3 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Abstracts/BashModules/Flow.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits\BashModules; +namespace Rocketeer\Abstracts\BashModules; /** * Handles the deployment flow (current/releases/shared) diff --git a/src/Rocketeer/Traits/BashModules/Scm.php b/src/Rocketeer/Abstracts/BashModules/Scm.php similarity index 98% rename from src/Rocketeer/Traits/BashModules/Scm.php rename to src/Rocketeer/Abstracts/BashModules/Scm.php index 5d216e91a..36d341390 100644 --- a/src/Rocketeer/Traits/BashModules/Scm.php +++ b/src/Rocketeer/Abstracts/BashModules/Scm.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits\BashModules; +namespace Rocketeer\Abstracts\BashModules; /** * Repository handling diff --git a/src/Rocketeer/Traits/Plugin.php b/src/Rocketeer/Abstracts/Plugin.php similarity index 97% rename from src/Rocketeer/Traits/Plugin.php rename to src/Rocketeer/Abstracts/Plugin.php index dc7e31be0..cec069382 100644 --- a/src/Rocketeer/Traits/Plugin.php +++ b/src/Rocketeer/Abstracts/Plugin.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits; +namespace Rocketeer\Abstracts; use Illuminate\Container\Container; use Illuminate\Support\Str; diff --git a/src/Rocketeer/Traits/Scm.php b/src/Rocketeer/Abstracts/Scm.php similarity index 97% rename from src/Rocketeer/Traits/Scm.php rename to src/Rocketeer/Abstracts/Scm.php index 66293e968..aa543282f 100644 --- a/src/Rocketeer/Traits/Scm.php +++ b/src/Rocketeer/Abstracts/Scm.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits; +namespace Rocketeer\Abstracts; /** * An abstract class with helpers for SCM implementations diff --git a/src/Rocketeer/Traits/Task.php b/src/Rocketeer/Abstracts/Task.php similarity index 99% rename from src/Rocketeer/Traits/Task.php rename to src/Rocketeer/Abstracts/Task.php index 5831ef280..2c93cb195 100644 --- a/src/Rocketeer/Traits/Task.php +++ b/src/Rocketeer/Abstracts/Task.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Traits; +namespace Rocketeer\Abstracts; use DateTime; use Rocketeer\Bash; diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index 5cab728ed..126bac31a 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -14,7 +14,7 @@ * * @author Maxime Fabre */ -class Bash extends Traits\BashModules\Flow +class Bash extends Abstracts\BashModules\Flow { // Composite class // Don't ask. diff --git a/src/Rocketeer/Commands/BaseTaskCommand.php b/src/Rocketeer/Commands/BaseTaskCommand.php index 627375120..372093bb4 100644 --- a/src/Rocketeer/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Commands/BaseTaskCommand.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Commands; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * A command that wraps around a Task class and runs diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 2d3ff5615..fd494d3ee 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -9,7 +9,6 @@ */ namespace Rocketeer; -use Exception; use Illuminate\Container\Container; use Illuminate\Support\Str; diff --git a/src/Rocketeer/Console/Compiler.php b/src/Rocketeer/Console/Compiler.php index 815a54f71..c74af54c8 100644 --- a/src/Rocketeer/Console/Compiler.php +++ b/src/Rocketeer/Console/Compiler.php @@ -130,8 +130,8 @@ protected function setStub() { $this->box->getPhar()->setStub( StubGenerator::create() - ->index('bin/rocketeer') - ->generate() + ->index('bin/rocketeer') + ->generate() ); } @@ -147,9 +147,9 @@ protected function addFolder($folder, array $ignore = array()) { $finder = new Finder(); $finder = $finder->files() - ->ignoreVCS(true) - ->name('*.php') - ->in($folder); + ->ignoreVCS(true) + ->name('*.php') + ->in($folder); // Ignore some files or folders if ($ignore) { diff --git a/src/Rocketeer/Facades/Console.php b/src/Rocketeer/Facades/Console.php index 69a4e01a8..38f1979a8 100644 --- a/src/Rocketeer/Facades/Console.php +++ b/src/Rocketeer/Facades/Console.php @@ -13,7 +13,6 @@ * Facade for Rocketeer's CLI * * @author Maxime Fabre - * * @see Rocketeer\Console\Console */ class Console extends StandaloneFacade diff --git a/src/Rocketeer/Facades/Rocketeer.php b/src/Rocketeer/Facades/Rocketeer.php index ec528e36f..02c19b782 100644 --- a/src/Rocketeer/Facades/Rocketeer.php +++ b/src/Rocketeer/Facades/Rocketeer.php @@ -13,7 +13,6 @@ * Facade for Rocketeer's CLI * * @author Maxime Fabre - * * @see Rocketeer\TasksQueue */ class Rocketeer extends StandaloneFacade diff --git a/src/Rocketeer/Facades/StandaloneFacade.php b/src/Rocketeer/Facades/StandaloneFacade.php index 3fdbe554c..1b6a94024 100644 --- a/src/Rocketeer/Facades/StandaloneFacade.php +++ b/src/Rocketeer/Facades/StandaloneFacade.php @@ -16,7 +16,6 @@ * Facade for Rocketeer's CLI * * @author Maxime Fabre - * * @see Rocketeer\Console\Console */ abstract class StandaloneFacade extends Facade diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index b8786209f..454d3441d 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -9,9 +9,9 @@ */ namespace Rocketeer\Plugins; +use Rocketeer\Abstracts\Plugin; +use Rocketeer\Abstracts\Task; use Rocketeer\TasksHandler; -use Rocketeer\Traits\Plugin; -use Rocketeer\Traits\Task; /** * A base class for notification services to extends diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 7ce1d343d..9aabd013f 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -178,7 +178,7 @@ public function getFolder($folder = null) { $folder = $this->replacePatterns($folder); - $base = $this->getHomeFolder().'/'; + $base = $this->getHomeFolder().'/'; $stage = $this->app['rocketeer.connections']->getStage(); if ($folder and $stage) { $base .= $stage.'/'; diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index dbb627a02..880b32d99 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -295,14 +295,12 @@ public function bindCommands(Container $app) $this->app->singleton($command, function () use ($commandClass) { return new $commandClass; }); - - // Else create a fake one + // Else create a fake one } else { $this->app->bind($command, function () use ($taskInstance, $slug) { return new Commands\BaseTaskCommand($taskInstance, $slug); }); } - } // Add commands to Artisan @@ -368,9 +366,7 @@ protected function loadFileOrFolder(Container $app, $handle) $file = $app['path.rocketeer.'.$handle]; if (!is_dir($file) and file_exists($file)) { include $file; - } - - // Else include its contents + } // Else include its contents elseif (is_dir($file)) { $folder = glob($file.'/*.php'); foreach ($folder as $file) { diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index cdbf685a4..d264622e1 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Scm; -use Rocketeer\Traits\Scm; +use Rocketeer\Abstracts\Scm; /** * The Git implementation of the ScmInterface diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index 82b01a917..58fc3999b 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Scm; -use Rocketeer\Traits\Scm; +use Rocketeer\Abstracts\Scm; /** * The Svn implementation of the ScmInterface diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 399b20e54..e30066b9f 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Check if the server is ready to receive the application diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index a0203613f..f68c135b1 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -10,7 +10,7 @@ namespace Rocketeer\Tasks; use Illuminate\Support\Str; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Clean up old releases from the server diff --git a/src/Rocketeer/Tasks/Closure.php b/src/Rocketeer/Tasks/Closure.php index b182f2747..e26ce5485 100644 --- a/src/Rocketeer/Tasks/Closure.php +++ b/src/Rocketeer/Tasks/Closure.php @@ -10,7 +10,7 @@ namespace Rocketeer\Tasks; use Closure as AnonymousFunction; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * A Task that wraps around a closure and execute it diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index e2a5ec83e..150a6cdea 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -10,7 +10,7 @@ namespace Rocketeer\Tasks; use DateTime; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Display what the current release is diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 128026985..ddad1a835 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Deploy the website diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index 309d2b979..3b7a85398 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * A task to ignite Rocketeer diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 6f870e582..1d742fa25 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Rollback to the previous release, or to a specific one diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 41ac6d395..d94e66463 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Set up the remote server for deployment diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 3827813ec..4cb42d207 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Remove the remote applications and existing caches diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index 18b5288d3..db861ec18 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\Task; /** * Run the tests on the server and displays the output diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index bb30520d1..dd46943e5 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -10,8 +10,8 @@ namespace Rocketeer; use Illuminate\Container\Container; +use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Commands\BaseTaskCommand; -use Rocketeer\Traits\AbstractLocatorClass; /** * Handles the registering and relating of tasks diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index 83060dc1a..d8d07723f 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -10,8 +10,8 @@ namespace Rocketeer; use Closure; -use Rocketeer\Traits\AbstractLocatorClass; -use Rocketeer\Traits\Task; +use Rocketeer\Abstracts\AbstractLocatorClass; +use Rocketeer\Abstracts\Task; /** * Handles the building and execution of tasks @@ -84,7 +84,6 @@ public function on($connections, $queue) /** * Run the queue - * * Run an array of Tasks instances on the various * connections and stages provided * @@ -125,8 +124,8 @@ public function run(array $tasks) /** * Run the queue, taking into account the stage * - * @param \Rocketeer\Traits\Task[] $tasks - * @param string $stage + * @param \Rocketeer\Abstracts\Task[] $tasks + * @param string $stage * * @return boolean */ @@ -156,7 +155,6 @@ protected function runQueue($tasks, $stage = null) /** * Build a queue from a list of tasks - * * Here we will take the various Tasks names, closures and string tasks * and unify all of those to actual Task instances * @@ -249,7 +247,7 @@ public function buildTaskFromClosure($task) * * @param string $task * - * @return \Rocketeer\Traits\Task + * @return \Rocketeer\Abstracts\Task */ public function buildTaskFromClass($task) { diff --git a/src/config/hooks.php b/src/config/hooks.php index a0a07fb2a..c5a7c6300 100644 --- a/src/config/hooks.php +++ b/src/config/hooks.php @@ -5,7 +5,7 @@ // Here you can define in the `before` and `after` array, Tasks to execute // before or after the core Rocketeer Tasks. You can either put a simple command, // a closure which receives a $task object, or the name of a class extending - // the Rocketeer\Traits\Task class + // the Rocketeer\Abstracts\Task class // // In the `custom` array you can list custom Tasks classes to be added // to Rocketeer. Those will then be available in the command line diff --git a/tests/Dummies/MyCustomTask.php b/tests/Dummies/MyCustomTask.php index 393cf8d4e..c1e10146f 100644 --- a/tests/Dummies/MyCustomTask.php +++ b/tests/Dummies/MyCustomTask.php @@ -1,7 +1,7 @@ Date: Tue, 5 Aug 2014 23:55:33 +0200 Subject: [PATCH 037/424] Update CHANGELOG --- CHANGELOG.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index de84e81cc..e89c7e699 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,7 +2,13 @@ ### 2.0.0 +#### Breaking changes + - Minimum requirement is now PHP 5.4+ +- The `Traits` folder was renamed to `Abstracts`, if you were extending `Rocketeer\Traits\Task`, change that accordingly to `Rocketeer\Abstracts\Task` + +#### Features and bugfixes + - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions - Fixed a bug where `rocketeer current` would fail to find the related task From 0da5e49e0cc6f4e2764c2c031e9193f99774377d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 00:00:12 +0200 Subject: [PATCH 038/424] Add HasLocator trait --- .../Abstracts/AbstractLocatorClass.php | 72 +------------- src/Rocketeer/Traits/HasLocator.php | 95 +++++++++++++++++++ tests/TasksQueueTest.php | 2 +- 3 files changed, 100 insertions(+), 69 deletions(-) create mode 100644 src/Rocketeer/Traits/HasLocator.php diff --git a/src/Rocketeer/Abstracts/AbstractLocatorClass.php b/src/Rocketeer/Abstracts/AbstractLocatorClass.php index 97d7ce354..b851f8c3c 100644 --- a/src/Rocketeer/Abstracts/AbstractLocatorClass.php +++ b/src/Rocketeer/Abstracts/AbstractLocatorClass.php @@ -9,87 +9,23 @@ */ namespace Rocketeer\Abstracts; -use Illuminate\Container\Container; +use Rocketeer\Traits\HasLocator; /** * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * + * @property \Rocketeer\ConnectionsHandler connections * @property \Illuminate\Console\Command command * @property \Illuminate\Remote\Connection remote * @property \Rocketeer\ReleasesManager releasesManager * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Server server * @property \Rocketeer\Abstracts\Scm scm + * * @author Maxime Fabre */ abstract class AbstractLocatorClass { - /** - * The IoC Container - * - * @var Container - */ - protected $app; - - /** - * Build a new Task - * - * @param Container $app - */ - public function __construct(Container $app) - { - $this->app = $app; - } - - /** - * Get an instance from the Container - * - * @param string $key - * - * @return object - */ - public function __get($key) - { - $shortcuts = array( - 'connections' => 'rocketeer.connections', - 'command' => 'rocketeer.command', - 'console' => 'rocketeer.console', - 'logs' => 'rocketeer.logs', - 'queue' => 'rocketeer.queue', - 'releasesManager' => 'rocketeer.releases', - 'rocketeer' => 'rocketeer.rocketeer', - 'scm' => 'rocketeer.scm', - 'server' => 'rocketeer.server', - 'tasks' => 'rocketeer.tasks', - ); - - // Replace shortcuts - if (array_key_exists($key, $shortcuts)) { - $key = $shortcuts[$key]; - } - - return $this->app[$key]; - } - - /** - * Set an instance on the Container - * - * @param string $key - * @param object $value - */ - public function __set($key, $value) - { - $this->app[$key] = $value; - } - - /** - * Check if the current instance has a Command bound - * - * @return boolean - */ - protected function hasCommand() - { - return $this->app->bound('rocketeer.command'); - } + use HasLocator; } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php new file mode 100644 index 000000000..3b66899ef --- /dev/null +++ b/src/Rocketeer/Traits/HasLocator.php @@ -0,0 +1,95 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Traits; + +use Illuminate\Container\Container; + +/** + * An abstract for Service Locator-based classes with adds + * a few shortcuts to Rocketeer classes + * + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Server server + * @property \Rocketeer\Abstracts\Scm scm + * @author Maxime Fabre + */ +trait HasLocator +{ + /** + * The IoC Container + * + * @var Container + */ + protected $app; + + /** + * Build a new Task + * + * @param Container $app + */ + public function __construct(Container $app) + { + $this->app = $app; + } + + /** + * Get an instance from the Container + * + * @param string $key + * + * @return object + */ + public function __get($key) + { + $shortcuts = array( + 'connections' => 'rocketeer.connections', + 'command' => 'rocketeer.command', + 'console' => 'rocketeer.console', + 'logs' => 'rocketeer.logs', + 'queue' => 'rocketeer.queue', + 'releasesManager' => 'rocketeer.releases', + 'rocketeer' => 'rocketeer.rocketeer', + 'scm' => 'rocketeer.scm', + 'server' => 'rocketeer.server', + 'tasks' => 'rocketeer.tasks', + ); + + // Replace shortcuts + if (array_key_exists($key, $shortcuts)) { + $key = $shortcuts[$key]; + } + + return $this->app[$key]; + } + + /** + * Set an instance on the Container + * + * @param string $key + * @param object $value + */ + public function __set($key, $value) + { + $this->app[$key] = $value; + } + + /** + * Check if the current instance has a Command bound + * + * @return boolean + */ + protected function hasCommand() + { + return $this->app->bound('rocketeer.command'); + } +} diff --git a/tests/TasksQueueTest.php b/tests/TasksQueueTest.php index e78893938..7519aba39 100644 --- a/tests/TasksQueueTest.php +++ b/tests/TasksQueueTest.php @@ -11,7 +11,7 @@ public function testCanBuildTaskByName() { $task = $this->tasksQueue()->buildTaskFromClass('Rocketeer\Tasks\Deploy'); - $this->assertInstanceOf('Rocketeer\Traits\Task', $task); + $this->assertInstanceOf('Rocketeer\Abstracts\Task', $task); } public function testCanBuildCustomTaskByName() From afa6c086d0d7a38e32670ed677aa8650437176f3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 00:07:05 +0200 Subject: [PATCH 039/424] Add Locator trait to some classes --- .../Abstracts/AbstractLocatorClass.php | 31 ------------ src/Rocketeer/Abstracts/BashModules/Core.php | 5 +- src/Rocketeer/Abstracts/Plugin.php | 5 +- src/Rocketeer/ConnectionsHandler.php | 48 +++++++------------ src/Rocketeer/LogsHandler.php | 25 +++------- src/Rocketeer/ReleasesManager.php | 34 ++++++------- src/Rocketeer/Rocketeer.php | 30 ++++-------- src/Rocketeer/TasksHandler.php | 5 +- src/Rocketeer/TasksQueue.php | 5 +- src/Rocketeer/Traits/HasLocator.php | 7 ++- 10 files changed, 68 insertions(+), 127 deletions(-) delete mode 100644 src/Rocketeer/Abstracts/AbstractLocatorClass.php diff --git a/src/Rocketeer/Abstracts/AbstractLocatorClass.php b/src/Rocketeer/Abstracts/AbstractLocatorClass.php deleted file mode 100644 index b851f8c3c..000000000 --- a/src/Rocketeer/Abstracts/AbstractLocatorClass.php +++ /dev/null @@ -1,31 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ -namespace Rocketeer\Abstracts; - -use Rocketeer\Traits\HasLocator; - -/** - * An abstract for Service Locator-based classes with adds - * a few shortcuts to Rocketeer classes - * - * @property \Rocketeer\ConnectionsHandler connections - * @property \Illuminate\Console\Command command - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\ReleasesManager releasesManager - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Server server - * @property \Rocketeer\Abstracts\Scm scm - * - * @author Maxime Fabre - */ -abstract class AbstractLocatorClass -{ - use HasLocator; -} diff --git a/src/Rocketeer/Abstracts/BashModules/Core.php b/src/Rocketeer/Abstracts/BashModules/Core.php index d6725d143..128ca7e13 100644 --- a/src/Rocketeer/Abstracts/BashModules/Core.php +++ b/src/Rocketeer/Abstracts/BashModules/Core.php @@ -11,14 +11,17 @@ use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractLocatorClass; +use Rocketeer\Traits\HasLocator; /** * Core handling of running commands and returning output * * @author Maxime Fabre */ -class Core extends AbstractLocatorClass +class Core { + use HasLocator; + /** * An history of executed commands * diff --git a/src/Rocketeer/Abstracts/Plugin.php b/src/Rocketeer/Abstracts/Plugin.php index cec069382..41d5a1144 100644 --- a/src/Rocketeer/Abstracts/Plugin.php +++ b/src/Rocketeer/Abstracts/Plugin.php @@ -12,14 +12,17 @@ use Illuminate\Container\Container; use Illuminate\Support\Str; use Rocketeer\TasksHandler; +use Rocketeer\Traits\HasLocator; /** * A basic abstract class for Rocketeer plugins to extend * * @author Maxime Fabre */ -abstract class Plugin extends AbstractLocatorClass +abstract class Plugin { + use HasLocator; + /** * The path to the configuration folder * diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index fd494d3ee..fe00e8817 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -11,6 +11,7 @@ use Illuminate\Container\Container; use Illuminate\Support\Str; +use Rocketeer\Traits\HasLocator; /** * Handles, get and return, the various connections/stages @@ -20,12 +21,7 @@ */ class ConnectionsHandler { - /** - * The IoC Container - * - * @var Container - */ - protected $app; + use HasLocator; /** * The current stage @@ -48,16 +44,6 @@ class ConnectionsHandler */ protected $connection; - /** - * Build a new ReleasesManager - * - * @param Container $app - */ - public function __construct(Container $app) - { - $this->app = $app; - } - //////////////////////////////////////////////////////////////////// //////////////////////////////// STAGES //////////////////////////// //////////////////////////////////////////////////////////////////// @@ -75,7 +61,7 @@ public function setStage($stage) // If we do have a stage, cleanup previous events if ($stage) { - $this->app['rocketeer.tasks']->registerConfiguredEvents(); + $this->tasks->registerConfiguredEvents(); } } @@ -96,7 +82,7 @@ public function getStage() */ public function getStages() { - return $this->app['rocketeer.rocketeer']->getOption('stages.stages'); + return $this->rocketeer->getOption('stages.stages'); } //////////////////////////////////////////////////////////////////// @@ -123,13 +109,13 @@ public function needsCredentials() public function getAvailableConnections($connection = null) { // Fetch stored credentials - $storage = (array) $this->app['rocketeer.server']->getValue('connections'); + $storage = (array) $this->server->getValue('connections'); // Merge with defaults from config file - $configuration = (array) $this->app['config']->get('rocketeer::connections'); + $configuration = (array) $this->config->get('rocketeer::connections'); // Fetch from remote file - $remote = (array) $this->app['config']->get('remote.connections'); + $remote = (array) $this->config->get('remote.connections'); // Merge configurations $storage = array_replace_recursive($remote, $configuration, $storage); @@ -164,8 +150,8 @@ public function getConnections() } // Get all and defaults - $connections = (array) $this->app['config']->get('rocketeer::default'); - $default = $this->app['config']->get('remote.default'); + $connections = (array) $this->config->get('rocketeer::default'); + $default = $this->config->get('remote.default'); // Remove invalid connections $instance = $this; @@ -228,14 +214,14 @@ public function syncConnectionCredentials($connection = null, array $credentials { // Store credentials if any if ($credentials) { - $this->app['rocketeer.server']->setValue('connections.'.$connection, $credentials); + $this->server->setValue('connections.'.$connection, $credentials); } // Get connection $connection = $connection ?: $this->getConnection(); $credentials = $this->getConnectionCredentials($connection); - $this->app['config']->set('remote.connections.'.$connection, $credentials); + $this->config->set('remote.connections.'.$connection, $credentials); } /** @@ -265,10 +251,10 @@ public function setConnection($connection) // Set the connection $this->connection = $connection; - $this->app['config']->set('remote.default', $connection); + $this->config->set('remote.default', $connection); // Update events - $this->app['rocketeer.tasks']->registerConfiguredEvents(); + $this->tasks->registerConfiguredEvents(); } /** @@ -293,9 +279,9 @@ public function disconnect() */ public function getCredentials() { - $credentials = $this->app['rocketeer.server']->getValue('credentials'); + $credentials = $this->server->getValue('credentials'); if (!$credentials) { - $credentials = $this->app['rocketeer.rocketeer']->getOption('scm'); + $credentials = $this->rocketeer->getOption('scm'); } // Cast to array @@ -343,9 +329,9 @@ public function getRepository() */ public function getRepositoryBranch() { - exec($this->app['rocketeer.scm']->currentBranch(), $fallback); + exec($this->scm->currentBranch(), $fallback); $fallback = trim($fallback[0]) ?: 'master'; - $branch = $this->app['rocketeer.rocketeer']->getOption('scm.branch') ?: $fallback; + $branch = $this->rocketeer->getOption('scm.branch') ?: $fallback; return $branch; } diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/LogsHandler.php index 244a273dc..15756c8c6 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/LogsHandler.php @@ -10,12 +10,15 @@ namespace Rocketeer; use Illuminate\Container\Container; +use Rocketeer\Traits\HasLocator; /** * Handles rotation of logs */ class LogsHandler { + use HasLocator; + /** * The loggers instances * @@ -23,23 +26,6 @@ class LogsHandler */ protected $loggers = array(); - /** - * The Container - * - * @var Container - */ - protected $app; - - /** - * Build a new LogsHandler instance - * - * @param Container $app - */ - public function __construct(Container $app) - { - $this->app = $app; - } - /** * Log by level * @@ -71,12 +57,13 @@ public function log($informations, $level = 'info') */ public function getCurrentLogsFile() { - $logs = $this->app['config']->get('rocketeer::logs'); + /** @type \Callable $logs */ + $logs = $this->config->get('rocketeer::logs'); if (!$logs) { return false; } - $file = $logs($this->app['rocketeer.connections']); + $file = $logs($this->connections); $file = $this->app['path.rocketeer.logs'].'/'.$file; return $file; diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index 032d82608..5f62ca578 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -10,6 +10,7 @@ namespace Rocketeer; use Illuminate\Container\Container; +use Rocketeer\Traits\HasLocator; /** * Provides informations and actions around releases @@ -18,12 +19,7 @@ */ class ReleasesManager { - /** - * The IoC Container - * - * @var Container - */ - protected $app; + use HasLocator; /** * Cache of the validation file @@ -64,7 +60,7 @@ public function getReleases() // Get releases on server if (!$this->releases) { $releases = $this->getReleasesPath(); - $releases = $this->app['rocketeer.bash']->listContents($releases); + $releases = $this->bash->listContents($releases); if (is_array($releases)) { rsort($releases); } @@ -83,7 +79,7 @@ public function getReleases() public function getDeprecatedReleases() { $releases = (array) $this->getReleases(); - $maxReleases = $this->app['config']->get('rocketeer::remote.keep_releases'); + $maxReleases = $this->config->get('rocketeer::remote.keep_releases'); return array_slice($releases, $maxReleases); } @@ -125,7 +121,7 @@ public function getNonCurrentReleases() */ public function getReleasesPath() { - return $this->app['rocketeer.rocketeer']->getFolder('releases'); + return $this->rocketeer->getFolder('releases'); } /** @@ -137,7 +133,7 @@ public function getReleasesPath() */ public function getPathToRelease($release) { - return $this->app['rocketeer.rocketeer']->getFolder('releases/'.$release); + return $this->rocketeer->getFolder('releases/'.$release); } /** @@ -168,8 +164,8 @@ public function getCurrentReleasePath($folder = null) public function getValidationFile() { // Get the contents of the validation file - $file = $this->app['rocketeer.rocketeer']->getFolder('state.json'); - $file = $this->app['rocketeer.bash']->getFile($file) ?: '{}'; + $file = $this->rocketeer->getFolder('state.json'); + $file = $this->bash->getFile($file) ?: '{}'; $file = (array) json_decode($file, true); // Fill the missing releases @@ -194,8 +190,8 @@ public function getValidationFile() */ public function saveValidationFile(array $validation) { - $file = $this->app['rocketeer.rocketeer']->getFolder('state.json'); - $this->app['rocketeer.bash']->putFile($file, json_encode($validation)); + $file = $this->rocketeer->getFolder('state.json'); + $this->bash->putFile($file, json_encode($validation)); $this->state = $validation; } @@ -251,8 +247,8 @@ protected function getCurrentReleaseKey() $key = 'current_release'; // Get the scopes - $connection = $this->app['rocketeer.connections']->getConnection(); - $stage = $this->app['rocketeer.connections']->getStage(); + $connection = $this->connections->getConnection(); + $stage = $this->connections->getStage(); $scopes = array($connection, $stage); foreach ($scopes as $scope) { $key .= $scope ? '.'.$scope : ''; @@ -269,7 +265,7 @@ protected function getCurrentReleaseKey() public function getCurrentRelease() { // If we have saved the last deployed release, return that - $cached = $this->app['rocketeer.server']->getValue($this->getCurrentReleaseKey()); + $cached = $this->server->getValue($this->getCurrentReleaseKey()); if ($cached) { return $this->sanitizeRelease($cached); } @@ -315,10 +311,10 @@ public function getPreviousRelease($release = null) public function updateCurrentRelease($release = null) { if (!$release) { - $release = $this->app['rocketeer.bash']->getTimestamp(); + $release = $this->bash->getTimestamp(); } - $this->app['rocketeer.server']->setValue($this->getCurrentReleaseKey(), $release); + $this->server->setValue($this->getCurrentReleaseKey(), $release); return $release; } diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 9aabd013f..8e5efe1e1 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -12,6 +12,7 @@ use Exception; use Illuminate\Container\Container; use Illuminate\Support\Str; +use Rocketeer\Traits\HasLocator; /** * Handles interaction between the User provided informations @@ -21,12 +22,7 @@ */ class Rocketeer { - /** - * The IoC Container - * - * @var Container - */ - protected $app; + use HasLocator; /** * The Rocketeer version @@ -35,16 +31,6 @@ class Rocketeer */ const VERSION = '2.0.0'; - /** - * Build a new ReleasesManager - * - * @param Container $app - */ - public function __construct(Container $app) - { - $this->app = $app; - } - /** * Get the name of the application to deploy * @@ -52,7 +38,7 @@ public function __construct(Container $app) */ public function getApplicationName() { - return $this->app['config']->get('rocketeer::application_name'); + return $this->config->get('rocketeer::application_name'); } /** @@ -64,7 +50,7 @@ public function getApplicationName() */ public function getOption($option) { - $original = $this->app['config']->get('rocketeer::'.$option); + $original = $this->config->get('rocketeer::'.$option); if ($contextual = $this->getContextualOption($option, 'stages', $original)) { return $contextual; @@ -91,11 +77,11 @@ protected function getContextualOption($option, $type, $original = null) // Switch context switch ($type) { case 'stages': - $contextual = sprintf('rocketeer::on.stages.%s.%s', $this->app['rocketeer.connections']->getStage(), $option); + $contextual = sprintf('rocketeer::on.stages.%s.%s', $this->connections->getStage(), $option); break; case 'connections': - $contextual = sprintf('rocketeer::on.connections.%s.%s', $this->app['rocketeer.connections']->getConnection(), $option); + $contextual = sprintf('rocketeer::on.connections.%s.%s', $this->connections->getConnection(), $option); break; default: @@ -104,7 +90,7 @@ protected function getContextualOption($option, $type, $original = null) } // Merge with defaults - $value = $this->app['config']->get($contextual); + $value = $this->config->get($contextual); if (is_array($value) and $original) { $value = array_replace($original, $value); } @@ -179,7 +165,7 @@ public function getFolder($folder = null) $folder = $this->replacePatterns($folder); $base = $this->getHomeFolder().'/'; - $stage = $this->app['rocketeer.connections']->getStage(); + $stage = $this->connections->getStage(); if ($folder and $stage) { $base .= $stage.'/'; } diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index dd46943e5..3798b5392 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -12,14 +12,17 @@ use Illuminate\Container\Container; use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Commands\BaseTaskCommand; +use Rocketeer\Traits\HasLocator; /** * Handles the registering and relating of tasks * * @author Maxime Fabre */ -class TasksHandler extends AbstractLocatorClass +class TasksHandler { + use HasLocator; + /** * The registered events * diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index d8d07723f..ee23e0312 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -12,14 +12,17 @@ use Closure; use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Abstracts\Task; +use Rocketeer\Traits\HasLocator; /** * Handles the building and execution of tasks * * @author Maxime Fabre */ -class TasksQueue extends AbstractLocatorClass +class TasksQueue { + use HasLocator; + /** * A list of Tasks to execute * diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 3b66899ef..adf136774 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,12 +15,16 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * + * @property \Illuminate\Config\Repository config * @property \Illuminate\Console\Command command * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\Scm scm * @property \Rocketeer\ReleasesManager releasesManager * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Server server - * @property \Rocketeer\Abstracts\Scm scm + * @property \Rocketeer\TasksHandler tasks + * @property \Rocketeer\TasksQueue queue + * @property \Rocketeer\Bash bash * @author Maxime Fabre */ trait HasLocator @@ -52,6 +56,7 @@ public function __construct(Container $app) public function __get($key) { $shortcuts = array( + 'bash' => 'rocketeer.bash', 'connections' => 'rocketeer.connections', 'command' => 'rocketeer.command', 'console' => 'rocketeer.console', From 916826f136cdcecef48c25ad9d2daa55595dbaa2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 00:10:27 +0200 Subject: [PATCH 040/424] Move Bash modules to be actual modules --- src/Rocketeer/Abstracts/Plugin.php | 2 +- src/Rocketeer/Bash.php | 15 ++++++++++++--- .../BashModules/Binaries.php | 4 ++-- .../{Abstracts => Traits}/BashModules/Core.php | 4 ++-- .../BashModules/Filesystem.php | 4 ++-- .../{Abstracts => Traits}/BashModules/Flow.php | 4 ++-- .../{Abstracts => Traits}/BashModules/Scm.php | 4 ++-- 7 files changed, 23 insertions(+), 14 deletions(-) rename src/Rocketeer/{Abstracts => Traits}/BashModules/Binaries.php (98%) rename src/Rocketeer/{Abstracts => Traits}/BashModules/Core.php (99%) rename src/Rocketeer/{Abstracts => Traits}/BashModules/Filesystem.php (98%) rename src/Rocketeer/{Abstracts => Traits}/BashModules/Flow.php (97%) rename src/Rocketeer/{Abstracts => Traits}/BashModules/Scm.php (97%) diff --git a/src/Rocketeer/Abstracts/Plugin.php b/src/Rocketeer/Abstracts/Plugin.php index 41d5a1144..68c11403c 100644 --- a/src/Rocketeer/Abstracts/Plugin.php +++ b/src/Rocketeer/Abstracts/Plugin.php @@ -22,7 +22,7 @@ abstract class Plugin { use HasLocator; - + /** * The path to the configuration folder * diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index 126bac31a..bf03891bf 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -9,13 +9,22 @@ */ namespace Rocketeer; +use Rocketeer\Traits\BashModules\Binaries; +use Rocketeer\Traits\BashModules\Core; +use Rocketeer\Traits\BashModules\Filesystem; +use Rocketeer\Traits\BashModules\Flow; +use Rocketeer\Traits\BashModules\Scm; + /** * An helper to execute low-level commands on the remote server * * @author Maxime Fabre */ -class Bash extends Abstracts\BashModules\Flow +class Bash { - // Composite class - // Don't ask. + use Core; + use Binaries; + use Filesystem; + use Flow; + use Scm; } diff --git a/src/Rocketeer/Abstracts/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php similarity index 98% rename from src/Rocketeer/Abstracts/BashModules/Binaries.php rename to src/Rocketeer/Traits/BashModules/Binaries.php index 1b4aecf2d..a02d4f31e 100644 --- a/src/Rocketeer/Abstracts/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -7,14 +7,14 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Abstracts\BashModules; +namespace Rocketeer\Traits\BashModules; /** * Handles finding and calling binaries * * @author Maxime Fabre */ -class Binaries extends Filesystem +trait Binaries { //////////////////////////////////////////////////////////////////// /////////////////////////////// BINARIES /////////////////////////// diff --git a/src/Rocketeer/Abstracts/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php similarity index 99% rename from src/Rocketeer/Abstracts/BashModules/Core.php rename to src/Rocketeer/Traits/BashModules/Core.php index 128ca7e13..99842aa97 100644 --- a/src/Rocketeer/Abstracts/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Abstracts\BashModules; +namespace Rocketeer\Traits\BashModules; use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractLocatorClass; @@ -18,7 +18,7 @@ * * @author Maxime Fabre */ -class Core +trait Core { use HasLocator; diff --git a/src/Rocketeer/Abstracts/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php similarity index 98% rename from src/Rocketeer/Abstracts/BashModules/Filesystem.php rename to src/Rocketeer/Traits/BashModules/Filesystem.php index fc7c0c2b1..f94105a39 100644 --- a/src/Rocketeer/Abstracts/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -7,14 +7,14 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Abstracts\BashModules; +namespace Rocketeer\Traits\BashModules; /** * Files and folders handling * * @author Maxime Fabre */ -class Filesystem extends Core +trait Filesystem { //////////////////////////////////////////////////////////////////// /////////////////////////////// COMMON ///////////////////////////// diff --git a/src/Rocketeer/Abstracts/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php similarity index 97% rename from src/Rocketeer/Abstracts/BashModules/Flow.php rename to src/Rocketeer/Traits/BashModules/Flow.php index e9ec80fd3..ca950e986 100644 --- a/src/Rocketeer/Abstracts/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -7,14 +7,14 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Abstracts\BashModules; +namespace Rocketeer\Traits\BashModules; /** * Handles the deployment flow (current/releases/shared) * * @author Maxime Fabre */ -class Flow extends Scm +trait Flow { /** * Check if the remote server is setup diff --git a/src/Rocketeer/Abstracts/BashModules/Scm.php b/src/Rocketeer/Traits/BashModules/Scm.php similarity index 97% rename from src/Rocketeer/Abstracts/BashModules/Scm.php rename to src/Rocketeer/Traits/BashModules/Scm.php index 36d341390..289f65a74 100644 --- a/src/Rocketeer/Abstracts/BashModules/Scm.php +++ b/src/Rocketeer/Traits/BashModules/Scm.php @@ -7,14 +7,14 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Abstracts\BashModules; +namespace Rocketeer\Traits\BashModules; /** * Repository handling * * @author Maxime Fabre */ -class Scm extends Binaries +trait Scm { /** * Copies the repository into a release folder and update it From c4a5c96defbdedae289a99cb7e66fa5f3004495e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 00:13:04 +0200 Subject: [PATCH 041/424] Update tests folder structure --- .../Commands/AbstractDeployCommand.php | 11 +- src/Rocketeer/Commands/DeployCommand.php | 8 +- src/Rocketeer/Commands/UpdateCommand.php | 2 +- src/Rocketeer/ConnectionsHandler.php | 1 - src/Rocketeer/LogsHandler.php | 1 - src/Rocketeer/Rocketeer.php | 1 - src/Rocketeer/Tasks/Check.php | 12 +- src/Rocketeer/Traits/BashModules/Binaries.php | 6 +- tests/{Traits => Abstracts}/ScmTest.php | 0 tests/{Traits => Abstracts}/TaskTest.php | 0 tests/ConnectionsHandlerTest.php | 141 ++++++++++++++++++ tests/RocketeerTest.php | 130 ---------------- tests/Traits/BashModules/BinariesTest.php | 2 +- tests/Traits/BashModules/CoreTest.php | 2 +- tests/Traits/BashModules/FilesystemTest.php | 2 +- tests/Traits/BashModules/ScmTest.php | 2 +- 16 files changed, 167 insertions(+), 154 deletions(-) rename tests/{Traits => Abstracts}/ScmTest.php (100%) rename tests/{Traits => Abstracts}/TaskTest.php (100%) create mode 100644 tests/ConnectionsHandlerTest.php diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 66cf4751d..740291bed 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -35,9 +35,14 @@ abstract public function fire(); protected function getOptions() { return array( - array('pretend', 'p', InputOption::VALUE_NONE, 'Returns an array of commands to be executed instead of actually executing them'), - array('on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'), - array('stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in') + array( + 'pretend', + 'p', + InputOption::VALUE_NONE, + 'Returns an array of commands to be executed instead of actually executing them' + ), + array('on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'), + array('stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in') ); } diff --git a/src/Rocketeer/Commands/DeployCommand.php b/src/Rocketeer/Commands/DeployCommand.php index b0157cad4..adeb6c9a9 100644 --- a/src/Rocketeer/Commands/DeployCommand.php +++ b/src/Rocketeer/Commands/DeployCommand.php @@ -53,10 +53,10 @@ public function fire() protected function getOptions() { return array_merge(parent::getOptions(), array( - array('tests', 't', InputOption::VALUE_NONE, 'Runs the tests on deploy'), - array('migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'), - array('seed', 's', InputOption::VALUE_NONE, 'Seed the database (after migrating it if --migrate)'), - array('clean-all', null, InputOption::VALUE_NONE, 'Cleanup all but the current release on deploy'), + array('tests', 't', InputOption::VALUE_NONE, 'Runs the tests on deploy'), + array('migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'), + array('seed', 's', InputOption::VALUE_NONE, 'Seed the database (after migrating it if --migrate)'), + array('clean-all', null, InputOption::VALUE_NONE, 'Cleanup all but the current release on deploy'), )); } } diff --git a/src/Rocketeer/Commands/UpdateCommand.php b/src/Rocketeer/Commands/UpdateCommand.php index 0aeb9ec6e..9fa15d0ce 100644 --- a/src/Rocketeer/Commands/UpdateCommand.php +++ b/src/Rocketeer/Commands/UpdateCommand.php @@ -51,7 +51,7 @@ protected function getOptions() { return array_merge(parent::getOptions(), array( array('migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'), - array('seed', 's', InputOption::VALUE_NONE, 'Seed the database after migrating the database'), + array('seed', 's', InputOption::VALUE_NONE, 'Seed the database after migrating the database'), )); } } diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index fe00e8817..16962a772 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -9,7 +9,6 @@ */ namespace Rocketeer; -use Illuminate\Container\Container; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/LogsHandler.php index 15756c8c6..91db5b379 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/LogsHandler.php @@ -9,7 +9,6 @@ */ namespace Rocketeer; -use Illuminate\Container\Container; use Rocketeer\Traits\HasLocator; /** diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 8e5efe1e1..54abf7395 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -10,7 +10,6 @@ namespace Rocketeer; use Exception; -use Illuminate\Container\Container; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index e30066b9f..d76f05ec7 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -86,13 +86,13 @@ protected function getChecks() $session = $this->app['config']->get('session.driver'); return array( - array('checkScm', $this->scm->binary. ' could not be found'), - array('checkPhpVersion', 'The version of PHP on the server does not match Laravel\'s requirements'), - array('checkComposer', 'Composer does not seem to be present on the server'), - array('checkPhpExtension', array('mcrypt', sprintf($extension, 'mcrypt'))), + array('checkScm', $this->scm->binary.' could not be found'), + array('checkPhpVersion', 'The version of PHP on the server does not match Laravel\'s requirements'), + array('checkComposer', 'Composer does not seem to be present on the server'), + array('checkPhpExtension', array('mcrypt', sprintf($extension, 'mcrypt'))), array('checkDatabaseDriver', array($database, sprintf($extension, $database))), - array('checkCacheDriver', array($cache, sprintf($extension, $cache))), - array('checkCacheDriver', array($session, sprintf($extension, $session))), + array('checkCacheDriver', array($cache, sprintf($extension, $cache))), + array('checkCacheDriver', array($session, sprintf($extension, $session))), ); } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index a02d4f31e..a244af5cc 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -211,9 +211,9 @@ public function which($binary, $fallback = null) { $location = false; $locations = array( - array($this->server, 'getValue', 'paths.'.$binary), - array($this->rocketeer, 'getPath', $binary), - array($this, 'runSilently', 'which '.$binary), + array($this->server, 'getValue', 'paths.'.$binary), + array($this->rocketeer, 'getPath', $binary), + array($this, 'runSilently', 'which '.$binary), ); // Add fallback if provided diff --git a/tests/Traits/ScmTest.php b/tests/Abstracts/ScmTest.php similarity index 100% rename from tests/Traits/ScmTest.php rename to tests/Abstracts/ScmTest.php diff --git a/tests/Traits/TaskTest.php b/tests/Abstracts/TaskTest.php similarity index 100% rename from tests/Traits/TaskTest.php rename to tests/Abstracts/TaskTest.php diff --git a/tests/ConnectionsHandlerTest.php b/tests/ConnectionsHandlerTest.php new file mode 100644 index 000000000..fcf42e7f9 --- /dev/null +++ b/tests/ConnectionsHandlerTest.php @@ -0,0 +1,141 @@ +app['rocketeer.connections']->getAvailableConnections(); + $this->assertEquals(array('production', 'staging'), array_keys($connections)); + + $this->app['rocketeer.server']->setValue('connections.custom.username', 'foobar'); + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); + } + + public function testCanGetCurrentConnection() + { + $this->swapConfig(array('rocketeer::default' => 'foobar')); + $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); + + $this->swapConfig(array('rocketeer::default' => 'production')); + $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); + + $this->swapConfig(array('rocketeer::default' => 'staging')); + $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); + } + + public function testCanChangeConnection() + { + $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); + + $this->app['rocketeer.connections']->setConnection('staging'); + $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); + + $this->app['rocketeer.connections']->setConnections('staging,production'); + $this->assertEquals(array('staging', 'production'), $this->app['rocketeer.connections']->getConnections()); + } + + public function testCanUseSshRepository() + { + $repository = 'git@github.com:'.$this->repository; + $this->expectRepositoryConfig($repository, '', ''); + + $this->assertEquals($repository, $this->app['rocketeer.connections']->getRepository()); + } + + public function testCanUseHttpsRepository() + { + $this->expectRepositoryConfig('https://github.com/'.$this->repository, 'foobar', 'bar'); + + $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + } + + public function testCanUseHttpsRepositoryWithUsernameProvided() + { + $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', 'bar'); + + $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + } + + public function testCanUseHttpsRepositoryWithOnlyUsernameProvided() + { + $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', ''); + + $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + } + + public function testCanCleanupProvidedRepositoryFromCredentials() + { + $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'Anahkiasen', ''); + + $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + } + + public function testCanUseHttpsRepositoryWithoutCredentials() + { + $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); + + $this->assertEquals('https://github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + } + + public function testCanCheckIfRepositoryNeedsCredentials() + { + $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); + $this->assertTrue($this->app['rocketeer.connections']->needsCredentials()); + } + + public function testCangetRepositoryBranch() + { + $this->assertEquals('master', $this->app['rocketeer.connections']->getRepositoryBranch()); + } + + public function testFillsConnectionCredentialsHoles() + { + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $this->assertArrayHasKey('production', $connections); + + $this->app['rocketeer.server']->setValue('connections', array( + 'staging' => array( + 'host' => 'foobar', + 'username' => 'user', + 'password' => '', + 'keyphrase' => '', + 'key' => '/Users/user/.ssh/id_rsa', + 'agent' => '' + ), + )); + $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $this->assertArrayHasKey('production', $connections); + } + + //////////////////////////////////////////////////////////////////// + //////////////////////////////// HELPERS /////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Make the config return specific SCM config + * + * @param string $repository + * @param string $username + * @param string $password + * + * @return void + */ + protected function expectRepositoryConfig($repository, $username, $password) + { + $this->swapConfig(array( + 'rocketeer::scm' => array( + 'repository' => $repository, + 'username' => $username, + 'password' => $password, + ), + )); + } +} diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 8991ea639..305cbe224 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -9,93 +9,6 @@ class RocketeerTest extends RocketeerTestCase //////////////////////////////// TESTS ///////////////////////////// //////////////////////////////////////////////////////////////////// - public function testCanGetAvailableConnections() - { - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); - $this->assertEquals(array('production', 'staging'), array_keys($connections)); - - $this->app['rocketeer.server']->setValue('connections.custom.username', 'foobar'); - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); - $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); - } - - public function testCanGetCurrentConnection() - { - $this->swapConfig(array('rocketeer::default' => 'foobar')); - $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); - - $this->swapConfig(array('rocketeer::default' => 'production')); - $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); - - $this->swapConfig(array('rocketeer::default' => 'staging')); - $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); - } - - public function testCanChangeConnection() - { - $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); - - $this->app['rocketeer.connections']->setConnection('staging'); - $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); - - $this->app['rocketeer.connections']->setConnections('staging,production'); - $this->assertEquals(array('staging', 'production'), $this->app['rocketeer.connections']->getConnections()); - } - - public function testCanUseSshRepository() - { - $repository = 'git@github.com:'.$this->repository; - $this->expectRepositoryConfig($repository, '', ''); - - $this->assertEquals($repository, $this->app['rocketeer.connections']->getRepository()); - } - - public function testCanUseHttpsRepository() - { - $this->expectRepositoryConfig('https://github.com/'.$this->repository, 'foobar', 'bar'); - - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); - } - - public function testCanUseHttpsRepositoryWithUsernameProvided() - { - $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', 'bar'); - - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); - } - - public function testCanUseHttpsRepositoryWithOnlyUsernameProvided() - { - $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', ''); - - $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); - } - - public function testCanCleanupProvidedRepositoryFromCredentials() - { - $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'Anahkiasen', ''); - - $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); - } - - public function testCanUseHttpsRepositoryWithoutCredentials() - { - $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - - $this->assertEquals('https://github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); - } - - public function testCanCheckIfRepositoryNeedsCredentials() - { - $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - $this->assertTrue($this->app['rocketeer.connections']->needsCredentials()); - } - - public function testCangetRepositoryBranch() - { - $this->assertEquals('master', $this->app['rocketeer.connections']->getRepositoryBranch()); - } - public function testCanGetApplicationName() { $this->assertEquals('foobar', $this->app['rocketeer.rocketeer']->getApplicationName()); @@ -175,47 +88,4 @@ public function testRocketeerCanGuessWhichStageHesIn() $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals(false, $stage); } - - public function testFillsConnectionCredentialsHoles() - { - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); - $this->assertArrayHasKey('production', $connections); - - $this->app['rocketeer.server']->setValue('connections', array( - 'staging' => array( - 'host' => 'foobar', - 'username' => 'user', - 'password' => '', - 'keyphrase' => '', - 'key' => '/Users/user/.ssh/id_rsa', - 'agent' => '' - ), - )); - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); - $this->assertArrayHasKey('production', $connections); - } - - //////////////////////////////////////////////////////////////////// - //////////////////////////////// HELPERS /////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Make the config return specific SCM config - * - * @param string $repository - * @param string $username - * @param string $password - * - * @return void - */ - protected function expectRepositoryConfig($repository, $username, $password) - { - $this->swapConfig(array( - 'rocketeer::scm' => array( - 'repository' => $repository, - 'username' => $username, - 'password' => $password, - ), - )); - } } diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 33e1b2072..87a969d07 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -1,5 +1,5 @@ Date: Wed, 6 Aug 2014 00:34:12 +0200 Subject: [PATCH 042/424] Fix some docblocks --- src/Rocketeer/Abstracts/Scm.php | 22 +++++++------------ src/Rocketeer/Abstracts/Task.php | 6 ++--- .../Commands/AbstractDeployCommand.php | 21 +++++------------- src/Rocketeer/Commands/BaseTaskCommand.php | 6 ++--- src/Rocketeer/Commands/CleanupCommand.php | 8 +++---- src/Rocketeer/Commands/DeployCommand.php | 14 +++++------- src/Rocketeer/Commands/FlushCommand.php | 2 -- src/Rocketeer/Commands/RocketeerCommand.php | 2 -- src/Rocketeer/Commands/RollbackCommand.php | 12 +++++----- src/Rocketeer/Commands/TestCommand.php | 4 +--- src/Rocketeer/Commands/UpdateCommand.php | 10 ++++----- src/Rocketeer/ConnectionsHandler.php | 22 ++++++++----------- src/Rocketeer/Console/Compiler.php | 20 +++++++---------- src/Rocketeer/Traits/HasLocator.php | 2 +- 14 files changed, 57 insertions(+), 94 deletions(-) diff --git a/src/Rocketeer/Abstracts/Scm.php b/src/Rocketeer/Abstracts/Scm.php index aa543282f..1653d5e77 100644 --- a/src/Rocketeer/Abstracts/Scm.php +++ b/src/Rocketeer/Abstracts/Scm.php @@ -9,6 +9,8 @@ */ namespace Rocketeer\Abstracts; +use Rocketeer\Traits\HasLocator; + /** * An abstract class with helpers for SCM implementations * @@ -16,22 +18,14 @@ */ abstract class Scm { - /** - * The IoC Container - * - * @var Container - */ - protected $app; + use HasLocator; /** - * Build a new Git instance + * The core binary * - * @param Container $app + * @var string */ - public function __construct($app) - { - $this->app = $app; - } + public $binary; //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// @@ -58,7 +52,7 @@ public function getCommand() * @param string $command * @param string $arguments,... * - * @return mixed + * @return string|array */ public function execute() { @@ -66,6 +60,6 @@ public function execute() $command = array_shift($arguments); $command = call_user_func_array(array($this, $command), $arguments); - return $this->app['rocketeer.bash']->run($command); + return $this->bash->run($command); } } diff --git a/src/Rocketeer/Abstracts/Task.php b/src/Rocketeer/Abstracts/Task.php index 2c93cb195..7f611380e 100644 --- a/src/Rocketeer/Abstracts/Task.php +++ b/src/Rocketeer/Abstracts/Task.php @@ -105,7 +105,7 @@ abstract public function execute(); /** * Fire the command * - * @return array + * @return array|false */ public function fire() { @@ -123,7 +123,7 @@ public function fire() /** * Cancel the task * - * @param string $errors Potential errors to display + * @param string|null $errors Potential errors to display * * @return boolean */ @@ -158,7 +158,7 @@ public function wasHalted() * * @param string $event * - * @return array|null + * @return boolean */ public function fireEvent($event) { diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 740291bed..c06a44346 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -30,19 +30,14 @@ abstract public function fire(); /** * Get the console command options. * - * @return array + * @return string[][] */ protected function getOptions() { return array( - array( - 'pretend', - 'p', - InputOption::VALUE_NONE, - 'Returns an array of commands to be executed instead of actually executing them' - ), - array('on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'), - array('stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in') + ['pretend', 'p', InputOption::VALUE_NONE, 'Returns an array of commands to be executed instead of actually executing them'], + ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], + ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'] ); } @@ -79,9 +74,7 @@ public function isInsideLaravel() /** * Fire a Tasks Queue * - * @param string|array $tasks - * - * @return mixed + * @param string|string[]|\Rocketeer\Abstracts\Task[] $tasks */ protected function fireTasksQueue($tasks) { @@ -170,10 +163,8 @@ protected function getServerCredentials() /** * Verifies and stores credentials for the given connection name * - * @param string $connections + * @param array $connections * @param string $connectionName - * - * @return void */ protected function storeServerCredentials($connections, $connectionName) { diff --git a/src/Rocketeer/Commands/BaseTaskCommand.php b/src/Rocketeer/Commands/BaseTaskCommand.php index 372093bb4..5fd70b349 100644 --- a/src/Rocketeer/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Commands/BaseTaskCommand.php @@ -36,8 +36,8 @@ class BaseTaskCommand extends AbstractDeployCommand /** * Build a new custom command * - * @param Task $task - * @param string $name A name for the command + * @param Task $task + * @param string|null $name A name for the command */ public function __construct(Task $task, $name = null) { @@ -62,7 +62,7 @@ public function __construct(Task $task, $name = null) */ public function fire() { - return $this->fireTasksQueue($this->task->getSlug()); + $this->fireTasksQueue($this->task->getSlug()); } /** diff --git a/src/Rocketeer/Commands/CleanupCommand.php b/src/Rocketeer/Commands/CleanupCommand.php index 538a84c7b..10c3f3d48 100644 --- a/src/Rocketeer/Commands/CleanupCommand.php +++ b/src/Rocketeer/Commands/CleanupCommand.php @@ -34,23 +34,21 @@ class CleanupCommand extends AbstractDeployCommand /** * Execute the tasks - * - * @return array */ public function fire() { - return $this->fireTasksQueue('cleanup'); + $this->fireTasksQueue('cleanup'); } /** * Get the console command options. * - * @return array + * @return string[][] */ protected function getOptions() { return array_merge(parent::getOptions(), array( - array('clean-all', null, InputOption::VALUE_NONE, 'Cleans up all non-current releases'), + ['clean-all', null, InputOption::VALUE_NONE, 'Cleans up all non-current releases'], )); } } diff --git a/src/Rocketeer/Commands/DeployCommand.php b/src/Rocketeer/Commands/DeployCommand.php index adeb6c9a9..0fd7f01b4 100644 --- a/src/Rocketeer/Commands/DeployCommand.php +++ b/src/Rocketeer/Commands/DeployCommand.php @@ -34,12 +34,10 @@ class DeployCommand extends AbstractDeployCommand /** * Execute the tasks - * - * @return array */ public function fire() { - return $this->fireTasksQueue(array( + $this->fireTasksQueue(array( 'deploy', 'cleanup', )); @@ -48,15 +46,15 @@ public function fire() /** * Get the console command options. * - * @return array + * @return string[][] */ protected function getOptions() { return array_merge(parent::getOptions(), array( - array('tests', 't', InputOption::VALUE_NONE, 'Runs the tests on deploy'), - array('migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'), - array('seed', 's', InputOption::VALUE_NONE, 'Seed the database (after migrating it if --migrate)'), - array('clean-all', null, InputOption::VALUE_NONE, 'Cleanup all but the current release on deploy'), + ['tests', 't', InputOption::VALUE_NONE, 'Runs the tests on deploy'], + ['migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'], + ['seed', 's', InputOption::VALUE_NONE, 'Seed the database (after migrating it if --migrate)'], + ['clean-all', null, InputOption::VALUE_NONE, 'Cleanup all but the current release on deploy'], )); } } diff --git a/src/Rocketeer/Commands/FlushCommand.php b/src/Rocketeer/Commands/FlushCommand.php index 7339c7255..b5c9ecaed 100644 --- a/src/Rocketeer/Commands/FlushCommand.php +++ b/src/Rocketeer/Commands/FlushCommand.php @@ -32,8 +32,6 @@ class FlushCommand extends AbstractDeployCommand /** * Execute the tasks - * - * @return array */ public function fire() { diff --git a/src/Rocketeer/Commands/RocketeerCommand.php b/src/Rocketeer/Commands/RocketeerCommand.php index 42eade36d..e5ebaf72c 100644 --- a/src/Rocketeer/Commands/RocketeerCommand.php +++ b/src/Rocketeer/Commands/RocketeerCommand.php @@ -27,8 +27,6 @@ class RocketeerCommand extends DeployCommand /** * Displays the current version - * - * @return string */ public function fire() { diff --git a/src/Rocketeer/Commands/RollbackCommand.php b/src/Rocketeer/Commands/RollbackCommand.php index bdee7f2c2..d691c2f38 100644 --- a/src/Rocketeer/Commands/RollbackCommand.php +++ b/src/Rocketeer/Commands/RollbackCommand.php @@ -35,35 +35,33 @@ class RollbackCommand extends AbstractDeployCommand /** * The tasks to execute - * - * @return array */ public function fire() { - return $this->fireTasksQueue('rollback'); + $this->fireTasksQueue('rollback'); } /** * Get the console command arguments. * - * @return array + * @return string[][] */ protected function getArguments() { return array( - array('release', InputArgument::OPTIONAL, 'The release to rollback to'), + ['release', InputArgument::OPTIONAL, 'The release to rollback to'], ); } /** * Get the console command options. * - * @return array + * @return string[][] */ protected function getOptions() { return array_merge(parent::getOptions(), array( - array('list', 'L', InputOption::VALUE_NONE, 'Shows the available releases to rollback to'), + ['list', 'L', InputOption::VALUE_NONE, 'Shows the available releases to rollback to'], )); } } diff --git a/src/Rocketeer/Commands/TestCommand.php b/src/Rocketeer/Commands/TestCommand.php index 17137c9c5..61412954d 100644 --- a/src/Rocketeer/Commands/TestCommand.php +++ b/src/Rocketeer/Commands/TestCommand.php @@ -32,13 +32,11 @@ class TestCommand extends AbstractDeployCommand /** * The tasks to execute - * - * @return array */ public function fire() { $this->input->setOption('verbose', true); - return $this->fireTasksQueue('test'); + $this->fireTasksQueue('test'); } } diff --git a/src/Rocketeer/Commands/UpdateCommand.php b/src/Rocketeer/Commands/UpdateCommand.php index 9fa15d0ce..6b3315579 100644 --- a/src/Rocketeer/Commands/UpdateCommand.php +++ b/src/Rocketeer/Commands/UpdateCommand.php @@ -34,24 +34,22 @@ class UpdateCommand extends AbstractDeployCommand /** * Execute the tasks - * - * @return array */ public function fire() { - return $this->fireTasksQueue('update'); + $this->fireTasksQueue('update'); } /** * Get the console command options. * - * @return array + * @return string[][] */ protected function getOptions() { return array_merge(parent::getOptions(), array( - array('migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'), - array('seed', 's', InputOption::VALUE_NONE, 'Seed the database after migrating the database'), + ['migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'], + ['seed', 's', InputOption::VALUE_NONE, 'Seed the database after migrating the database'], )); } } diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 16962a772..884053264 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -77,7 +77,7 @@ public function getStage() /** * Get the various stages provided by the User * - * @return array + * @return string[] */ public function getStages() { @@ -103,7 +103,7 @@ public function needsCredentials() * * @param string|null $connection A connection to fetch from the resulting array * - * @return array + * @return string[][]|string[] */ public function getAvailableConnections($connection = null) { @@ -139,7 +139,7 @@ public function isValidConnection($connection) /** * Get the connection in use * - * @return string + * @return string[] */ public function getConnections() { @@ -190,9 +190,9 @@ public function getConnection() /** * Get the credentials for a particular connection * - * @param string $connection + * @param string|null $connection * - * @return array + * @return string[][] */ public function getConnectionCredentials($connection = null) { @@ -204,10 +204,8 @@ public function getConnectionCredentials($connection = null) /** * Sync Rocketeer's credentials with Laravel's * - * @param string $connection - * @param array $credentials - * - * @return void + * @param string|null $connection + * @param string[]|null $credentials */ public function syncConnectionCredentials($connection = null, array $credentials = array()) { @@ -226,7 +224,7 @@ public function syncConnectionCredentials($connection = null, array $credentials /** * Set the active connections * - * @param string|array $connections + * @param string|string[] $connections */ public function setConnections($connections) { @@ -258,8 +256,6 @@ public function setConnection($connection) /** * Flush active connection(s) - * - * @return void */ public function disconnect() { @@ -274,7 +270,7 @@ public function disconnect() /** * Get the credentials for the repository * - * @return array + * @return string[] */ public function getCredentials() { diff --git a/src/Rocketeer/Console/Compiler.php b/src/Rocketeer/Console/Compiler.php index c74af54c8..087cd6b70 100644 --- a/src/Rocketeer/Console/Compiler.php +++ b/src/Rocketeer/Console/Compiler.php @@ -56,8 +56,6 @@ public function __construct() * Extract an existing Phar * * @param string $destination - * - * @return void */ public function extract($destination) { @@ -123,25 +121,23 @@ public function compile() /** * Set the stub to use - * - * @return string */ protected function setStub() { - $this->box->getPhar()->setStub( - StubGenerator::create() - ->index('bin/rocketeer') - ->generate() - ); + $stub = StubGenerator::create() + ->index('bin/rocketeer') + ->generate(); + + $this->box->getPhar()->setStub($stub); } /** * Add a folder to the PHAR * - * @param string $folder - * @param array $ignore + * @param string $folder + * @param string[] $ignore * - * @return array + * @return string[] */ protected function addFolder($folder, array $ignore = array()) { diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index adf136774..9d80acec2 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -19,12 +19,12 @@ * @property \Illuminate\Console\Command command * @property \Illuminate\Remote\Connection remote * @property \Rocketeer\Abstracts\Scm scm + * @property \Rocketeer\Bash bash * @property \Rocketeer\ReleasesManager releasesManager * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Server server * @property \Rocketeer\TasksHandler tasks * @property \Rocketeer\TasksQueue queue - * @property \Rocketeer\Bash bash * @author Maxime Fabre */ trait HasLocator From bdbcd115ac9d70ee9095a32f2eeb6561be194586 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 00:52:20 +0200 Subject: [PATCH 043/424] More docblocks fixes --- src/Rocketeer/Abstracts/Scm.php | 2 +- src/Rocketeer/Abstracts/Task.php | 2 +- src/Rocketeer/Commands/BaseTaskCommand.php | 2 -- src/Rocketeer/Commands/CleanupCommand.php | 2 +- src/Rocketeer/Commands/DeployCommand.php | 2 +- src/Rocketeer/Console/Console.php | 6 +++--- src/Rocketeer/Igniter.php | 4 ++-- src/Rocketeer/LogsHandler.php | 4 ++-- src/Rocketeer/Plugins/Notifier.php | 2 +- src/Rocketeer/ReleasesManager.php | 20 ++++++++++---------- src/Rocketeer/TasksHandler.php | 1 + src/Rocketeer/Traits/BashModules/Core.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 21 +++++++++++---------- 13 files changed, 35 insertions(+), 35 deletions(-) diff --git a/src/Rocketeer/Abstracts/Scm.php b/src/Rocketeer/Abstracts/Scm.php index 1653d5e77..7749e7ded 100644 --- a/src/Rocketeer/Abstracts/Scm.php +++ b/src/Rocketeer/Abstracts/Scm.php @@ -52,7 +52,7 @@ public function getCommand() * @param string $command * @param string $arguments,... * - * @return string|array + * @return string|string[] */ public function execute() { diff --git a/src/Rocketeer/Abstracts/Task.php b/src/Rocketeer/Abstracts/Task.php index 7f611380e..3ab1d122b 100644 --- a/src/Rocketeer/Abstracts/Task.php +++ b/src/Rocketeer/Abstracts/Task.php @@ -105,7 +105,7 @@ abstract public function execute(); /** * Fire the command * - * @return array|false + * @return boolean */ public function fire() { diff --git a/src/Rocketeer/Commands/BaseTaskCommand.php b/src/Rocketeer/Commands/BaseTaskCommand.php index 5fd70b349..2168ec79e 100644 --- a/src/Rocketeer/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Commands/BaseTaskCommand.php @@ -57,8 +57,6 @@ public function __construct(Task $task, $name = null) /** * Fire the custom Task - * - * @return string */ public function fire() { diff --git a/src/Rocketeer/Commands/CleanupCommand.php b/src/Rocketeer/Commands/CleanupCommand.php index 10c3f3d48..9439bdbb2 100644 --- a/src/Rocketeer/Commands/CleanupCommand.php +++ b/src/Rocketeer/Commands/CleanupCommand.php @@ -43,7 +43,7 @@ public function fire() /** * Get the console command options. * - * @return string[][] + * @return array> */ protected function getOptions() { diff --git a/src/Rocketeer/Commands/DeployCommand.php b/src/Rocketeer/Commands/DeployCommand.php index 0fd7f01b4..9c502c857 100644 --- a/src/Rocketeer/Commands/DeployCommand.php +++ b/src/Rocketeer/Commands/DeployCommand.php @@ -46,7 +46,7 @@ public function fire() /** * Get the console command options. * - * @return string[][] + * @return array> */ protected function getOptions() { diff --git a/src/Rocketeer/Console/Console.php b/src/Rocketeer/Console/Console.php index cb1f8f284..86b1ddf7f 100644 --- a/src/Rocketeer/Console/Console.php +++ b/src/Rocketeer/Console/Console.php @@ -37,8 +37,8 @@ public function getHelp() /** * Build an help block * - * @param string $title - * @param array $informations + * @param string $title + * @param string[] $informations * * @return string */ @@ -55,7 +55,7 @@ protected function buildBlock($title, $informations) /** * Get current state of the CLI * - * @return array + * @return string[] */ protected function getCurrentState() { diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index e1bb6b5e7..fa4f863d2 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -84,8 +84,8 @@ public function exportConfiguration() /** * Replace placeholders in configuration * - * @param string $folder - * @param array $values + * @param string $folder + * @param string[] $values */ public function updateConfiguration($folder, array $values = array()) { diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/LogsHandler.php index 91db5b379..aca468560 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/LogsHandler.php @@ -52,7 +52,7 @@ public function log($informations, $level = 'info') /** * Get the logs file being currently used * - * @return string + * @return string|boolean */ public function getCurrentLogsFile() { @@ -73,7 +73,7 @@ public function getCurrentLogsFile() * * @param string $file * - * @return Illuminate\Log\Writer + * @return \Illuminate\Log\Writer */ protected function getLogger($file) { diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 454d3441d..a3103e328 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -54,7 +54,7 @@ abstract public function send($message); /** * Get the message's components * - * @return array + * @return string[] */ protected function getComponents() { diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index 5f62ca578..223b7f3ce 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -53,7 +53,7 @@ public function __construct(Container $app) /** * Get all the releases on the server * - * @return array + * @return integer[] */ public function getReleases() { @@ -74,7 +74,7 @@ public function getReleases() /** * Get an array of deprecated releases * - * @return array + * @return integer[] */ public function getDeprecatedReleases() { @@ -87,7 +87,7 @@ public function getDeprecatedReleases() /** * Get an array of invalid releases * - * @return array + * @return integer[] */ public function getInvalidReleases() { @@ -101,7 +101,7 @@ public function getInvalidReleases() /** * Get an array of non-current releases * - * @return array + * @return integer[] */ public function getNonCurrentReleases() { @@ -139,7 +139,7 @@ public function getPathToRelease($release) /** * Get the path to the current release * - * @param string $folder A folder in the release + * @param string|null $folder A folder in the release * * @return string */ @@ -230,7 +230,7 @@ public function checkReleaseState($release) * * @param string $release * - * @return string + * @return string|null */ protected function sanitizeRelease($release) { @@ -260,7 +260,7 @@ protected function getCurrentReleaseKey() /** * Get the current release * - * @return string + * @return string|null */ public function getCurrentRelease() { @@ -280,7 +280,7 @@ public function getCurrentRelease() /** * Get the release before the current one * - * @param string $release A release name + * @param string|null $release A release name * * @return string */ @@ -304,9 +304,9 @@ public function getPreviousRelease($release = null) /** * Update the current release * - * @param string $release A release name + * @param string|null $release A release name * - * @return void + * @return string */ public function updateCurrentRelease($release = null) { diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index 3798b5392..86cbd385d 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -9,6 +9,7 @@ */ namespace Rocketeer; +use Closure; use Illuminate\Container\Container; use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Commands\BaseTaskCommand; diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 99842aa97..770bf264d 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -54,7 +54,7 @@ public function getHistory() * @param boolean $silent Whether the command should stay silent no matter what * @param boolean $array Whether the output should be returned as an array * - * @return string|array + * @return string|string[] */ public function run($commands, $silent = false, $array = false) { diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 9d80acec2..c01c97102 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,16 +15,17 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Config\Repository config - * @property \Illuminate\Console\Command command - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Abstracts\Scm scm - * @property \Rocketeer\Bash bash - * @property \Rocketeer\ReleasesManager releasesManager - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Server server - * @property \Rocketeer\TasksHandler tasks - * @property \Rocketeer\TasksQueue queue + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\Scm scm + * @property \Rocketeer\ConnectionsHandler connections + * @property \Rocketeer\Bash bash + * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Server server + * @property \Rocketeer\TasksHandler tasks + * @property \Rocketeer\TasksQueue queue * @author Maxime Fabre */ trait HasLocator From 89e4353e5d8d3806e11b5553764e180e30f9c566 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 00:59:44 +0200 Subject: [PATCH 044/424] Use ServiceProvider::boot instead of static make --- src/Rocketeer/Facades/StandaloneFacade.php | 7 +- src/Rocketeer/RocketeerServiceProvider.php | 161 +++++++-------------- tests/TestCases/ContainerTestCase.php | 8 +- 3 files changed, 59 insertions(+), 117 deletions(-) diff --git a/src/Rocketeer/Facades/StandaloneFacade.php b/src/Rocketeer/Facades/StandaloneFacade.php index 1b6a94024..0f554572d 100644 --- a/src/Rocketeer/Facades/StandaloneFacade.php +++ b/src/Rocketeer/Facades/StandaloneFacade.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Facades; +use Illuminate\Container\Container; use Illuminate\Support\Facades\Facade; use Rocketeer\RocketeerServiceProvider; @@ -35,7 +36,11 @@ abstract class StandaloneFacade extends Facade protected static function getFacadeAccessor() { if (!static::$app) { - static::$app = RocketeerServiceProvider::make(); + $container = new Container(); + $provider = new RocketeerServiceProvider($container); + $provider->boot(); + + static::$app = $container; } return static::$accessor; diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 880b32d99..d9b0f3123 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -55,8 +55,19 @@ public function register() */ public function boot() { - // Register classes and commands - $this->app = static::make($this->app); + $this->bindPaths(); + $this->bindCoreClasses(); + + // Bind Rocketeer's classes + $this->bindClasses(); + $this->bindScm(); + + // Load the user's events and tasks + $this->loadFileOrFolder('tasks'); + $this->loadFileOrFolder('events'); + + // Bind commands + $this->bindCommands(); } /** @@ -73,179 +84,118 @@ public function provides() /////////////////////////// CLASS BINDINGS ///////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Make a Rocketeer container - * - * @param Container $app - * - * @return Container - */ - public static function make($app = null) - { - if (!$app) { - $app = new Container; - } - - $serviceProvider = new static($app); - - // Bind core paths and classes - $app = $serviceProvider->bindPaths($app); - $app = $serviceProvider->bindCoreClasses($app); - - // Bind Rocketeer's classes - $app = $serviceProvider->bindClasses($app); - $app = $serviceProvider->bindScm($app); - - // Load the user's events and tasks - $app = $serviceProvider->loadFileOrFolder($app, 'tasks'); - $app = $serviceProvider->loadFileOrFolder($app, 'events'); - - // Bind commands - $app = $serviceProvider->bindCommands($app); - - return $app; - } - /** * Bind the Rocketeer paths - * - * @param Container $app - * - * @return Container */ - public function bindPaths(Container $app) + public function bindPaths() { - $app->bind('rocketeer.igniter', function ($app) { + $this->app->bind('rocketeer.igniter', function ($app) { return new Igniter($app); }); // Bind paths - $app['rocketeer.igniter']->bindPaths(); - - return $app; + $this->app['rocketeer.igniter']->bindPaths(); } /** * Bind the core classes - * - * @param Container $app - * - * @return Container */ - public function bindCoreClasses(Container $app) + public function bindCoreClasses() { - $app->bindIf('files', 'Illuminate\Filesystem\Filesystem'); + $this->app->bindIf('files', 'Illuminate\Filesystem\Filesystem'); - $app->bindIf('request', function () { + $this->app->bindIf('request', function () { return Request::createFromGlobals(); }, true); - $app->bindIf('config', function ($app) { + $this->app->bindIf('config', function ($app) { $fileloader = new FileLoader($app['files'], __DIR__.'/../config'); return new Repository($fileloader, 'config'); }, true); - $app->bindIf('remote', function ($app) { + $this->app->bindIf('remote', function ($app) { return new RemoteManager($app); }, true); - $app->bindIf('events', function ($app) { + $this->app->bindIf('events', function ($app) { return new Dispatcher($app); }, true); - $app->bindIf('log', function () { + $this->app->bindIf('log', function () { return new Writer(new Logger('rocketeer')); }, true); // Register factory and custom configurations - $app = $this->registerConfig($app); - - return $app; + $this->registerConfig(); } /** * Bind the Rocketeer classes to the Container - * - * @param Container $app - * - * @return Container */ - public function bindClasses(Container $app) + public function bindClasses() { - $app->singleton('rocketeer.rocketeer', function ($app) { + $this->app->singleton('rocketeer.rocketeer', function ($app) { return new Rocketeer($app); }); - $app->singleton('rocketeer.connections', function ($app) { + $this->app->singleton('rocketeer.connections', function ($app) { return new ConnectionsHandler($app); }); - $app->singleton('rocketeer.releases', function ($app) { + $this->app->singleton('rocketeer.releases', function ($app) { return new ReleasesManager($app); }); - $app->bind('rocketeer.server', function ($app) { + $this->app->bind('rocketeer.server', function ($app) { $filename = $app['rocketeer.rocketeer']->getApplicationName(); $filename = $filename === '{application_name}' ? 'deployments' : $filename; return new Server($app, $filename); }); - $app->bind('rocketeer.bash', function ($app) { + $this->app->bind('rocketeer.bash', function ($app) { return new Bash($app); }); - $app->singleton('rocketeer.queue', function ($app) { + $this->app->singleton('rocketeer.queue', function ($app) { return new TasksQueue($app); }); - $app->singleton('rocketeer.tasks', function ($app) { + $this->app->singleton('rocketeer.tasks', function ($app) { return new TasksHandler($app); }); - $app->singleton('rocketeer.logs', function ($app) { + $this->app->singleton('rocketeer.logs', function ($app) { return new LogsHandler($app); }); - $app->singleton('rocketeer.console', function () { + $this->app->singleton('rocketeer.console', function () { return new Console\Console('Rocketeer', Rocketeer::VERSION); }); - $app['rocketeer.console']->setLaravel($app); - $app['rocketeer.connections']->syncConnectionCredentials(); - - return $app; + $this->app['rocketeer.console']->setLaravel($this->app); + $this->app['rocketeer.connections']->syncConnectionCredentials(); } /** * Bind the SCM instance - * - * @param Container $app - * - * @return Container */ - public function bindScm(Container $app) + public function bindScm() { // Currently only one $scm = $this->app['rocketeer.rocketeer']->getOption('scm.scm'); $scm = 'Rocketeer\Scm\\'.ucfirst($scm); - $app->bind('rocketeer.scm', function ($app) use ($scm) { + $this->app->bind('rocketeer.scm', function ($app) use ($scm) { return new $scm($app); }); - - return $app; } /** * Bind the commands to the Container - * - * @param Container $app - * - * @return Container */ - public function bindCommands(Container $app) + public function bindCommands() { // Base commands $tasks = array( @@ -305,13 +255,11 @@ public function bindCommands(Container $app) // Add commands to Artisan foreach ($this->commands as $command) { - $app['rocketeer.console']->add($app[$command]); + $this->app['rocketeer.console']->add($this->app[$command]); if (isset($app['events'])) { $this->commands($command); } } - - return $app; } //////////////////////////////////////////////////////////////////// @@ -320,21 +268,17 @@ public function bindCommands(Container $app) /** * Register factory and custom configurations - * - * @param Container $app - * - * @return Container */ - protected function registerConfig(Container $app) + protected function registerConfig() { // Register config file - $app['config']->package('anahkiasen/rocketeer', __DIR__.'/../config'); - $app['config']->getLoader(); + $this->app['config']->package('anahkiasen/rocketeer', __DIR__.'/../config'); + $this->app['config']->getLoader(); // Register custom config - $custom = $app['path.rocketeer.config']; + $custom = $this->app['path.rocketeer.config']; if (file_exists($custom)) { - $app['config']->afterLoading('rocketeer', function ($me, $group, $items) use ($custom) { + $this->app['config']->afterLoading('rocketeer', function ($me, $group, $items) use ($custom) { $customItems = $custom.'/'.$group.'.php'; if (!file_exists($customItems)) { return $items; @@ -345,25 +289,20 @@ protected function registerConfig(Container $app) return array_replace($items, $customItems); }); } - - return $app; } /** * Load a file or its contents if a folder * - * @param Container $app - * @param string $handle - * - * @return Container + * @param string $handle */ - protected function loadFileOrFolder(Container $app, $handle) + protected function loadFileOrFolder($handle) { // Bind ourselves into the facade to avoid automatic resolution - Facades\Rocketeer::setFacadeApplication($app); + Facades\Rocketeer::setFacadeApplication($this->app); // If we have one unified tasks file, include it - $file = $app['path.rocketeer.'.$handle]; + $file = $this->app['path.rocketeer.'.$handle]; if (!is_dir($file) and file_exists($file)) { include $file; } // Else include its contents @@ -373,7 +312,5 @@ protected function loadFileOrFolder(Container $app, $handle) include $file; } } - - return $app; } } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 345087c19..b6c986965 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -42,10 +42,10 @@ public function setUp() // Rocketeer classes ------------------------------------------- / $serviceProvider = new RocketeerServiceProvider($this->app); - $this->app = $serviceProvider->bindPaths($this->app); - $this->app = $serviceProvider->bindCoreClasses($this->app); - $this->app = $serviceProvider->bindClasses($this->app); - $this->app = $serviceProvider->bindScm($this->app); + $serviceProvider->bindPaths(); + $serviceProvider->bindCoreClasses(); + $serviceProvider->bindClasses(); + $serviceProvider->bindScm(); } /** From d2818e5b255540a19ccd53d17b4b992486865049 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:02:14 +0200 Subject: [PATCH 045/424] Fix leftover call to --- src/Rocketeer/RocketeerServiceProvider.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index d9b0f3123..cb301f77d 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -256,7 +256,7 @@ public function bindCommands() // Add commands to Artisan foreach ($this->commands as $command) { $this->app['rocketeer.console']->add($this->app[$command]); - if (isset($app['events'])) { + if (isset($this->app['events'])) { $this->commands($command); } } From 697a590e46d53fdfda5b03a19a70d2a0774f7461 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:07:35 +0200 Subject: [PATCH 046/424] Fix wrong method calls --- src/Rocketeer/Commands/AbstractDeployCommand.php | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index c06a44346..3be506042 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -113,9 +113,9 @@ protected function fireTasksQueue($tasks) protected function getRepositoryCredentials() { // Check for repository credentials - $repositoryInfos = $this->laravel['rocketeer.rocketeer']->getCredentials(); + $repositoryInfos = $this->laravel['rocketeer.connections']->getCredentials(); $credentials = array('repository'); - if (!array_get($repositoryInfos, 'repository') or $this->laravel['rocketeer.rocketeer']->needsCredentials()) { + if (!array_get($repositoryInfos, 'repository') or $this->laravel['rocketeer.connections']->needsCredentials()) { $credentials = array('repository', 'username', 'password'); } @@ -143,12 +143,12 @@ protected function getRepositoryCredentials() protected function getServerCredentials() { if ($connections = $this->option('on')) { - $this->laravel['rocketeer.rocketeer']->setConnections($connections); + $this->laravel['rocketeer.connections']->setConnections($connections); } // Check for configured connections - $availableConnections = $this->laravel['rocketeer.rocketeer']->getAvailableConnections(); - $activeConnections = $this->laravel['rocketeer.rocketeer']->getConnections(); + $availableConnections = $this->laravel['rocketeer.connections']->getAvailableConnections(); + $activeConnections = $this->laravel['rocketeer.connections']->getConnections(); if (count($activeConnections) <= 0) { $connectionName = $this->ask('No connections have been set, please create one : (production)', 'production'); @@ -201,8 +201,8 @@ protected function storeServerCredentials($connections, $connectionName) // Save credentials $credentials = compact(array_keys($credentials)); - $this->laravel['rocketeer.rocketeer']->syncConnectionCredentials($connectionName, $credentials); - $this->laravel['rocketeer.rocketeer']->setConnection($connectionName); + $this->laravel['rocketeer.connections']->syncConnectionCredentials($connectionName, $credentials); + $this->laravel['rocketeer.connections']->setConnection($connectionName); } /** From 6c077a07d54291fe3d0fbc9b7ab0f1000a1eff7f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:11:27 +0200 Subject: [PATCH 047/424] Add mention of connection property --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index e89c7e699..0155f36e6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,7 @@ - Minimum requirement is now PHP 5.4+ - The `Traits` folder was renamed to `Abstracts`, if you were extending `Rocketeer\Traits\Task`, change that accordingly to `Rocketeer\Abstracts\Task` +- Connections and stages handling was moved to a ConnectionsHandler class. If you were doing per example `$task->rocketeer->getStage()` you'll need to change it to `$task->connections->getStage()`, etc. #### Features and bugfixes From 5454123e140f18e71c7cb72dc9c5c47cd67ce36a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:15:21 +0200 Subject: [PATCH 048/424] Fix HHVM check --- src/Rocketeer/Tasks/Check.php | 3 ++- tests/Tasks/CheckTest.php | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index d76f05ec7..979ac653c 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -278,7 +278,8 @@ public function checkPhpExtension($extension) public function usesHhvm() { $version = $this->php('--version'); - $version = $this->runLast($version); + $version = $this->runRaw($version, true); + $version = head($version); $version = strtolower($version); return strpos($version, 'hiphop') !== false; diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index 90894bb05..e4a83d7e9 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -53,7 +53,7 @@ public function testCanCheckPhpExtensions() public function testCanCheckForHhvmExtensions() { - $this->app['remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'); + $this->app['remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); $exists = $this->task('Check')->checkPhpExtension('_hhvm'); $this->assertTrue($exists); From ca2e3b7940e74daba15e4aede66c7eece3108462 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:27:11 +0200 Subject: [PATCH 049/424] Fix when current repository is not a Git repo --- src/Rocketeer/ConnectionsHandler.php | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 884053264..58e973cfe 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -325,7 +325,8 @@ public function getRepository() public function getRepositoryBranch() { exec($this->scm->currentBranch(), $fallback); - $fallback = trim($fallback[0]) ?: 'master'; + $fallback = array_get($fallback, 0, 'master'); + $fallback = trim($fallback); $branch = $this->rocketeer->getOption('scm.branch') ?: $fallback; return $branch; From 7cbc4ff06e0be51f6bb743726798794b9ba1148d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:43:48 +0200 Subject: [PATCH 050/424] Add parallel tasks --- CHANGELOG.md | 1 + composer.json | 3 +- composer.lock | 42 +++++++++- .../Commands/AbstractDeployCommand.php | 1 + src/Rocketeer/TasksQueue.php | 81 ++++++++++++++----- 5 files changed, 106 insertions(+), 22 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0155f36e6..6edf36562 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,7 @@ #### Features and bugfixes +- Added ability to run tasks in parallel via the `--parallel` flag (or `-P`) - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions - Fixed a bug where `rocketeer current` would fail to find the related task diff --git a/composer.json b/composer.json index abb6bea60..4251ccbdb 100644 --- a/composer.json +++ b/composer.json @@ -22,7 +22,8 @@ "illuminate/filesystem": "~4.2", "illuminate/events": "~4.2", "illuminate/remote": "~4.2", - "illuminate/log": "~4.2" + "illuminate/log": "~4.2", + "kzykhys/parallel": "dev-master" }, "require-dev": { "phpunit/phpunit": "~4.0", diff --git a/composer.lock b/composer.lock index 2131b7e49..d1ba81921 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "e8764dc76959a981db6664c1eb87c737", + "hash": "3d39384fcd43b395809b09d575026048", "packages": [ { "name": "illuminate/config", @@ -359,6 +359,42 @@ ], "time": "2014-07-21 21:14:59" }, + { + "name": "kzykhys/parallel", + "version": "dev-master", + "source": { + "type": "git", + "url": "https://github.com/kzykhys/Parallel.php.git", + "reference": "d15bc88f06d279112a0facb6607072dfb48dfc6f" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/kzykhys/Parallel.php/zipball/d15bc88f06d279112a0facb6607072dfb48dfc6f", + "reference": "d15bc88f06d279112a0facb6607072dfb48dfc6f", + "shasum": "" + }, + "require-dev": { + "phpunit/php-code-coverage": "1.2.*" + }, + "type": "library", + "autoload": { + "psr-0": { + "": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Kazuyuki Hayashi", + "email": "hayashi@valnur.net" + } + ], + "description": "Simple multitasking library", + "time": "2014-02-04 13:24:07" + }, { "name": "monolog/monolog", "version": "1.10.0", @@ -1700,7 +1736,9 @@ ], "aliases": [], "minimum-stability": "stable", - "stability-flags": [], + "stability-flags": { + "kzykhys/parallel": 20 + }, "prefer-stable": false, "platform": { "php": ">=5.4.0" diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 3be506042..b9aa00820 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -35,6 +35,7 @@ abstract public function fire(); protected function getOptions() { return array( + ['parallel','P', InputOption::VALUE_NONE, 'Run the tasks asynchronously instead of sequentially'], ['pretend', 'p', InputOption::VALUE_NONE, 'Returns an array of commands to be executed instead of actually executing them'], ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'] diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index ee23e0312..bcc7b6cc1 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -10,6 +10,8 @@ namespace Rocketeer; use Closure; +use Exception; +use KzykHys\Parallel\Parallel; use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Abstracts\Task; use Rocketeer\Traits\HasLocator; @@ -92,32 +94,25 @@ public function on($connections, $queue) * * @param array $tasks An array of tasks * + * @throws Exception * @return array An array of output */ public function run(array $tasks) { - // First we'll build the queue - $queue = $this->buildQueue($tasks); - - // Get the connections to execute the tasks on - $connections = (array) $this->connections->getConnections(); - foreach ($connections as $connection) { - $this->connections->setConnection($connection); + $queue = $this->buildQueue($tasks); + $pipeline = $this->buildPipeline($queue); - // Check if we provided a stage - $stage = $this->getStage(); - $stages = $this->connections->getStages(); - if ($stage and in_array($stage, $stages)) { - $stages = array($stage); + // Run pipeline + if ($this->command->option('parallel')) { + if (!extension_loaded('pcntl')) { + throw new Exception('Parallel jobs require the PCNTL extension'); } - // Run the Tasks on each stage - if (!empty($stages)) { - foreach ($stages as $stage) { - $this->runQueue($queue, $stage); - } - } else { - $this->runQueue($queue); + $parallel = new Parallel(); + $parallel->run($pipeline); + } else { + foreach ($pipeline as $job) { + $job(); } } @@ -152,6 +147,54 @@ protected function runQueue($tasks, $stage = null) return true; } + /** + * Build a pipeline of jobs for Parallel to execute + * + * @param array $queue + * + * @return array + */ + protected function buildPipeline(array $queue) + { + // First we'll build the queue + $pipeline = []; + + // Get the connections to execute the tasks on + $connections = (array) $this->connections->getConnections(); + foreach ($connections as $connection) { + // Sanitize stage + $stage = $this->getStage(); + $stages = $this->connections->getStages(); + if ($stage and in_array($stage, $stages)) { + $stages = array($stage); + } + + // Default to no stages + if (empty($stages)) { + $stages = [null]; + } + + // Add job to pipeline + foreach ($stages as $stage) { + $pipeline[] = array( + 'connection' => $connection, + 'stage' => $stage, + 'queue' => $queue, + ); + } + } + + // Build pipeline + foreach ($pipeline as $key => $job) { + $pipeline[$key] = function () use ($job) { + $this->connections->setConnection($job['connection']); + $this->runQueue($job['queue'], $job['stage']); + }; + } + + return $pipeline; + } + //////////////////////////////////////////////////////////////////// /////////////////////////////// BUILDING /////////////////////////// //////////////////////////////////////////////////////////////////// From 762a8cb99d4bef585b2ad3ea720763c7d5c10cea Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:58:58 +0200 Subject: [PATCH 051/424] Add upload method --- src/Rocketeer/Traits/BashModules/Filesystem.php | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index f94105a39..f004414f9 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -150,6 +150,22 @@ public function putFile($file, $contents) $this->remote->putString($file, $contents); } + /** + * Upload a local file to remote + * + * @param string $file + * @param string $destination + */ + public function upload($file, $destination) + { + if (!file_exists($file)) { + return; + } + + $contents = file_get_contents($file); + $this->putFile($destination, $contents); + } + //////////////////////////////////////////////////////////////////// /////////////////////////////// FOLDERS //////////////////////////// //////////////////////////////////////////////////////////////////// From 2cb1e39c3af19dacc33314df3a29c8c178ffaded Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 01:59:46 +0200 Subject: [PATCH 052/424] Default to filename --- src/Rocketeer/Traits/BashModules/Filesystem.php | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index f004414f9..c4f713ab1 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -154,15 +154,18 @@ public function putFile($file, $contents) * Upload a local file to remote * * @param string $file - * @param string $destination + * @param string|null $destination */ - public function upload($file, $destination) + public function upload($file, $destination = null) { if (!file_exists($file)) { return; } + // Get contents and destination + $destination = $destination ?: basename($file); $contents = file_get_contents($file); + $this->putFile($destination, $contents); } From 44db6de335a9c788c479793f4758d69ae843712d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 02:00:45 +0200 Subject: [PATCH 053/424] Update CHANGELOG --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6edf36562..c48033807 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ - Added ability to run tasks in parallel via the `--parallel` flag (or `-P`) - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions +- Added `Task::upload(file, destination)` to upload files to remote, destination can be null and the basename of the file would then be used - Fixed a bug where `rocketeer current` would fail to find the related task - Fixed a bug where Artisan wouldn't be found even if at the default location - Fixed a bug where ignition would fail when the default connection isn't `production` From c162a0500515102911372744bba955a1566ce58a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 02:43:14 +0200 Subject: [PATCH 054/424] Work on multiservers connections --- bin/rocketeer | 2 +- composer.json | 3 +- composer.lock | 51 ++++++++++++++++++- .../Commands/AbstractDeployCommand.php | 35 +++++++++---- src/Rocketeer/ConnectionsHandler.php | 43 ++++++++++++---- src/Rocketeer/Plugins/Notifier.php | 2 +- src/Rocketeer/TasksQueue.php | 44 ++++++++-------- src/config/config.php | 23 +++++++++ 8 files changed, 159 insertions(+), 44 deletions(-) diff --git a/bin/rocketeer b/bin/rocketeer index 832787794..e3377d588 100644 --- a/bin/rocketeer +++ b/bin/rocketeer @@ -10,7 +10,7 @@ $vendors = array( // one available foreach ($vendors as $vendor) { if (file_exists($vendor)) { - require $vendor; + require_once $vendor; } } diff --git a/composer.json b/composer.json index 4251ccbdb..7d2007682 100644 --- a/composer.json +++ b/composer.json @@ -31,7 +31,8 @@ "nesbot/carbon": "~1.4", "patchwork/utf8": "~1.1.18", "herrera-io/box": "~1.5.3", - "phpseclib/phpseclib": "~0.3.5" + "phpseclib/phpseclib": "~0.3.5", + "raveren/kint": "dev-master" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", diff --git a/composer.lock b/composer.lock index d1ba81921..33c1c53f5 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "3d39384fcd43b395809b09d575026048", + "hash": "58b19259896590daf4a76f42413947d8", "packages": [ { "name": "illuminate/config", @@ -1416,6 +1416,52 @@ ], "time": "2014-06-12 07:22:15" }, + { + "name": "raveren/kint", + "version": "dev-master", + "source": { + "type": "git", + "url": "https://github.com/raveren/kint.git", + "reference": "cd801406b28cfa74d257bbd4f9e9fdddf59390c5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/raveren/kint/zipball/cd801406b28cfa74d257bbd4f9e9fdddf59390c5", + "reference": "cd801406b28cfa74d257bbd4f9e9fdddf59390c5", + "shasum": "" + }, + "require": { + "php": ">=5.2.0" + }, + "type": "library", + "autoload": { + "files": [ + "Kint.class.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Rokas Šleinius", + "homepage": "https://github.com/raveren" + }, + { + "name": "Contributors", + "homepage": "https://github.com/raveren/kint/contributors" + } + ], + "description": "Kint - debugging helper for PHP developers", + "homepage": "https://github.com/raveren/kint", + "keywords": [ + "debug", + "kint", + "php" + ], + "time": "2014-08-04 19:57:55" + }, { "name": "sebastian/comparator", "version": "1.0.0", @@ -1737,7 +1783,8 @@ "aliases": [], "minimum-stability": "stable", "stability-flags": { - "kzykhys/parallel": 20 + "kzykhys/parallel": 20, + "raveren/kint": 20 }, "prefer-stable": false, "platform": { diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index b9aa00820..0874acaba 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -35,10 +35,15 @@ abstract public function fire(); protected function getOptions() { return array( - ['parallel','P', InputOption::VALUE_NONE, 'Run the tasks asynchronously instead of sequentially'], - ['pretend', 'p', InputOption::VALUE_NONE, 'Returns an array of commands to be executed instead of actually executing them'], - ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], - ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'] + ['parallel', 'P', InputOption::VALUE_NONE, 'Run the tasks asynchronously instead of sequentially'], + [ + 'pretend', + 'p', + InputOption::VALUE_NONE, + 'Returns an array of commands to be executed instead of actually executing them' + ], + ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], + ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'] ); } @@ -151,12 +156,16 @@ protected function getServerCredentials() $availableConnections = $this->laravel['rocketeer.connections']->getAvailableConnections(); $activeConnections = $this->laravel['rocketeer.connections']->getConnections(); - if (count($activeConnections) <= 0) { + if (sizeof($activeConnections) <= 0) { $connectionName = $this->ask('No connections have been set, please create one : (production)', 'production'); $this->storeServerCredentials($availableConnections, $connectionName); } else { foreach ($activeConnections as $connectionName) { - $this->storeServerCredentials($availableConnections, $connectionName); + $servers = array_get($availableConnections, $connectionName.'.servers'); + $servers = array_keys($servers); + foreach ($servers as $server) { + $this->storeServerCredentials($availableConnections, $connectionName, $server); + } } } } @@ -164,13 +173,16 @@ protected function getServerCredentials() /** * Verifies and stores credentials for the given connection name * - * @param array $connections - * @param string $connectionName + * @param array $connections + * @param string $connectionName + * @param integer|null $server */ - protected function storeServerCredentials($connections, $connectionName) + protected function storeServerCredentials($connections, $connectionName, $server = null) { // Check for server credentials - $connection = array_get($connections, $connectionName, array()); + $connection = $connectionName.'.servers'; + $connection = !is_null($server) ? $connection.'.'.$server : $connection; + $connection = array_get($connections, $connection, array()); $credentials = array( 'host' => true, 'username' => true, @@ -180,6 +192,9 @@ protected function storeServerCredentials($connections, $connectionName) 'agent' => false ); + // Update connection name + $connectionName = !is_null($server) ? $connectionName.'#'.$server : $connectionName; + // Gather credentials foreach ($credentials as $credential => $required) { ${$credential} = $this->getCredential($connection, $credential); diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 58e973cfe..d533a8770 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -101,11 +101,9 @@ public function needsCredentials() /** * Get the available connections * - * @param string|null $connection A connection to fetch from the resulting array - * * @return string[][]|string[] */ - public function getAvailableConnections($connection = null) + public function getAvailableConnections() { // Fetch stored credentials $storage = (array) $this->server->getValue('connections'); @@ -117,9 +115,15 @@ public function getAvailableConnections($connection = null) $remote = (array) $this->config->get('remote.connections'); // Merge configurations - $storage = array_replace_recursive($remote, $configuration, $storage); + $connections = array_replace_recursive($remote, $configuration, $storage); + + // Unify multiservers + foreach ($connections as $key => $servers) { + $servers = array_get($servers, 'servers', [$servers]); + $connections[$key] = ['servers' => array_values($servers)]; + } - return $connection ? array_get($storage, $connection) : $storage; + return $connections; } /** @@ -133,7 +137,7 @@ public function isValidConnection($connection) { $available = (array) $this->getAvailableConnections(); - return array_key_exists($connection, $available); + return (bool) array_get($available, $connection.'.servers'); } /** @@ -197,8 +201,24 @@ public function getConnection() public function getConnectionCredentials($connection = null) { $connection = $connection ?: $this->getConnection(); + $available = $this->getAvailableConnections(); + + return array_get($available, $connection.'.servers'); + } + + /** + * Get thecredentials for as server + * + * @param string|null $connection + * @param int $server + * + * @return mixed + */ + public function getServerCredentials($connection = null, $server = 0) + { + $connection = $this->getConnectionCredentials($connection); - return $this->getAvailableConnections($connection); + return array_get($connection, $server); } /** @@ -239,16 +259,21 @@ public function setConnections($connections) * Set the current connection * * @param string $connection + * @param int $server */ - public function setConnection($connection) + public function setConnection($connection, $server = 0) { if (!$this->isValidConnection($connection)) { return; } + // Fetch the credentials + $credentials = $this->getServerCredentials($connection, $server); + // Set the connection $this->connection = $connection; - $this->config->set('remote.default', $connection); + $this->config->set('remote.default', 'current'); + $this->config->set('remote.connections.current', $credentials); // Update events $this->tasks->registerConfiguredEvents(); diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index a3103e328..1c8aff002 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -71,7 +71,7 @@ protected function getComponents() $connection = $this->connections->getConnection(); // Get hostname - $credentials = $this->connections->getAvailableConnections($connection); + $credentials = $this->connections->getConnectionCredentials($connection); $host = array_get($credentials, 'host'); if ($stage) { $connection = $stage.'@'.$connection; diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index bcc7b6cc1..7d2c6d0d7 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -162,32 +162,36 @@ protected function buildPipeline(array $queue) // Get the connections to execute the tasks on $connections = (array) $this->connections->getConnections(); foreach ($connections as $connection) { - // Sanitize stage - $stage = $this->getStage(); - $stages = $this->connections->getStages(); - if ($stage and in_array($stage, $stages)) { - $stages = array($stage); - } - - // Default to no stages - if (empty($stages)) { - $stages = [null]; - } - - // Add job to pipeline - foreach ($stages as $stage) { - $pipeline[] = array( - 'connection' => $connection, - 'stage' => $stage, - 'queue' => $queue, - ); + $servers = $this->connections->getConnectionCredentials($connection); + foreach ($servers as $server => $credentials) { + // Sanitize stage + $stage = $this->getStage(); + $stages = $this->connections->getStages(); + if ($stage and in_array($stage, $stages)) { + $stages = array($stage); + } + + // Default to no stages + if (empty($stages)) { + $stages = [null]; + } + + // Add job to pipeline + foreach ($stages as $stage) { + $pipeline[] = array( + 'connection' => $connection, + 'server' => $server, + 'stage' => $stage, + 'queue' => $queue, + ); + } } } // Build pipeline foreach ($pipeline as $key => $job) { $pipeline[$key] = function () use ($job) { - $this->connections->setConnection($job['connection']); + $this->connections->setConnection($job['connection'], $job['server']); $this->runQueue($job['queue'], $job['stage']); }; } diff --git a/src/config/config.php b/src/config/config.php index b60c38618..8584914a0 100644 --- a/src/config/config.php +++ b/src/config/config.php @@ -34,6 +34,29 @@ 'keyphrase' => '{keyphrase}', 'agent' => '{agent}', ), + + // You can also deploy to multiple servers as part + // of one connection + 'multiservers' => array( + 'servers' => array( + 'first' => array( + 'host' => '{host}', + 'username' => '{username}', + 'password' => '{password}', + 'key' => '{key}', + 'keyphrase' => '{keyphrase}', + 'agent' => '{agent}', + ), + 'second' => array( + 'host' => '{host}', + 'username' => '{username}', + 'password' => '{password}', + 'key' => '{key}', + 'keyphrase' => '{keyphrase}', + 'agent' => '{agent}', + ), + ), + ) ), // Contextual options From 2e165d15002c47339774eccc86d00de7c7294585 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 02:49:47 +0200 Subject: [PATCH 055/424] Update tests --- src/Rocketeer/ConnectionsHandler.php | 22 ++++++++++++++++++++++ src/Rocketeer/Plugins/Notifier.php | 3 ++- src/Rocketeer/Tasks/Ignite.php | 2 +- 3 files changed, 25 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index d533a8770..249aa028f 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -29,6 +29,13 @@ class ConnectionsHandler */ protected $stage; + /** + * The current server + * + * @type integer + */ + protected $currentServer = 0; + /** * The connections to use * @@ -43,6 +50,18 @@ class ConnectionsHandler */ protected $connection; + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// SERVERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * @return int + */ + public function getServer() + { + return $this->currentServer; + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// STAGES //////////////////////////// //////////////////////////////////////////////////////////////////// @@ -272,6 +291,9 @@ public function setConnection($connection, $server = 0) // Set the connection $this->connection = $connection; + $this->server = $server; + + // Register it with SSH component $this->config->set('remote.default', 'current'); $this->config->set('remote.connections.current', $credentials); diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 1c8aff002..0105bb58f 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -69,9 +69,10 @@ protected function getComponents() $branch = $this->connections->getRepositoryBranch(); $stage = $this->connections->getStage(); $connection = $this->connections->getConnection(); + $server = $this->connections->getServer(); // Get hostname - $credentials = $this->connections->getConnectionCredentials($connection); + $credentials = $this->connections->getServerCredentials($connection, $server); $host = array_get($credentials, 'host'); if ($stage) { $connection = $stage.'@'.$connection; diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index 3b7a85398..3fe66b3af 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -82,7 +82,7 @@ protected function getConfigurationInformations() $name = basename($this->app['path.base']); return array_merge( - $this->connections->getConnectionCredentials(), + $this->connections->getServerCredentials(), array( 'connection' => $this->connections->getConnection(), 'scm_repository' => $repositoryCredentials['repository'], From f098c04fa793a1069cbf67afce30de840fe41d83 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 02:50:34 +0200 Subject: [PATCH 056/424] Update CHANGEOG --- CHANGELOG.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c48033807..d843882ad 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,7 +10,8 @@ #### Features and bugfixes -- Added ability to run tasks in parallel via the `--parallel` flag (or `-P`) +- **Added ability to run tasks in parallel via the `--parallel` flag (or `-P`)** +- **Added ability to have multiple servers for one connection, just define them in a `servers` array in your connection, each entry being an usual connection credentials array** - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions - Added `Task::upload(file, destination)` to upload files to remote, destination can be null and the basename of the file would then be used From 9bd50f2a8a1b7300d894bac953f61de7ec8a6e43 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 03:04:33 +0200 Subject: [PATCH 057/424] Fix some bugs when using single server --- src/Rocketeer/Commands/AbstractDeployCommand.php | 8 ++++---- src/Rocketeer/ConnectionsHandler.php | 5 +++-- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 0874acaba..411a52eaa 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -193,19 +193,19 @@ protected function storeServerCredentials($connections, $connectionName, $server ); // Update connection name - $connectionName = !is_null($server) ? $connectionName.'#'.$server : $connectionName; + $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; // Gather credentials foreach ($credentials as $credential => $required) { ${$credential} = $this->getCredential($connection, $credential); if ($required and !${$credential}) { - ${$credential} = $this->ask('No '.$credential.' is set for ['.$connectionName.'], please provide one :'); + ${$credential} = $this->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); } } // Get password or key if (!$password and !$key) { - $type = $this->ask('No password or SSH key is set for ['.$connectionName.'], which would you use ? [key/password]', 'key'); + $type = $this->ask('No password or SSH key is set for ['.$handle.'], which would you use ? [key/password]', 'key'); if ($type == 'key') { $default = $this->laravel['rocketeer.rocketeer']->getUserHomeFolder().'/.ssh/id_rsa'; $key = $this->ask('Please enter the full path to your key ('.$default.')', $default); @@ -217,7 +217,7 @@ protected function storeServerCredentials($connections, $connectionName, $server // Save credentials $credentials = compact(array_keys($credentials)); - $this->laravel['rocketeer.connections']->syncConnectionCredentials($connectionName, $credentials); + $this->laravel['rocketeer.connections']->syncConnectionCredentials($connectionName, $credentials, $server); $this->laravel['rocketeer.connections']->setConnection($connectionName); } diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 249aa028f..310ab7139 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -245,12 +245,13 @@ public function getServerCredentials($connection = null, $server = 0) * * @param string|null $connection * @param string[]|null $credentials + * @param int $server */ - public function syncConnectionCredentials($connection = null, array $credentials = array()) + public function syncConnectionCredentials($connection = null, array $credentials = array(), $server = 0) { // Store credentials if any if ($credentials) { - $this->server->setValue('connections.'.$connection, $credentials); + $this->server->setValue('connections.'.$connection.'.servers.'.$server, $credentials); } // Get connection From b65fc2bf39a7bd8da995927559d6f1d864b12860 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 03:06:26 +0200 Subject: [PATCH 058/424] Fix placeholder name of production being displayed --- bin/rocketeer | 0 src/Rocketeer/ConnectionsHandler.php | 5 +++-- 2 files changed, 3 insertions(+), 2 deletions(-) mode change 100644 => 100755 bin/rocketeer diff --git a/bin/rocketeer b/bin/rocketeer old mode 100644 new mode 100755 diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 310ab7139..50366bbc7 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -295,8 +295,9 @@ public function setConnection($connection, $server = 0) $this->server = $server; // Register it with SSH component - $this->config->set('remote.default', 'current'); - $this->config->set('remote.connections.current', $credentials); + $name = $connection.'#'.$server; + $this->config->set('remote.default', $name); + $this->config->set('remote.connections.'.$name, $credentials); // Update events $this->tasks->registerConfiguredEvents(); From b85080672ddc68d225cdb1da073daec7181073ed Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 03:14:17 +0200 Subject: [PATCH 059/424] Purge state file when doing a full cleanup --- src/Rocketeer/ReleasesManager.php | 5 +++-- src/Rocketeer/Tasks/Cleanup.php | 6 ++++++ 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index 223b7f3ce..7bc801f1f 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -199,10 +199,11 @@ public function saveValidationFile(array $validation) /** * Mark a release as valid * - * @param integer $release + * @param integer|null $release */ - public function markReleaseAsValid($release) + public function markReleaseAsValid($release = null) { + $release = $release ?: $this->getCurrentRelease(); $validation = $this->getValidationFile(); $validation[$release] = true; diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index f68c135b1..7915ba5e9 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -47,6 +47,12 @@ public function execute() $trash = sizeof($trash); $message = sprintf('Removing %d %s from the server', $trash, Str::plural('release', $trash)); + // Delete state file + if ($this->getOption('clean-all')) { + $this->removeFolder('state.json'); + $this->releasesManager->markReleaseAsValid(); + } + return $this->command->line($message); } From 48e2fadecd6ce247796c63d108e25461aeb41776 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 13:03:13 +0200 Subject: [PATCH 060/424] Update dependencies, suggest PCNTL --- composer.json | 3 +- composer.lock | 254 +++++++++++++++++++++++++++++++++++--------------- 2 files changed, 183 insertions(+), 74 deletions(-) diff --git a/composer.json b/composer.json index 7d2007682..8c285284b 100644 --- a/composer.json +++ b/composer.json @@ -36,7 +36,8 @@ }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", - "anahkiasen/rocketeer-slack": "Slack plugin to create deployments notifications" + "anahkiasen/rocketeer-slack": "Slack plugin to create deployments notifications", + "ext-pcntl": "Allow parallel deployments" }, "bin": [ "bin/rocketeer" diff --git a/composer.lock b/composer.lock index 33c1c53f5..d5043b29e 100644 --- a/composer.lock +++ b/composer.lock @@ -8,7 +8,7 @@ "packages": [ { "name": "illuminate/config", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Config", "source": { "type": "git", @@ -51,17 +51,17 @@ }, { "name": "illuminate/console", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Console", "source": { "type": "git", "url": "https://github.com/illuminate/console.git", - "reference": "2cfb8c65ea03c44d27ee02acf367de5b9b62f1c9" + "reference": "26ab2d3f5223851ac537668c778f13cad8742e4c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/console/zipball/2cfb8c65ea03c44d27ee02acf367de5b9b62f1c9", - "reference": "2cfb8c65ea03c44d27ee02acf367de5b9b62f1c9", + "url": "https://api.github.com/repos/illuminate/console/zipball/26ab2d3f5223851ac537668c778f13cad8742e4c", + "reference": "26ab2d3f5223851ac537668c778f13cad8742e4c", "shasum": "" }, "require": { @@ -89,11 +89,11 @@ "email": "taylorotwell@gmail.com" } ], - "time": "2014-07-16 03:00:55" + "time": "2014-08-01 12:29:44" }, { "name": "illuminate/container", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Container", "source": { "type": "git", @@ -134,17 +134,17 @@ }, { "name": "illuminate/events", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Events", "source": { "type": "git", "url": "https://github.com/illuminate/events.git", - "reference": "c95614873f4e437ed7a723c1734197b51feaf991" + "reference": "3fd59a0dd07d2b569487d99a37011f33fc01aafd" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/events/zipball/c95614873f4e437ed7a723c1734197b51feaf991", - "reference": "c95614873f4e437ed7a723c1734197b51feaf991", + "url": "https://api.github.com/repos/illuminate/events/zipball/3fd59a0dd07d2b569487d99a37011f33fc01aafd", + "reference": "3fd59a0dd07d2b569487d99a37011f33fc01aafd", "shasum": "" }, "require": { @@ -173,21 +173,21 @@ "email": "taylorotwell@gmail.com" } ], - "time": "2014-06-06 13:58:46" + "time": "2014-08-03 15:26:23" }, { "name": "illuminate/filesystem", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Filesystem", "source": { "type": "git", "url": "https://github.com/illuminate/filesystem.git", - "reference": "568f829aebe886bbe84bcd726e1509f830d5a1b0" + "reference": "1e517251a924b5f90b1ed10966e38ff0798ddc24" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/filesystem/zipball/568f829aebe886bbe84bcd726e1509f830d5a1b0", - "reference": "568f829aebe886bbe84bcd726e1509f830d5a1b0", + "url": "https://api.github.com/repos/illuminate/filesystem/zipball/1e517251a924b5f90b1ed10966e38ff0798ddc24", + "reference": "1e517251a924b5f90b1ed10966e38ff0798ddc24", "shasum": "" }, "require": { @@ -216,21 +216,21 @@ "email": "taylorotwell@gmail.com" } ], - "time": "2014-05-23 16:40:19" + "time": "2014-08-01 20:11:25" }, { "name": "illuminate/log", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Log", "source": { "type": "git", "url": "https://github.com/illuminate/log.git", - "reference": "6f317b78f316862a21e386ca63dd9a55873a81f4" + "reference": "da1d827118dbc30ce77e3a1b8e9dab4306302ee9" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/log/zipball/6f317b78f316862a21e386ca63dd9a55873a81f4", - "reference": "6f317b78f316862a21e386ca63dd9a55873a81f4", + "url": "https://api.github.com/repos/illuminate/log/zipball/da1d827118dbc30ce77e3a1b8e9dab4306302ee9", + "reference": "da1d827118dbc30ce77e3a1b8e9dab4306302ee9", "shasum": "" }, "require": { @@ -262,11 +262,11 @@ "email": "taylorotwell@gmail.com" } ], - "time": "2014-07-21 19:47:50" + "time": "2014-08-03 15:26:23" }, { "name": "illuminate/remote", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Remote", "source": { "type": "git", @@ -313,17 +313,17 @@ }, { "name": "illuminate/support", - "version": "v4.2.7", + "version": "v4.2.8", "target-dir": "Illuminate/Support", "source": { "type": "git", "url": "https://github.com/illuminate/support.git", - "reference": "b3d84fa93aa3f2081a935158f860de8308d62d5a" + "reference": "8702d655da1f7502037a2206df38399656ff35ae" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/illuminate/support/zipball/b3d84fa93aa3f2081a935158f860de8308d62d5a", - "reference": "b3d84fa93aa3f2081a935158f860de8308d62d5a", + "url": "https://api.github.com/repos/illuminate/support/zipball/8702d655da1f7502037a2206df38399656ff35ae", + "reference": "8702d655da1f7502037a2206df38399656ff35ae", "shasum": "" }, "require": { @@ -357,7 +357,7 @@ "email": "taylorotwell@gmail.com" } ], - "time": "2014-07-21 21:14:59" + "time": "2014-08-05 12:08:34" }, { "name": "kzykhys/parallel", @@ -600,17 +600,17 @@ }, { "name": "symfony/console", - "version": "v2.5.2", + "version": "v2.5.3", "target-dir": "Symfony/Component/Console", "source": { "type": "git", "url": "https://github.com/symfony/Console.git", - "reference": "386fa63407805959bd2c5fe540294721ad4224c8" + "reference": "cd2d1e4bac2206b337326b0140ff475fe9ad5f63" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Console/zipball/386fa63407805959bd2c5fe540294721ad4224c8", - "reference": "386fa63407805959bd2c5fe540294721ad4224c8", + "url": "https://api.github.com/repos/symfony/Console/zipball/cd2d1e4bac2206b337326b0140ff475fe9ad5f63", + "reference": "cd2d1e4bac2206b337326b0140ff475fe9ad5f63", "shasum": "" }, "require": { @@ -640,34 +640,32 @@ "MIT" ], "authors": [ - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" - }, { "name": "Symfony Community", "homepage": "http://symfony.com/contributors" + }, + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" } ], "description": "Symfony Console Component", "homepage": "http://symfony.com", - "time": "2014-07-15 14:15:12" + "time": "2014-08-05 09:00:40" }, { "name": "symfony/finder", - "version": "v2.5.2", + "version": "v2.5.3", "target-dir": "Symfony/Component/Finder", "source": { "type": "git", "url": "https://github.com/symfony/Finder.git", - "reference": "576d8f69feec477067e91b6bd0367c113e76a1a0" + "reference": "090fe4eaff414d8f2171c7a4748ea868d530775f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Finder/zipball/576d8f69feec477067e91b6bd0367c113e76a1a0", - "reference": "576d8f69feec477067e91b6bd0367c113e76a1a0", + "url": "https://api.github.com/repos/symfony/Finder/zipball/090fe4eaff414d8f2171c7a4748ea868d530775f", + "reference": "090fe4eaff414d8f2171c7a4748ea868d530775f", "shasum": "" }, "require": { @@ -689,20 +687,18 @@ "MIT" ], "authors": [ - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" - }, { "name": "Symfony Community", "homepage": "http://symfony.com/contributors" + }, + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" } ], "description": "Symfony Finder Component", "homepage": "http://symfony.com", - "time": "2014-07-15 14:15:12" + "time": "2014-07-28 13:20:46" } ], "packages-dev": [ @@ -878,6 +874,119 @@ ], "time": "2014-07-18 03:44:47" }, + { + "name": "ocramius/instantiator", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/Ocramius/Instantiator.git", + "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Ocramius/Instantiator/zipball/cc754c2289ffd4483c319f6ed6ee88ce21676f64", + "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64", + "shasum": "" + }, + "require": { + "ocramius/lazy-map": "1.0.*", + "php": "~5.3" + }, + "require-dev": { + "athletic/athletic": "~0.1.8", + "ext-phar": "*", + "phpunit/phpunit": "~4.0", + "squizlabs/php_codesniffer": "2.0.*@ALPHA" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "psr-0": { + "Instantiator\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Marco Pivetta", + "email": "ocramius@gmail.com", + "homepage": "http://ocramius.github.com/", + "role": "Developer" + } + ], + "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors", + "homepage": "https://github.com/Ocramius/Instantiator", + "keywords": [ + "constructor", + "instantiate" + ], + "time": "2014-06-15 11:44:46" + }, + { + "name": "ocramius/lazy-map", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/Ocramius/LazyMap.git", + "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Ocramius/LazyMap/zipball/7fe3d347f5e618bcea7d39345ff83f3651d8b752", + "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "athletic/athletic": "~0.1.6", + "phpmd/phpmd": "1.5.*", + "phpunit/phpunit": ">=3.7", + "satooshi/php-coveralls": "~0.6", + "squizlabs/php_codesniffer": "1.4.*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-0": { + "LazyMap\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Marco Pivetta", + "email": "ocramius@gmail.com", + "homepage": "http://ocramius.github.com/", + "role": "Developer" + } + ], + "description": "A library that provides lazy instantiation logic for a map of objects", + "homepage": "https://github.com/Ocramius/LazyMap", + "keywords": [ + "lazy", + "lazy instantiation", + "lazy loading", + "map", + "service location" + ], + "time": "2013-11-09 22:30:54" + }, { "name": "patchwork/utf8", "version": "v1.1.25", @@ -1039,16 +1148,16 @@ }, { "name": "phpunit/php-code-coverage", - "version": "2.0.9", + "version": "2.0.10", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/php-code-coverage.git", - "reference": "ed8ac99ce38c3fd134128c898f7ca74665abef7f" + "reference": "6d196af48e8c100a3ae881940123e693da5a9217" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/ed8ac99ce38c3fd134128c898f7ca74665abef7f", - "reference": "ed8ac99ce38c3fd134128c898f7ca74665abef7f", + "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/6d196af48e8c100a3ae881940123e693da5a9217", + "reference": "6d196af48e8c100a3ae881940123e693da5a9217", "shasum": "" }, "require": { @@ -1100,7 +1209,7 @@ "testing", "xunit" ], - "time": "2014-06-29 08:14:40" + "time": "2014-08-06 06:39:42" }, { "name": "phpunit/php-file-iterator", @@ -1361,24 +1470,25 @@ }, { "name": "phpunit/phpunit-mock-objects", - "version": "2.1.5", + "version": "2.2.0", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", - "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a" + "reference": "42e589e08bc86e3e9bdf20d385e948347788505b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/7878b9c41edb3afab92b85edf5f0981014a2713a", - "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/42e589e08bc86e3e9bdf20d385e948347788505b", + "reference": "42e589e08bc86e3e9bdf20d385e948347788505b", "shasum": "" }, "require": { + "ocramius/instantiator": "~1.0", "php": ">=5.3.3", "phpunit/php-text-template": "~1.2" }, "require-dev": { - "phpunit/phpunit": "~4.1" + "phpunit/phpunit": "4.2.*@dev" }, "suggest": { "ext-soap": "*" @@ -1386,7 +1496,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-master": "2.1.x-dev" + "dev-master": "2.2.x-dev" } }, "autoload": { @@ -1414,7 +1524,7 @@ "mock", "xunit" ], - "time": "2014-06-12 07:22:15" + "time": "2014-08-02 13:50:58" }, { "name": "raveren/kint", @@ -1732,17 +1842,17 @@ }, { "name": "symfony/yaml", - "version": "v2.5.2", + "version": "v2.5.3", "target-dir": "Symfony/Component/Yaml", "source": { "type": "git", "url": "https://github.com/symfony/Yaml.git", - "reference": "f868ecdbcc0276b6158dfbf08b9e98ce07f014e1" + "reference": "5a75366ae9ca8b4792cd0083e4ca4dff9fe96f1f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/Yaml/zipball/f868ecdbcc0276b6158dfbf08b9e98ce07f014e1", - "reference": "f868ecdbcc0276b6158dfbf08b9e98ce07f014e1", + "url": "https://api.github.com/repos/symfony/Yaml/zipball/5a75366ae9ca8b4792cd0083e4ca4dff9fe96f1f", + "reference": "5a75366ae9ca8b4792cd0083e4ca4dff9fe96f1f", "shasum": "" }, "require": { @@ -1764,20 +1874,18 @@ "MIT" ], "authors": [ - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" - }, { "name": "Symfony Community", "homepage": "http://symfony.com/contributors" + }, + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" } ], "description": "Symfony Yaml Component", "homepage": "http://symfony.com", - "time": "2014-07-09 09:05:48" + "time": "2014-08-05 09:00:40" } ], "aliases": [], From 2a6bb899d59981bbce9fe38e96ec9557d6e1eea4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 13:05:12 +0200 Subject: [PATCH 061/424] Fix tests --- .travis.yml | 38 +++++++++++++-------------- tests/Tasks/CleanupTest.php | 1 + tests/TestCases/RocketeerTestCase.php | 1 + 3 files changed, 21 insertions(+), 19 deletions(-) diff --git a/.travis.yml b/.travis.yml index cca97f3fa..14335be4f 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,19 +1,19 @@ -language: php - -php: - - 5.3 - - 5.4 - - 5.5 - - 5.6 - - hhvm - -before_script: - - composer self-update - - composer install --dev --prefer-dist - -matrix: - allow_failures: - - php: hhvm - fast_finish: true - -script: phpunit \ No newline at end of file +language: php + +php: + - 5.3 + - 5.4 + - 5.5 + - 5.6 + - hhvm + +before_script: + - travis_retry composer self-update + - travis_retry composer install --dev --prefer-dist + +matrix: + allow_failures: + - php: hhvm + fast_finish: true + +script: phpunit --verbose diff --git a/tests/Tasks/CleanupTest.php b/tests/Tasks/CleanupTest.php index db541efb1..795d17bf3 100644 --- a/tests/Tasks/CleanupTest.php +++ b/tests/Tasks/CleanupTest.php @@ -24,6 +24,7 @@ public function testCanPruneAllReleasesIfCleanAll() return $mock ->shouldReceive('getDeprecatedReleases')->never() ->shouldReceive('getNonCurrentReleases')->once()->andReturn(array(1, 2)) + ->shouldReceive('markReleaseAsValid')->once() ->shouldReceive('getPathToRelease')->times(2)->andReturnUsing(function ($release) { return $release; }); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index e706c1153..bf6f26f55 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -3,6 +3,7 @@ use Closure; use Rocketeer\Server; +use Mockery; abstract class RocketeerTestCase extends ContainerTestCase { From fafd8b4846f500edee54f5706bc49b797b39f8e9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 13:07:27 +0200 Subject: [PATCH 062/424] Remove 5.3 from tests matrix --- .travis.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 14335be4f..5f70e65a9 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,7 +1,6 @@ language: php php: - - 5.3 - 5.4 - 5.5 - 5.6 From ff220fcdd0430da1dbfe8fd0f65066a27f84619e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 13:08:07 +0200 Subject: [PATCH 063/424] Code tweaks --- .../Commands/AbstractDeployCommand.php | 4 ++-- src/Rocketeer/Commands/DeployCommand.php | 6 ++--- src/Rocketeer/Commands/UpdateCommand.php | 2 +- src/Rocketeer/Facades/StandaloneFacade.php | 2 +- src/Rocketeer/RocketeerServiceProvider.php | 1 - .../Traits/BashModules/Filesystem.php | 4 ++-- tests/RocketeerTest.php | 6 ++--- tests/Scm/GitTest.php | 1 - tests/Tasks/CheckTest.php | 2 +- tests/TasksHandlerTest.php | 4 ++-- tests/TasksQueueTest.php | 6 ++--- tests/TestCases/ContainerTestCase.php | 12 +++++----- tests/TestCases/RocketeerTestCase.php | 22 +++++++++++-------- tests/Traits/BashModules/CoreTest.php | 2 +- 14 files changed, 38 insertions(+), 36 deletions(-) diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Commands/AbstractDeployCommand.php index 411a52eaa..a06a1525a 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Commands/AbstractDeployCommand.php @@ -180,8 +180,8 @@ protected function getServerCredentials() protected function storeServerCredentials($connections, $connectionName, $server = null) { // Check for server credentials - $connection = $connectionName.'.servers'; - $connection = !is_null($server) ? $connection.'.'.$server : $connection; + $connection = $connectionName.'.servers'; + $connection = !is_null($server) ? $connection.'.'.$server : $connection; $connection = array_get($connections, $connection, array()); $credentials = array( 'host' => true, diff --git a/src/Rocketeer/Commands/DeployCommand.php b/src/Rocketeer/Commands/DeployCommand.php index 9c502c857..6f0475e94 100644 --- a/src/Rocketeer/Commands/DeployCommand.php +++ b/src/Rocketeer/Commands/DeployCommand.php @@ -51,9 +51,9 @@ public function fire() protected function getOptions() { return array_merge(parent::getOptions(), array( - ['tests', 't', InputOption::VALUE_NONE, 'Runs the tests on deploy'], - ['migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'], - ['seed', 's', InputOption::VALUE_NONE, 'Seed the database (after migrating it if --migrate)'], + ['tests', 't', InputOption::VALUE_NONE, 'Runs the tests on deploy'], + ['migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'], + ['seed', 's', InputOption::VALUE_NONE, 'Seed the database (after migrating it if --migrate)'], ['clean-all', null, InputOption::VALUE_NONE, 'Cleanup all but the current release on deploy'], )); } diff --git a/src/Rocketeer/Commands/UpdateCommand.php b/src/Rocketeer/Commands/UpdateCommand.php index 6b3315579..12572d868 100644 --- a/src/Rocketeer/Commands/UpdateCommand.php +++ b/src/Rocketeer/Commands/UpdateCommand.php @@ -49,7 +49,7 @@ protected function getOptions() { return array_merge(parent::getOptions(), array( ['migrate', 'm', InputOption::VALUE_NONE, 'Run the migrations'], - ['seed', 's', InputOption::VALUE_NONE, 'Seed the database after migrating the database'], + ['seed', 's', InputOption::VALUE_NONE, 'Seed the database after migrating the database'], )); } } diff --git a/src/Rocketeer/Facades/StandaloneFacade.php b/src/Rocketeer/Facades/StandaloneFacade.php index 0f554572d..347cdb137 100644 --- a/src/Rocketeer/Facades/StandaloneFacade.php +++ b/src/Rocketeer/Facades/StandaloneFacade.php @@ -37,7 +37,7 @@ protected static function getFacadeAccessor() { if (!static::$app) { $container = new Container(); - $provider = new RocketeerServiceProvider($container); + $provider = new RocketeerServiceProvider($container); $provider->boot(); static::$app = $container; diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index cb301f77d..b7e7ab2d6 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -11,7 +11,6 @@ use Illuminate\Config\FileLoader; use Illuminate\Config\Repository; -use Illuminate\Container\Container; use Illuminate\Events\Dispatcher; use Illuminate\Http\Request; use Illuminate\Log\Writer; diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index c4f713ab1..7e9dfecf4 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -153,7 +153,7 @@ public function putFile($file, $contents) /** * Upload a local file to remote * - * @param string $file + * @param string $file * @param string|null $destination */ public function upload($file, $destination = null) @@ -164,7 +164,7 @@ public function upload($file, $destination = null) // Get contents and destination $destination = $destination ?: basename($file); - $contents = file_get_contents($file); + $contents = file_get_contents($file); $this->putFile($destination, $contents); } diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 305cbe224..5a2519c4b 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -76,15 +76,15 @@ public function testCanUseRecursiveConnectionConfiguration() public function testRocketeerCanGuessWhichStageHesIn() { - $path = '/home/www/foobar/production/releases/12345678901234/app'; + $path = '/home/www/foobar/production/releases/12345678901234/app'; $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals('production', $stage); - $path = '/home/www/foobar/staging/releases/12345678901234/app'; + $path = '/home/www/foobar/staging/releases/12345678901234/app'; $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals('staging', $stage); - $path = '/home/www/foobar/releases/12345678901234/app'; + $path = '/home/www/foobar/releases/12345678901234/app'; $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals(false, $stage); } diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index e8f7a7e41..b203c7e97 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -71,7 +71,6 @@ public function testCanGetDeepClone() ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); - $command = $this->scm->checkout($this->server); $this->assertEquals('git clone -b develop "http://github.com/my/repository" '.$this->server, $command); diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index e4a83d7e9..03d112c9d 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -54,7 +54,7 @@ public function testCanCheckPhpExtensions() public function testCanCheckForHhvmExtensions() { $this->app['remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); - $exists = $this->task('Check')->checkPhpExtension('_hhvm'); + $exists = $this->task('Check')->checkPhpExtension('_hhvm'); $this->assertTrue($exists); } diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index c530a9ffd..b21e25fc3 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -127,8 +127,8 @@ public function testCanHaveCustomConnectionHooks() ); $this->swapConfig(array( - 'rocketeer::default' => 'production', - 'rocketeer::hooks' => [], + 'rocketeer::default' => 'production', + 'rocketeer::hooks' => [], 'rocketeer::on.connections.staging.hooks' => ['after' => ['deploy' => $tasks]], )); $this->tasksQueue()->registerConfiguredEvents(); diff --git a/tests/TasksQueueTest.php b/tests/TasksQueueTest.php index 7519aba39..f07f234c2 100644 --- a/tests/TasksQueueTest.php +++ b/tests/TasksQueueTest.php @@ -52,7 +52,7 @@ public function testCanBuildQueue() { $queue = array( 'foobar', - function ($task) { + function () { return 'lol'; }, 'Rocketeer\Tasks\Deploy' @@ -73,7 +73,7 @@ public function testCanRunQueue() $this->expectOutputString('JOEY DOESNT SHARE FOOD'); $this->tasksQueue()->run(array( - function ($task) { + function () { print 'JOEY DOESNT SHARE FOOD'; } ), $this->getCommand()); @@ -112,7 +112,7 @@ public function testCanRunQueueViaExecute() $output = $this->tasksQueue()->execute(array( 'ls -a', - function ($task) { + function () { return 'JOEY DOESNT SHARE FOOD'; } )); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index b6c986965..6b0dc6541 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -28,9 +28,9 @@ public function setUp() // Laravel classes --------------------------------------------- / - $this->app->instance('path.base', '/src'); - $this->app->instance('path', '/src/app'); - $this->app->instance('path.public', '/src/public'); + $this->app->instance('path.base', '/src'); + $this->app->instance('path', '/src/app'); + $this->app->instance('path.public', '/src/public'); $this->app->instance('path.storage', '/src/app/storage'); $this->app['files'] = new Filesystem; @@ -151,9 +151,9 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('database.default')->andReturn('mysql'); $config->shouldReceive('get')->with('remote.default')->andReturn('production'); $config->shouldReceive('get')->with('remote.connections')->andReturn(array( - 'production' => array(), - 'staging' => array() - )); + 'production' => array(), + 'staging' => array() + )); $config->shouldReceive('get')->with('session.driver')->andReturn('file'); // Rocketeer diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index bf6f26f55..52157de07 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -2,8 +2,8 @@ namespace Rocketeer\TestCases; use Closure; -use Rocketeer\Server; use Mockery; +use Rocketeer\Server; abstract class RocketeerTestCase extends ContainerTestCase { @@ -23,9 +23,8 @@ abstract class RocketeerTestCase extends ContainerTestCase /** * A dummy Task to use for helpers tests - * -*@var \Rocketeer\Abstracts\Task + * @var \Rocketeer\Abstracts\Task */ protected $task; @@ -80,7 +79,14 @@ protected function recreateVirtualServer() // Recreate altered local server $this->app['files']->deleteDirectory($rootPath.'/storage'); $this->app['files']->deleteDirectory($this->server.'/logs'); - $folders = array('current', 'shared', 'releases','releases/10000000000000', 'releases/15000000000000', 'releases/20000000000000'); + $folders = array( + 'current', + 'shared', + 'releases', + 'releases/10000000000000', + 'releases/15000000000000', + 'releases/20000000000000' + ); foreach ($folders as $folder) { $folder = $this->server.'/'.$folder; @@ -249,13 +255,11 @@ protected function pretendTask($task = 'Deploy', $options = array(), array $expe /** * Get Task instance - * -*@param string $task - * @param null $command - + * @param string $task + * @param null $command * -*@return \Rocketeer\Abstracts\Task + * @return \Rocketeer\Abstracts\Task */ protected function task($task = null, $command = null) { diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 0bad9e381..1ad746db4 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -55,7 +55,7 @@ public function testDoesntAppendEnvironmentToStandardTasks() public function testCanRemoveCommonPollutingOutput() { $this->app['remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); - $result = $this->app['rocketeer.bash']->run('ls'); + $result = $this->app['rocketeer.bash']->run('ls'); $this->assertEquals('something', $result); } From f33e79513203f2ef386f78a36891d57843e11787 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 18:49:44 +0200 Subject: [PATCH 064/424] Move interfaces in a separate namespace --- .../{Scm => Interfaces}/ScmInterface.php | 2 +- .../Interfaces/StrategyInterface.php | 20 +++++++++++++++++++ src/Rocketeer/Scm/Git.php | 1 + src/Rocketeer/Scm/Svn.php | 1 + 4 files changed, 23 insertions(+), 1 deletion(-) rename src/Rocketeer/{Scm => Interfaces}/ScmInterface.php (97%) create mode 100644 src/Rocketeer/Interfaces/StrategyInterface.php diff --git a/src/Rocketeer/Scm/ScmInterface.php b/src/Rocketeer/Interfaces/ScmInterface.php similarity index 97% rename from src/Rocketeer/Scm/ScmInterface.php rename to src/Rocketeer/Interfaces/ScmInterface.php index 72ad1fe15..d17cab18d 100644 --- a/src/Rocketeer/Scm/ScmInterface.php +++ b/src/Rocketeer/Interfaces/ScmInterface.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Scm; +namespace Rocketeer\Interfaces; /** * The interface for all SCM implementations diff --git a/src/Rocketeer/Interfaces/StrategyInterface.php b/src/Rocketeer/Interfaces/StrategyInterface.php new file mode 100644 index 000000000..b73b86cfa --- /dev/null +++ b/src/Rocketeer/Interfaces/StrategyInterface.php @@ -0,0 +1,20 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Interfaces; + +/** + * Interface for the various deployment strategies + * + * @author Maxime Fabre + */ +interface StrategyInterface +{ + +} diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index d264622e1..0ca3fd941 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -10,6 +10,7 @@ namespace Rocketeer\Scm; use Rocketeer\Abstracts\Scm; +use Rocketeer\Interfaces\ScmInterface; /** * The Git implementation of the ScmInterface diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index 58fc3999b..e09613621 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -10,6 +10,7 @@ namespace Rocketeer\Scm; use Rocketeer\Abstracts\Scm; +use Rocketeer\Interfaces\ScmInterface; /** * The Svn implementation of the ScmInterface From 2474670c53098f39ab962860094af6bf5bba8ffa Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 18:52:33 +0200 Subject: [PATCH 065/424] Move commands under Console/ --- .../{ => Console}/Commands/AbstractDeployCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/BaseTaskCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/CleanupCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/DeployCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/FlushCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/RocketeerCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/RollbackCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/TestCommand.php | 2 +- src/Rocketeer/{ => Console}/Commands/UpdateCommand.php | 2 +- src/Rocketeer/RocketeerServiceProvider.php | 5 +++-- src/Rocketeer/TasksHandler.php | 2 +- tests/TasksHandlerTest.php | 2 +- 12 files changed, 14 insertions(+), 13 deletions(-) rename src/Rocketeer/{ => Console}/Commands/AbstractDeployCommand.php (99%) rename src/Rocketeer/{ => Console}/Commands/BaseTaskCommand.php (97%) rename src/Rocketeer/{ => Console}/Commands/CleanupCommand.php (96%) rename src/Rocketeer/{ => Console}/Commands/DeployCommand.php (97%) rename src/Rocketeer/{ => Console}/Commands/FlushCommand.php (95%) rename src/Rocketeer/{ => Console}/Commands/RocketeerCommand.php (95%) rename src/Rocketeer/{ => Console}/Commands/RollbackCommand.php (97%) rename src/Rocketeer/{ => Console}/Commands/TestCommand.php (95%) rename src/Rocketeer/{ => Console}/Commands/UpdateCommand.php (96%) diff --git a/src/Rocketeer/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php similarity index 99% rename from src/Rocketeer/Commands/AbstractDeployCommand.php rename to src/Rocketeer/Console/Commands/AbstractDeployCommand.php index a06a1525a..6524a345a 100644 --- a/src/Rocketeer/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Illuminate\Console\Command; use Symfony\Component\Console\Input\InputOption; diff --git a/src/Rocketeer/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php similarity index 97% rename from src/Rocketeer/Commands/BaseTaskCommand.php rename to src/Rocketeer/Console/Commands/BaseTaskCommand.php index 2168ec79e..b2d2560b0 100644 --- a/src/Rocketeer/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Rocketeer\Abstracts\Task; diff --git a/src/Rocketeer/Commands/CleanupCommand.php b/src/Rocketeer/Console/Commands/CleanupCommand.php similarity index 96% rename from src/Rocketeer/Commands/CleanupCommand.php rename to src/Rocketeer/Console/Commands/CleanupCommand.php index 9439bdbb2..91397f4d4 100644 --- a/src/Rocketeer/Commands/CleanupCommand.php +++ b/src/Rocketeer/Console/Commands/CleanupCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Symfony\Component\Console\Input\InputOption; diff --git a/src/Rocketeer/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php similarity index 97% rename from src/Rocketeer/Commands/DeployCommand.php rename to src/Rocketeer/Console/Commands/DeployCommand.php index 6f0475e94..18eb4ad50 100644 --- a/src/Rocketeer/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Symfony\Component\Console\Input\InputOption; diff --git a/src/Rocketeer/Commands/FlushCommand.php b/src/Rocketeer/Console/Commands/FlushCommand.php similarity index 95% rename from src/Rocketeer/Commands/FlushCommand.php rename to src/Rocketeer/Console/Commands/FlushCommand.php index b5c9ecaed..ea4bf1bd4 100644 --- a/src/Rocketeer/Commands/FlushCommand.php +++ b/src/Rocketeer/Console/Commands/FlushCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; /** * Flushes any custom storage Rocketeer has created diff --git a/src/Rocketeer/Commands/RocketeerCommand.php b/src/Rocketeer/Console/Commands/RocketeerCommand.php similarity index 95% rename from src/Rocketeer/Commands/RocketeerCommand.php rename to src/Rocketeer/Console/Commands/RocketeerCommand.php index e5ebaf72c..ae7daf1b5 100644 --- a/src/Rocketeer/Commands/RocketeerCommand.php +++ b/src/Rocketeer/Console/Commands/RocketeerCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Rocketeer\Rocketeer; diff --git a/src/Rocketeer/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php similarity index 97% rename from src/Rocketeer/Commands/RollbackCommand.php rename to src/Rocketeer/Console/Commands/RollbackCommand.php index d691c2f38..6b0a766d0 100644 --- a/src/Rocketeer/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputOption; diff --git a/src/Rocketeer/Commands/TestCommand.php b/src/Rocketeer/Console/Commands/TestCommand.php similarity index 95% rename from src/Rocketeer/Commands/TestCommand.php rename to src/Rocketeer/Console/Commands/TestCommand.php index 61412954d..60232e52b 100644 --- a/src/Rocketeer/Commands/TestCommand.php +++ b/src/Rocketeer/Console/Commands/TestCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; /** * Run the tests on the server and displays the output diff --git a/src/Rocketeer/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php similarity index 96% rename from src/Rocketeer/Commands/UpdateCommand.php rename to src/Rocketeer/Console/Commands/UpdateCommand.php index 12572d868..3b6e936f1 100644 --- a/src/Rocketeer/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Commands; +namespace Rocketeer\Console\Commands; use Symfony\Component\Console\Input\InputOption; diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b7e7ab2d6..a9093eff4 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -17,6 +17,7 @@ use Illuminate\Remote\RemoteManager; use Illuminate\Support\ServiceProvider; use Monolog\Logger; +use Rocketeer\Console\Commands\BaseTaskCommand; // Define DS if (!defined('DS')) { @@ -220,7 +221,7 @@ public function bindCommands() foreach ($tasks as $slug => $task) { // Check if we have an actual command to use - $commandClass = 'Rocketeer\Commands\\'.$task.'Command'; + $commandClass = 'Rocketeer\Console\Commands\\'.$task.'Command'; $fakeCommand = !class_exists($commandClass); // Build command slug @@ -247,7 +248,7 @@ public function bindCommands() // Else create a fake one } else { $this->app->bind($command, function () use ($taskInstance, $slug) { - return new Commands\BaseTaskCommand($taskInstance, $slug); + return new BaseTaskCommand($taskInstance, $slug); }); } } diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index 86cbd385d..1f7d8feca 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -12,7 +12,7 @@ use Closure; use Illuminate\Container\Container; use Rocketeer\Abstracts\AbstractLocatorClass; -use Rocketeer\Commands\BaseTaskCommand; +use Rocketeer\Console\Commands\BaseTaskCommand; use Rocketeer\Traits\HasLocator; /** diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index b21e25fc3..814a6ea26 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -9,7 +9,7 @@ class TasksHandlerTest extends RocketeerTestCase public function testCanAddCommandsToArtisan() { $command = $this->tasksQueue()->add('Rocketeer\Tasks\Deploy'); - $this->assertInstanceOf('Rocketeer\Commands\BaseTaskCommand', $command); + $this->assertInstanceOf('Rocketeer\Console\Commands\BaseTaskCommand', $command); $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $command->getTask()); } From 39653049b73d26e6337dc150af8a72e8c27f53d5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 20:00:59 +0200 Subject: [PATCH 066/424] Work on Strategies and History refactor --- src/Rocketeer/Abstracts/Strategy.php | 14 +++ src/Rocketeer/Bash.php | 2 - src/Rocketeer/History/History.php | 22 ++++ src/Rocketeer/{ => History}/LogsHandler.php | 2 +- .../Interfaces/StrategyInterface.php | 16 +++ src/Rocketeer/RocketeerServiceProvider.php | 20 +++- src/Rocketeer/Strategies/CloneStrategy.php | 62 +++++++++++ src/Rocketeer/Strategies/CopyStrategy.php | 36 +++++++ src/Rocketeer/Tasks/Check.php | 4 +- src/Rocketeer/Tasks/Deploy.php | 11 +- src/Rocketeer/Tasks/Update.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 29 +---- src/Rocketeer/Traits/BashModules/Scm.php | 102 ------------------ src/Rocketeer/Traits/HasHistory.php | 62 +++++++++++ src/Rocketeer/Traits/HasLocator.php | 28 ++--- tests/Abstracts/ScmTest.php | 7 +- tests/Abstracts/TaskTest.php | 16 --- tests/Strategies/CloneStrategyTest.php | 39 +++++++ tests/Tasks/DeployTest.php | 4 +- tests/Tasks/IgniteTest.php | 4 +- tests/Tasks/SetupTest.php | 6 ++ tests/TestCases/ContainerTestCase.php | 16 ++- tests/TestCases/RocketeerTestCase.php | 37 ++++--- tests/Traits/BashModules/ScmTest.php | 2 +- 24 files changed, 348 insertions(+), 195 deletions(-) create mode 100644 src/Rocketeer/Abstracts/Strategy.php create mode 100644 src/Rocketeer/History/History.php rename src/Rocketeer/{ => History}/LogsHandler.php (98%) create mode 100644 src/Rocketeer/Strategies/CloneStrategy.php create mode 100644 src/Rocketeer/Strategies/CopyStrategy.php delete mode 100644 src/Rocketeer/Traits/BashModules/Scm.php create mode 100644 src/Rocketeer/Traits/HasHistory.php create mode 100644 tests/Strategies/CloneStrategyTest.php diff --git a/src/Rocketeer/Abstracts/Strategy.php b/src/Rocketeer/Abstracts/Strategy.php new file mode 100644 index 000000000..7029447a5 --- /dev/null +++ b/src/Rocketeer/Abstracts/Strategy.php @@ -0,0 +1,14 @@ +items as $class => $entries) { + $history = array_merge($history, $entries); + } + + ksort($history); + + return array_values($history); + } +} diff --git a/src/Rocketeer/LogsHandler.php b/src/Rocketeer/History/LogsHandler.php similarity index 98% rename from src/Rocketeer/LogsHandler.php rename to src/Rocketeer/History/LogsHandler.php index aca468560..017669e9f 100644 --- a/src/Rocketeer/LogsHandler.php +++ b/src/Rocketeer/History/LogsHandler.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer; +namespace Rocketeer\History; use Rocketeer\Traits\HasLocator; diff --git a/src/Rocketeer/Interfaces/StrategyInterface.php b/src/Rocketeer/Interfaces/StrategyInterface.php index b73b86cfa..083802bc4 100644 --- a/src/Rocketeer/Interfaces/StrategyInterface.php +++ b/src/Rocketeer/Interfaces/StrategyInterface.php @@ -16,5 +16,21 @@ */ interface StrategyInterface { + /** + * Deploy a new clean copy of the application + * + * @param string|null $destination + * + * @return boolean + */ + public function deploy($destination = null); + /** + * Update the latest version of the application + * + * @param boolean $reset + * + * @return boolean + */ + public function update($reset = true); } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index a9093eff4..bf22056e7 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -18,6 +18,8 @@ use Illuminate\Support\ServiceProvider; use Monolog\Logger; use Rocketeer\Console\Commands\BaseTaskCommand; +use Rocketeer\History\History; +use Rocketeer\History\LogsHandler; // Define DS if (!defined('DS')) { @@ -60,7 +62,7 @@ public function boot() // Bind Rocketeer's classes $this->bindClasses(); - $this->bindScm(); + $this->bindStrategies(); // Load the user's events and tasks $this->loadFileOrFolder('tasks'); @@ -166,6 +168,10 @@ public function bindClasses() return new TasksHandler($app); }); + $this->app->singleton('rocketeer.history', function () { + return new History; + }); + $this->app->singleton('rocketeer.logs', function ($app) { return new LogsHandler($app); }); @@ -181,15 +187,23 @@ public function bindClasses() /** * Bind the SCM instance */ - public function bindScm() + public function bindStrategies() { - // Currently only one + // Bind SCM class $scm = $this->app['rocketeer.rocketeer']->getOption('scm.scm'); $scm = 'Rocketeer\Scm\\'.ucfirst($scm); $this->app->bind('rocketeer.scm', function ($app) use ($scm) { return new $scm($app); }); + + // Bind strategy + $this->app->bind('rocketeer.strategy', function ($app) { + $strategy = $app['rocketeer.rocketeer']->getOption('remote.strategy'); + $strategy = sprintf('Rocketeer\Strategies\%sStrategy', ucfirst($strategy)); + + return new $strategy($app); + }); } /** diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php new file mode 100644 index 000000000..be8c11215 --- /dev/null +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -0,0 +1,62 @@ +releasesManager->getCurrentReleasePath(); + } + + // Executing checkout + $this->command->info('Cloning repository in "'.$destination.'"'); + $output = $this->bash->run($this->scm->checkout($destination)); + + // Cancel if failed and forget credentials + $success = $this->bash->checkStatus('Unable to clone the repository', $output) !== false; + if (!$success) { + $this->server->forgetValue('credentials'); + + return false; + } + + // Deploy submodules + if ($this->rocketeer->getOption('scm.submodules')) { + $this->command->info('Initializing submodules if any'); + $this->bash->runForCurrentRelease($this->scm->submodules()); + } + + return $success; + } + + /** + * Update the latest version of the application + * + * @param boolean $reset + * + * @return boolean + */ + public function update($reset = true) + { + $this->command->info('Pulling changes'); + $tasks = [$this->scm->update()]; + + // Reset if requested + if ($reset) { + array_unshift($tasks, $this->scm->reset()); + } + + return $this->bash->runForCurrentRelease($tasks); + } +} diff --git a/src/Rocketeer/Strategies/CopyStrategy.php b/src/Rocketeer/Strategies/CopyStrategy.php new file mode 100644 index 000000000..6ebe7d0f5 --- /dev/null +++ b/src/Rocketeer/Strategies/CopyStrategy.php @@ -0,0 +1,36 @@ +releasesManager->getPreviousRelease(); + $previous = $this->releasesManager->getPathToRelease($previous); + if (!$previous) { + return parent::deploy($destination); + } + + // Recompute destination + if (!$destination) { + $destination = $this->releasesManager->getCurrentReleasePath(); + } + + // Copy old release into new one + $this->command->info('Copying previous release "'.$previous.'" in "'.$destination.'"'); + $this->bash->copy($previous, $destination); + + // Update repository + return $this->update(); + } +} diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 979ac653c..679af7082 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -108,7 +108,9 @@ protected function getChecks() public function checkScm() { $this->command->comment('Checking presence of '.$this->scm->binary); - $this->history[] = $this->scm->execute('check'); + $results = $this->scm->execute('check'); + + //$this->toHistory($results); return $this->remote->status() == 0; } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index ddad1a835..c6bf642f4 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -46,11 +46,12 @@ public function execute() // Run halting methods foreach ($this->halting as $method) { - if (!$this->fireEvent($method)) { + if (!$this->fireEvent($method['as'])) { return false; } - if (!$this->$method()) { + list ($class, $method) = $method['on']; + if (!$class->$method()) { return $this->halt(); } } @@ -125,9 +126,9 @@ protected function createEvents() { $strategy = $this->rocketeer->getOption('remote.strategy'); $this->halting = array( - $strategy.'Repository', - 'runComposer', - 'checkTestsResults', + ['as' => $strategy.'Repository', 'on' => [$this->strategy, 'deploy']], + ['as' => 'runComposer', 'on' => [$this, 'runComposer']], + ['as' => 'checkTestsResults', 'on' => [$this, 'checkTestsResults']], ); } diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 8e9167675..1088f35b2 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -31,7 +31,7 @@ class Update extends Deploy public function execute() { // Update repository - $this->updateRepository(); + $this->strategy->update(); // Recreate symlinks if necessary $this->syncSharedFolders(); diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 770bf264d..4a3309359 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -11,6 +11,7 @@ use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractLocatorClass; +use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; /** @@ -21,27 +22,7 @@ trait Core { use HasLocator; - - /** - * An history of executed commands - * - * @var array - */ - protected $history = array(); - - //////////////////////////////////////////////////////////////////// - /////////////////////////////// HISTORY //////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Get the Task's history - * - * @return array - */ - public function getHistory() - { - return $this->history; - } + use HasHistory; //////////////////////////////////////////////////////////////////// ///////////////////////////// CORE METHODS ///////////////////////// @@ -84,7 +65,7 @@ public function run($commands, $silent = false, $array = false) // Append output if (!$silent) { - $this->history[] = $output; + $this->toHistory($output); } return $output; @@ -231,8 +212,8 @@ protected function getOption($option) protected function addCommandsToHistory($commands) { $this->command->line(implode(PHP_EOL, $commands)); - $commands = (sizeof($commands) == 1) ? $commands[0] : $commands; - $this->history[] = $commands; + $commands = (sizeof($commands) == 1) ? $commands[0] : $commands; + $this->toHistory($commands); return $commands; } diff --git a/src/Rocketeer/Traits/BashModules/Scm.php b/src/Rocketeer/Traits/BashModules/Scm.php deleted file mode 100644 index 289f65a74..000000000 --- a/src/Rocketeer/Traits/BashModules/Scm.php +++ /dev/null @@ -1,102 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ -namespace Rocketeer\Traits\BashModules; - -/** - * Repository handling - * - * @author Maxime Fabre - */ -trait Scm -{ - /** - * Copies the repository into a release folder and update it - * - * @param string $destination - * - * @return string - */ - public function copyRepository($destination = null) - { - // Get the previous release, if none clone from scratch - $previous = $this->releasesManager->getPreviousRelease(); - $previous = $this->releasesManager->getPathToRelease($previous); - if (!$previous) { - return $this->cloneRepository($destination); - } - - // Recompute destination - if (!$destination) { - $destination = $this->releasesManager->getCurrentReleasePath(); - } - - // Copy old release into new one - $this->command->info('Copying previous release "'.$previous.'" in "'.$destination.'"'); - $this->copy($previous, $destination); - - // Update repository - return $this->updateRepository(); - } - - /** - * Clone the repo into a release folder - * - * @param string $destination Where to clone to - * - * @return string - */ - public function cloneRepository($destination = null) - { - if (!$destination) { - $destination = $this->releasesManager->getCurrentReleasePath(); - } - - // Executing checkout - $this->command->info('Cloning repository in "'.$destination.'"'); - $output = $this->scm->execute('checkout', $destination); - $this->history[] = $output; - - // Cancel if failed and forget credentials - $success = $this->checkStatus('Unable to clone the repository', $output) !== false; - if (!$success) { - $this->server->forgetValue('credentials'); - - return false; - } - - // Deploy submodules - if ($this->rocketeer->getOption('scm.submodules')) { - $this->command->info('Initializing submodules if any'); - $this->runForCurrentRelease($this->scm->submodules()); - } - - return $success; - } - - /** - * Update the current release - * - * @param boolean $reset Whether the repository should be reset first - * - * @return string - */ - public function updateRepository($reset = true) - { - $this->command->info('Pulling changes'); - $tasks = array($this->scm->update()); - - // Reset if requested - if ($reset) { - array_unshift($tasks, $this->scm->reset()); - } - - return $this->runForCurrentRelease($tasks); - } -} diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php new file mode 100644 index 000000000..e9bbf2303 --- /dev/null +++ b/src/Rocketeer/Traits/HasHistory.php @@ -0,0 +1,62 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Traits; + +/** + * A class that maintains an history of results/commands + * + * @author Maxime Fabre + */ +trait HasHistory +{ + /** + * Get the class's history + * + * @return array + */ + public function getHistory() + { + $handle = $this->getHistoryHandle(); + + return $this->history[$handle]; + } + + /** + * Append an entry to the history + * + * @param array|string $output + */ + public function toHistory($output) + { + $handle = $this->getHistoryHandle(); + $history = $this->getHistory(); + $timestamp = (string) microtime(true); + $history[$timestamp] = $output; + + $this->history[$handle] = $history; + } + + /** + * Get the class's handle in the history + * + * @return string + */ + protected function getHistoryHandle() + { + $handle = get_called_class(); + + // Create entry if it doesn't exist yet + if (!isset($this->history[$handle])) { + $this->history[$handle] = []; + } + + return $handle; + } +} diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index c01c97102..65df8a1c1 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,17 +15,19 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Config\Repository config - * @property \Illuminate\Console\Command command - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Abstracts\Scm scm - * @property \Rocketeer\ConnectionsHandler connections - * @property \Rocketeer\Bash bash - * @property \Rocketeer\ReleasesManager releasesManager - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Server server - * @property \Rocketeer\TasksHandler tasks - * @property \Rocketeer\TasksQueue queue + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Bash bash + * @property \Rocketeer\ConnectionsHandler connections + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Server server + * @property \Rocketeer\TasksHandler tasks + * @property \Rocketeer\TasksQueue queue + * @property \Rocketeer\History\History history * @author Maxime Fabre */ trait HasLocator @@ -58,15 +60,17 @@ public function __get($key) { $shortcuts = array( 'bash' => 'rocketeer.bash', - 'connections' => 'rocketeer.connections', 'command' => 'rocketeer.command', + 'connections' => 'rocketeer.connections', 'console' => 'rocketeer.console', + 'history' => 'rocketeer.history', 'logs' => 'rocketeer.logs', 'queue' => 'rocketeer.queue', 'releasesManager' => 'rocketeer.releases', 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', 'server' => 'rocketeer.server', + 'strategy' => 'rocketeer.strategy', 'tasks' => 'rocketeer.tasks', ); diff --git a/tests/Abstracts/ScmTest.php b/tests/Abstracts/ScmTest.php index e671e96ca..e906787ad 100644 --- a/tests/Abstracts/ScmTest.php +++ b/tests/Abstracts/ScmTest.php @@ -22,9 +22,10 @@ public function testCanExecuteMethod() }); }); - $scm = new Git($this->app); - $command = $scm->execute('checkout', $this->server); + $scm = new Git($this->app); + $command = $scm->execute('checkout', $this->server); + $expected = $this->replaceHistoryPlaceholders(['git clone --depth 1 -b master "{repository}" {server}']); - $this->assertEquals('git clone --depth 1 -b master "" '.$this->server, $command); + $this->assertEquals($expected[0], $command); } } diff --git a/tests/Abstracts/TaskTest.php b/tests/Abstracts/TaskTest.php index cd755c5c3..32dc94baf 100644 --- a/tests/Abstracts/TaskTest.php +++ b/tests/Abstracts/TaskTest.php @@ -5,22 +5,6 @@ class TaskTest extends RocketeerTestCase { - public function testCanUpdateRepository() - { - $task = $this->pretendTask('Deploy'); - $task->updateRepository(); - - $matcher = array( - array( - "cd $this->server/releases/20000000000000", - "git reset --hard", - "git pull", - ), - ); - - $this->assertEquals($matcher, $task->getHistory()); - } - public function testCanDisplayOutputOfCommandsIfVerbose() { $task = $this->pretendTask('Check', array( diff --git a/tests/Strategies/CloneStrategyTest.php b/tests/Strategies/CloneStrategyTest.php new file mode 100644 index 000000000..6ed699648 --- /dev/null +++ b/tests/Strategies/CloneStrategyTest.php @@ -0,0 +1,39 @@ +pretendTask('Deploy'); + $task->strategy->deploy(); + + $matcher = array( + 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + array( + "cd {server}/releases/{release}", + "git submodule update --init --recursive" + ), + ); + + $this->assertHistory($matcher, $task->history->getFlattened()); + } + + public function testCanUpdateRepository() + { + $task = $this->pretendTask('Deploy'); + $task->strategy->update(); + + $matcher = array( + array( + "cd $this->server/releases/20000000000000", + "git reset --hard", + "git pull", + ) + ); + + $this->assertHistory($matcher, $task->history->getFlattened()); + } +} diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 1d796c442..c96728971 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -116,7 +116,7 @@ public function testCanConfigureComposerCommands() $deploy = $this->pretendTask('Deploy'); $deploy->runComposer(true); - $this->assertTaskHistory($deploy->getHistory(), $matcher, array( + $this->assertTaskHistory($deploy->history->getFlattened(), $matcher, array( 'tests' => false, 'seed' => false, 'migrate' => false @@ -164,7 +164,7 @@ public function testCanUseCopyStrategy() public function testCanRunDeployWithSeed() { $matcher = array( - 'git clone --depth 1 -b master "" {server}/releases/{release}', + 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', array( "cd {server}/releases/{release}", "git submodule update --init --recursive" diff --git a/tests/Tasks/IgniteTest.php b/tests/Tasks/IgniteTest.php index 49242c182..038918485 100644 --- a/tests/Tasks/IgniteTest.php +++ b/tests/Tasks/IgniteTest.php @@ -16,7 +16,7 @@ public function testCanIgniteConfigurationOutsideLaravel() ->shouldReceive('exportConfiguration')->once()->andReturn($server) ->shouldReceive('updateConfiguration')->once()->with($server, array( 'connection' => 'production', - 'scm_repository' => '', + 'scm_repository' => 'https://github.com/'.$this->repository, 'scm_username' => '', 'scm_password' => '', 'application_name' => 'foobar', @@ -38,7 +38,7 @@ public function testCanIgniteConfigurationInLaravel() ->shouldReceive('exportConfiguration')->never() ->shouldReceive('updateConfiguration')->once()->with($path, array( 'connection' => 'production', - 'scm_repository' => '', + 'scm_repository' => 'https://github.com/'.$this->repository, 'scm_username' => '', 'scm_password' => '', 'application_name' => '', diff --git a/tests/Tasks/SetupTest.php b/tests/Tasks/SetupTest.php index ef8425a24..c7124cb9c 100644 --- a/tests/Tasks/SetupTest.php +++ b/tests/Tasks/SetupTest.php @@ -14,6 +14,8 @@ public function testCanSetupServer() }); $this->assertTaskHistory('Setup', array( + 'git --version', + '/usr/local/bin/php -m', "mkdir {server}/", "mkdir -p {server}/releases", "mkdir -p {server}/current", @@ -33,6 +35,8 @@ public function testCanSetupStages() )); $this->assertTaskHistory('Setup', array( + 'git --version', + '/usr/local/bin/php -m', "mkdir {server}/", "mkdir -p {server}/staging/releases", "mkdir -p {server}/staging/current", @@ -57,6 +61,8 @@ public function testRunningSetupKeepsCurrentCongiguredStage() $this->app['rocketeer.connections']->setStage('staging'); $this->assertEquals('staging', $this->app['rocketeer.connections']->getStage()); $this->assertTaskHistory('Setup', array( + 'git --version', + '/usr/local/bin/php -m', "mkdir {server}/", "mkdir -p {server}/staging/releases", "mkdir -p {server}/staging/current", diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 6b0dc6541..76204c128 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -17,6 +17,13 @@ abstract class ContainerTestCase extends PHPUnit_Framework_TestCase */ protected $app; + /** + * The test repository + * + * @var string + */ + protected $repository = 'Anahkiasen/html-object.git'; + /** * Set up the tests * @@ -45,7 +52,7 @@ public function setUp() $serviceProvider->bindPaths(); $serviceProvider->bindCoreClasses(); $serviceProvider->bindClasses(); - $serviceProvider->bindScm(); + $serviceProvider->bindStrategies(); } /** @@ -189,6 +196,13 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('rocketeer::paths.artisan')->andReturn(''); // SCM + $config->shouldReceive('get')->with('rocketeer::scm')->andReturn(array( + 'branch' => 'master', + 'repository' => 'https://github.com/'.$this->repository, + 'scm' => 'git', + 'shallow' => true, + 'submodules' => true, + )); $config->shouldReceive('get')->with('rocketeer::scm.branch')->andReturn('master'); $config->shouldReceive('get')->with('rocketeer::scm.repository')->andReturn('https://github.com/'.$this->repository); $config->shouldReceive('get')->with('rocketeer::scm.scm')->andReturn('git'); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 52157de07..179e738d2 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -28,13 +28,6 @@ abstract class RocketeerTestCase extends ContainerTestCase */ protected $task; - /** - * The test repository - * - * @var string - */ - protected $repository = 'Anahkiasen/html-object.git'; - /** * Set up the tests */ @@ -146,11 +139,18 @@ protected function assertTaskHistory($task, array $expectedHistory, array $optio $taskHistory = $task; } else { $results = $task->execute(); - $taskHistory = $task->getHistory(); + $taskHistory = $task->history->getFlattened(); } + $this->assertHistory($expectedHistory, $taskHistory); + + return $results; + } + + public function assertHistory($expected, $obtained) + { // Look for release in history - $release = implode(array_flatten($taskHistory)); + $release = implode(array_flatten($obtained)); preg_match_all('/[0-9]{14}/', $release, $releases); $release = array_get($releases, '0.0', date('YmdHis')); if ($release === '10000000000000') { @@ -158,12 +158,10 @@ protected function assertTaskHistory($task, array $expectedHistory, array $optio } // Replace placeholders - $expectedHistory = $this->replaceHistoryPlaceholders($expectedHistory, $release); + $expected = $this->replaceHistoryPlaceholders($expected, $release); // Check equality - $this->assertEquals($expectedHistory, $taskHistory); - - return $results; + $this->assertEquals($expected, $obtained); } /** @@ -184,11 +182,12 @@ protected function replaceHistoryPlaceholders($history, $release = null) } $history[$key] = strtr($entries, array( - '{php}' => exec('which php'), - '{phpunit}' => exec('which phpunit'), - '{server}' => $this->server, - '{release}' => $release, - '{composer}' => exec('which composer'), + '{php}' => exec('which php'), + '{phpunit}' => exec('which phpunit'), + '{repository}' => 'https://github.com/'.$this->repository, + '{server}' => $this->server, + '{release}' => $release, + '{composer}' => exec('which composer'), )); } @@ -237,7 +236,7 @@ protected function usesComposer($uses = true) * @param array $options * @param array $expectations * - * @return Task + * @return \Rocketeer\Abstracts\Task */ protected function pretendTask($task = 'Deploy', $options = array(), array $expectations = array()) { diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index c1b52817b..2e992d82f 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -19,7 +19,7 @@ public function testCanForgetCredentialsIfInvalid() $task = $this->pretendTask(); $task->remote = $remote; - $task->cloneRepository($this->server.'/test'); + $task->strategy->deploy($this->server.'/test'); $this->assertNull($this->app['rocketeer.server']->getValue('credentials')); } } From 27afff553e2b2d3ed6c5d66273ca7507158cf3fa Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 6 Aug 2014 23:55:42 +0200 Subject: [PATCH 067/424] Close #189 - Fix behavior of copy strategy --- src/Rocketeer/ReleasesManager.php | 17 ++-- src/Rocketeer/Strategies/CopyStrategy.php | 6 ++ .../Traits/BashModules/Filesystem.php | 2 +- tests/Abstracts/TaskTest.php | 3 +- tests/ReleasesManagerTest.php | 56 ++++++++++++- tests/Strategies/CopyStrategyTest.php | 78 +++++++++++++++++++ tests/Tasks/DeployTest.php | 6 +- tests/TestCases/RocketeerTestCase.php | 77 ++++++++++++++---- 8 files changed, 216 insertions(+), 29 deletions(-) create mode 100644 tests/Strategies/CopyStrategyTest.php diff --git a/src/Rocketeer/ReleasesManager.php b/src/Rocketeer/ReleasesManager.php index 7bc801f1f..b911b6255 100644 --- a/src/Rocketeer/ReleasesManager.php +++ b/src/Rocketeer/ReleasesManager.php @@ -33,7 +33,7 @@ class ReleasesManager * * @type array */ - public $releases = array(); + public $releases; /** * Build a new ReleasesManager @@ -58,12 +58,16 @@ public function __construct(Container $app) public function getReleases() { // Get releases on server - if (!$this->releases) { + if (is_null($this->releases)) { $releases = $this->getReleasesPath(); - $releases = $this->bash->listContents($releases); - if (is_array($releases)) { - rsort($releases); - } + $releases = (array) $this->bash->listContents($releases); + + // Filter and sort releases + $releases = array_filter($releases, function ($release) { + return preg_match('#[0-9]{14}#', $release); + }); + + rsort($releases); $this->releases = $releases; } @@ -293,6 +297,7 @@ public function getPreviousRelease($release = null) // Get the one before that, or default to current $key = array_search($current, $releases); + $key = !is_int($key) ? -1 : $key; $next = 1; do { $release = array_get($releases, $key + $next); diff --git a/src/Rocketeer/Strategies/CopyStrategy.php b/src/Rocketeer/Strategies/CopyStrategy.php index 6ebe7d0f5..9edec5177 100644 --- a/src/Rocketeer/Strategies/CopyStrategy.php +++ b/src/Rocketeer/Strategies/CopyStrategy.php @@ -15,6 +15,12 @@ class CopyStrategy extends CloneStrategy implements StrategyInterface public function deploy($destination = null) { // Get the previous release, if none clone from scratch + $previous = $this->releasesManager->getReleases(); + if (!$previous) { + return parent::deploy($destination); + } + + // If we have a previous release, check its validity $previous = $this->releasesManager->getPreviousRelease(); $previous = $this->releasesManager->getPathToRelease($previous); if (!$previous) { diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index 7e9dfecf4..a379b09cb 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -67,7 +67,7 @@ public function move($origin, $destination) */ public function copy($origin, $destination) { - return $this->fromTo('cp', $origin, $destination); + return $this->fromTo('cp -r', $origin, $destination); } /** diff --git a/tests/Abstracts/TaskTest.php b/tests/Abstracts/TaskTest.php index 32dc94baf..a50e23200 100644 --- a/tests/Abstracts/TaskTest.php +++ b/tests/Abstracts/TaskTest.php @@ -7,9 +7,8 @@ class TaskTest extends RocketeerTestCase { public function testCanDisplayOutputOfCommandsIfVerbose() { - $task = $this->pretendTask('Check', array( + $task = $this->task('Check', array( 'verbose' => true, - 'pretend' => false )); ob_start(); diff --git a/tests/ReleasesManagerTest.php b/tests/ReleasesManagerTest.php index 927dcfaf1..888ee575c 100644 --- a/tests/ReleasesManagerTest.php +++ b/tests/ReleasesManagerTest.php @@ -107,17 +107,40 @@ public function testCanGetPreviousValidRelease() public function testReturnsCurrentReleaseIfNoPreviousValidRelease() { - file_put_contents($this->server.'/state.json', json_encode(array( + $this->mockState(array( '10000000000000' => false, '15000000000000' => false, '20000000000000' => true, - ))); + )); $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); $this->assertEquals(20000000000000, $currentRelease); } + public function testReturnsCurrentReleaseIfOnlyRelease() + { + $this->mockState(array( + '20000000000000' => true, + )); + + $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); + + $this->assertEquals(20000000000000, $currentRelease); + } + + public function testReturnsCorrectPreviousReleaseIfUpdatedBeforehand() + { + $this->mockState(array( + '20000000000000' => true, + )); + + $this->app['rocketeer.releases']->updateCurrentRelease(); + $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); + + $this->assertEquals(20000000000000, $currentRelease); + } + public function testCanUpdateCurrentRelease() { $this->app['rocketeer.releases']->updateCurrentRelease(30000000000000); @@ -137,7 +160,21 @@ public function testDoesntPingForReleasesAllTheFuckingTime() $this->mock('rocketeer.bash', 'Rocketeer\Bash', function ($mock) { return $mock ->shouldReceive('getFile')->times(1) - ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([1, 2, 3]); + ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([20000000000000]); + }); + + $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->app['rocketeer.releases']->getNonCurrentReleases(); + } + + public function testDoesntPingForReleasesIfNoReleases() + { + $this->mock('rocketeer.bash', 'Rocketeer\Bash', function ($mock) { + return $mock + ->shouldReceive('getFile')->times(1) + ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([]); }); $this->app['rocketeer.releases']->getNonCurrentReleases(); @@ -145,4 +182,17 @@ public function testDoesntPingForReleasesAllTheFuckingTime() $this->app['rocketeer.releases']->getNonCurrentReleases(); $this->app['rocketeer.releases']->getNonCurrentReleases(); } + + public function testIgnoresErrorsAndStuffWhenFetchingReleases() + { + $this->mock('rocketeer.bash', 'Rocketeer\Bash', function ($mock) { + return $mock + ->shouldReceive('getFile')->times(1) + ->shouldReceive('listContents')->times(1)->with($this->server.'/releases')->andReturn(['IMPOSSIBLE BECAUSE NOPE FUCK YOU']); + }); + + $releases = $this->app['rocketeer.releases']->getReleases(); + + $this->assertEmpty($releases); + } } diff --git a/tests/Strategies/CopyStrategyTest.php b/tests/Strategies/CopyStrategyTest.php new file mode 100644 index 000000000..7b23970d9 --- /dev/null +++ b/tests/Strategies/CopyStrategyTest.php @@ -0,0 +1,78 @@ +app->bind('rocketeer.strategy', function ($app) { + return new CopyStrategy($app); + }); + + $this->pretend(); + } + + public function testCanCopyPreviousRelease() + { + $this->app['rocketeer.strategy']->deploy(); + + $matcher = array( + 'cp -r {server}/releases/10000000000000 {server}/releases/20000000000000', + array( + "cd {server}/releases/{release}", + "git reset --hard", + "git pull", + ), + ); + + $this->assertHistory($matcher, $this->app['rocketeer.history']->getFlattened()); + } + + public function testClonesIfNoPreviousRelease() + { + $this->mock('rocketeer.releases', 'ReleasesManager', function (MockInterface $mock) { + return $mock->shouldReceive('getReleases')->andReturn([]) + ->shouldReceive('getCurrentReleasePath')->andReturn($this->server.'/releases/10000000000000'); + }); + + $this->app['rocketeer.strategy']->deploy(); + + $matcher = array( + 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + array( + "cd {server}/releases/{release}", + "git submodule update --init --recursive" + ), + ); + + $this->assertHistory($matcher, $this->app['rocketeer.history']->getFlattened()); + } + + public function testCanCloneIfPreviousReleaseIsInvalid() + { + $this->mock('rocketeer.releases', 'ReleasesManager', function (MockInterface $mock) { + return $mock->shouldReceive('getReleases')->andReturn([10000000000000]) + ->shouldReceive('getPreviousRelease')->andReturn(null) + ->shouldReceive('getPathToRelease')->andReturn(null) + ->shouldReceive('getCurrentReleasePath')->andReturn($this->server.'/releases/10000000000000'); + }); + + $this->app['rocketeer.strategy']->deploy(); + + $matcher = array( + 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + array( + "cd {server}/releases/{release}", + "git submodule update --init --recursive" + ), + ); + + $this->assertHistory($matcher, $this->app['rocketeer.history']->getFlattened()); + } +} diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index c96728971..fea585dd0 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -134,8 +134,12 @@ public function testCanUseCopyStrategy() ) )); + $this->mockState(array( + '10000000000000' => true, + )); + $matcher = array( - 'cp {server}/releases/10000000000000 {server}/releases/{release}', + 'cp -r {server}/releases/10000000000000 {server}/releases/{release}', array( 'cd {server}/releases/{release}', 'git reset --hard', diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 179e738d2..c3980df98 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -114,7 +114,11 @@ protected function recreateVirtualServer() */ protected function assertTaskOutput($task, $output, $command = null) { - return $this->assertContains($output, $this->task($task, $command)->execute()); + if ($command) { + $this->app['rocketeer.command'] = $command; + } + + return $this->assertContains($output, $this->task($task)->execute()); } /** @@ -147,7 +151,13 @@ protected function assertTaskHistory($task, array $expectedHistory, array $optio return $results; } - public function assertHistory($expected, $obtained) + /** + * Assert an history matches another + * + * @param array $expected + * @param array $obtained + */ + public function assertHistory(array $expected, array $obtained) { // Look for release in history $release = implode(array_flatten($obtained)); @@ -167,7 +177,8 @@ public function assertHistory($expected, $obtained) /** * Replace placeholders in an history * - * @param array $history + * @param array $history + * @param integer|null $release * * @return array */ @@ -210,6 +221,34 @@ protected function mockReleases(Closure $expectations) return $this->mock('rocketeer.releases', 'ReleasesManager', $expectations); } + /** + * Mock a Command + * + * @param array $options + * @param array $expectations + */ + protected function mockCommand($options = array(), $expectations = array()) + { + // Default options + $options = array_merge(array( + 'pretend' => false, + 'verbose' => false, + 'tests' => false, + 'migrate' => false, + 'seed' => false, + ), $options); + + $this->app['rocketeer.command'] = $this->getCommand($expectations, $options); + } + + /** + * @param array $state + */ + protected function mockState(array $state) + { + file_put_contents($this->server.'/state.json', json_encode($state)); + } + //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// @@ -229,6 +268,19 @@ protected function usesComposer($uses = true) }); } + /** + * Set Rocketeer in pretend mode + * + * @param array $options + * @param array $expectations + */ + protected function pretend($options = array(), $expectations = array()) + { + $options['pretend'] = true; + + $this->mockCommand($options, $expectations); + } + /** * Get a pretend Task to run bogus commands * @@ -240,30 +292,23 @@ protected function usesComposer($uses = true) */ protected function pretendTask($task = 'Deploy', $options = array(), array $expectations = array()) { - // Default options - $options = array_merge(array( - 'pretend' => true, - 'verbose' => false, - 'tests' => false, - 'migrate' => false, - 'seed' => false, - ), $options); + $this->pretend($options, $expectations); - return $this->task($task, $this->getCommand($expectations, $options)); + return $this->task($task); } /** * Get Task instance * * @param string $task - * @param null $command + * @param array $options * * @return \Rocketeer\Abstracts\Task */ - protected function task($task = null, $command = null) + protected function task($task = null, $options = array()) { - if ($command) { - $this->app['rocketeer.command'] = $command; + if ($options) { + $this->mockCommand($options); } if (!$task) { From 8e5abb8a4ccccabf6e9816cf72ea698ff1a33dd8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 00:08:25 +0200 Subject: [PATCH 068/424] Add HasLocator to TestCases --- tests/ConnectionsHandlerTest.php | 40 +++++++++---------- tests/LogsHandlerTest.php | 20 +++++----- tests/MetaTest.php | 2 +- tests/Plugins/NotifierTest.php | 8 ++-- tests/ReleasesManagerTest.php | 56 +++++++++++++-------------- tests/RocketeerTest.php | 24 ++++++------ tests/ServerTest.php | 2 +- tests/Strategies/CopyStrategyTest.php | 12 +++--- tests/Tasks/RollbackTest.php | 2 +- tests/Tasks/SetupTest.php | 6 +-- tests/TasksHandlerTest.php | 8 ++-- tests/TestCases/ContainerTestCase.php | 15 +++---- tests/Traits/BashModules/CoreTest.php | 4 +- 13 files changed, 100 insertions(+), 99 deletions(-) diff --git a/tests/ConnectionsHandlerTest.php b/tests/ConnectionsHandlerTest.php index fcf42e7f9..813f6e194 100644 --- a/tests/ConnectionsHandlerTest.php +++ b/tests/ConnectionsHandlerTest.php @@ -11,35 +11,35 @@ class ConnectionsHandlerTest extends RocketeerTestCase public function testCanGetAvailableConnections() { - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $connections = $this->connections->getAvailableConnections(); $this->assertEquals(array('production', 'staging'), array_keys($connections)); $this->app['rocketeer.server']->setValue('connections.custom.username', 'foobar'); - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $connections = $this->connections->getAvailableConnections(); $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); } public function testCanGetCurrentConnection() { $this->swapConfig(array('rocketeer::default' => 'foobar')); - $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); + $this->assertEquals('production', $this->connections->getConnection()); $this->swapConfig(array('rocketeer::default' => 'production')); - $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); + $this->assertEquals('production', $this->connections->getConnection()); $this->swapConfig(array('rocketeer::default' => 'staging')); - $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); + $this->assertEquals('staging', $this->connections->getConnection()); } public function testCanChangeConnection() { - $this->assertEquals('production', $this->app['rocketeer.connections']->getConnection()); + $this->assertEquals('production', $this->connections->getConnection()); - $this->app['rocketeer.connections']->setConnection('staging'); - $this->assertEquals('staging', $this->app['rocketeer.connections']->getConnection()); + $this->connections->setConnection('staging'); + $this->assertEquals('staging', $this->connections->getConnection()); - $this->app['rocketeer.connections']->setConnections('staging,production'); - $this->assertEquals(array('staging', 'production'), $this->app['rocketeer.connections']->getConnections()); + $this->connections->setConnections('staging,production'); + $this->assertEquals(array('staging', 'production'), $this->connections->getConnections()); } public function testCanUseSshRepository() @@ -47,58 +47,58 @@ public function testCanUseSshRepository() $repository = 'git@github.com:'.$this->repository; $this->expectRepositoryConfig($repository, '', ''); - $this->assertEquals($repository, $this->app['rocketeer.connections']->getRepository()); + $this->assertEquals($repository, $this->connections->getRepository()); } public function testCanUseHttpsRepository() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, 'foobar', 'bar'); - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->connections->getRepository()); } public function testCanUseHttpsRepositoryWithUsernameProvided() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', 'bar'); - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->connections->getRepository()); } public function testCanUseHttpsRepositoryWithOnlyUsernameProvided() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', ''); - $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->connections->getRepository()); } public function testCanCleanupProvidedRepositoryFromCredentials() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'Anahkiasen', ''); - $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->connections->getRepository()); } public function testCanUseHttpsRepositoryWithoutCredentials() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - $this->assertEquals('https://github.com/'.$this->repository, $this->app['rocketeer.connections']->getRepository()); + $this->assertEquals('https://github.com/'.$this->repository, $this->connections->getRepository()); } public function testCanCheckIfRepositoryNeedsCredentials() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - $this->assertTrue($this->app['rocketeer.connections']->needsCredentials()); + $this->assertTrue($this->connections->needsCredentials()); } public function testCangetRepositoryBranch() { - $this->assertEquals('master', $this->app['rocketeer.connections']->getRepositoryBranch()); + $this->assertEquals('master', $this->connections->getRepositoryBranch()); } public function testFillsConnectionCredentialsHoles() { - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $connections = $this->connections->getAvailableConnections(); $this->assertArrayHasKey('production', $connections); $this->app['rocketeer.server']->setValue('connections', array( @@ -111,7 +111,7 @@ public function testFillsConnectionCredentialsHoles() 'agent' => '' ), )); - $connections = $this->app['rocketeer.connections']->getAvailableConnections(); + $connections = $this->connections->getAvailableConnections(); $this->assertArrayHasKey('production', $connections); } diff --git a/tests/LogsHandlerTest.php b/tests/LogsHandlerTest.php index 924abac37..10e12631a 100644 --- a/tests/LogsHandlerTest.php +++ b/tests/LogsHandlerTest.php @@ -19,19 +19,19 @@ public function setUp() public function testCanGetCurrentLogsFile() { - $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); + $logs = $this->logs->getCurrentLogsFile(); $this->assertEquals($this->server.'/logs/production-.log', $logs); - $this->app['rocketeer.connections']->setConnection('staging'); - $this->app['rocketeer.connections']->setStage('foobar'); - $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); + $this->connections->setConnection('staging'); + $this->connections->setStage('foobar'); + $logs = $this->logs->getCurrentLogsFile(); $this->assertEquals($this->server.'/logs/staging-foobar.log', $logs); } public function testCanLogInformations() { - $this->app['rocketeer.logs']->log('foobar', 'error'); - $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); + $this->logs->log('foobar', 'error'); + $logs = $this->logs->getCurrentLogsFile(); $logs = file_get_contents($logs); $this->assertContains('rocketeer.ERROR: foobar [] []', $logs); @@ -39,8 +39,8 @@ public function testCanLogInformations() public function testCanLogViaMagicMethods() { - $this->app['rocketeer.logs']->error('foobar'); - $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); + $this->logs->error('foobar'); + $logs = $this->logs->getCurrentLogsFile(); $logs = file_get_contents($logs); $this->assertContains('rocketeer.ERROR: foobar [] []', $logs); @@ -49,8 +49,8 @@ public function testCanLogViaMagicMethods() public function testCanCreateLogsFolderIfItDoesntExistAlready() { $this->app['path.rocketeer.logs'] = $this->server.'/newlogs'; - $this->app['rocketeer.logs']->error('foobar'); - $logs = $this->app['rocketeer.logs']->getCurrentLogsFile(); + $this->logs->error('foobar'); + $logs = $this->logs->getCurrentLogsFile(); $this->assertFileExists($logs); $this->app['files']->deleteDirectory(dirname($logs)); diff --git a/tests/MetaTest.php b/tests/MetaTest.php index 313d1f5aa..a2778c46d 100644 --- a/tests/MetaTest.php +++ b/tests/MetaTest.php @@ -12,7 +12,7 @@ public function testCanOverwriteTasksViaContainer() return new MyCustomTask($app); }); - $queue = $this->app['rocketeer.tasks']->on('production', array('cleanup'), $this->getCommand()); + $queue = $this->tasks->on('production', array('cleanup'), $this->getCommand()); $this->assertEquals(array('foobar'), $queue); } } diff --git a/tests/Plugins/NotifierTest.php b/tests/Plugins/NotifierTest.php index b86286ad6..f1a304a9e 100644 --- a/tests/Plugins/NotifierTest.php +++ b/tests/Plugins/NotifierTest.php @@ -19,19 +19,19 @@ public function setUp() ), ), )); - $this->app['rocketeer.tasks']->registerConfiguredEvents(); + $this->tasks->registerConfiguredEvents(); $this->notifier = new DummyNotifier($this->app); - $this->app['rocketeer.tasks']->plugin($this->notifier); + $this->tasks->plugin($this->notifier); } public function testCanAppendStageToDetails() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "staging@production" (foo.bar.com)'); $this->app['rocketeer.server']->setValue('notifier.name', 'Jean Eude'); - $this->app['rocketeer.connections']->setStage('staging'); + $this->connections->setStage('staging'); $this->notifier = new DummyNotifier($this->app); - $this->app['rocketeer.tasks']->plugin($this->notifier); + $this->tasks->plugin($this->notifier); $this->task('Deploy')->fireEvent('after'); } diff --git a/tests/ReleasesManagerTest.php b/tests/ReleasesManagerTest.php index 888ee575c..df7467eac 100644 --- a/tests/ReleasesManagerTest.php +++ b/tests/ReleasesManagerTest.php @@ -7,14 +7,14 @@ class ReleasesManagerTest extends RocketeerTestCase { public function testCanGetCurrentRelease() { - $currentRelease = $this->app['rocketeer.releases']->getCurrentRelease(); + $currentRelease = $this->releasesManager->getCurrentRelease(); $this->assertEquals(20000000000000, $currentRelease); } public function testCanGetStateOfReleases() { - $validation = $this->app['rocketeer.releases']->getValidationFile(); + $validation = $this->releasesManager->getValidationFile(); $this->assertEquals(array( 10000000000000 => true, @@ -25,15 +25,15 @@ public function testCanGetStateOfReleases() public function testCanGetInvalidReleases() { - $validation = $this->app['rocketeer.releases']->getInvalidReleases(); + $validation = $this->releasesManager->getInvalidReleases(); $this->assertEquals(array(1 => 15000000000000), $validation); } public function testCanUpdateStateOfReleases() { - $this->app['rocketeer.releases']->markReleaseAsValid(15000000000000); - $validation = $this->app['rocketeer.releases']->getValidationFile(); + $this->releasesManager->markReleaseAsValid(15000000000000); + $validation = $this->releasesManager->getValidationFile(); $this->assertEquals(array( 10000000000000 => true, @@ -44,8 +44,8 @@ public function testCanUpdateStateOfReleases() public function testCanMarkReleaseAsValid() { - $this->app['rocketeer.releases']->markReleaseAsValid(123456789); - $validation = $this->app['rocketeer.releases']->getValidationFile(); + $this->releasesManager->markReleaseAsValid(123456789); + $validation = $this->releasesManager->getValidationFile(); $this->assertEquals(array( 10000000000000 => true, @@ -65,42 +65,42 @@ public function testCanGetCurrentReleaseFromServerIfUncached() ->shouldReceive('getLineEndings')->andReturn(PHP_EOL); }); - $currentRelease = $this->app['rocketeer.releases']->getCurrentRelease(); + $currentRelease = $this->releasesManager->getCurrentRelease(); $this->assertEquals(20000000000000, $currentRelease); } public function testCanGetReleasesPath() { - $releasePath = $this->app['rocketeer.releases']->getReleasesPath(); + $releasePath = $this->releasesManager->getReleasesPath(); $this->assertEquals($this->server.'/releases', $releasePath); } public function testCanGetCurrentReleaseFolder() { - $currentReleasePath = $this->app['rocketeer.releases']->getCurrentReleasePath(); + $currentReleasePath = $this->releasesManager->getCurrentReleasePath(); $this->assertEquals($this->server.'/releases/20000000000000', $currentReleasePath); } public function testCanGetReleases() { - $releases = $this->app['rocketeer.releases']->getReleases(); + $releases = $this->releasesManager->getReleases(); $this->assertEquals(array(1 => 15000000000000, 0 => 20000000000000, 2 => 10000000000000), $releases); } public function testCanGetDeprecatedReleases() { - $releases = $this->app['rocketeer.releases']->getDeprecatedReleases(); + $releases = $this->releasesManager->getDeprecatedReleases(); $this->assertEquals(array(15000000000000, 10000000000000), $releases); } public function testCanGetPreviousValidRelease() { - $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); + $currentRelease = $this->releasesManager->getPreviousRelease(); $this->assertEquals(10000000000000, $currentRelease); } @@ -113,7 +113,7 @@ public function testReturnsCurrentReleaseIfNoPreviousValidRelease() '20000000000000' => true, )); - $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); + $currentRelease = $this->releasesManager->getPreviousRelease(); $this->assertEquals(20000000000000, $currentRelease); } @@ -124,7 +124,7 @@ public function testReturnsCurrentReleaseIfOnlyRelease() '20000000000000' => true, )); - $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); + $currentRelease = $this->releasesManager->getPreviousRelease(); $this->assertEquals(20000000000000, $currentRelease); } @@ -135,22 +135,22 @@ public function testReturnsCorrectPreviousReleaseIfUpdatedBeforehand() '20000000000000' => true, )); - $this->app['rocketeer.releases']->updateCurrentRelease(); - $currentRelease = $this->app['rocketeer.releases']->getPreviousRelease(); + $this->releasesManager->updateCurrentRelease(); + $currentRelease = $this->releasesManager->getPreviousRelease(); $this->assertEquals(20000000000000, $currentRelease); } public function testCanUpdateCurrentRelease() { - $this->app['rocketeer.releases']->updateCurrentRelease(30000000000000); + $this->releasesManager->updateCurrentRelease(30000000000000); $this->assertEquals(30000000000000, $this->app['rocketeer.server']->getValue('current_release.production')); } public function testCanGetFolderInRelease() { - $folder = $this->app['rocketeer.releases']->getCurrentReleasePath('{path.storage}'); + $folder = $this->releasesManager->getCurrentReleasePath('{path.storage}'); $this->assertEquals($this->server.'/releases/20000000000000/app/storage', $folder); } @@ -163,10 +163,10 @@ public function testDoesntPingForReleasesAllTheFuckingTime() ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([20000000000000]); }); - $this->app['rocketeer.releases']->getNonCurrentReleases(); - $this->app['rocketeer.releases']->getNonCurrentReleases(); - $this->app['rocketeer.releases']->getNonCurrentReleases(); - $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); } public function testDoesntPingForReleasesIfNoReleases() @@ -177,10 +177,10 @@ public function testDoesntPingForReleasesIfNoReleases() ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([]); }); - $this->app['rocketeer.releases']->getNonCurrentReleases(); - $this->app['rocketeer.releases']->getNonCurrentReleases(); - $this->app['rocketeer.releases']->getNonCurrentReleases(); - $this->app['rocketeer.releases']->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); + $this->releasesManager->getNonCurrentReleases(); } public function testIgnoresErrorsAndStuffWhenFetchingReleases() @@ -191,7 +191,7 @@ public function testIgnoresErrorsAndStuffWhenFetchingReleases() ->shouldReceive('listContents')->times(1)->with($this->server.'/releases')->andReturn(['IMPOSSIBLE BECAUSE NOPE FUCK YOU']); }); - $releases = $this->app['rocketeer.releases']->getReleases(); + $releases = $this->releasesManager->getReleases(); $this->assertEmpty($releases); } diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 5a2519c4b..e104bc43c 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -11,36 +11,36 @@ class RocketeerTest extends RocketeerTestCase public function testCanGetApplicationName() { - $this->assertEquals('foobar', $this->app['rocketeer.rocketeer']->getApplicationName()); + $this->assertEquals('foobar', $this->rocketeer->getApplicationName()); } public function testCanGetHomeFolder() { - $this->assertEquals($this->server.'', $this->app['rocketeer.rocketeer']->getHomeFolder()); + $this->assertEquals($this->server.'', $this->rocketeer->getHomeFolder()); } public function testCanGetFolderWithStage() { - $this->app['rocketeer.connections']->setStage('test'); + $this->connections->setStage('test'); - $this->assertEquals($this->server.'/test/current', $this->app['rocketeer.rocketeer']->getFolder('current')); + $this->assertEquals($this->server.'/test/current', $this->rocketeer->getFolder('current')); } public function testCanGetAnyFolder() { - $this->assertEquals($this->server.'/current', $this->app['rocketeer.rocketeer']->getFolder('current')); + $this->assertEquals($this->server.'/current', $this->rocketeer->getFolder('current')); } public function testCanReplacePatternsInFolders() { - $folder = $this->app['rocketeer.rocketeer']->getFolder('{path.storage}'); + $folder = $this->rocketeer->getFolder('{path.storage}'); $this->assertEquals($this->server.'/app/storage', $folder); } public function testCannotReplaceUnexistingPatternsInFolders() { - $folder = $this->app['rocketeer.rocketeer']->getFolder('{path.foobar}'); + $folder = $this->rocketeer->getFolder('{path.foobar}'); $this->assertEquals($this->server.'/', $folder); } @@ -52,9 +52,9 @@ public function testCanUseRecursiveStageConfiguration() 'rocketeer::on.stages.staging.scm.branch' => 'staging', )); - $this->assertEquals('master', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); - $this->app['rocketeer.connections']->setStage('staging'); - $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); + $this->assertEquals('master', $this->rocketeer->getOption('scm.branch')); + $this->connections->setStage('staging'); + $this->assertEquals('staging', $this->rocketeer->getOption('scm.branch')); } public function testCanUseRecursiveConnectionConfiguration() @@ -64,14 +64,14 @@ public function testCanUseRecursiveConnectionConfiguration() 'rocketeer::scm.branch' => 'master', 'rocketeer::on.connections.staging.scm.branch' => 'staging', )); - $this->assertEquals('master', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); + $this->assertEquals('master', $this->rocketeer->getOption('scm.branch')); $this->swapConfig(array( 'rocketeer::default' => 'staging', 'rocketeer::scm.branch' => 'master', 'rocketeer::on.connections.staging.scm.branch' => 'staging', )); - $this->assertEquals('staging', $this->app['rocketeer.rocketeer']->getOption('scm.branch')); + $this->assertEquals('staging', $this->rocketeer->getOption('scm.branch')); } public function testRocketeerCanGuessWhichStageHesIn() diff --git a/tests/ServerTest.php b/tests/ServerTest.php index 44c649af2..dbb6dfde5 100644 --- a/tests/ServerTest.php +++ b/tests/ServerTest.php @@ -16,7 +16,7 @@ public function testCanCreateDeploymentsFileAnywhere() new Server($this->app); - $storage = $this->app['rocketeer.rocketeer']->getRocketeerConfigFolder(); + $storage = $this->rocketeer->getRocketeerConfigFolder(); $exists = file_exists($storage); $this->app['files']->deleteDirectory($storage); $this->assertTrue($exists); diff --git a/tests/Strategies/CopyStrategyTest.php b/tests/Strategies/CopyStrategyTest.php index 7b23970d9..1bf68543c 100644 --- a/tests/Strategies/CopyStrategyTest.php +++ b/tests/Strategies/CopyStrategyTest.php @@ -20,7 +20,7 @@ public function setUp() public function testCanCopyPreviousRelease() { - $this->app['rocketeer.strategy']->deploy(); + $this->strategy->deploy(); $matcher = array( 'cp -r {server}/releases/10000000000000 {server}/releases/20000000000000', @@ -31,7 +31,7 @@ public function testCanCopyPreviousRelease() ), ); - $this->assertHistory($matcher, $this->app['rocketeer.history']->getFlattened()); + $this->assertHistory($matcher, $this->history->getFlattened()); } public function testClonesIfNoPreviousRelease() @@ -41,7 +41,7 @@ public function testClonesIfNoPreviousRelease() ->shouldReceive('getCurrentReleasePath')->andReturn($this->server.'/releases/10000000000000'); }); - $this->app['rocketeer.strategy']->deploy(); + $this->strategy->deploy(); $matcher = array( 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', @@ -51,7 +51,7 @@ public function testClonesIfNoPreviousRelease() ), ); - $this->assertHistory($matcher, $this->app['rocketeer.history']->getFlattened()); + $this->assertHistory($matcher, $this->history->getFlattened()); } public function testCanCloneIfPreviousReleaseIsInvalid() @@ -63,7 +63,7 @@ public function testCanCloneIfPreviousReleaseIsInvalid() ->shouldReceive('getCurrentReleasePath')->andReturn($this->server.'/releases/10000000000000'); }); - $this->app['rocketeer.strategy']->deploy(); + $this->strategy->deploy(); $matcher = array( 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', @@ -73,6 +73,6 @@ public function testCanCloneIfPreviousReleaseIsInvalid() ), ); - $this->assertHistory($matcher, $this->app['rocketeer.history']->getFlattened()); + $this->assertHistory($matcher, $this->history->getFlattened()); } } diff --git a/tests/Tasks/RollbackTest.php b/tests/Tasks/RollbackTest.php index 857b268d4..db05ee70e 100644 --- a/tests/Tasks/RollbackTest.php +++ b/tests/Tasks/RollbackTest.php @@ -9,6 +9,6 @@ public function testCanRollbackRelease() { $this->task('Rollback')->execute(); - $this->assertEquals(10000000000000, $this->app['rocketeer.releases']->getCurrentRelease()); + $this->assertEquals(10000000000000, $this->releasesManager->getCurrentRelease()); } } diff --git a/tests/Tasks/SetupTest.php b/tests/Tasks/SetupTest.php index c7124cb9c..a3300979a 100644 --- a/tests/Tasks/SetupTest.php +++ b/tests/Tasks/SetupTest.php @@ -58,8 +58,8 @@ public function testRunningSetupKeepsCurrentCongiguredStage() 'rocketeer::stages.stages' => array('staging', 'production'), )); - $this->app['rocketeer.connections']->setStage('staging'); - $this->assertEquals('staging', $this->app['rocketeer.connections']->getStage()); + $this->connections->setStage('staging'); + $this->assertEquals('staging', $this->connections->getStage()); $this->assertTaskHistory('Setup', array( 'git --version', '/usr/local/bin/php -m', @@ -73,6 +73,6 @@ public function testRunningSetupKeepsCurrentCongiguredStage() ), array( 'stage' => 'staging', )); - $this->assertEquals('staging', $this->app['rocketeer.connections']->getStage()); + $this->assertEquals('staging', $this->connections->getStage()); } } diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index 814a6ea26..68251e8df 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -95,10 +95,10 @@ public function testCanExecuteContextualEvents() 'rocketeer::on.stages.hasEvent.hooks' => array('before' => array('check' => 'ls')), )); - $this->app['rocketeer.connections']->setStage('hasEvent'); + $this->connections->setStage('hasEvent'); $this->assertEquals(array('ls'), $this->tasksQueue()->getTasksListeners('check', 'before', true)); - $this->app['rocketeer.connections']->setStage('noEvent'); + $this->connections->setStage('noEvent'); $this->assertEquals(array(), $this->tasksQueue()->getTasksListeners('check', 'before', true)); } @@ -133,11 +133,11 @@ public function testCanHaveCustomConnectionHooks() )); $this->tasksQueue()->registerConfiguredEvents(); - $this->app['rocketeer.connections']->setConnection('production'); + $this->connections->setConnection('production'); $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); $this->assertEmpty($events); - $this->app['rocketeer.connections']->setConnection('staging'); + $this->connections->setConnection('staging'); $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); $this->assertEquals($tasks, $events); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 76204c128..2dc60556f 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -7,15 +7,16 @@ use Mockery; use PHPUnit_Framework_TestCase; use Rocketeer\RocketeerServiceProvider; +use Rocketeer\Traits\HasLocator; abstract class ContainerTestCase extends PHPUnit_Framework_TestCase { - /** - * The IoC Container - * - * @var Container - */ - protected $app; + use HasLocator; + + public function __construct() + { + parent::__construct(); + } /** * The test repository @@ -240,7 +241,7 @@ protected function getConfig($expectations = array()) */ protected function swapConfig($config) { - $this->app['rocketeer.connections']->disconnect(); + $this->connections->disconnect(); $this->app['config'] = $this->getConfig($config); } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 1ad746db4..3d37ebfcd 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -40,7 +40,7 @@ public function testCanGetLocalTimestampIfError() public function testDoesntAppendEnvironmentToStandardTasks() { - $this->app['rocketeer.connections']->setStage('staging'); + $this->connections->setStage('staging'); $commands = $this->pretendTask()->processCommands(array( 'artisan something', 'rm readme*', @@ -55,7 +55,7 @@ public function testDoesntAppendEnvironmentToStandardTasks() public function testCanRemoveCommonPollutingOutput() { $this->app['remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); - $result = $this->app['rocketeer.bash']->run('ls'); + $result = $this->bash->run('ls'); $this->assertEquals('something', $result); } From 47564fccef7a6c53d4cff4ca71223d1d62bb8463 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 00:11:31 +0200 Subject: [PATCH 069/424] Move custom assertions to a separate trait --- tests/ConnectionsHandlerTest.php | 10 +- tests/TestCases/RocketeerAssertions.php | 121 ++++++++++++++++++++++++ tests/TestCases/RocketeerTestCase.php | 108 +-------------------- 3 files changed, 128 insertions(+), 111 deletions(-) create mode 100644 tests/TestCases/RocketeerAssertions.php diff --git a/tests/ConnectionsHandlerTest.php b/tests/ConnectionsHandlerTest.php index 813f6e194..f22eb55a1 100644 --- a/tests/ConnectionsHandlerTest.php +++ b/tests/ConnectionsHandlerTest.php @@ -22,21 +22,21 @@ public function testCanGetAvailableConnections() public function testCanGetCurrentConnection() { $this->swapConfig(array('rocketeer::default' => 'foobar')); - $this->assertEquals('production', $this->connections->getConnection()); + $this->assertConnectionIs('production'); $this->swapConfig(array('rocketeer::default' => 'production')); - $this->assertEquals('production', $this->connections->getConnection()); + $this->assertConnectionIs('production'); $this->swapConfig(array('rocketeer::default' => 'staging')); - $this->assertEquals('staging', $this->connections->getConnection()); + $this->assertConnectionIs('staging'); } public function testCanChangeConnection() { - $this->assertEquals('production', $this->connections->getConnection()); + $this->assertConnectionIs('production'); $this->connections->setConnection('staging'); - $this->assertEquals('staging', $this->connections->getConnection()); + $this->assertConnectionIs('staging'); $this->connections->setConnections('staging,production'); $this->assertEquals(array('staging', 'production'), $this->connections->getConnections()); diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php new file mode 100644 index 000000000..66e70a5c6 --- /dev/null +++ b/tests/TestCases/RocketeerAssertions.php @@ -0,0 +1,121 @@ +assertEquals($connection, $this->connections->getConnection()); + } + + /** + * Assert a task has a particular output + * + * @param string $task + * @param string $output + * @param Mockery $command + * + * @return Assertion + */ + protected function assertTaskOutput($task, $output, $command = null) + { + if ($command) { + $this->app['rocketeer.command'] = $command; + } + + return $this->assertContains($output, $this->task($task)->execute()); + } + + /** + * Assert a task's history matches an array + * + * @param string|Task $task + * @param array $expectedHistory + * @param array $options + * + * @return string + */ + protected function assertTaskHistory($task, array $expectedHistory, array $options = array()) + { + // Create task if needed + if (is_string($task)) { + $task = $this->pretendTask($task, $options); + } + + // Execute task and get history + if (is_array($task)) { + $results = ''; + $taskHistory = $task; + } else { + $results = $task->execute(); + $taskHistory = $task->history->getFlattened(); + } + + $this->assertHistory($expectedHistory, $taskHistory); + + return $results; + } + + /** + * Assert an history matches another + * + * @param array $expected + * @param array $obtained + */ + public function assertHistory(array $expected, array $obtained) + { + // Look for release in history + $release = implode(array_flatten($obtained)); + preg_match_all('/[0-9]{14}/', $release, $releases); + $release = array_get($releases, '0.0', date('YmdHis')); + if ($release === '10000000000000') { + $release = array_get($releases, '0.1', date('YmdHis')); + } + + // Replace placeholders + $expected = $this->replaceHistoryPlaceholders($expected, $release); + + // Check equality + $this->assertEquals($expected, $obtained); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Replace placeholders in an history + * + * @param array $history + * @param integer|null $release + * + * @return array + */ + protected function replaceHistoryPlaceholders($history, $release = null) + { + $release = $release ?: date('YmdHis'); + + foreach ($history as $key => $entries) { + if (is_array($entries)) { + $history[$key] = $this->replaceHistoryPlaceholders($entries, $release); + continue; + } + + $history[$key] = strtr($entries, array( + '{php}' => exec('which php'), + '{phpunit}' => exec('which phpunit'), + '{repository}' => 'https://github.com/'.$this->repository, + '{server}' => $this->server, + '{release}' => $release, + '{composer}' => exec('which composer'), + )); + } + + return $history; + } +} diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index c3980df98..07394fdc1 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -7,6 +7,8 @@ abstract class RocketeerTestCase extends ContainerTestCase { + use RocketeerAssertions; + /** * The path to the local fake server * @@ -99,112 +101,6 @@ protected function recreateVirtualServer() $this->app['files']->deleteDirectory($binary); } - //////////////////////////////////////////////////////////////////// - ///////////////////////////// ASSERTIONS /////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Assert a task has a particular output - * - * @param string $task - * @param string $output - * @param Mockery $command - * - * @return Assertion - */ - protected function assertTaskOutput($task, $output, $command = null) - { - if ($command) { - $this->app['rocketeer.command'] = $command; - } - - return $this->assertContains($output, $this->task($task)->execute()); - } - - /** - * Assert a task's history matches an array - * - * @param string|Task $task - * @param array $expectedHistory - * @param array $options - * - * @return string - */ - protected function assertTaskHistory($task, array $expectedHistory, array $options = array()) - { - // Create task if needed - if (is_string($task)) { - $task = $this->pretendTask($task, $options); - } - - // Execute task and get history - if (is_array($task)) { - $results = ''; - $taskHistory = $task; - } else { - $results = $task->execute(); - $taskHistory = $task->history->getFlattened(); - } - - $this->assertHistory($expectedHistory, $taskHistory); - - return $results; - } - - /** - * Assert an history matches another - * - * @param array $expected - * @param array $obtained - */ - public function assertHistory(array $expected, array $obtained) - { - // Look for release in history - $release = implode(array_flatten($obtained)); - preg_match_all('/[0-9]{14}/', $release, $releases); - $release = array_get($releases, '0.0', date('YmdHis')); - if ($release === '10000000000000') { - $release = array_get($releases, '0.1', date('YmdHis')); - } - - // Replace placeholders - $expected = $this->replaceHistoryPlaceholders($expected, $release); - - // Check equality - $this->assertEquals($expected, $obtained); - } - - /** - * Replace placeholders in an history - * - * @param array $history - * @param integer|null $release - * - * @return array - */ - protected function replaceHistoryPlaceholders($history, $release = null) - { - $release = $release ?: date('YmdHis'); - - foreach ($history as $key => $entries) { - if (is_array($entries)) { - $history[$key] = $this->replaceHistoryPlaceholders($entries, $release); - continue; - } - - $history[$key] = strtr($entries, array( - '{php}' => exec('which php'), - '{phpunit}' => exec('which phpunit'), - '{repository}' => 'https://github.com/'.$this->repository, - '{server}' => $this->server, - '{release}' => $release, - '{composer}' => exec('which composer'), - )); - } - - return $history; - } - //////////////////////////////////////////////////////////////////// ////////////////////////////// MOCKERIES /////////////////////////// //////////////////////////////////////////////////////////////////// From 577f86c98961fdf24d2c4cc169df5d31d9e8bde6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 00:19:05 +0200 Subject: [PATCH 070/424] Add some custom assertions --- tests/Abstracts/TaskTest.php | 4 ++-- tests/ConnectionsHandlerTest.php | 22 +++++++++++----------- tests/MetaTest.php | 2 +- tests/ReleasesManagerTest.php | 6 +++--- tests/RocketeerTest.php | 10 +++++----- tests/TasksHandlerTest.php | 10 +++++----- tests/TestCases/RocketeerAssertions.php | 25 +++++++++++++++++++++++-- 7 files changed, 50 insertions(+), 29 deletions(-) diff --git a/tests/Abstracts/TaskTest.php b/tests/Abstracts/TaskTest.php index a50e23200..2fcc28078 100644 --- a/tests/Abstracts/TaskTest.php +++ b/tests/Abstracts/TaskTest.php @@ -49,11 +49,11 @@ public function testCanFireEventsDuringTasks() { $this->expectOutputString('foobar'); - $this->tasksQueue()->listenTo('closure.test.foobar', function ($task) { + $this->tasksQueue()->listenTo('closure.test.foobar', function () { echo 'foobar'; }); - $task = $this->tasksQueue()->execute(function ($task) { + $this->tasksQueue()->execute(function ($task) { $task->fireEvent('test.foobar'); }, 'staging'); } diff --git a/tests/ConnectionsHandlerTest.php b/tests/ConnectionsHandlerTest.php index f22eb55a1..2d598a58b 100644 --- a/tests/ConnectionsHandlerTest.php +++ b/tests/ConnectionsHandlerTest.php @@ -22,21 +22,21 @@ public function testCanGetAvailableConnections() public function testCanGetCurrentConnection() { $this->swapConfig(array('rocketeer::default' => 'foobar')); - $this->assertConnectionIs('production'); + $this->assertConnectionEquals('production'); $this->swapConfig(array('rocketeer::default' => 'production')); - $this->assertConnectionIs('production'); + $this->assertConnectionEquals('production'); $this->swapConfig(array('rocketeer::default' => 'staging')); - $this->assertConnectionIs('staging'); + $this->assertConnectionEquals('staging'); } public function testCanChangeConnection() { - $this->assertConnectionIs('production'); + $this->assertConnectionEquals('production'); $this->connections->setConnection('staging'); - $this->assertConnectionIs('staging'); + $this->assertConnectionEquals('staging'); $this->connections->setConnections('staging,production'); $this->assertEquals(array('staging', 'production'), $this->connections->getConnections()); @@ -47,42 +47,42 @@ public function testCanUseSshRepository() $repository = 'git@github.com:'.$this->repository; $this->expectRepositoryConfig($repository, '', ''); - $this->assertEquals($repository, $this->connections->getRepository()); + $this->assertRepositoryEquals($repository); } public function testCanUseHttpsRepository() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, 'foobar', 'bar'); - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->connections->getRepository()); + $this->assertRepositoryEquals('https://foobar:bar@github.com/'.$this->repository); } public function testCanUseHttpsRepositoryWithUsernameProvided() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', 'bar'); - $this->assertEquals('https://foobar:bar@github.com/'.$this->repository, $this->connections->getRepository()); + $this->assertRepositoryEquals('https://foobar:bar@github.com/'.$this->repository); } public function testCanUseHttpsRepositoryWithOnlyUsernameProvided() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'foobar', ''); - $this->assertEquals('https://foobar@github.com/'.$this->repository, $this->connections->getRepository()); + $this->assertRepositoryEquals('https://foobar@github.com/'.$this->repository); } public function testCanCleanupProvidedRepositoryFromCredentials() { $this->expectRepositoryConfig('https://foobar@github.com/'.$this->repository, 'Anahkiasen', ''); - $this->assertEquals('https://Anahkiasen@github.com/'.$this->repository, $this->connections->getRepository()); + $this->assertRepositoryEquals('https://Anahkiasen@github.com/'.$this->repository); } public function testCanUseHttpsRepositoryWithoutCredentials() { $this->expectRepositoryConfig('https://github.com/'.$this->repository, '', ''); - $this->assertEquals('https://github.com/'.$this->repository, $this->connections->getRepository()); + $this->assertRepositoryEquals('https://github.com/'.$this->repository); } public function testCanCheckIfRepositoryNeedsCredentials() diff --git a/tests/MetaTest.php b/tests/MetaTest.php index a2778c46d..94b3d4dfd 100644 --- a/tests/MetaTest.php +++ b/tests/MetaTest.php @@ -13,6 +13,6 @@ public function testCanOverwriteTasksViaContainer() }); $queue = $this->tasks->on('production', array('cleanup'), $this->getCommand()); - $this->assertEquals(array('foobar'), $queue); + $this->assertEquals(['foobar'], $queue); } } diff --git a/tests/ReleasesManagerTest.php b/tests/ReleasesManagerTest.php index df7467eac..8d1c70082 100644 --- a/tests/ReleasesManagerTest.php +++ b/tests/ReleasesManagerTest.php @@ -27,7 +27,7 @@ public function testCanGetInvalidReleases() { $validation = $this->releasesManager->getInvalidReleases(); - $this->assertEquals(array(1 => 15000000000000), $validation); + $this->assertEquals([1 => 15000000000000], $validation); } public function testCanUpdateStateOfReleases() @@ -88,14 +88,14 @@ public function testCanGetReleases() { $releases = $this->releasesManager->getReleases(); - $this->assertEquals(array(1 => 15000000000000, 0 => 20000000000000, 2 => 10000000000000), $releases); + $this->assertEquals([1 => 15000000000000, 0 => 20000000000000, 2 => 10000000000000], $releases); } public function testCanGetDeprecatedReleases() { $releases = $this->releasesManager->getDeprecatedReleases(); - $this->assertEquals(array(15000000000000, 10000000000000), $releases); + $this->assertEquals([15000000000000, 10000000000000], $releases); } public function testCanGetPreviousValidRelease() diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index e104bc43c..1720f6860 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -16,7 +16,7 @@ public function testCanGetApplicationName() public function testCanGetHomeFolder() { - $this->assertEquals($this->server.'', $this->rocketeer->getHomeFolder()); + $this->assertEquals($this->server, $this->rocketeer->getHomeFolder()); } public function testCanGetFolderWithStage() @@ -52,9 +52,9 @@ public function testCanUseRecursiveStageConfiguration() 'rocketeer::on.stages.staging.scm.branch' => 'staging', )); - $this->assertEquals('master', $this->rocketeer->getOption('scm.branch')); + $this->assertOptionValueEquals('master', 'scm.branch'); $this->connections->setStage('staging'); - $this->assertEquals('staging', $this->rocketeer->getOption('scm.branch')); + $this->assertOptionValueEquals('staging', 'scm.branch'); } public function testCanUseRecursiveConnectionConfiguration() @@ -64,14 +64,14 @@ public function testCanUseRecursiveConnectionConfiguration() 'rocketeer::scm.branch' => 'master', 'rocketeer::on.connections.staging.scm.branch' => 'staging', )); - $this->assertEquals('master', $this->rocketeer->getOption('scm.branch')); + $this->assertOptionValueEquals('master', 'scm.branch'); $this->swapConfig(array( 'rocketeer::default' => 'staging', 'rocketeer::scm.branch' => 'master', 'rocketeer::on.connections.staging.scm.branch' => 'staging', )); - $this->assertEquals('staging', $this->rocketeer->getOption('scm.branch')); + $this->assertOptionValueEquals('staging', 'scm.branch'); } public function testRocketeerCanGuessWhichStageHesIn() diff --git a/tests/TasksHandlerTest.php b/tests/TasksHandlerTest.php index 68251e8df..c70266f47 100644 --- a/tests/TasksHandlerTest.php +++ b/tests/TasksHandlerTest.php @@ -18,7 +18,7 @@ public function testCanUseFacadeOutsideOfLaravel() Rocketeer::before('deploy', 'ls'); $before = Rocketeer::getTasksListeners('deploy', 'before', true); - $this->assertEquals(array('ls'), $before); + $this->assertEquals(['ls'], $before); } public function testCanGetTasksBeforeOrAfterAnotherTask() @@ -26,7 +26,7 @@ public function testCanGetTasksBeforeOrAfterAnotherTask() $task = $this->task('Deploy'); $before = $this->tasksQueue()->getTasksListeners($task, 'before', true); - $this->assertEquals(array('before', 'foobar'), $before); + $this->assertEquals(['before', 'foobar'], $before); } public function testCanAddTasksViaFacade() @@ -85,7 +85,7 @@ public function testCanAddEventsWithPriority() $this->tasksQueue()->before('deploy', 'first'); $listeners = $this->tasksQueue()->getTasksListeners('deploy', 'before', true); - $this->assertEquals(array('before', 'foobar', 'first', 'second'), $listeners); + $this->assertEquals(['before', 'foobar', 'first', 'second'], $listeners); } public function testCanExecuteContextualEvents() @@ -96,10 +96,10 @@ public function testCanExecuteContextualEvents() )); $this->connections->setStage('hasEvent'); - $this->assertEquals(array('ls'), $this->tasksQueue()->getTasksListeners('check', 'before', true)); + $this->assertEquals(['ls'], $this->tasksQueue()->getTasksListeners('check', 'before', true)); $this->connections->setStage('noEvent'); - $this->assertEquals(array(), $this->tasksQueue()->getTasksListeners('check', 'before', true)); + $this->assertEquals([], $this->tasksQueue()->getTasksListeners('check', 'before', true)); } public function testCanBuildQueueFromConfigHook() diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index 66e70a5c6..7740a50e8 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -8,17 +8,38 @@ trait RocketeerAssertions * * @param string $connection */ - protected function assertConnectionIs($connection) + protected function assertConnectionEquals($connection) { $this->assertEquals($connection, $this->connections->getConnection()); } + /** + * Assert that the current repository equals + * + * @param string $repository + */ + protected function assertRepositoryEquals($repository) + { + $this->assertEquals($repository, $this->connections->getRepository()); + } + + /** + * Assert an option has a certain value + * + * @param string $value + * @param string $option + */ + protected function assertOptionValueEquals($value, $option) + { + $this->assertEquals($value, $this->rocketeer->getOption($option)); + } + /** * Assert a task has a particular output * * @param string $task * @param string $output - * @param Mockery $command + * @param \Mockery $command * * @return Assertion */ From 0efcd47b7bcf3be0559cef2e187c37ae7cfbf906 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 00:28:50 +0200 Subject: [PATCH 071/424] Work on logging output and history separately --- src/Rocketeer/History/History.php | 28 +++++++++++++++-- src/Rocketeer/Tasks/Check.php | 3 +- src/Rocketeer/Traits/HasHistory.php | 41 ++++++++++++++++++++----- tests/Strategies/CloneStrategyTest.php | 4 +-- tests/Strategies/CopyStrategyTest.php | 6 ++-- tests/Tasks/DeployTest.php | 2 +- tests/TestCases/RocketeerAssertions.php | 2 +- 7 files changed, 67 insertions(+), 19 deletions(-) diff --git a/src/Rocketeer/History/History.php b/src/Rocketeer/History/History.php index 0fed79cab..9a03e9554 100644 --- a/src/Rocketeer/History/History.php +++ b/src/Rocketeer/History/History.php @@ -7,12 +7,36 @@ class History extends Collection { /** * Get the history, flattened + * + * @return array */ - public function getFlattened() + public function getFlattenedHistory() + { + return $this->getFlattened('history'); + } + + /** + * Get the output, flattened + * + * @return array + */ + public function getFlattenedOutput() + { + return $this->getFlattened('output'); + } + + /** + * Get a flattened list of a certain type + * + * @param string $type + * + * @return array + */ + protected function getFlattened($type) { $history = []; foreach ($this->items as $class => $entries) { - $history = array_merge($history, $entries); + $history = array_merge($history, $entries[$type]); } ksort($history); diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 679af7082..507574ba5 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -109,8 +109,7 @@ public function checkScm() { $this->command->comment('Checking presence of '.$this->scm->binary); $results = $this->scm->execute('check'); - - //$this->toHistory($results); + $this->toOutput($results); return $this->remote->status() == 0; } diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index e9bbf2303..223fc4f87 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -31,16 +31,21 @@ public function getHistory() /** * Append an entry to the history * - * @param array|string $output + * @param array|string $command */ - public function toHistory($output) + public function toHistory($command) { - $handle = $this->getHistoryHandle(); - $history = $this->getHistory(); - $timestamp = (string) microtime(true); - $history[$timestamp] = $output; + $this->appendTo('history', $command); + } - $this->history[$handle] = $history; + /** + * Append an entry to the output + * + * @param array|string $output + */ + public function toOutput($output) + { + $this->appendTo('output', $output); } /** @@ -54,9 +59,29 @@ protected function getHistoryHandle() // Create entry if it doesn't exist yet if (!isset($this->history[$handle])) { - $this->history[$handle] = []; + $this->history[$handle] = array( + 'history' => [], + 'output' => [], + ); } return $handle; } + + /** + * Append something to the history + * + * @param string $type + * @param string|array $command + */ + protected function appendTo($type, $command) + { + $handle = $this->getHistoryHandle(); + $history = $this->getHistory(); + $timestamp = (string) microtime(true); + + $history[$type][$timestamp] = $command; + + $this->history[$handle] = $history; + } } diff --git a/tests/Strategies/CloneStrategyTest.php b/tests/Strategies/CloneStrategyTest.php index 6ed699648..32f53bb30 100644 --- a/tests/Strategies/CloneStrategyTest.php +++ b/tests/Strategies/CloneStrategyTest.php @@ -18,7 +18,7 @@ public function testCanDeployRepository() ), ); - $this->assertHistory($matcher, $task->history->getFlattened()); + $this->assertHistory($matcher, $task->history->getFlattenedHistory()); } public function testCanUpdateRepository() @@ -34,6 +34,6 @@ public function testCanUpdateRepository() ) ); - $this->assertHistory($matcher, $task->history->getFlattened()); + $this->assertHistory($matcher, $task->history->getFlattenedHistory()); } } diff --git a/tests/Strategies/CopyStrategyTest.php b/tests/Strategies/CopyStrategyTest.php index 1bf68543c..db98a1baa 100644 --- a/tests/Strategies/CopyStrategyTest.php +++ b/tests/Strategies/CopyStrategyTest.php @@ -31,7 +31,7 @@ public function testCanCopyPreviousRelease() ), ); - $this->assertHistory($matcher, $this->history->getFlattened()); + $this->assertHistory($matcher, $this->history->getFlattenedHistory()); } public function testClonesIfNoPreviousRelease() @@ -51,7 +51,7 @@ public function testClonesIfNoPreviousRelease() ), ); - $this->assertHistory($matcher, $this->history->getFlattened()); + $this->assertHistory($matcher, $this->history->getFlattenedHistory()); } public function testCanCloneIfPreviousReleaseIsInvalid() @@ -73,6 +73,6 @@ public function testCanCloneIfPreviousReleaseIsInvalid() ), ); - $this->assertHistory($matcher, $this->history->getFlattened()); + $this->assertHistory($matcher, $this->history->getFlattenedHistory()); } } diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index fea585dd0..f7d57e91c 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -116,7 +116,7 @@ public function testCanConfigureComposerCommands() $deploy = $this->pretendTask('Deploy'); $deploy->runComposer(true); - $this->assertTaskHistory($deploy->history->getFlattened(), $matcher, array( + $this->assertTaskHistory($deploy->history->getFlattenedHistory(), $matcher, array( 'tests' => false, 'seed' => false, 'migrate' => false diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index 7740a50e8..7be2a9b6e 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -74,7 +74,7 @@ protected function assertTaskHistory($task, array $expectedHistory, array $optio $taskHistory = $task; } else { $results = $task->execute(); - $taskHistory = $task->history->getFlattened(); + $taskHistory = $task->history->getFlattenedHistory(); } $this->assertHistory($expectedHistory, $taskHistory); From 67dcea039f541438cfdcc68cda691f4a905e667a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 00:47:14 +0200 Subject: [PATCH 072/424] More work on history/output --- src/Rocketeer/TasksHandler.php | 6 ++-- src/Rocketeer/Traits/BashModules/Core.php | 41 +++++++---------------- src/Rocketeer/Traits/HasHistory.php | 14 ++++++-- tests/Abstracts/TaskTest.php | 8 ++--- 4 files changed, 32 insertions(+), 37 deletions(-) diff --git a/src/Rocketeer/TasksHandler.php b/src/Rocketeer/TasksHandler.php index 1f7d8feca..6150361c5 100644 --- a/src/Rocketeer/TasksHandler.php +++ b/src/Rocketeer/TasksHandler.php @@ -158,9 +158,9 @@ public function registerConfiguredEvents() /** * Register listeners for a particular event * - * @param string $event - * @param array $listeners - * @param integer $priority + * @param string $event + * @param array|callable $listeners + * @param integer $priority * * @return string */ diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 4a3309359..70fce4f41 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -42,31 +42,32 @@ public function run($commands, $silent = false, $array = false) $commands = $this->processCommands($commands); $verbose = $this->getOption('verbose') && !$silent; - // Log the commands for pretend + // Log the commands + if (!$silent) { + $this->toHistory($commands); + } + + // Display for pretend mode if ($this->getOption('pretend') and !$silent) { - return $this->addCommandsToHistory($commands); + $this->toOutput($commands); + $this->command->line(implode(PHP_EOL, $commands)); + + return sizeof($commands) == 1 ? $commands[0] : $commands; } // Run commands - $me = $this; $output = null; - $this->remote->run($commands, function ($results) use (&$output, $verbose, $me) { + $this->remote->run($commands, function ($results) use (&$output, $verbose) { $output .= $results; if ($verbose) { - $me->remote->display(trim($results)); + $this->remote->display(trim($results)); } }); // Process and log the output and commands $output = $this->processOutput($output, $array, true); - $this->logs->log($commands); - $this->logs->log($output); - - // Append output - if (!$silent) { - $this->toHistory($output); - } + $this->toOutput($output); return $output; } @@ -202,22 +203,6 @@ protected function getOption($option) return $this->hasCommand() ? $this->command->option($option) : null; } - /** - * Add an array/command to the history - * - * @param string|array $commands - * - * @return array|string - */ - protected function addCommandsToHistory($commands) - { - $this->command->line(implode(PHP_EOL, $commands)); - $commands = (sizeof($commands) == 1) ? $commands[0] : $commands; - $this->toHistory($commands); - - return $commands; - } - //////////////////////////////////////////////////////////////////// ///////////////////////////// PROCESSORS /////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index 223fc4f87..1c0cc035e 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -19,13 +19,17 @@ trait HasHistory /** * Get the class's history * + * @param string|null $type + * * @return array */ - public function getHistory() + public function getHistory($type = null) { $handle = $this->getHistoryHandle(); + $history = $this->history[$handle]; + $history = array_get($history, $type); - return $this->history[$handle]; + return $history; } /** @@ -76,10 +80,16 @@ protected function getHistoryHandle() */ protected function appendTo($type, $command) { + // Flatten one-liners + $command = (array) $command; + $command = sizeof($command) == 1 ? $command[0] : $command; + + // Get the various handles $handle = $this->getHistoryHandle(); $history = $this->getHistory(); $timestamp = (string) microtime(true); + // Set new history on correct handle $history[$type][$timestamp] = $command; $this->history[$handle] = $history; diff --git a/tests/Abstracts/TaskTest.php b/tests/Abstracts/TaskTest.php index 2fcc28078..20680492f 100644 --- a/tests/Abstracts/TaskTest.php +++ b/tests/Abstracts/TaskTest.php @@ -20,10 +20,10 @@ public function testCanDisplayOutputOfCommandsIfVerbose() public function testCanPretendToRunTasks() { - $task = $this->pretendTask(); + $task = $this->pretendTask(); + $commands = $task->run('ls'); - $output = $task->run('ls'); - $this->assertEquals('ls', $output); + $this->assertEquals('ls', $commands); } public function testCanGetDescription() @@ -53,7 +53,7 @@ public function testCanFireEventsDuringTasks() echo 'foobar'; }); - $this->tasksQueue()->execute(function ($task) { + $this->tasksQueue()->execute(function ($task) { $task->fireEvent('test.foobar'); }, 'staging'); } From 63153ed4a7a614e2dc366b9a535e719ab8a299a5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:01:48 +0200 Subject: [PATCH 073/424] Silence that goddamn git clone in the tests --- src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- tests/TestCases/ContainerTestCase.php | 15 ++++++++++----- tests/Traits/BashModules/CoreTest.php | 13 +++++++++---- tests/Traits/BashModules/ScmTest.php | 3 ++- 4 files changed, 23 insertions(+), 12 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 70fce4f41..f393f3b66 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -166,9 +166,9 @@ public function checkStatus($error, $output = null, $success = null) return $output || true; } - // Else + // Else display the error + $error = sprintf('An error occured: "%s", while running:'.PHP_EOL.'%s', $error, $output); $this->command->error($error); - print $output.PHP_EOL; return false; } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 2dc60556f..9a5eb39dd 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -104,10 +104,14 @@ protected function getCommand(array $expectations = array(), array $options = ar }; $command = Mockery::mock('Command'); - $command->shouldReceive('comment')->andReturnUsing($message); - $command->shouldReceive('error')->andReturnUsing($message); - $command->shouldReceive('line')->andReturnUsing($message); - $command->shouldReceive('info')->andReturnUsing($message); + + // Bind the output expectations + $types = ['comment', 'error', 'line', 'info']; + foreach ($types as $type) { + if (!array_key_exists($type, $expectations)) { + $command->shouldReceive($type)->andReturnUsing($message); + } + } // Merge defaults $expectations = array_merge(array( @@ -124,7 +128,8 @@ protected function getCommand(array $expectations = array(), array $options = ar if ($key === 'option') { $command->shouldReceive($key)->andReturn($value)->byDefault(); } else { - $command->shouldReceive($key)->andReturn($value); + $returnMethod = $value instanceof Closure ? 'andReturnUsing' : 'andReturn'; + $command->shouldReceive($key)->$returnMethod($value); } } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 3d37ebfcd..2705988de 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -14,12 +14,17 @@ public function testCanGetArraysFromRawCommands() public function testCanCheckStatusOfACommand() { + $this->expectOutputString('An error occured: "Oh noes", while running:'.PHP_EOL.'git clone'); + $this->task->remote = clone $this->getRemote()->shouldReceive('status')->andReturn(1)->mock(); - ob_start(); - $status = $this->task->checkStatus(null, 'error'); - $output = ob_get_clean(); + $this->mockCommand([], array( + 'error' => function($error) { + echo $error; + } + )); + + $status = $this->task->checkStatus('Oh noes', 'git clone'); - $this->assertEquals('error'.PHP_EOL, $output); $this->assertFalse($status); } diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index 2e992d82f..b5e9b9f63 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -14,8 +14,9 @@ public function testCanForgetCredentialsIfInvalid() )); // Create fake remote - $remote = clone $this->getRemote(); + $remote = $this->getRemote(); $remote->shouldReceive('status')->andReturn(1); + $task = $this->pretendTask(); $task->remote = $remote; From 4e4e01110c0457abbdb3f2ea430c17689ab64658 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:04:41 +0200 Subject: [PATCH 074/424] Fix tests --- tests/Tasks/SetupTest.php | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/tests/Tasks/SetupTest.php b/tests/Tasks/SetupTest.php index a3300979a..025f67016 100644 --- a/tests/Tasks/SetupTest.php +++ b/tests/Tasks/SetupTest.php @@ -15,7 +15,7 @@ public function testCanSetupServer() $this->assertTaskHistory('Setup', array( 'git --version', - '/usr/local/bin/php -m', + '{php} -m', "mkdir {server}/", "mkdir -p {server}/releases", "mkdir -p {server}/current", @@ -36,7 +36,7 @@ public function testCanSetupStages() $this->assertTaskHistory('Setup', array( 'git --version', - '/usr/local/bin/php -m', + '{php} -m', "mkdir {server}/", "mkdir -p {server}/staging/releases", "mkdir -p {server}/staging/current", @@ -62,7 +62,7 @@ public function testRunningSetupKeepsCurrentCongiguredStage() $this->assertEquals('staging', $this->connections->getStage()); $this->assertTaskHistory('Setup', array( 'git --version', - '/usr/local/bin/php -m', + '{php} -m', "mkdir {server}/", "mkdir -p {server}/staging/releases", "mkdir -p {server}/staging/current", From 5faa838d2ba93648df13afd327d5c662338c468e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:11:22 +0200 Subject: [PATCH 075/424] Fix some issues --- src/Rocketeer/Abstracts/Scm.php | 12 +++++++++++- src/Rocketeer/ConnectionsHandler.php | 4 ++-- src/Rocketeer/Interfaces/ScmInterface.php | 7 +++++++ src/Rocketeer/Scm/Git.php | 2 +- src/Rocketeer/Tasks/Check.php | 4 ++-- src/Rocketeer/TasksQueue.php | 8 ++++---- src/Rocketeer/Traits/HasHistory.php | 2 ++ 7 files changed, 29 insertions(+), 10 deletions(-) diff --git a/src/Rocketeer/Abstracts/Scm.php b/src/Rocketeer/Abstracts/Scm.php index 7749e7ded..ede290aba 100644 --- a/src/Rocketeer/Abstracts/Scm.php +++ b/src/Rocketeer/Abstracts/Scm.php @@ -25,7 +25,17 @@ abstract class Scm * * @var string */ - public $binary; + protected $binary; + + /** + * Get the current binary name + * + * @return string + */ + public function getBinary() + { + return $this->binary; + } //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/ConnectionsHandler.php index 50366bbc7..7afc28dc4 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/ConnectionsHandler.php @@ -39,14 +39,14 @@ class ConnectionsHandler /** * The connections to use * - * @var array + * @var array|null */ protected $connections; /** * The current connection * - * @var string + * @var string|null */ protected $connection; diff --git a/src/Rocketeer/Interfaces/ScmInterface.php b/src/Rocketeer/Interfaces/ScmInterface.php index d17cab18d..b92cf762f 100644 --- a/src/Rocketeer/Interfaces/ScmInterface.php +++ b/src/Rocketeer/Interfaces/ScmInterface.php @@ -16,6 +16,13 @@ */ interface ScmInterface { + /** + * Get the current binary name + * + * @return string + */ + public function getBinary(); + /** * Check if the SCM is available * diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index 0ca3fd941..807828340 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -24,7 +24,7 @@ class Git extends Scm implements ScmInterface * * @var string */ - public $binary = 'git'; + protected $binary = 'git'; //////////////////////////////////////////////////////////////////// ///////////////////////////// INFORMATIONS ///////////////////////// diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 507574ba5..e048774c2 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -86,7 +86,7 @@ protected function getChecks() $session = $this->app['config']->get('session.driver'); return array( - array('checkScm', $this->scm->binary.' could not be found'), + array('checkScm', $this->scm->getBinary().' could not be found'), array('checkPhpVersion', 'The version of PHP on the server does not match Laravel\'s requirements'), array('checkComposer', 'Composer does not seem to be present on the server'), array('checkPhpExtension', array('mcrypt', sprintf($extension, 'mcrypt'))), @@ -107,7 +107,7 @@ protected function getChecks() */ public function checkScm() { - $this->command->comment('Checking presence of '.$this->scm->binary); + $this->command->comment('Checking presence of '.$this->scm->getBinary()); $results = $this->scm->execute('check'); $this->toOutput($results); diff --git a/src/Rocketeer/TasksQueue.php b/src/Rocketeer/TasksQueue.php index 7d2c6d0d7..47e8f8be1 100644 --- a/src/Rocketeer/TasksQueue.php +++ b/src/Rocketeer/TasksQueue.php @@ -54,7 +54,7 @@ class TasksQueue * Execute Tasks on the default connection * * @param string|array|Closure $queue - * @param string|array $connections + * @param string|string[] $connections * * @return array */ @@ -260,7 +260,7 @@ public function buildTask($task, $name = null) /** * Build a Task from a Closure or a string command * - * @param Closure|string $task + * @param Closure|string $task * * @return Task */ @@ -274,7 +274,7 @@ public function buildTaskFromClosure($task) return $task->runForCurrentRelease($stringTask); }; // If the User provided a Closure - } elseif ($task instanceof Closure) { + } else { $closure = $task; } @@ -350,7 +350,7 @@ protected function getStage() /** * Check if a string is a command or a task * - * @param string $string + * @param Closure|string $string * * @return boolean */ diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index 1c0cc035e..951a2816a 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -12,6 +12,8 @@ /** * A class that maintains an history of results/commands * + * @property \Rocketeer\History\History history + * * @author Maxime Fabre */ trait HasHistory From b602a91474fcdfde8c0e980a391f3888618d3c1b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:16:02 +0200 Subject: [PATCH 076/424] Move timing function to a separate method --- .../Commands/AbstractDeployCommand.php | 31 ++++++++++++------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index 6524a345a..63a1d163b 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Console\Commands; +use Closure; use Illuminate\Console\Command; use Symfony\Component\Console\Input\InputOption; @@ -36,12 +37,7 @@ protected function getOptions() { return array( ['parallel', 'P', InputOption::VALUE_NONE, 'Run the tasks asynchronously instead of sequentially'], - [ - 'pretend', - 'p', - InputOption::VALUE_NONE, - 'Returns an array of commands to be executed instead of actually executing them' - ], + ['pretend', 'p', InputOption::VALUE_NONE, 'Shows which command would execute without actually doing anything'], ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'] ); @@ -88,9 +84,6 @@ protected function fireTasksQueue($tasks) $this->getServerCredentials(); $this->getRepositoryCredentials(); - // Start timer - $timerStart = microtime(true); - // Convert tasks to array if necessary if (!is_array($tasks)) { $tasks = array($tasks); @@ -100,13 +93,29 @@ protected function fireTasksQueue($tasks) $this->laravel->instance('rocketeer.command', $this); // Run tasks and display timer - $this->laravel['rocketeer.tasks']->run($tasks, $this); - $this->line('Execution time: '.round(microtime(true) - $timerStart, 4).'s'); + $this->time(function() use ($tasks) { + $this->laravel['rocketeer.tasks']->run($tasks, $this); + }); // Remove command instance unset($this->laravel['rocketeer.command']); } + /** + * Time an operation and display it afterwards + * + * @param callable $callback + */ + protected function time(Closure $callback) + { + // Start timer, execute callback, close timer + $timerStart = microtime(true); + $callback(); + $time = round(microtime(true) - $timerStart, 4); + + $this->line('Execution time: '.$time.'s'); + } + //////////////////////////////////////////////////////////////////// ///////////////////////////// CREDENTIALS ////////////////////////// //////////////////////////////////////////////////////////////////// From 7d8435fdc3ed5c31c0169e5c9a18fdf15f3eb66f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:19:21 +0200 Subject: [PATCH 077/424] Group Services in their own namespace --- src/Rocketeer/Abstracts/Plugin.php | 14 +++++++---- src/Rocketeer/Plugins/Notifier.php | 14 +++++++---- src/Rocketeer/RocketeerServiceProvider.php | 8 +++++-- .../{ => Services}/ConnectionsHandler.php | 3 ++- .../{ => Services}/History/History.php | 2 +- .../{ => Services}/History/LogsHandler.php | 2 +- .../{ => Services}/ReleasesManager.php | 3 ++- src/Rocketeer/{ => Services}/TasksHandler.php | 4 +++- src/Rocketeer/{ => Services}/TasksQueue.php | 4 +++- src/Rocketeer/Traits/HasHistory.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 24 +++++++++++++------ tests/TestCases/RocketeerTestCase.php | 6 +++-- 12 files changed, 58 insertions(+), 28 deletions(-) rename src/Rocketeer/{ => Services}/ConnectionsHandler.php (99%) rename src/Rocketeer/{ => Services}/History/History.php (94%) rename src/Rocketeer/{ => Services}/History/LogsHandler.php (98%) rename src/Rocketeer/{ => Services}/ReleasesManager.php (99%) rename src/Rocketeer/{ => Services}/TasksHandler.php (98%) rename src/Rocketeer/{ => Services}/TasksQueue.php (99%) diff --git a/src/Rocketeer/Abstracts/Plugin.php b/src/Rocketeer/Abstracts/Plugin.php index 68c11403c..6d3481c7d 100644 --- a/src/Rocketeer/Abstracts/Plugin.php +++ b/src/Rocketeer/Abstracts/Plugin.php @@ -11,7 +11,7 @@ use Illuminate\Container\Container; use Illuminate\Support\Str; -use Rocketeer\TasksHandler; +use Rocketeer\Services\TasksHandler; use Rocketeer\Traits\HasLocator; /** @@ -58,10 +58,14 @@ public function register(Container $app) /** * Register Tasks with Rocketeer - * - * @param TasksHandler $queue - * - * @return void + + +* +*@param \Rocketeer\Services\TasksHandler $queue + + +* +*@return void */ abstract public function onQueue(TasksHandler $queue); } diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 0105bb58f..3bc44227e 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -11,7 +11,7 @@ use Rocketeer\Abstracts\Plugin; use Rocketeer\Abstracts\Task; -use Rocketeer\TasksHandler; +use Rocketeer\Services\TasksHandler; /** * A base class for notification services to extends @@ -20,10 +20,14 @@ abstract class Notifier extends Plugin { /** * Register Tasks with Rocketeer - * - * @param TasksHandler $queue - * - * @return void + + +* +*@param \Rocketeer\Services\TasksHandler $queue + + +* +*@return void */ public function onQueue(TasksHandler $queue) { diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index bf22056e7..1b9e6b2ee 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -18,8 +18,12 @@ use Illuminate\Support\ServiceProvider; use Monolog\Logger; use Rocketeer\Console\Commands\BaseTaskCommand; -use Rocketeer\History\History; -use Rocketeer\History\LogsHandler; +use Rocketeer\Services\ConnectionsHandler; +use Rocketeer\Services\History\History; +use Rocketeer\Services\History\LogsHandler; +use Rocketeer\Services\ReleasesManager; +use Rocketeer\Services\TasksHandler; +use Rocketeer\Services\TasksQueue; // Define DS if (!defined('DS')) { diff --git a/src/Rocketeer/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php similarity index 99% rename from src/Rocketeer/ConnectionsHandler.php rename to src/Rocketeer/Services/ConnectionsHandler.php index 7afc28dc4..a609eb57e 100644 --- a/src/Rocketeer/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -7,10 +7,11 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer; +namespace Rocketeer\Services; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; +use string; /** * Handles, get and return, the various connections/stages diff --git a/src/Rocketeer/History/History.php b/src/Rocketeer/Services/History/History.php similarity index 94% rename from src/Rocketeer/History/History.php rename to src/Rocketeer/Services/History/History.php index 9a03e9554..133a5efb2 100644 --- a/src/Rocketeer/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -1,5 +1,5 @@ */ diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 65df8a1c1..3293f009e 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -14,20 +14,30 @@ /** * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes - * - * @property \Illuminate\Config\Repository config + + + + + + + + + + +* +*@property \Illuminate\Config\Repository config * @property \Illuminate\Console\Command command * @property \Illuminate\Remote\Connection remote * @property \Rocketeer\Bash bash - * @property \Rocketeer\ConnectionsHandler connections + * @property \Rocketeer\Services\ConnectionsHandler connections * @property \Rocketeer\Interfaces\ScmInterface scm * @property \Rocketeer\Interfaces\StrategyInterface strategy - * @property \Rocketeer\ReleasesManager releasesManager + * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Server server - * @property \Rocketeer\TasksHandler tasks - * @property \Rocketeer\TasksQueue queue - * @property \Rocketeer\History\History history + * @property \Rocketeer\Services\TasksHandler tasks + * @property \Rocketeer\Services\TasksQueue queue + * @property \Rocketeer\Services\History\History history * @author Maxime Fabre */ trait HasLocator diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 07394fdc1..26d66cc01 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -216,8 +216,10 @@ protected function task($task = null, $options = array()) /** * Get TasksQueue instance - * - * @return \Rocketeer\TasksHandler + + +* +*@return \Rocketeer\Services\TasksHandler */ protected function tasksQueue() { From cc774487da702adedbcad2140f031787146bc06e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:21:24 +0200 Subject: [PATCH 078/424] Move Server to Storages\LocalStorage --- src/Rocketeer/Console/Commands/AbstractDeployCommand.php | 2 +- src/Rocketeer/RocketeerServiceProvider.php | 3 ++- .../{Server.php => Services/Storages/LocalStorage.php} | 4 ++-- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 6 +++++- tests/IgniterTest.php | 2 +- tests/ReleasesManagerTest.php | 2 +- tests/ServerTest.php | 3 ++- tests/Tasks/TeardownTest.php | 4 ++-- tests/TestCases/RocketeerTestCase.php | 6 +++--- tests/_meta/coverage.txt | 2 +- 11 files changed, 21 insertions(+), 15 deletions(-) rename src/Rocketeer/{Server.php => Services/Storages/LocalStorage.php} (99%) diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index 63a1d163b..281ccefe1 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -151,7 +151,7 @@ protected function getRepositoryCredentials() } /** - * Get the Server's credentials + * Get the LocalStorage's credentials * * @return void */ diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 1b9e6b2ee..290ea9f03 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -22,6 +22,7 @@ use Rocketeer\Services\History\History; use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; +use Rocketeer\Services\Storages\LocalStorage; use Rocketeer\Services\TasksHandler; use Rocketeer\Services\TasksQueue; @@ -157,7 +158,7 @@ public function bindClasses() $filename = $app['rocketeer.rocketeer']->getApplicationName(); $filename = $filename === '{application_name}' ? 'deployments' : $filename; - return new Server($app, $filename); + return new LocalStorage($app, $filename); }); $this->app->bind('rocketeer.bash', function ($app) { diff --git a/src/Rocketeer/Server.php b/src/Rocketeer/Services/Storages/LocalStorage.php similarity index 99% rename from src/Rocketeer/Server.php rename to src/Rocketeer/Services/Storages/LocalStorage.php index ce69a9be7..3eaf20cb3 100644 --- a/src/Rocketeer/Server.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer; +namespace Rocketeer\Services\Storages; use Exception; use Illuminate\Container\Container; @@ -17,7 +17,7 @@ * * @author Maxime Fabre */ -class Server +class LocalStorage { /** * The IoC Container diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index c6bf642f4..76ba283e5 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -37,7 +37,7 @@ public function execute() // Setup if necessary if (!$this->isSetup()) { - $this->command->error('Server is not ready, running Setup task'); + $this->command->error('LocalStorage is not ready, running Setup task'); $this->executeTask('Setup'); } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 3293f009e..60acf2886 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -24,6 +24,10 @@ + + + + * *@property \Illuminate\Config\Repository config * @property \Illuminate\Console\Command command @@ -34,7 +38,7 @@ * @property \Rocketeer\Interfaces\StrategyInterface strategy * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Server server + * @property \Rocketeer\Services\Storages\LocalStorage server * @property \Rocketeer\Services\TasksHandler tasks * @property \Rocketeer\Services\TasksQueue queue * @property \Rocketeer\Services\History\History history diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index e22c30174..fcabcf048 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -87,7 +87,7 @@ public function testCanReplaceStubsInConfigurationFile() public function testCanSetCurrentApplication() { - $this->mock('rocketeer.server', 'Server', function ($mock) { + $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { return $mock->shouldReceive('setRepository')->once()->with('foobar'); }); diff --git a/tests/ReleasesManagerTest.php b/tests/ReleasesManagerTest.php index 8d1c70082..9b5dcc8ce 100644 --- a/tests/ReleasesManagerTest.php +++ b/tests/ReleasesManagerTest.php @@ -57,7 +57,7 @@ public function testCanMarkReleaseAsValid() public function testCanGetCurrentReleaseFromServerIfUncached() { - $this->mock('rocketeer.server', 'Server', function ($mock) { + $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getValue')->with('current_release.production')->once()->andReturn(null) ->shouldReceive('setValue')->with('current_release.production', '20000000000000')->once() diff --git a/tests/ServerTest.php b/tests/ServerTest.php index dbb6dfde5..eca61bc2f 100644 --- a/tests/ServerTest.php +++ b/tests/ServerTest.php @@ -1,6 +1,7 @@ app['path.storage'] = null; $this->app->offsetUnset('path.storage'); - new Server($this->app); + new LocalStorage($this->app); $storage = $this->rocketeer->getRocketeerConfigFolder(); $exists = file_exists($storage); diff --git a/tests/Tasks/TeardownTest.php b/tests/Tasks/TeardownTest.php index 63f8146ca..695d3d0ad 100644 --- a/tests/Tasks/TeardownTest.php +++ b/tests/Tasks/TeardownTest.php @@ -7,7 +7,7 @@ class TeardownTest extends RocketeerTestCase { public function testCanTeardownServer() { - $this->mock('rocketeer.server', 'Server', function ($mock) { + $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getSeparator')->andReturn(DIRECTORY_SEPARATOR) ->shouldReceive('deleteRepository')->once(); @@ -20,7 +20,7 @@ public function testCanTeardownServer() public function testCanAbortTeardown() { - $this->mock('rocketeer.server', 'Server', function ($mock) { + $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getSeparator')->andReturn(DIRECTORY_SEPARATOR) ->shouldReceive('deleteRepository')->never(); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 26d66cc01..ce4d367b3 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -3,7 +3,7 @@ use Closure; use Mockery; -use Rocketeer\Server; +use Rocketeer\Services\Storages\LocalStorage; abstract class RocketeerTestCase extends ContainerTestCase { @@ -41,10 +41,10 @@ public function setUp() $this->server = __DIR__.'/../_server/foobar'; $this->deploymentsFile = __DIR__.'/../_meta/deployments.json'; - // Bind new Server instance + // Bind new LocalStorage instance $meta = dirname($this->deploymentsFile); $this->app->bind('rocketeer.server', function ($app) use ($meta) { - return new Server($app, 'deployments', $meta); + return new LocalStorage($app, 'deployments', $meta); }); // Bind dummy Task diff --git a/tests/_meta/coverage.txt b/tests/_meta/coverage.txt index e564f68e2..cfc9dc1c1 100644 --- a/tests/_meta/coverage.txt +++ b/tests/_meta/coverage.txt @@ -16,7 +16,7 @@ Code Coverage Report: Methods: 94.12% (16/17) Lines: 97.14% ( 68/ 70) \Rocketeer::Rocketeer Methods: 96.00% (24/25) Lines: 98.31% (116/118) -\Rocketeer::Server +\Rocketeer::LocalStorage Methods: 69.23% ( 9/13) Lines: 86.49% ( 64/ 74) \Rocketeer::TasksHandler Methods: 81.82% ( 9/11) Lines: 91.94% ( 57/ 62) From ff096c17080ea2b78ade5df0a6809f74b049fd8d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:22:22 +0200 Subject: [PATCH 079/424] Code cleanup --- src/Rocketeer/Abstracts/Plugin.php | 12 ++---- .../Commands/AbstractDeployCommand.php | 2 +- src/Rocketeer/Plugins/Notifier.php | 12 ++---- src/Rocketeer/Services/ReleasesManager.php | 2 +- src/Rocketeer/Traits/HasHistory.php | 3 +- src/Rocketeer/Traits/HasLocator.php | 42 +++++++------------ tests/TestCases/RocketeerAssertions.php | 4 +- tests/TestCases/RocketeerTestCase.php | 6 +-- tests/Traits/BashModules/CoreTest.php | 2 +- 9 files changed, 30 insertions(+), 55 deletions(-) diff --git a/src/Rocketeer/Abstracts/Plugin.php b/src/Rocketeer/Abstracts/Plugin.php index 6d3481c7d..c5c3e1b66 100644 --- a/src/Rocketeer/Abstracts/Plugin.php +++ b/src/Rocketeer/Abstracts/Plugin.php @@ -58,14 +58,10 @@ public function register(Container $app) /** * Register Tasks with Rocketeer - - -* -*@param \Rocketeer\Services\TasksHandler $queue - - -* -*@return void + * + * @param \Rocketeer\Services\TasksHandler $queue + * + * @return void */ abstract public function onQueue(TasksHandler $queue); } diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index 281ccefe1..ef8511b8b 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -93,7 +93,7 @@ protected function fireTasksQueue($tasks) $this->laravel->instance('rocketeer.command', $this); // Run tasks and display timer - $this->time(function() use ($tasks) { + $this->time(function () use ($tasks) { $this->laravel['rocketeer.tasks']->run($tasks, $this); }); diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 3bc44227e..92ea9f96b 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -20,14 +20,10 @@ abstract class Notifier extends Plugin { /** * Register Tasks with Rocketeer - - -* -*@param \Rocketeer\Services\TasksHandler $queue - - -* -*@return void + * + * @param \Rocketeer\Services\TasksHandler $queue + * + * @return void */ public function onQueue(TasksHandler $queue) { diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 9f6d37471..62ed91b57 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -298,7 +298,7 @@ public function getPreviousRelease($release = null) // Get the one before that, or default to current $key = array_search($current, $releases); - $key = !is_int($key) ? -1 : $key; + $key = !is_int($key) ? -1 : $key; $next = 1; do { $release = array_get($releases, $key + $next); diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index fe0df360b..db0c60997 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -13,7 +13,6 @@ * A class that maintains an history of results/commands * * @property \Rocketeer\Services\History\History history - * * @author Maxime Fabre */ trait HasHistory @@ -27,7 +26,7 @@ trait HasHistory */ public function getHistory($type = null) { - $handle = $this->getHistoryHandle(); + $handle = $this->getHistoryHandle(); $history = $this->history[$handle]; $history = array_get($history, $type); diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 60acf2886..0e7897a2d 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -14,34 +14,20 @@ /** * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes - - - - - - - - - - - - - - -* -*@property \Illuminate\Config\Repository config - * @property \Illuminate\Console\Command command - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Bash bash - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\StrategyInterface strategy - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\Storages\LocalStorage server - * @property \Rocketeer\Services\TasksHandler tasks - * @property \Rocketeer\Services\TasksQueue queue - * @property \Rocketeer\Services\History\History history + * + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Bash bash + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage server + * @property \Rocketeer\Services\TasksHandler tasks + * @property \Rocketeer\Services\TasksQueue queue * @author Maxime Fabre */ trait HasLocator diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index 7be2a9b6e..729dfad39 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -37,8 +37,8 @@ protected function assertOptionValueEquals($value, $option) /** * Assert a task has a particular output * - * @param string $task - * @param string $output + * @param string $task + * @param string $output * @param \Mockery $command * * @return Assertion diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index ce4d367b3..d47a71eed 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -216,10 +216,8 @@ protected function task($task = null, $options = array()) /** * Get TasksQueue instance - - -* -*@return \Rocketeer\Services\TasksHandler + * + * @return \Rocketeer\Services\TasksHandler */ protected function tasksQueue() { diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 2705988de..e8bb61ad4 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -18,7 +18,7 @@ public function testCanCheckStatusOfACommand() $this->task->remote = clone $this->getRemote()->shouldReceive('status')->andReturn(1)->mock(); $this->mockCommand([], array( - 'error' => function($error) { + 'error' => function ($error) { echo $error; } )); From ae677c46796598978e848cfbf674c59ff527fe0d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:25:57 +0200 Subject: [PATCH 080/424] Update tests folder structure --- {tests => src/Rocketeer/Services}/ConnectionsHandlerTest.php | 4 +--- tests/{ => Services/History}/LogsHandlerTest.php | 2 +- tests/{ => Services}/ReleasesManagerTest.php | 2 +- .../Storages/LocalStorageTest.php} | 5 ++--- tests/{ => Services}/TasksHandlerTest.php | 2 +- tests/{ => Services}/TasksQueueTest.php | 3 +-- 6 files changed, 7 insertions(+), 11 deletions(-) rename {tests => src/Rocketeer/Services}/ConnectionsHandlerTest.php (98%) rename tests/{ => Services/History}/LogsHandlerTest.php (97%) rename tests/{ => Services}/ReleasesManagerTest.php (99%) rename tests/{ServerTest.php => Services/Storages/LocalStorageTest.php} (95%) rename tests/{ => Services}/TasksHandlerTest.php (99%) rename tests/{ => Services}/TasksQueueTest.php (99%) diff --git a/tests/ConnectionsHandlerTest.php b/src/Rocketeer/Services/ConnectionsHandlerTest.php similarity index 98% rename from tests/ConnectionsHandlerTest.php rename to src/Rocketeer/Services/ConnectionsHandlerTest.php index 2d598a58b..6d6739951 100644 --- a/tests/ConnectionsHandlerTest.php +++ b/src/Rocketeer/Services/ConnectionsHandlerTest.php @@ -1,7 +1,5 @@ tasksQueue()->buildTaskFromClass('Rocketeer\Tasks\Deploy'); From bf616c76da942bba34f06aecf6a6be5f98a2d112 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:32:59 +0200 Subject: [PATCH 081/424] Add ServerStorage class --- .../Services/Storages/LocalStorage.php | 2 +- .../Services/Storages/ServerStorage.php | 100 ++++++++++++++++++ 2 files changed, 101 insertions(+), 1 deletion(-) create mode 100644 src/Rocketeer/Services/Storages/ServerStorage.php diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index 3eaf20cb3..c85fc6b45 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -13,7 +13,7 @@ use Illuminate\Container\Container; /** - * Provides and persists informations about the remote server + * Provides and persists informations in local * * @author Maxime Fabre */ diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php new file mode 100644 index 000000000..464afaea1 --- /dev/null +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -0,0 +1,100 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Storages; + +use Illuminate\Support\Arr; +use Rocketeer\Traits\HasLocator; + +/** + * Provides and persists informations on the server + * + * @author Maxime Fabre + */ +class ServerStorage +{ + use HasLocator; + + /** + * Get a value on the server + * + * @param string $file + * @param string $key + * + * @return mixed + */ + public function get($file, $key) + { + $contents = $this->getContents($file); + + return Arr::get($contents, $key); + } + + /** + * Set a value on the server + * + * @param string $file + * @param string $key + * @param mixed|null $value + */ + public function set($file, $key, $value = null) + { + if (is_null($value)) { + return $this->saveContents($file, $key); + } + + $contents = $this->getContents($file); + $contents = Arr::set($contents, $key, $value); + $this->saveContents($file, $contents); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the full path to a file + * + * @param string $file + * + * @return string + */ + protected function getFilepath($file) + { + return $this->rocketeer->getFolder($file.'.json'); + } + + /** + * Get the contents of a file + * + * @param string $file + * + * @return array + */ + protected function getContents($file) + { + $file = $this->getFilepath($file); + $file = $this->bash->getFile($file) ?: '{}'; + $file = (array) json_decode($file, true); + + return $file; + } + + /** + * Save the contents of a file + * + * @param string $file + * @param array $contents + */ + protected function saveContents($file, $contents) + { + $file = $this->getFilepath($file.'.json'); + $this->bash->putFile($file, json_encode($contents)); + } +} From 57c449f5a8bb511be52791d90fcbb14e441291e3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:38:36 +0200 Subject: [PATCH 082/424] Rename server binding to localStorage --- .../Commands/AbstractDeployCommand.php | 2 +- .../Console/Commands/FlushCommand.php | 2 +- src/Rocketeer/Igniter.php | 26 +++++-------------- src/Rocketeer/Plugins/Notifier.php | 4 +-- src/Rocketeer/RocketeerServiceProvider.php | 7 ++++- src/Rocketeer/Services/ConnectionsHandler.php | 8 +++--- .../Services/ConnectionsHandlerTest.php | 4 +-- src/Rocketeer/Services/ReleasesManager.php | 4 +-- .../Services/Storages/ServerStorage.php | 6 ++--- src/Rocketeer/Strategies/CloneStrategy.php | 2 +- src/Rocketeer/Tasks/Check.php | 2 +- src/Rocketeer/Tasks/Setup.php | 6 ++--- src/Rocketeer/Tasks/Teardown.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 6 ++--- src/Rocketeer/Traits/BashModules/Core.php | 4 +-- src/Rocketeer/Traits/HasLocator.php | 5 ++-- tests/IgniterTest.php | 2 +- tests/Plugins/NotifierTest.php | 6 ++--- tests/Services/ReleasesManagerTest.php | 4 +-- tests/Services/Storages/LocalStorageTest.php | 26 +++++++++---------- tests/Tasks/TeardownTest.php | 4 +-- tests/TestCases/RocketeerTestCase.php | 2 +- tests/Traits/BashModules/ScmTest.php | 4 +-- 23 files changed, 65 insertions(+), 73 deletions(-) diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index ef8511b8b..3fe8a9714 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -144,7 +144,7 @@ protected function getRepositoryCredentials() // Save them $credentials = compact($credentials); - $this->laravel['rocketeer.server']->setValue('credentials', $credentials); + $this->laravel['rocketeer.storage.local']->setValue('credentials', $credentials); foreach ($credentials as $key => $credential) { $this->laravel['config']->set('rocketeer::scm.'.$key, $credential); } diff --git a/src/Rocketeer/Console/Commands/FlushCommand.php b/src/Rocketeer/Console/Commands/FlushCommand.php index ea4bf1bd4..1f16ba1f9 100644 --- a/src/Rocketeer/Console/Commands/FlushCommand.php +++ b/src/Rocketeer/Console/Commands/FlushCommand.php @@ -35,7 +35,7 @@ class FlushCommand extends AbstractDeployCommand */ public function fire() { - $this->laravel['rocketeer.server']->deleteRepository(); + $this->laravel['rocketeer.storage.local']->deleteRepository(); $this->info("Rocketeer's cache has been properly flushed"); } } diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index fa4f863d2..79eda8a1b 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -10,6 +10,7 @@ namespace Rocketeer; use Illuminate\Container\Container; +use Rocketeer\Traits\HasLocator; /** * Finds configurations and paths @@ -18,22 +19,7 @@ */ class Igniter { - /** - * The Container - * - * @var Container - */ - protected $app; - - /** - * Build a new Igniter - * - * @param Container $app - */ - public function __construct(Container $app) - { - $this->app = $app; - } + use HasLocator; /** * Bind paths to the container @@ -76,7 +62,7 @@ public function exportConfiguration() $destination = $this->getConfigurationPath(); // Unzip configuration files - $this->app['files']->copyDirectory($source, $destination); + $this->files->copyDirectory($source, $destination); return $destination; } @@ -90,17 +76,17 @@ public function exportConfiguration() public function updateConfiguration($folder, array $values = array()) { // Replace stub values in files - $files = $this->app['files']->files($folder); + $files = $this->files->files($folder); foreach ($files as $file) { foreach ($values as $name => $value) { $contents = str_replace('{'.$name.'}', $value, file_get_contents($file)); - $this->app['files']->put($file, $contents); + $this->files->put($file, $contents); } } // Change repository in use $application = array_get($values, 'application_name'); - $this->app['rocketeer.server']->setRepository($application); + $this->localStorage->setRepository($application); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 92ea9f96b..a1a20e939 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -59,10 +59,10 @@ abstract public function send($message); protected function getComponents() { // Get user name - $user = $this->server->getValue('notifier.name'); + $user = $this->localStorage->getValue('notifier.name'); if (!$user) { $user = $this->command->ask('Who is deploying ?'); - $this->server->setValue('notifier.name', $user); + $this->localStorage->setValue('notifier.name', $user); } // Get what was deployed diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 290ea9f03..3652c770b 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -23,6 +23,7 @@ use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; use Rocketeer\Services\Storages\LocalStorage; +use Rocketeer\Services\Storages\ServerStorage; use Rocketeer\Services\TasksHandler; use Rocketeer\Services\TasksQueue; @@ -154,13 +155,17 @@ public function bindClasses() return new ReleasesManager($app); }); - $this->app->bind('rocketeer.server', function ($app) { + $this->app->bind('rocketeer.storage.local', function ($app) { $filename = $app['rocketeer.rocketeer']->getApplicationName(); $filename = $filename === '{application_name}' ? 'deployments' : $filename; return new LocalStorage($app, $filename); }); + $this->app->bind('rocketeer.storage.server', function ($app) { + return new ServerStorage($app); + }); + $this->app->bind('rocketeer.bash', function ($app) { return new Bash($app); }); diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index a609eb57e..abf60e5b5 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -126,7 +126,7 @@ public function needsCredentials() public function getAvailableConnections() { // Fetch stored credentials - $storage = (array) $this->server->getValue('connections'); + $storage = (array) $this->localStorage->getValue('connections'); // Merge with defaults from config file $configuration = (array) $this->config->get('rocketeer::connections'); @@ -252,7 +252,7 @@ public function syncConnectionCredentials($connection = null, array $credentials { // Store credentials if any if ($credentials) { - $this->server->setValue('connections.'.$connection.'.servers.'.$server, $credentials); + $this->localStorage->setValue('connections.'.$connection.'.servers.'.$server, $credentials); } // Get connection @@ -293,7 +293,7 @@ public function setConnection($connection, $server = 0) // Set the connection $this->connection = $connection; - $this->server = $server; + $this->localStorage = $server; // Register it with SSH component $name = $connection.'#'.$server; @@ -324,7 +324,7 @@ public function disconnect() */ public function getCredentials() { - $credentials = $this->server->getValue('credentials'); + $credentials = $this->localStorage->getValue('credentials'); if (!$credentials) { $credentials = $this->rocketeer->getOption('scm'); } diff --git a/src/Rocketeer/Services/ConnectionsHandlerTest.php b/src/Rocketeer/Services/ConnectionsHandlerTest.php index 6d6739951..ddf8fae70 100644 --- a/src/Rocketeer/Services/ConnectionsHandlerTest.php +++ b/src/Rocketeer/Services/ConnectionsHandlerTest.php @@ -12,7 +12,7 @@ public function testCanGetAvailableConnections() $connections = $this->connections->getAvailableConnections(); $this->assertEquals(array('production', 'staging'), array_keys($connections)); - $this->app['rocketeer.server']->setValue('connections.custom.username', 'foobar'); + $this->app['rocketeer.storage.local']->setValue('connections.custom.username', 'foobar'); $connections = $this->connections->getAvailableConnections(); $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); } @@ -99,7 +99,7 @@ public function testFillsConnectionCredentialsHoles() $connections = $this->connections->getAvailableConnections(); $this->assertArrayHasKey('production', $connections); - $this->app['rocketeer.server']->setValue('connections', array( + $this->app['rocketeer.storage.local']->setValue('connections', array( 'staging' => array( 'host' => 'foobar', 'username' => 'user', diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 62ed91b57..57c40688a 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -271,7 +271,7 @@ protected function getCurrentReleaseKey() public function getCurrentRelease() { // If we have saved the last deployed release, return that - $cached = $this->server->getValue($this->getCurrentReleaseKey()); + $cached = $this->localStorage->getValue($this->getCurrentReleaseKey()); if ($cached) { return $this->sanitizeRelease($cached); } @@ -321,7 +321,7 @@ public function updateCurrentRelease($release = null) $release = $this->bash->getTimestamp(); } - $this->server->setValue($this->getCurrentReleaseKey(), $release); + $this->localStorage->setValue($this->getCurrentReleaseKey(), $release); return $release; } diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index 464afaea1..fc10f3f13 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -24,12 +24,12 @@ class ServerStorage /** * Get a value on the server * - * @param string $file - * @param string $key + * @param string $file + * @param string|null $key * * @return mixed */ - public function get($file, $key) + public function get($file, $key = null) { $contents = $this->getContents($file); diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php index be8c11215..8d598b9f9 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -26,7 +26,7 @@ public function deploy($destination = null) // Cancel if failed and forget credentials $success = $this->bash->checkStatus('Unable to clone the repository', $output) !== false; if (!$success) { - $this->server->forgetValue('credentials'); + $this->localStorage->forgetValue('credentials'); return false; } diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index e048774c2..755408294 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -121,7 +121,7 @@ public function checkScm() */ public function checkComposer() { - if (!$this->server->usesComposer()) { + if (!$this->localStorage->usesComposer()) { return true; } diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index d94e66463..bda3ca6cf 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -49,12 +49,12 @@ public function execute() $this->createStages(); // Set setup to true - $this->server->setValue('is_setup', true); + $this->localStorage->setValue('is_setup', true); // Get server informations $this->command->comment('Getting some informations about the server'); - $this->server->getSeparator(); - $this->server->getLineEndings(); + $this->localStorage->getSeparator(); + $this->localStorage->getLineEndings(); // Create confirmation message $application = $this->rocketeer->getApplicationName(); diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 4cb42d207..261c9a7ce 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -49,7 +49,7 @@ public function execute() $this->removeFolder(); // Remove deployments file - $this->server->deleteRepository(); + $this->localStorage->deleteRepository(); $this->command->info('The application was successfully removed from the remote servers'); } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index a244af5cc..ee0538622 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -166,7 +166,7 @@ public function composer($command = null) */ public function runComposer($force = false) { - if (!$this->server->usesComposer() and !$force) { + if (!$this->localStorage->usesComposer() and !$force) { return true; } @@ -211,7 +211,7 @@ public function which($binary, $fallback = null) { $location = false; $locations = array( - array($this->server, 'getValue', 'paths.'.$binary), + array($this->localStorage, 'getValue', 'paths.'.$binary), array($this->rocketeer, 'getPath', $binary), array($this, 'runSilently', 'which '.$binary), ); @@ -237,7 +237,7 @@ public function which($binary, $fallback = null) } // Store found location - $this->server->setValue('paths.'.$binary, $location); + $this->localStorage->setValue('paths.'.$binary, $location); return $location ?: false; } diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index f393f3b66..b4b437b9d 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -217,7 +217,7 @@ protected function getOption($option) public function processCommands($commands) { $stage = $this->connections->getStage(); - $separator = $this->server->getSeparator(); + $separator = $this->localStorage->getSeparator(); // Cast commands to array if (!is_array($commands)) { @@ -257,7 +257,7 @@ protected function processOutput($output, $array = false, $trim = true) // Explode output if necessary if ($array) { - $output = explode($this->server->getLineEndings(), $output); + $output = explode($this->localStorage->getLineEndings(), $output); } // Trim output diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 0e7897a2d..513633c30 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -25,7 +25,7 @@ * @property \Rocketeer\Services\ConnectionsHandler connections * @property \Rocketeer\Services\History\History history * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage server + * @property \Rocketeer\Services\Storages\LocalStorage localStorage * @property \Rocketeer\Services\TasksHandler tasks * @property \Rocketeer\Services\TasksQueue queue * @author Maxime Fabre @@ -69,7 +69,8 @@ public function __get($key) 'releasesManager' => 'rocketeer.releases', 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', - 'server' => 'rocketeer.server', + 'localStorage' => 'rocketeer.storage.local', + 'serverStorage' => 'rocketeer.storage.server', 'strategy' => 'rocketeer.strategy', 'tasks' => 'rocketeer.tasks', ); diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index fcabcf048..bb61771a6 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -87,7 +87,7 @@ public function testCanReplaceStubsInConfigurationFile() public function testCanSetCurrentApplication() { - $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { + $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock->shouldReceive('setRepository')->once()->with('foobar'); }); diff --git a/tests/Plugins/NotifierTest.php b/tests/Plugins/NotifierTest.php index f1a304a9e..fe83905c5 100644 --- a/tests/Plugins/NotifierTest.php +++ b/tests/Plugins/NotifierTest.php @@ -28,7 +28,7 @@ public function setUp() public function testCanAppendStageToDetails() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "staging@production" (foo.bar.com)'); - $this->app['rocketeer.server']->setValue('notifier.name', 'Jean Eude'); + $this->app['rocketeer.storage.local']->setValue('notifier.name', 'Jean Eude'); $this->connections->setStage('staging'); $this->notifier = new DummyNotifier($this->app); $this->tasks->plugin($this->notifier); @@ -39,7 +39,7 @@ public function testCanAppendStageToDetails() public function testCanSendDeploymentsNotifications() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "production" (foo.bar.com)'); - $this->app['rocketeer.server']->setValue('notifier.name', 'Jean Eude'); + $this->app['rocketeer.storage.local']->setValue('notifier.name', 'Jean Eude'); $this->task('Deploy')->fireEvent('after'); } @@ -47,7 +47,7 @@ public function testCanSendDeploymentsNotifications() public function testDoesntSendNotificationsInPretendMode() { $this->expectOutputString(''); - $this->app['rocketeer.server']->setValue('notifier.name', 'Jean Eude'); + $this->app['rocketeer.storage.local']->setValue('notifier.name', 'Jean Eude'); $this->pretendTask('Deploy')->fireEvent('after'); } diff --git a/tests/Services/ReleasesManagerTest.php b/tests/Services/ReleasesManagerTest.php index 3c45a640d..1536b563a 100644 --- a/tests/Services/ReleasesManagerTest.php +++ b/tests/Services/ReleasesManagerTest.php @@ -57,7 +57,7 @@ public function testCanMarkReleaseAsValid() public function testCanGetCurrentReleaseFromServerIfUncached() { - $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { + $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getValue')->with('current_release.production')->once()->andReturn(null) ->shouldReceive('setValue')->with('current_release.production', '20000000000000')->once() @@ -145,7 +145,7 @@ public function testCanUpdateCurrentRelease() { $this->releasesManager->updateCurrentRelease(30000000000000); - $this->assertEquals(30000000000000, $this->app['rocketeer.server']->getValue('current_release.production')); + $this->assertEquals(30000000000000, $this->app['rocketeer.storage.local']->getValue('current_release.production')); } public function testCanGetFolderInRelease() diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 5157f2bf0..26eb5aad5 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -24,42 +24,42 @@ public function testCanCreateDeploymentsFileAnywhere() public function testCanGetValueFromDeploymentsFile() { - $this->assertEquals('bar', $this->app['rocketeer.server']->getValue('foo')); + $this->assertEquals('bar', $this->app['rocketeer.storage.local']->getValue('foo')); } public function testCanSetValueInDeploymentsFile() { - $this->app['rocketeer.server']->setValue('foo', 'baz'); + $this->app['rocketeer.storage.local']->setValue('foo', 'baz'); - $this->assertEquals('baz', $this->app['rocketeer.server']->getValue('foo')); + $this->assertEquals('baz', $this->app['rocketeer.storage.local']->getValue('foo')); } public function testCandeleteRepository() { - $this->app['rocketeer.server']->deleteRepository(); + $this->app['rocketeer.storage.local']->deleteRepository(); $this->assertFalse($this->app['files']->exists(__DIR__.'/_meta/deployments.json')); } public function testCanFallbackIfFileDoesntExist() { - $this->app['rocketeer.server']->deleteRepository(); + $this->app['rocketeer.storage.local']->deleteRepository(); - $this->assertEquals(null, $this->app['rocketeer.server']->getValue('foo')); + $this->assertEquals(null, $this->app['rocketeer.storage.local']->getValue('foo')); } public function testCanGetLineEndings() { - $this->app['rocketeer.server']->deleteRepository(); + $this->app['rocketeer.storage.local']->deleteRepository(); - $this->assertEquals(PHP_EOL, $this->app['rocketeer.server']->getLineEndings()); + $this->assertEquals(PHP_EOL, $this->app['rocketeer.storage.local']->getLineEndings()); } public function testCanGetSeparators() { - $this->app['rocketeer.server']->deleteRepository(); + $this->app['rocketeer.storage.local']->deleteRepository(); - $this->assertEquals(DIRECTORY_SEPARATOR, $this->app['rocketeer.server']->getSeparator()); + $this->assertEquals(DIRECTORY_SEPARATOR, $this->app['rocketeer.storage.local']->getSeparator()); } public function testCanComputeHashAccordingToContentsOfFiles() @@ -73,7 +73,7 @@ public function testCanComputeHashAccordingToContentsOfFiles() ->shouldReceive('getRequire')->once()->with('bar')->andReturn(array('bar')); }); - $hash = $this->app['rocketeer.server']->getHash(); + $hash = $this->app['rocketeer.storage.local']->getHash(); $this->assertEquals(md5('["foo"]["bar"]'), $hash); } @@ -81,9 +81,9 @@ public function testCanComputeHashAccordingToContentsOfFiles() public function testCanCheckIfComposerIsNeeded() { $this->usesComposer(true); - $this->assertTrue($this->app['rocketeer.server']->usesComposer()); + $this->assertTrue($this->app['rocketeer.storage.local']->usesComposer()); $this->usesComposer(false); - $this->assertFalse($this->app['rocketeer.server']->usesComposer()); + $this->assertFalse($this->app['rocketeer.storage.local']->usesComposer()); } } diff --git a/tests/Tasks/TeardownTest.php b/tests/Tasks/TeardownTest.php index 695d3d0ad..0c19cd194 100644 --- a/tests/Tasks/TeardownTest.php +++ b/tests/Tasks/TeardownTest.php @@ -7,7 +7,7 @@ class TeardownTest extends RocketeerTestCase { public function testCanTeardownServer() { - $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { + $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getSeparator')->andReturn(DIRECTORY_SEPARATOR) ->shouldReceive('deleteRepository')->once(); @@ -20,7 +20,7 @@ public function testCanTeardownServer() public function testCanAbortTeardown() { - $this->mock('rocketeer.server', 'LocalStorage', function ($mock) { + $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getSeparator')->andReturn(DIRECTORY_SEPARATOR) ->shouldReceive('deleteRepository')->never(); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index d47a71eed..5a3031108 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -43,7 +43,7 @@ public function setUp() // Bind new LocalStorage instance $meta = dirname($this->deploymentsFile); - $this->app->bind('rocketeer.server', function ($app) use ($meta) { + $this->app->bind('rocketeer.storage.local', function ($app) use ($meta) { return new LocalStorage($app, 'deployments', $meta); }); diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index b5e9b9f63..c20c61d9f 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -7,7 +7,7 @@ class ScmTest extends RocketeerTestCase { public function testCanForgetCredentialsIfInvalid() { - $this->app['rocketeer.server']->setValue('credentials', array( + $this->app['rocketeer.storage.local']->setValue('credentials', array( 'repository' => 'https://Anahkiasen@bitbucket.org/Anahkiasen/registry.git', 'username' => 'Anahkiasen', 'password' => 'baz', @@ -21,6 +21,6 @@ public function testCanForgetCredentialsIfInvalid() $task->remote = $remote; $task->strategy->deploy($this->server.'/test'); - $this->assertNull($this->app['rocketeer.server']->getValue('credentials')); + $this->assertNull($this->app['rocketeer.storage.local']->getValue('credentials')); } } From cd9cf48b652baf7ae2a38c80617dc5610fa92d43 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:45:02 +0200 Subject: [PATCH 083/424] Make ReleaseManger use ServerStorage for state management --- src/Rocketeer/Services/ReleasesManager.php | 15 ++++------- .../Services/Storages/ServerStorage.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 27 ++++++++++--------- 3 files changed, 20 insertions(+), 24 deletions(-) diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 57c40688a..976df19d6 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -168,10 +168,7 @@ public function getCurrentReleasePath($folder = null) */ public function getValidationFile() { - // Get the contents of the validation file - $file = $this->rocketeer->getFolder('state.json'); - $file = $this->bash->getFile($file) ?: '{}'; - $file = (array) json_decode($file, true); + $file = $this->serverStorage->get('state'); // Fill the missing releases $releases = (array) $this->getReleases(); @@ -195,8 +192,7 @@ public function getValidationFile() */ public function saveValidationFile(array $validation) { - $file = $this->rocketeer->getFolder('state.json'); - $this->bash->putFile($file, json_encode($validation)); + $this->serverStorage->set('state', $validation); $this->state = $validation; } @@ -208,11 +204,10 @@ public function saveValidationFile(array $validation) */ public function markReleaseAsValid($release = null) { - $release = $release ?: $this->getCurrentRelease(); - $validation = $this->getValidationFile(); - $validation[$release] = true; + $release = $release ?: $this->getCurrentRelease(); - $this->saveValidationFile($validation); + $this->state[$release] = true; + $this->serverStorage->set('state', $release, true); } /** diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index fc10f3f13..413f27728 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -94,7 +94,7 @@ protected function getContents($file) */ protected function saveContents($file, $contents) { - $file = $this->getFilepath($file.'.json'); + $file = $this->getFilepath($file); $this->bash->putFile($file, json_encode($contents)); } } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 513633c30..42fdf3736 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,19 +15,20 @@ * An abstract for Service Locator-based classes with adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Config\Repository config - * @property \Illuminate\Console\Command command - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Bash bash - * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\StrategyInterface strategy - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Services\History\History history - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\TasksHandler tasks - * @property \Rocketeer\Services\TasksQueue queue + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Console\Command command + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Bash bash + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage localStorage + * @property \Rocketeer\Services\Storages\ServerStorage serverStorage + * @property \Rocketeer\Services\TasksHandler tasks + * @property \Rocketeer\Services\TasksQueue queue * @author Maxime Fabre */ trait HasLocator From de49feff74228ba233e1ddf6c4d0fc0ee0602f85 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:52:39 +0200 Subject: [PATCH 084/424] Update some docblocks --- src/Rocketeer/Abstracts/Task.php | 2 +- src/Rocketeer/Rocketeer.php | 16 ++++++++-------- src/Rocketeer/RocketeerServiceProvider.php | 4 ++-- src/Rocketeer/Services/History/History.php | 6 +++--- src/Rocketeer/Services/History/LogsHandler.php | 2 +- src/Rocketeer/Services/ReleasesManager.php | 2 +- src/Rocketeer/Services/Storages/LocalStorage.php | 14 +++++++------- .../Services/Storages/ServerStorage.php | 6 +++--- src/Rocketeer/Traits/HasLocator.php | 1 + 9 files changed, 27 insertions(+), 26 deletions(-) diff --git a/src/Rocketeer/Abstracts/Task.php b/src/Rocketeer/Abstracts/Task.php index 3ab1d122b..efc664ab5 100644 --- a/src/Rocketeer/Abstracts/Task.php +++ b/src/Rocketeer/Abstracts/Task.php @@ -105,7 +105,7 @@ abstract public function execute(); /** * Fire the command * - * @return boolean + * @return string|boolean */ public function fire() { diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 54abf7395..88ccd7e23 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -65,11 +65,11 @@ public function getOption($option) /** * Get a contextual option * - * @param string $option - * @param string $type [stage,connection] - * @param string|array $original + * @param string $option + * @param string $type [stage,connection] + * @param string|array|null $original * - * @return mixed + * @return string|array|\Closure */ protected function getContextualOption($option, $type, $original = null) { @@ -100,10 +100,10 @@ protected function getContextualOption($option, $type, $original = null) /** * Returns what stage Rocketeer thinks he's in * - * @param string $application - * @param string $path + * @param string $application + * @param string|null $path * - * @return string + * @return string|false */ public static function getDetectedStage($application = 'application', $path = null) { @@ -155,7 +155,7 @@ public function replacePatterns($path) /** * Get the path to a folder, taking into account application name and stage * - * @param string $folder + * @param string|null $folder * * @return string */ diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 3652c770b..faafb0adf 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -81,11 +81,11 @@ public function boot() /** * Get the services provided by the provider. * - * @return array + * @return string[] */ public function provides() { - return array('rocketeer'); + return ['rocketeer']; } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 133a5efb2..375c75c6f 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -8,7 +8,7 @@ class History extends Collection /** * Get the history, flattened * - * @return array + * @return string[]|string[][] */ public function getFlattenedHistory() { @@ -18,7 +18,7 @@ public function getFlattenedHistory() /** * Get the output, flattened * - * @return array + * @return string[]|string[][] */ public function getFlattenedOutput() { @@ -30,7 +30,7 @@ public function getFlattenedOutput() * * @param string $type * - * @return array + * @return string[]|string[][] */ protected function getFlattened($type) { diff --git a/src/Rocketeer/Services/History/LogsHandler.php b/src/Rocketeer/Services/History/LogsHandler.php index 4b38b4ac3..abd7e795b 100644 --- a/src/Rocketeer/Services/History/LogsHandler.php +++ b/src/Rocketeer/Services/History/LogsHandler.php @@ -52,7 +52,7 @@ public function log($informations, $level = 'info') /** * Get the logs file being currently used * - * @return string|boolean + * @return string|false */ public function getCurrentLogsFile() { diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 976df19d6..d019fb5a4 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -132,7 +132,7 @@ public function getReleasesPath() /** * Get the path to a release * - * @param integer $release + * @param string $release * * @return string */ diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index c85fc6b45..fc3220807 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -43,9 +43,9 @@ class LocalStorage /** * Build a new ReleasesManager * - * @param Container $app - * @param string $filename - * @param string $storage + * @param Container $app + * @param string $filename + * @param string|null $storage */ public function __construct(Container $app, $filename = 'deployments', $storage = null) { @@ -123,8 +123,8 @@ public function shouldFlush() /** * Change the repository in use * - * @param string $filename - * @param string $storage + * @param string $filename + * @param string|null $storage */ public function setRepository($filename, $storage = null) { @@ -219,8 +219,8 @@ public function usesComposer() /** * Get a value from the repository file * - * @param string $key - * @param \Closure|string $fallback + * @param string $key + * @param \Closure|string|null $fallback * * @return mixed */ diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index 413f27728..336b7f734 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -39,9 +39,9 @@ public function get($file, $key = null) /** * Set a value on the server * - * @param string $file - * @param string $key - * @param mixed|null $value + * @param string $file + * @param string|array $key + * @param mixed|null $value */ public function set($file, $key, $value = null) { diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 42fdf3736..e6a28045a 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -17,6 +17,7 @@ * * @property \Illuminate\Config\Repository config * @property \Illuminate\Console\Command command + * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Remote\Connection remote * @property \Rocketeer\Bash bash * @property \Rocketeer\Interfaces\ScmInterface scm From 032afc5dde158547bb67f7056c6ce43aaf6aa730 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 01:53:33 +0200 Subject: [PATCH 085/424] Fix misplaced class --- {src/Rocketeer => tests}/Services/ConnectionsHandlerTest.php | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename {src/Rocketeer => tests}/Services/ConnectionsHandlerTest.php (100%) diff --git a/src/Rocketeer/Services/ConnectionsHandlerTest.php b/tests/Services/ConnectionsHandlerTest.php similarity index 100% rename from src/Rocketeer/Services/ConnectionsHandlerTest.php rename to tests/Services/ConnectionsHandlerTest.php From bbe5efc7e7f098d9f91bbe04c9da61499119b7ee Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 02:26:42 +0200 Subject: [PATCH 086/424] Unify storages under a common interface --- src/Rocketeer/Abstracts/Storage.php | 115 ++++++++++ .../Commands/AbstractDeployCommand.php | 2 +- .../Console/Commands/FlushCommand.php | 2 +- src/Rocketeer/Igniter.php | 2 +- src/Rocketeer/Interfaces/StorageInterface.php | 37 ++++ src/Rocketeer/Plugins/Notifier.php | 4 +- src/Rocketeer/RocketeerServiceProvider.php | 5 - src/Rocketeer/Services/ConnectionsHandler.php | 6 +- src/Rocketeer/Services/ReleasesManager.php | 23 +- .../Services/Storages/LocalStorage.php | 197 ++++++------------ .../Services/Storages/ServerStorage.php | 64 ++---- src/Rocketeer/Strategies/CloneStrategy.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Tasks/Teardown.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 4 +- src/Rocketeer/Traits/HasLocator.php | 2 - tests/IgniterTest.php | 2 +- tests/Plugins/NotifierTest.php | 6 +- tests/Services/ConnectionsHandlerTest.php | 6 +- tests/Services/ReleasesManagerTest.php | 6 +- tests/Services/Storages/LocalStorageTest.php | 20 +- tests/Tasks/TeardownTest.php | 4 +- tests/Traits/BashModules/ScmTest.php | 4 +- 23 files changed, 289 insertions(+), 228 deletions(-) create mode 100644 src/Rocketeer/Abstracts/Storage.php create mode 100644 src/Rocketeer/Interfaces/StorageInterface.php diff --git a/src/Rocketeer/Abstracts/Storage.php b/src/Rocketeer/Abstracts/Storage.php new file mode 100644 index 000000000..cf4fcd7ed --- /dev/null +++ b/src/Rocketeer/Abstracts/Storage.php @@ -0,0 +1,115 @@ +app = $app; + $this->file = $file; + } + + /** + * Change the file in use + * + * @param string $file + */ + public function setFile($file) + { + $this->file = $file; + } + + ////////////////////////////////////////////////////////////////////// + /////////////////////////////// VALUES /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get a value on the server + * + * @param string|null $key + * @param string|Closure|null $fallback + * + * @return mixed + */ + public function get($key = null, $fallback = null) + { + $contents = $this->getContents(); + + return Arr::get($contents, $key, $fallback); + } + + /** + * Set a value on the server + * + * @param string|array $key + * @param mixed|null $value + */ + public function set($key, $value = null) + { + // Set the value on the contents + $contents = $this->getContents(); + Arr::set($contents, $key, $value); + + $this->saveContents($contents); + } + + /** + * Forget a value from the repository file + * + * @param string $key + * + * @return array + */ + public function forget($key) + { + $contents = $this->getContents(); + Arr::forget($contents, $key); + + $this->saveContents($contents); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the full path to the file + * + * @return string + */ + abstract protected function getFilepath(); + + /** + * Get the contents of the file + * + * @return array + */ + abstract protected function getContents(); + + /** + * Save the contents of the file + * + * @param array $contents + */ + abstract protected function saveContents($contents); +} diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index 3fe8a9714..7ea30b94e 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -144,7 +144,7 @@ protected function getRepositoryCredentials() // Save them $credentials = compact($credentials); - $this->laravel['rocketeer.storage.local']->setValue('credentials', $credentials); + $this->laravel['rocketeer.storage.local']->set('credentials', $credentials); foreach ($credentials as $key => $credential) { $this->laravel['config']->set('rocketeer::scm.'.$key, $credential); } diff --git a/src/Rocketeer/Console/Commands/FlushCommand.php b/src/Rocketeer/Console/Commands/FlushCommand.php index 1f16ba1f9..21d9cdfb6 100644 --- a/src/Rocketeer/Console/Commands/FlushCommand.php +++ b/src/Rocketeer/Console/Commands/FlushCommand.php @@ -35,7 +35,7 @@ class FlushCommand extends AbstractDeployCommand */ public function fire() { - $this->laravel['rocketeer.storage.local']->deleteRepository(); + $this->laravel['rocketeer.storage.local']->destroy(); $this->info("Rocketeer's cache has been properly flushed"); } } diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 79eda8a1b..c05fb295d 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -86,7 +86,7 @@ public function updateConfiguration($folder, array $values = array()) // Change repository in use $application = array_get($values, 'application_name'); - $this->localStorage->setRepository($application); + $this->localStorage->setFile($application); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Interfaces/StorageInterface.php b/src/Rocketeer/Interfaces/StorageInterface.php new file mode 100644 index 000000000..665c333d9 --- /dev/null +++ b/src/Rocketeer/Interfaces/StorageInterface.php @@ -0,0 +1,37 @@ +localStorage->getValue('notifier.name'); + $user = $this->localStorage->get('notifier.name'); if (!$user) { $user = $this->command->ask('Who is deploying ?'); - $this->localStorage->setValue('notifier.name', $user); + $this->localStorage->set('notifier.name', $user); } // Get what was deployed diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index faafb0adf..8442eb4e0 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -23,7 +23,6 @@ use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; use Rocketeer\Services\Storages\LocalStorage; -use Rocketeer\Services\Storages\ServerStorage; use Rocketeer\Services\TasksHandler; use Rocketeer\Services\TasksQueue; @@ -162,10 +161,6 @@ public function bindClasses() return new LocalStorage($app, $filename); }); - $this->app->bind('rocketeer.storage.server', function ($app) { - return new ServerStorage($app); - }); - $this->app->bind('rocketeer.bash', function ($app) { return new Bash($app); }); diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index abf60e5b5..86ebe4329 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -126,7 +126,7 @@ public function needsCredentials() public function getAvailableConnections() { // Fetch stored credentials - $storage = (array) $this->localStorage->getValue('connections'); + $storage = (array) $this->localStorage->get('connections'); // Merge with defaults from config file $configuration = (array) $this->config->get('rocketeer::connections'); @@ -252,7 +252,7 @@ public function syncConnectionCredentials($connection = null, array $credentials { // Store credentials if any if ($credentials) { - $this->localStorage->setValue('connections.'.$connection.'.servers.'.$server, $credentials); + $this->localStorage->set('connections.'.$connection.'.servers.'.$server, $credentials); } // Get connection @@ -324,7 +324,7 @@ public function disconnect() */ public function getCredentials() { - $credentials = $this->localStorage->getValue('credentials'); + $credentials = $this->localStorage->get('credentials'); if (!$credentials) { $credentials = $this->rocketeer->getOption('scm'); } diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index d019fb5a4..a8606292a 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -11,6 +11,7 @@ use Illuminate\Container\Container; use integer; +use Rocketeer\Services\Storages\ServerStorage; use Rocketeer\Traits\HasLocator; /** @@ -36,6 +37,13 @@ class ReleasesManager */ public $releases; + /** + * The storage + * + * @type ServerStorage + */ + protected $storage; + /** * Build a new ReleasesManager * @@ -43,8 +51,9 @@ class ReleasesManager */ public function __construct(Container $app) { - $this->app = $app; - $this->state = $this->getValidationFile(); + $this->app = $app; + $this->storage = new ServerStorage($app, 'state'); + $this->state = $this->getValidationFile(); } //////////////////////////////////////////////////////////////////// @@ -168,7 +177,7 @@ public function getCurrentReleasePath($folder = null) */ public function getValidationFile() { - $file = $this->serverStorage->get('state'); + $file = $this->storage->get(); // Fill the missing releases $releases = (array) $this->getReleases(); @@ -192,7 +201,7 @@ public function getValidationFile() */ public function saveValidationFile(array $validation) { - $this->serverStorage->set('state', $validation); + $this->storage->set($validation); $this->state = $validation; } @@ -207,7 +216,7 @@ public function markReleaseAsValid($release = null) $release = $release ?: $this->getCurrentRelease(); $this->state[$release] = true; - $this->serverStorage->set('state', $release, true); + $this->storage->set($release, true); } /** @@ -266,7 +275,7 @@ protected function getCurrentReleaseKey() public function getCurrentRelease() { // If we have saved the last deployed release, return that - $cached = $this->localStorage->getValue($this->getCurrentReleaseKey()); + $cached = $this->localStorage->get($this->getCurrentReleaseKey()); if ($cached) { return $this->sanitizeRelease($cached); } @@ -316,7 +325,7 @@ public function updateCurrentRelease($release = null) $release = $this->bash->getTimestamp(); } - $this->localStorage->setValue($this->getCurrentReleaseKey(), $release); + $this->localStorage->set($this->getCurrentReleaseKey(), $release); return $release; } diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index fc3220807..702a41de6 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -11,54 +11,56 @@ use Exception; use Illuminate\Container\Container; +use Rocketeer\Abstracts\Storage; +use Rocketeer\Interfaces\StorageInterface; /** * Provides and persists informations in local * * @author Maxime Fabre */ -class LocalStorage +class LocalStorage extends Storage implements StorageInterface { /** - * The IoC Container - * - * @var Container - */ - protected $app; - - /** - * The path to the storage file + * The current hash in use * * @var string */ - protected $repository; + protected $hash; /** - * The current hash in use + * The folder where file resides * - * @var string + * @type string */ - protected $hash; + protected $folder; /** - * Build a new ReleasesManager + * Build a new LocalStorage * * @param Container $app - * @param string $filename - * @param string|null $storage + * @param string $file + * @param string|null $folder */ - public function __construct(Container $app, $filename = 'deployments', $storage = null) + public function __construct(Container $app, $file = 'deployments', $folder = null) { - $this->app = $app; + parent::__construct($app, $file); - // Create repository and update it if necessary - $this->setRepository($filename, $storage); + // Create personal storage if necessary + if (!$this->app->bound('path.storage')) { + $folder = $this->rocketeer->getRocketeerConfigFolder(); + $this->files->makeDirectory($folder, 0755, false, true); + } + + // Set path to storage folder + $this->folder = $folder ?: $this->app['path.storage'].DS.'meta'; + + // Flush if necessary if ($this->shouldFlush()) { - $this->deleteRepository(); + $this->destroy(); } - // Add salt to current repository - $this->setValue('hash', $this->getHash()); + $this->set('hash', $this->getHash()); } //////////////////////////////////////////////////////////////////// @@ -80,7 +82,7 @@ public function getHash() // Get the contents of the configuration folder $salt = ''; $folder = $this->app['rocketeer.igniter']->getConfigurationPath(); - $files = $this->app['files']->glob($folder.'/*.php'); + $files = $this->files->glob($folder.'/*.php'); // Remove custom files and folders $handles = array('events', 'tasks'); @@ -94,7 +96,7 @@ public function getHash() // Compute the salts foreach ($files as $file) { - $file = $this->app['files']->getRequire($file); + $file = $this->files->getRequire($file); $salt .= json_encode($file); } @@ -104,10 +106,6 @@ public function getHash() return $this->hash; } - //////////////////////////////////////////////////////////////////// - ///////////////////////////// REPOSITORY /////////////////////////// - //////////////////////////////////////////////////////////////////// - /** * Flushes the repository if required * @@ -115,31 +113,11 @@ public function getHash() */ public function shouldFlush() { - $currentHash = $this->getValue('hash'); + $currentHash = $this->get('hash'); return $currentHash and $currentHash !== $this->getHash(); } - /** - * Change the repository in use - * - * @param string $filename - * @param string|null $storage - */ - public function setRepository($filename, $storage = null) - { - // Create personal storage if necessary - if (!$this->app->bound('path.storage')) { - $storage = $this->app['rocketeer.rocketeer']->getRocketeerConfigFolder(); - $this->app['files']->makeDirectory($storage, 0755, false, true); - } - - // Get path to storage - $storage = $storage ?: $this->app['path.storage'].DS.'meta'; - - $this->repository = $storage.DS.$filename.'.json'; - } - //////////////////////////////////////////////////////////////////// /////////////////////////// REMOTE VARIABLES /////////////////////// //////////////////////////////////////////////////////////////////// @@ -152,15 +130,13 @@ public function setRepository($filename, $storage = null) public function getSeparator() { // If manually set by the user, return it - $user = $this->app['rocketeer.rocketeer']->getOption('remote.variables.directory_separator'); + $user = $this->rocketeer->getOption('remote.variables.directory_separator'); if ($user) { return $user; } - $bash = $this->app['rocketeer.bash']; - - return $this->getValue('directory_separator', function ($server) use ($bash) { - $separator = $bash->runLast('php -r "echo DIRECTORY_SEPARATOR;"'); + return $this->get('directory_separator', function () { + $separator = $this->bash->runLast('php -r "echo DIRECTORY_SEPARATOR;"'); // Throw an Exception if we receive invalid output if (strlen($separator) > 1) { @@ -171,7 +147,7 @@ public function getSeparator() } // Cache separator - $server->setValue('directory_separator', $separator); + $this->set('directory_separator', $separator); return $separator; }); @@ -185,16 +161,14 @@ public function getSeparator() public function getLineEndings() { // If manually set by the user, return it - $user = $this->app['rocketeer.rocketeer']->getOption('remote.variables.line_endings'); + $user = $this->rocketeer->getOption('remote.variables.line_endings'); if ($user) { return $user; } - $bash = $this->app['rocketeer.bash']; - - return $this->getValue('line_endings', function ($server) use ($bash) { - $endings = $bash->runRaw('php -r "echo PHP_EOL;"'); - $server->setValue('line_endings', $endings); + return $this->get('line_endings', function () { + $endings = $this->bash->runRaw('php -r "echo PHP_EOL;"'); + $this->set('line_endings', $endings); return $endings; }); @@ -209,62 +183,17 @@ public function usesComposer() { $path = $this->app['path.base'].DIRECTORY_SEPARATOR.'composer.json'; - return $this->app['files']->exists($path); + return $this->files->exists($path); } - //////////////////////////////////////////////////////////////////// - /////////////////////////////// KEYSTORE /////////////////////////// - //////////////////////////////////////////////////////////////////// - /** - * Get a value from the repository file - * - * @param string $key - * @param \Closure|string|null $fallback + * Change the folder in use * - * @return mixed + * @param string $folder */ - public function getValue($key, $fallback = null) + public function setFolder($folder) { - $value = array_get($this->getRepository(), $key, null); - - // Get fallback value - if (is_null($value)) { - return is_callable($fallback) ? $fallback($this) : $fallback; - } - - return $value; - } - - /** - * Set a value from the repository file - * - * @param string $key - * @param mixed $value - * - * @return array - */ - public function setValue($key, $value) - { - $repository = $this->getRepository(); - array_set($repository, $key, $value); - - return $this->updateRepository($repository); - } - - /** - * Forget a value from the repository file - * - * @param string $key - * - * @return array - */ - public function forgetValue($key) - { - $repository = $this->getRepository(); - array_forget($repository, $key); - - return $this->updateRepository($repository); + $this->folder = $folder; } //////////////////////////////////////////////////////////////////// @@ -272,46 +201,52 @@ public function forgetValue($key) //////////////////////////////////////////////////////////////////// /** - * Replace the contents of the deployments file + * Get the full path to the file * - * @param array $data - * - * @return array + * @return string */ - public function updateRepository($data) + protected function getFilepath() { - // Yup. Don't look at me like that. - @$this->app['files']->put($this->repository, json_encode($data)); - - return $data; + return $this->folder.'/'.$this->file.'.json'; } /** - * Get the contents of the deployments file + * Get the contents of a file * * @return array */ - public function getRepository() + protected function getContents() { // Cancel if the file doesn't exist - if (!$this->app['files']->exists($this->repository)) { - return array(); + if (!$this->files->exists($this->getFilepath())) { + return []; } // Get and parse file - $repository = $this->app['files']->get($this->repository); - $repository = json_decode($repository, true); + $contents = $this->files->get($this->getFilepath()); + $contents = json_decode($contents, true); + + return $contents; + } - return $repository; + /** + * Save the contents of a file + * + * @param array $contents + */ + protected function saveContents($contents) + { + // Yup. Don't look at me like that. + @$this->files->put($this->getFilepath(), json_encode($contents)); } /** - * Deletes the deployments file + * Destroy the file * * @return boolean */ - public function deleteRepository() + public function destroy() { - return $this->app['files']->delete($this->repository); + return $this->files->delete($this->getFilepath()); } } diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index 336b7f734..09b287b3d 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -9,49 +9,24 @@ */ namespace Rocketeer\Services\Storages; -use Illuminate\Support\Arr; -use Rocketeer\Traits\HasLocator; +use Rocketeer\Abstracts\Storage; +use Rocketeer\Interfaces\StorageInterface; /** * Provides and persists informations on the server * * @author Maxime Fabre */ -class ServerStorage +class ServerStorage extends Storage implements StorageInterface { - use HasLocator; - - /** - * Get a value on the server - * - * @param string $file - * @param string|null $key - * - * @return mixed - */ - public function get($file, $key = null) - { - $contents = $this->getContents($file); - - return Arr::get($contents, $key); - } - /** - * Set a value on the server + * Destroy the file * - * @param string $file - * @param string|array $key - * @param mixed|null $value + * @return boolean */ - public function set($file, $key, $value = null) + public function destroy() { - if (is_null($value)) { - return $this->saveContents($file, $key); - } - - $contents = $this->getContents($file); - $contents = Arr::set($contents, $key, $value); - $this->saveContents($file, $contents); + $this->bash->removeFolder($this->getFilepath()); } ////////////////////////////////////////////////////////////////////// @@ -59,27 +34,23 @@ public function set($file, $key, $value = null) ////////////////////////////////////////////////////////////////////// /** - * Get the full path to a file - * - * @param string $file + * Get the full path to the file * * @return string */ - protected function getFilepath($file) + protected function getFilepath() { - return $this->rocketeer->getFolder($file.'.json'); + return $this->rocketeer->getFolder($this->file.'.json'); } /** - * Get the contents of a file - * - * @param string $file + * Get the contents of the file * * @return array */ - protected function getContents($file) + protected function getContents() { - $file = $this->getFilepath($file); + $file = $this->getFilepath(); $file = $this->bash->getFile($file) ?: '{}'; $file = (array) json_decode($file, true); @@ -87,14 +58,13 @@ protected function getContents($file) } /** - * Save the contents of a file + * Save the contents of the file * - * @param string $file - * @param array $contents + * @param array $contents */ - protected function saveContents($file, $contents) + protected function saveContents($contents) { - $file = $this->getFilepath($file); + $file = $this->getFilepath(); $this->bash->putFile($file, json_encode($contents)); } } diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php index 8d598b9f9..2e9220e87 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -26,7 +26,7 @@ public function deploy($destination = null) // Cancel if failed and forget credentials $success = $this->bash->checkStatus('Unable to clone the repository', $output) !== false; if (!$success) { - $this->localStorage->forgetValue('credentials'); + $this->localStorage->forget('credentials'); return false; } diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index bda3ca6cf..ffbd068a9 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -49,7 +49,7 @@ public function execute() $this->createStages(); // Set setup to true - $this->localStorage->setValue('is_setup', true); + $this->localStorage->set('is_setup', true); // Get server informations $this->command->comment('Getting some informations about the server'); diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 261c9a7ce..602d5dafb 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -49,7 +49,7 @@ public function execute() $this->removeFolder(); // Remove deployments file - $this->localStorage->deleteRepository(); + $this->localStorage->destroy(); $this->command->info('The application was successfully removed from the remote servers'); } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index ee0538622..a961714df 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -211,7 +211,7 @@ public function which($binary, $fallback = null) { $location = false; $locations = array( - array($this->localStorage, 'getValue', 'paths.'.$binary), + array($this->localStorage, 'get', 'paths.'.$binary), array($this->rocketeer, 'getPath', $binary), array($this, 'runSilently', 'which '.$binary), ); @@ -237,7 +237,7 @@ public function which($binary, $fallback = null) } // Store found location - $this->localStorage->setValue('paths.'.$binary, $location); + $this->localStorage->set('paths.'.$binary, $location); return $location ?: false; } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index e6a28045a..482a76caf 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -27,7 +27,6 @@ * @property \Rocketeer\Services\History\History history * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\Storages\ServerStorage serverStorage * @property \Rocketeer\Services\TasksHandler tasks * @property \Rocketeer\Services\TasksQueue queue * @author Maxime Fabre @@ -72,7 +71,6 @@ public function __get($key) 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', 'localStorage' => 'rocketeer.storage.local', - 'serverStorage' => 'rocketeer.storage.server', 'strategy' => 'rocketeer.strategy', 'tasks' => 'rocketeer.tasks', ); diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index bb61771a6..290003850 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -88,7 +88,7 @@ public function testCanReplaceStubsInConfigurationFile() public function testCanSetCurrentApplication() { $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { - return $mock->shouldReceive('setRepository')->once()->with('foobar'); + return $mock->shouldReceive('setFile')->once()->with('foobar'); }); $this->igniter->bindPaths(); diff --git a/tests/Plugins/NotifierTest.php b/tests/Plugins/NotifierTest.php index fe83905c5..bc6538521 100644 --- a/tests/Plugins/NotifierTest.php +++ b/tests/Plugins/NotifierTest.php @@ -28,7 +28,7 @@ public function setUp() public function testCanAppendStageToDetails() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "staging@production" (foo.bar.com)'); - $this->app['rocketeer.storage.local']->setValue('notifier.name', 'Jean Eude'); + $this->localStorage->set('notifier.name', 'Jean Eude'); $this->connections->setStage('staging'); $this->notifier = new DummyNotifier($this->app); $this->tasks->plugin($this->notifier); @@ -39,7 +39,7 @@ public function testCanAppendStageToDetails() public function testCanSendDeploymentsNotifications() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "production" (foo.bar.com)'); - $this->app['rocketeer.storage.local']->setValue('notifier.name', 'Jean Eude'); + $this->localStorage->set('notifier.name', 'Jean Eude'); $this->task('Deploy')->fireEvent('after'); } @@ -47,7 +47,7 @@ public function testCanSendDeploymentsNotifications() public function testDoesntSendNotificationsInPretendMode() { $this->expectOutputString(''); - $this->app['rocketeer.storage.local']->setValue('notifier.name', 'Jean Eude'); + $this->localStorage->set('notifier.name', 'Jean Eude'); $this->pretendTask('Deploy')->fireEvent('after'); } diff --git a/tests/Services/ConnectionsHandlerTest.php b/tests/Services/ConnectionsHandlerTest.php index ddf8fae70..0b1ef8fe5 100644 --- a/tests/Services/ConnectionsHandlerTest.php +++ b/tests/Services/ConnectionsHandlerTest.php @@ -1,6 +1,8 @@ connections->getAvailableConnections(); $this->assertEquals(array('production', 'staging'), array_keys($connections)); - $this->app['rocketeer.storage.local']->setValue('connections.custom.username', 'foobar'); + $this->app['rocketeer.storage.local']->set('connections.custom.username', 'foobar'); $connections = $this->connections->getAvailableConnections(); $this->assertEquals(array('production', 'staging', 'custom'), array_keys($connections)); } @@ -99,7 +101,7 @@ public function testFillsConnectionCredentialsHoles() $connections = $this->connections->getAvailableConnections(); $this->assertArrayHasKey('production', $connections); - $this->app['rocketeer.storage.local']->setValue('connections', array( + $this->app['rocketeer.storage.local']->set('connections', array( 'staging' => array( 'host' => 'foobar', 'username' => 'user', diff --git a/tests/Services/ReleasesManagerTest.php b/tests/Services/ReleasesManagerTest.php index 1536b563a..991ce9137 100644 --- a/tests/Services/ReleasesManagerTest.php +++ b/tests/Services/ReleasesManagerTest.php @@ -59,8 +59,8 @@ public function testCanGetCurrentReleaseFromServerIfUncached() { $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock - ->shouldReceive('getValue')->with('current_release.production')->once()->andReturn(null) - ->shouldReceive('setValue')->with('current_release.production', '20000000000000')->once() + ->shouldReceive('get')->with('current_release.production')->once()->andReturn(null) + ->shouldReceive('set')->with('current_release.production', '20000000000000')->once() ->shouldReceive('getSeparator')->andReturn('/') ->shouldReceive('getLineEndings')->andReturn(PHP_EOL); }); @@ -145,7 +145,7 @@ public function testCanUpdateCurrentRelease() { $this->releasesManager->updateCurrentRelease(30000000000000); - $this->assertEquals(30000000000000, $this->app['rocketeer.storage.local']->getValue('current_release.production')); + $this->assertEquals(30000000000000, $this->app['rocketeer.storage.local']->get('current_release.production')); } public function testCanGetFolderInRelease() diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 26eb5aad5..266fe922f 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -24,40 +24,40 @@ public function testCanCreateDeploymentsFileAnywhere() public function testCanGetValueFromDeploymentsFile() { - $this->assertEquals('bar', $this->app['rocketeer.storage.local']->getValue('foo')); + $this->assertEquals('bar', $this->app['rocketeer.storage.local']->get('foo')); } - public function testCanSetValueInDeploymentsFile() + public function testCansetInDeploymentsFile() { - $this->app['rocketeer.storage.local']->setValue('foo', 'baz'); + $this->app['rocketeer.storage.local']->set('foo', 'baz'); - $this->assertEquals('baz', $this->app['rocketeer.storage.local']->getValue('foo')); + $this->assertEquals('baz', $this->app['rocketeer.storage.local']->get('foo')); } - public function testCandeleteRepository() + public function testCandestroy() { - $this->app['rocketeer.storage.local']->deleteRepository(); + $this->app['rocketeer.storage.local']->destroy(); $this->assertFalse($this->app['files']->exists(__DIR__.'/_meta/deployments.json')); } public function testCanFallbackIfFileDoesntExist() { - $this->app['rocketeer.storage.local']->deleteRepository(); + $this->app['rocketeer.storage.local']->destroy(); - $this->assertEquals(null, $this->app['rocketeer.storage.local']->getValue('foo')); + $this->assertEquals(null, $this->app['rocketeer.storage.local']->get('foo')); } public function testCanGetLineEndings() { - $this->app['rocketeer.storage.local']->deleteRepository(); + $this->app['rocketeer.storage.local']->destroy(); $this->assertEquals(PHP_EOL, $this->app['rocketeer.storage.local']->getLineEndings()); } public function testCanGetSeparators() { - $this->app['rocketeer.storage.local']->deleteRepository(); + $this->app['rocketeer.storage.local']->destroy(); $this->assertEquals(DIRECTORY_SEPARATOR, $this->app['rocketeer.storage.local']->getSeparator()); } diff --git a/tests/Tasks/TeardownTest.php b/tests/Tasks/TeardownTest.php index 0c19cd194..81ca215df 100644 --- a/tests/Tasks/TeardownTest.php +++ b/tests/Tasks/TeardownTest.php @@ -10,7 +10,7 @@ public function testCanTeardownServer() $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getSeparator')->andReturn(DIRECTORY_SEPARATOR) - ->shouldReceive('deleteRepository')->once(); + ->shouldReceive('destroy')->once(); }); $this->assertTaskHistory('Teardown', array( @@ -23,7 +23,7 @@ public function testCanAbortTeardown() $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock ->shouldReceive('getSeparator')->andReturn(DIRECTORY_SEPARATOR) - ->shouldReceive('deleteRepository')->never(); + ->shouldReceive('destroy')->never(); }); $task = $this->pretendTask('Teardown', array(), array('confirm' => false)); diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index c20c61d9f..3a61b5924 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -7,7 +7,7 @@ class ScmTest extends RocketeerTestCase { public function testCanForgetCredentialsIfInvalid() { - $this->app['rocketeer.storage.local']->setValue('credentials', array( + $this->app['rocketeer.storage.local']->set('credentials', array( 'repository' => 'https://Anahkiasen@bitbucket.org/Anahkiasen/registry.git', 'username' => 'Anahkiasen', 'password' => 'baz', @@ -21,6 +21,6 @@ public function testCanForgetCredentialsIfInvalid() $task->remote = $remote; $task->strategy->deploy($this->server.'/test'); - $this->assertNull($this->app['rocketeer.storage.local']->getValue('credentials')); + $this->assertNull($this->app['rocketeer.storage.local']->get('credentials')); } } From cad87db0f05ee1f6e56def09e182c60250066607 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 09:51:12 +0200 Subject: [PATCH 087/424] Update HasLocator.php --- src/Rocketeer/Traits/HasLocator.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 482a76caf..05d2802ab 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -12,7 +12,7 @@ use Illuminate\Container\Container; /** - * An abstract for Service Locator-based classes with adds + * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes * * @property \Illuminate\Config\Repository config From ddf46f09b9e10e71f9739e388f0eaf129143a699 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 21:19:04 +0200 Subject: [PATCH 088/424] Add log property --- src/Rocketeer/Services/History/LogsHandler.php | 6 +++--- src/Rocketeer/Traits/HasLocator.php | 1 + 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Services/History/LogsHandler.php b/src/Rocketeer/Services/History/LogsHandler.php index abd7e795b..fbf6caec4 100644 --- a/src/Rocketeer/Services/History/LogsHandler.php +++ b/src/Rocketeer/Services/History/LogsHandler.php @@ -82,7 +82,7 @@ protected function getLogger($file) $this->createLogsFile($file); // Store specific logger instance - $logger = clone $this->app['log']; + $logger = clone $this->log; $logger->useFiles($file); $this->loggers[$file] = $logger; } @@ -101,12 +101,12 @@ protected function createLogsFile($file) // Create directory if (!is_dir($directory)) { - $this->app['files']->makeDirectory($directory, 0777, true); + $this->files->makeDirectory($directory, 0777, true); } // Create file if (!file_exists($file)) { - $this->app['files']->put($file, ''); + $this->files->put($file, ''); } } } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 05d2802ab..47506d2b2 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -29,6 +29,7 @@ * @property \Rocketeer\Services\Storages\LocalStorage localStorage * @property \Rocketeer\Services\TasksHandler tasks * @property \Rocketeer\Services\TasksQueue queue + * @property \Illuminate\Log\Writer log * @author Maxime Fabre */ trait HasLocator From ac817ddeec7c4ddd73e3adc1d62cdadb1ef01b6e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 21:23:06 +0200 Subject: [PATCH 089/424] Update dependencies --- composer.lock | 142 +++++--------------------------------------------- 1 file changed, 14 insertions(+), 128 deletions(-) diff --git a/composer.lock b/composer.lock index d5043b29e..21f8f40cc 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "58b19259896590daf4a76f42413947d8", + "hash": "c3144b2ca3ff23f1c805405f66e1e1c2", "packages": [ { "name": "illuminate/config", @@ -874,119 +874,6 @@ ], "time": "2014-07-18 03:44:47" }, - { - "name": "ocramius/instantiator", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/Ocramius/Instantiator.git", - "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/Ocramius/Instantiator/zipball/cc754c2289ffd4483c319f6ed6ee88ce21676f64", - "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64", - "shasum": "" - }, - "require": { - "ocramius/lazy-map": "1.0.*", - "php": "~5.3" - }, - "require-dev": { - "athletic/athletic": "~0.1.8", - "ext-phar": "*", - "phpunit/phpunit": "~4.0", - "squizlabs/php_codesniffer": "2.0.*@ALPHA" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0.x-dev" - } - }, - "autoload": { - "psr-0": { - "Instantiator\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Marco Pivetta", - "email": "ocramius@gmail.com", - "homepage": "http://ocramius.github.com/", - "role": "Developer" - } - ], - "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors", - "homepage": "https://github.com/Ocramius/Instantiator", - "keywords": [ - "constructor", - "instantiate" - ], - "time": "2014-06-15 11:44:46" - }, - { - "name": "ocramius/lazy-map", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/Ocramius/LazyMap.git", - "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/Ocramius/LazyMap/zipball/7fe3d347f5e618bcea7d39345ff83f3651d8b752", - "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "athletic/athletic": "~0.1.6", - "phpmd/phpmd": "1.5.*", - "phpunit/phpunit": ">=3.7", - "satooshi/php-coveralls": "~0.6", - "squizlabs/php_codesniffer": "1.4.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "autoload": { - "psr-0": { - "LazyMap\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Marco Pivetta", - "email": "ocramius@gmail.com", - "homepage": "http://ocramius.github.com/", - "role": "Developer" - } - ], - "description": "A library that provides lazy instantiation logic for a map of objects", - "homepage": "https://github.com/Ocramius/LazyMap", - "keywords": [ - "lazy", - "lazy instantiation", - "lazy loading", - "map", - "service location" - ], - "time": "2013-11-09 22:30:54" - }, { "name": "patchwork/utf8", "version": "v1.1.25", @@ -1396,16 +1283,16 @@ }, { "name": "phpunit/phpunit", - "version": "4.1.4", + "version": "4.1.5", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "a71c4842c5fb836d8b200624583b859ec34e8a26" + "reference": "e0de628ff849e1804c7d644cbaa16d0a5504807a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/a71c4842c5fb836d8b200624583b859ec34e8a26", - "reference": "a71c4842c5fb836d8b200624583b859ec34e8a26", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/e0de628ff849e1804c7d644cbaa16d0a5504807a", + "reference": "e0de628ff849e1804c7d644cbaa16d0a5504807a", "shasum": "" }, "require": { @@ -1419,7 +1306,7 @@ "phpunit/php-file-iterator": "~1.3.1", "phpunit/php-text-template": "~1.2", "phpunit/php-timer": "~1.0.2", - "phpunit/phpunit-mock-objects": "~2.1", + "phpunit/phpunit-mock-objects": "2.1.5", "sebastian/comparator": "~1.0", "sebastian/diff": "~1.1", "sebastian/environment": "~1.0", @@ -1466,29 +1353,28 @@ "testing", "xunit" ], - "time": "2014-07-18 07:15:58" + "time": "2014-08-07 05:43:51" }, { "name": "phpunit/phpunit-mock-objects", - "version": "2.2.0", + "version": "2.1.5", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", - "reference": "42e589e08bc86e3e9bdf20d385e948347788505b" + "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/42e589e08bc86e3e9bdf20d385e948347788505b", - "reference": "42e589e08bc86e3e9bdf20d385e948347788505b", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/7878b9c41edb3afab92b85edf5f0981014a2713a", + "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a", "shasum": "" }, "require": { - "ocramius/instantiator": "~1.0", "php": ">=5.3.3", "phpunit/php-text-template": "~1.2" }, "require-dev": { - "phpunit/phpunit": "4.2.*@dev" + "phpunit/phpunit": "~4.1" }, "suggest": { "ext-soap": "*" @@ -1496,7 +1382,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-master": "2.2.x-dev" + "dev-master": "2.1.x-dev" } }, "autoload": { @@ -1524,7 +1410,7 @@ "mock", "xunit" ], - "time": "2014-08-02 13:50:58" + "time": "2014-06-12 07:22:15" }, { "name": "raveren/kint", From d0e19fdc27d79fa0dbb77e032231dedd0782dfe8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 22:40:37 +0200 Subject: [PATCH 090/424] Fix setting of contents --- src/Rocketeer/Abstracts/Storage.php | 10 +++-- .../Services/Storages/LocalStorage.php | 10 ++++- .../Services/Storages/ServerStorage.php | 2 +- tests/Services/Storages/LocalStorageTest.php | 40 ++++++++++++------- tests/TestCases/RocketeerTestCase.php | 7 ++-- 5 files changed, 46 insertions(+), 23 deletions(-) diff --git a/src/Rocketeer/Abstracts/Storage.php b/src/Rocketeer/Abstracts/Storage.php index cf4fcd7ed..01e2c70f8 100644 --- a/src/Rocketeer/Abstracts/Storage.php +++ b/src/Rocketeer/Abstracts/Storage.php @@ -55,7 +55,7 @@ public function get($key = null, $fallback = null) { $contents = $this->getContents(); - return Arr::get($contents, $key, $fallback); + return Arr::get($contents, $key, $fallback); } /** @@ -68,7 +68,11 @@ public function set($key, $value = null) { // Set the value on the contents $contents = $this->getContents(); - Arr::set($contents, $key, $value); + if (is_null($value)) { + $contents = $key; + } else { + Arr::set($contents, $key, $value); + } $this->saveContents($contents); } @@ -97,7 +101,7 @@ public function forget($key) * * @return string */ - abstract protected function getFilepath(); + abstract public function getFilepath(); /** * Get the contents of the file diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index 702a41de6..f238b00be 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -196,6 +196,14 @@ public function setFolder($folder) $this->folder = $folder; } + /** + * @return string + */ + public function getFolder() + { + return $this->folder; + } + //////////////////////////////////////////////////////////////////// ////////////////////////// REPOSITORY FILE ///////////////////////// //////////////////////////////////////////////////////////////////// @@ -205,7 +213,7 @@ public function setFolder($folder) * * @return string */ - protected function getFilepath() + public function getFilepath() { return $this->folder.'/'.$this->file.'.json'; } diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index 09b287b3d..a458a2445 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -38,7 +38,7 @@ public function destroy() * * @return string */ - protected function getFilepath() + public function getFilepath() { return $this->rocketeer->getFolder($this->file.'.json'); } diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 266fe922f..54211c218 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -18,48 +18,58 @@ public function testCanCreateDeploymentsFileAnywhere() $storage = $this->rocketeer->getRocketeerConfigFolder(); $exists = file_exists($storage); - $this->app['files']->deleteDirectory($storage); + $this->files->deleteDirectory($storage); $this->assertTrue($exists); } + public function testCanSetContentsViaSet() + { + $matcher = ['foo' => 'caca']; + $this->localStorage->set($matcher); + $contents = $this->localStorage->get(); + unset($contents['hash']); + + $this->assertEquals($matcher, $contents); + } + public function testCanGetValueFromDeploymentsFile() { - $this->assertEquals('bar', $this->app['rocketeer.storage.local']->get('foo')); + $this->assertEquals('bar', $this->localStorage->get('foo')); } public function testCansetInDeploymentsFile() { - $this->app['rocketeer.storage.local']->set('foo', 'baz'); + $this->localStorage->set('foo', 'baz'); - $this->assertEquals('baz', $this->app['rocketeer.storage.local']->get('foo')); + $this->assertEquals('baz', $this->localStorage->get('foo')); } public function testCandestroy() { - $this->app['rocketeer.storage.local']->destroy(); + $this->localStorage->destroy(); - $this->assertFalse($this->app['files']->exists(__DIR__.'/_meta/deployments.json')); + $this->assertFalse($this->files->exists(__DIR__.'/_meta/deployments.json')); } public function testCanFallbackIfFileDoesntExist() { - $this->app['rocketeer.storage.local']->destroy(); + $this->localStorage->destroy(); - $this->assertEquals(null, $this->app['rocketeer.storage.local']->get('foo')); + $this->assertEquals(null, $this->localStorage->get('foo')); } public function testCanGetLineEndings() { - $this->app['rocketeer.storage.local']->destroy(); + $this->localStorage->destroy(); - $this->assertEquals(PHP_EOL, $this->app['rocketeer.storage.local']->getLineEndings()); + $this->assertEquals(PHP_EOL, $this->localStorage->getLineEndings()); } public function testCanGetSeparators() { - $this->app['rocketeer.storage.local']->destroy(); + $this->localStorage->destroy(); - $this->assertEquals(DIRECTORY_SEPARATOR, $this->app['rocketeer.storage.local']->getSeparator()); + $this->assertEquals(DIRECTORY_SEPARATOR, $this->localStorage->getSeparator()); } public function testCanComputeHashAccordingToContentsOfFiles() @@ -73,7 +83,7 @@ public function testCanComputeHashAccordingToContentsOfFiles() ->shouldReceive('getRequire')->once()->with('bar')->andReturn(array('bar')); }); - $hash = $this->app['rocketeer.storage.local']->getHash(); + $hash = $this->localStorage->getHash(); $this->assertEquals(md5('["foo"]["bar"]'), $hash); } @@ -81,9 +91,9 @@ public function testCanComputeHashAccordingToContentsOfFiles() public function testCanCheckIfComposerIsNeeded() { $this->usesComposer(true); - $this->assertTrue($this->app['rocketeer.storage.local']->usesComposer()); + $this->assertTrue($this->localStorage->usesComposer()); $this->usesComposer(false); - $this->assertFalse($this->app['rocketeer.storage.local']->usesComposer()); + $this->assertFalse($this->localStorage->usesComposer()); } } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 5a3031108..888246fbf 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -42,9 +42,10 @@ public function setUp() $this->deploymentsFile = __DIR__.'/../_meta/deployments.json'; // Bind new LocalStorage instance - $meta = dirname($this->deploymentsFile); - $this->app->bind('rocketeer.storage.local', function ($app) use ($meta) { - return new LocalStorage($app, 'deployments', $meta); + $this->app->bind('rocketeer.storage.local', function ($app) { + $folder = dirname($this->deploymentsFile); + + return new LocalStorage($app, 'deployments', $folder); }); // Bind dummy Task From d1e7f65722cde58213ab0901b18edc6d0c82360e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 22:42:20 +0200 Subject: [PATCH 091/424] Move some tests to StorageTest --- tests/Abstracts/StorageTest.php | 44 ++++++++++++++++++++ tests/Services/Storages/LocalStorageTest.php | 36 ---------------- 2 files changed, 44 insertions(+), 36 deletions(-) create mode 100644 tests/Abstracts/StorageTest.php diff --git a/tests/Abstracts/StorageTest.php b/tests/Abstracts/StorageTest.php new file mode 100644 index 000000000..9ac8e077c --- /dev/null +++ b/tests/Abstracts/StorageTest.php @@ -0,0 +1,44 @@ + 'caca']; + $this->localStorage->set($matcher); + $contents = $this->localStorage->get(); + unset($contents['hash']); + + $this->assertEquals($matcher, $contents); + } + + public function testCanGetValue() + { + $this->assertEquals('bar', $this->localStorage->get('foo')); + } + + public function testCanSetValue() + { + $this->localStorage->set('foo', 'baz'); + + $this->assertEquals('baz', $this->localStorage->get('foo')); + } + + public function testCanDestroy() + { + $this->localStorage->destroy(); + + $this->assertFalse($this->files->exists(__DIR__.'/_meta/deployments.json')); + } + + public function testCanFallbackIfFileDoesntExist() + { + $this->localStorage->destroy(); + + $this->assertEquals(null, $this->localStorage->get('foo')); + } +} diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 54211c218..0a85a71c4 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -22,42 +22,6 @@ public function testCanCreateDeploymentsFileAnywhere() $this->assertTrue($exists); } - public function testCanSetContentsViaSet() - { - $matcher = ['foo' => 'caca']; - $this->localStorage->set($matcher); - $contents = $this->localStorage->get(); - unset($contents['hash']); - - $this->assertEquals($matcher, $contents); - } - - public function testCanGetValueFromDeploymentsFile() - { - $this->assertEquals('bar', $this->localStorage->get('foo')); - } - - public function testCansetInDeploymentsFile() - { - $this->localStorage->set('foo', 'baz'); - - $this->assertEquals('baz', $this->localStorage->get('foo')); - } - - public function testCandestroy() - { - $this->localStorage->destroy(); - - $this->assertFalse($this->files->exists(__DIR__.'/_meta/deployments.json')); - } - - public function testCanFallbackIfFileDoesntExist() - { - $this->localStorage->destroy(); - - $this->assertEquals(null, $this->localStorage->get('foo')); - } - public function testCanGetLineEndings() { $this->localStorage->destroy(); From 63887a1754212a73771295b5f8b6afc8b21476e6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 23:04:27 +0200 Subject: [PATCH 092/424] Docblock fixes --- src/Rocketeer/Abstracts/Storage.php | 2 ++ src/Rocketeer/Abstracts/Task.php | 7 ---- src/Rocketeer/Interfaces/StorageInterface.php | 4 +++ src/Rocketeer/Services/ConnectionsHandler.php | 7 ++-- src/Rocketeer/Services/ReleasesManager.php | 27 ++++++++++++---- src/Rocketeer/Services/TasksHandler.php | 16 +++++----- src/Rocketeer/Services/TasksQueue.php | 6 ++-- src/Rocketeer/Tasks/Check.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 8 +---- src/Rocketeer/Traits/BashModules/Core.php | 2 +- src/Rocketeer/Traits/BashModules/Flow.php | 9 +++++- src/Rocketeer/Traits/HasLocator.php | 32 ++++++++++--------- 12 files changed, 69 insertions(+), 53 deletions(-) diff --git a/src/Rocketeer/Abstracts/Storage.php b/src/Rocketeer/Abstracts/Storage.php index 01e2c70f8..f50c6b502 100644 --- a/src/Rocketeer/Abstracts/Storage.php +++ b/src/Rocketeer/Abstracts/Storage.php @@ -114,6 +114,8 @@ abstract protected function getContents(); * Save the contents of the file * * @param array $contents + * + * @return void */ abstract protected function saveContents($contents); } diff --git a/src/Rocketeer/Abstracts/Task.php b/src/Rocketeer/Abstracts/Task.php index efc664ab5..5bd250711 100644 --- a/src/Rocketeer/Abstracts/Task.php +++ b/src/Rocketeer/Abstracts/Task.php @@ -40,13 +40,6 @@ abstract class Task extends Bash */ protected $halted = false; - /** - * Whether the Task needs to be run on each stage or globally - * - * @var boolean - */ - public $usesStages = true; - //////////////////////////////////////////////////////////////////// ////////////////////////////// REFLECTION ////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Interfaces/StorageInterface.php b/src/Rocketeer/Interfaces/StorageInterface.php index 665c333d9..db0eba9ae 100644 --- a/src/Rocketeer/Interfaces/StorageInterface.php +++ b/src/Rocketeer/Interfaces/StorageInterface.php @@ -18,6 +18,8 @@ public function get($key = null, $fallback = null); * * @param string|array $key * @param mixed|null $value + * + * @return void */ public function set($key, $value = null); @@ -25,6 +27,8 @@ public function set($key, $value = null); * Forget a value * * @param string $key + * + * @return void */ public function forget($key); diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index 86ebe4329..4a4304ccf 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Services; +use Illuminate\Support\Arr; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; use string; @@ -70,9 +71,7 @@ public function getServer() /** * Set the stage Tasks will execute on * - * @param string $stage - * - * @return void + * @param string|null $stage */ public function setStage($stage) { @@ -375,7 +374,7 @@ public function getRepository() public function getRepositoryBranch() { exec($this->scm->currentBranch(), $fallback); - $fallback = array_get($fallback, 0, 'master'); + $fallback = Arr::get($fallback, 0, 'master'); $fallback = trim($fallback); $branch = $this->rocketeer->getOption('scm.branch') ?: $fallback; diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index a8606292a..6a6807777 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -74,7 +74,7 @@ public function getReleases() // Filter and sort releases $releases = array_filter($releases, function ($release) { - return preg_match('#[0-9]{14}#', $release); + return $this->isRelease($release); }); rsort($releases); @@ -209,14 +209,17 @@ public function saveValidationFile(array $validation) /** * Mark a release as valid * - * @param integer|null $release + * @param integer|string|null $release */ public function markReleaseAsValid($release = null) { $release = $release ?: $this->getCurrentRelease(); - $this->state[$release] = true; - $this->storage->set($release, true); + // If the release is not null, mark it as valid + if ($release) { + $this->state[$release] = true; + $this->storage->set($release, true); + } } /** @@ -238,13 +241,25 @@ public function checkReleaseState($release) /** * Sanitize a possible release * - * @param string $release + * @param string|integer $release * * @return string|null */ protected function sanitizeRelease($release) { - return strlen($release) === 14 ? $release : null; + return $this->isRelease($release) ? $release : null; + } + + /** + * Check if it quacks like a duck + * + * @param string|integer $release + * + * @return bool + */ + protected function isRelease($release) + { + return (bool) preg_match('#[0-9]{14}#', $release); } /** diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 113bcb6c5..2d0e34804 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -73,7 +73,7 @@ public function __call($method, $parameters) public function add($task, $name = null) { // Build Task if necessary - $task = $this->buildTask($task, $name); + $task = $this->queue->buildTask($task, $name); $slug = 'rocketeer.tasks.'.$task->getSlug(); // Add the task to Rocketeer @@ -169,7 +169,7 @@ public function registerConfiguredEvents() public function listenTo($event, $listeners, $priority = 0) { // Create array if it doesn't exist - $listeners = $this->buildQueue((array) $listeners); + $listeners = $this->queue->buildQueue((array) $listeners); // Register events foreach ($listeners as $listener) { @@ -182,10 +182,10 @@ public function listenTo($event, $listeners, $priority = 0) /** * Bind a listener to a task * - * @param string $task - * @param string $event - * @param mixed $listeners - * @param integer $priority + * @param string $task + * @param string $event + * @param array|callable $listeners + * @param integer $priority * * @return string */ @@ -201,7 +201,7 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) } // Get event name and register listeners - $event = $this->buildTaskFromClass($task)->getSlug().'.'.$event; + $event = $this->queue->buildTaskFromClass($task)->getSlug().'.'.$event; $event = $this->listenTo($event, $listeners, $priority); return $event; @@ -219,7 +219,7 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) public function getTasksListeners($task, $event, $flatten = false) { // Get events - $task = $this->buildTaskFromClass($task)->getSlug(); + $task = $this->queue->buildTaskFromClass($task)->getSlug(); $events = $this->events->getListeners('rocketeer.'.$task.'.'.$event); // Flatten the queue if requested diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index b0751844f..537b1abca 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -75,7 +75,7 @@ public function execute($queue, $connections = null) /** * Execute Tasks on various connections * - * @param string|array $connections + * @param string|string[] $connections * @param string|array|Closure $queue * * @return array @@ -297,9 +297,9 @@ public function buildTaskFromClosure($task) /** * Build a Task from its name * - * @param string $task + * @param string|Task $task * - * @return \Rocketeer\Abstracts\Task + * @return Task */ public function buildTaskFromClass($task) { diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 755408294..494f9d482 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -146,7 +146,7 @@ public function checkPhpVersion() $composer = json_decode($composer, true); // Strip versions of constraints - $required = array_get($composer, 'require.php'); + $required = (string) array_get($composer, 'require.php'); $required = preg_replace('/>=/', '', $required); } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 76ba283e5..938bdaf64 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -83,8 +83,6 @@ public function execute() /** * Run PHPUnit tests - * - * @return void */ protected function checkTestsResults() { @@ -99,12 +97,10 @@ protected function checkTestsResults() /** * Run migrations and seed database - * - * @return void */ protected function runMigrationsAndSeed() { - $seed = $this->getOption('seed'); + $seed = (bool) $this->getOption('seed'); if ($this->getOption('migrate')) { return $this->runMigrations($seed); @@ -119,8 +115,6 @@ protected function runMigrationsAndSeed() /** * Create the events Deploy will run - * - * @return void */ protected function createEvents() { diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index b4b437b9d..26e269006 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -96,7 +96,7 @@ public function runLast($commands) * @param boolean $array Whether the output should be returned as an array * @param boolean $trim Whether the output should be trimmed * - * @return string + * @return string|string[] */ public function runRaw($commands, $array = false, $trim = false) { diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index ca950e986..28dbdd06e 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -16,6 +16,13 @@ */ trait Flow { + /** + * Whether the Task needs to be run on each stage or globally + * + * @var boolean + */ + public $usesStages = true; + /** * Check if the remote server is setup * @@ -70,7 +77,7 @@ protected function syncSharedFolders() /** * Update the current symlink * - * @param integer $release A release to mark as current + * @param integer|null $release A release to mark as current * * @return string */ diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 47506d2b2..6de65494e 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,21 +15,23 @@ * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Config\Repository config - * @property \Illuminate\Console\Command command - * @property \Illuminate\Filesystem\Filesystem files - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Bash bash - * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\StrategyInterface strategy - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Services\History\History history - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\TasksHandler tasks - * @property \Rocketeer\Services\TasksQueue queue - * @property \Illuminate\Log\Writer log + * @property \Illuminate\Config\Repository config + * @property \Rocketeer\Console\Commands\AbstractDeployCommand command + * @property \Illuminate\Events\Dispatcher events + * @property \Illuminate\Filesystem\Filesystem files + * @property \Illuminate\Log\Writer log + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Bash bash + * @property \Rocketeer\Console\Console console + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage localStorage + * @property \Rocketeer\Services\TasksHandler tasks + * @property \Rocketeer\Services\TasksQueue queue * @author Maxime Fabre */ trait HasLocator From f488e8a422a4b94dcbc56548c390f02ba37cf832 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 7 Aug 2014 23:22:26 +0200 Subject: [PATCH 093/424] Make Abstract classes match Abstract[Name] --- CHANGELOG.md | 2 +- .../{Plugin.php => AbstractPlugin.php} | 2 +- .../Abstracts/{Scm.php => AbstractScm.php} | 2 +- .../{Storage.php => AbstractStorage.php} | 2 +- .../{Strategy.php => AbstractStrategy.php} | 2 +- .../Abstracts/{Task.php => AbstractTask.php} | 24 +++++----- .../Commands/AbstractDeployCommand.php | 2 +- .../Console/Commands/BaseTaskCommand.php | 21 +++++---- src/Rocketeer/Plugins/Notifier.php | 14 +++--- src/Rocketeer/Scm/Git.php | 4 +- src/Rocketeer/Scm/Svn.php | 4 +- .../Services/Storages/LocalStorage.php | 4 +- .../Services/Storages/ServerStorage.php | 4 +- src/Rocketeer/Services/TasksHandler.php | 14 +++--- src/Rocketeer/Services/TasksQueue.php | 44 ++++++++++++------- src/Rocketeer/Strategies/CloneStrategy.php | 4 +- src/Rocketeer/Tasks/Check.php | 10 ++--- src/Rocketeer/Tasks/Cleanup.php | 8 ++-- src/Rocketeer/Tasks/Closure.php | 12 ++--- src/Rocketeer/Tasks/CurrentRelease.php | 8 ++-- src/Rocketeer/Tasks/Deploy.php | 6 +-- src/Rocketeer/Tasks/Ignite.php | 6 +-- src/Rocketeer/Tasks/Rollback.php | 6 +-- src/Rocketeer/Tasks/Setup.php | 10 ++--- src/Rocketeer/Tasks/Teardown.php | 10 ++--- src/Rocketeer/Tasks/Test.php | 8 ++-- src/Rocketeer/Tasks/Update.php | 4 +- src/Rocketeer/Traits/BashModules/Flow.php | 4 +- src/Rocketeer/Traits/HasLocator.php | 2 +- src/config/hooks.php | 2 +- tests/Dummies/MyCustomTask.php | 4 +- tests/Services/TasksQueueTest.php | 2 +- tests/TestCases/RocketeerTestCase.php | 23 ++++++---- tests/_meta/coverage.txt | 10 ++--- 34 files changed, 152 insertions(+), 132 deletions(-) rename src/Rocketeer/Abstracts/{Plugin.php => AbstractPlugin.php} (97%) rename src/Rocketeer/Abstracts/{Scm.php => AbstractScm.php} (98%) rename src/Rocketeer/Abstracts/{Storage.php => AbstractStorage.php} (98%) rename src/Rocketeer/Abstracts/{Strategy.php => AbstractStrategy.php} (84%) rename src/Rocketeer/Abstracts/{Task.php => AbstractTask.php} (89%) diff --git a/CHANGELOG.md b/CHANGELOG.md index d843882ad..79e668201 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,7 +5,7 @@ #### Breaking changes - Minimum requirement is now PHP 5.4+ -- The `Traits` folder was renamed to `Abstracts`, if you were extending `Rocketeer\Traits\Task`, change that accordingly to `Rocketeer\Abstracts\Task` +- The `Traits` folder was renamed to `Abstracts`, if you were extending `Rocketeer\Traits\Task`, change that accordingly to `Rocketeer\Abstracts\AbstractTask` - Connections and stages handling was moved to a ConnectionsHandler class. If you were doing per example `$task->rocketeer->getStage()` you'll need to change it to `$task->connections->getStage()`, etc. #### Features and bugfixes diff --git a/src/Rocketeer/Abstracts/Plugin.php b/src/Rocketeer/Abstracts/AbstractPlugin.php similarity index 97% rename from src/Rocketeer/Abstracts/Plugin.php rename to src/Rocketeer/Abstracts/AbstractPlugin.php index c5c3e1b66..bbe0b1e2f 100644 --- a/src/Rocketeer/Abstracts/Plugin.php +++ b/src/Rocketeer/Abstracts/AbstractPlugin.php @@ -19,7 +19,7 @@ * * @author Maxime Fabre */ -abstract class Plugin +abstract class AbstractPlugin { use HasLocator; diff --git a/src/Rocketeer/Abstracts/Scm.php b/src/Rocketeer/Abstracts/AbstractScm.php similarity index 98% rename from src/Rocketeer/Abstracts/Scm.php rename to src/Rocketeer/Abstracts/AbstractScm.php index ede290aba..0be4aff11 100644 --- a/src/Rocketeer/Abstracts/Scm.php +++ b/src/Rocketeer/Abstracts/AbstractScm.php @@ -16,7 +16,7 @@ * * @author Maxime Fabre */ -abstract class Scm +abstract class AbstractScm { use HasLocator; diff --git a/src/Rocketeer/Abstracts/Storage.php b/src/Rocketeer/Abstracts/AbstractStorage.php similarity index 98% rename from src/Rocketeer/Abstracts/Storage.php rename to src/Rocketeer/Abstracts/AbstractStorage.php index f50c6b502..624331c42 100644 --- a/src/Rocketeer/Abstracts/Storage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -6,7 +6,7 @@ use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; -abstract class Storage +abstract class AbstractStorage { use HasLocator; diff --git a/src/Rocketeer/Abstracts/Strategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php similarity index 84% rename from src/Rocketeer/Abstracts/Strategy.php rename to src/Rocketeer/Abstracts/AbstractStrategy.php index 7029447a5..d7b9bb60a 100644 --- a/src/Rocketeer/Abstracts/Strategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -7,7 +7,7 @@ /** * Core class for strategies */ -abstract class Strategy +abstract class AbstractStrategy { use HasLocator; use HasHistory; diff --git a/src/Rocketeer/Abstracts/Task.php b/src/Rocketeer/Abstracts/AbstractTask.php similarity index 89% rename from src/Rocketeer/Abstracts/Task.php rename to src/Rocketeer/Abstracts/AbstractTask.php index 5bd250711..e23f50b90 100644 --- a/src/Rocketeer/Abstracts/Task.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -13,11 +13,11 @@ use Rocketeer\Bash; /** - * An abstract Task with common helpers, from which all Tasks derive + * An abstract AbstractTask with common helpers, from which all Tasks derive * * @author Maxime Fabre */ -abstract class Task extends Bash +abstract class AbstractTask extends Bash { /** * The name of the task @@ -27,7 +27,7 @@ abstract class Task extends Bash protected $name; /** - * A description of what the Task does + * A description of what the task does * * @var string */ @@ -45,7 +45,7 @@ abstract class Task extends Bash //////////////////////////////////////////////////////////////////// /** - * Get the name of the Task + * Get the name of the task * * @return string */ @@ -55,7 +55,7 @@ public function getName() } /** - * Change the Task's name + * Change the task's name * * @param string $name */ @@ -65,7 +65,7 @@ public function setName($name) } /** - * Get the basic name of the Task + * Get the basic name of the task * * @return string */ @@ -75,7 +75,7 @@ public function getSlug() } /** - * Get what the Task does + * Get what the task does * * @return string */ @@ -89,7 +89,7 @@ public function getDescription() //////////////////////////////////////////////////////////////////// /** - * Run the Task + * Run the task * * @return string */ @@ -102,7 +102,7 @@ abstract public function execute(); */ public function fire() { - // Fire the Task if the before event passes + // Fire the task if the before event passes if ($this->fireEvent('before')) { $results = $this->execute(); $this->fireEvent('after'); @@ -133,7 +133,7 @@ public function halt($errors = null) } /** - * Whether the Task was halted mid-course + * Whether the task was halted mid-course * * @return boolean */ @@ -206,11 +206,11 @@ protected function displayReleases() } /** - * Execute another Task by name + * Execute another AbstractTask by name * * @param string $task * - * @return string The Task's output + * @return string the task's output */ public function executeTask($task) { diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index 7ea30b94e..72742dfbd 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -76,7 +76,7 @@ public function isInsideLaravel() /** * Fire a Tasks Queue * - * @param string|string[]|\Rocketeer\Abstracts\Task[] $tasks + * @param string|string[]|\Rocketeer\Abstracts\AbstractTask[] $tasks */ protected function fireTasksQueue($tasks) { diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index b2d2560b0..d6012b0cb 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -9,10 +9,10 @@ */ namespace Rocketeer\Console\Commands; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** - * A command that wraps around a Task class and runs + * A command that wraps around a task class and runs * its execute method on fire * * @author Maxime Fabre @@ -27,23 +27,25 @@ class BaseTaskCommand extends AbstractDeployCommand protected $name = 'deploy:custom'; /** - * The Task to execute on fire + * the task to execute on fire + * - * @var Task +*@var AbstractTask */ protected $task; /** * Build a new custom command + * - * @param Task $task +*@param AbstractTask $task * @param string|null $name A name for the command */ - public function __construct(Task $task, $name = null) + public function __construct(AbstractTask $task, $name = null) { parent::__construct(); - // Set Task + // Set task $this->task = $task; $this->task->command = $this; @@ -64,9 +66,10 @@ public function fire() } /** - * Get the Task this command executes + * Get the task this command executes + * - * @return Task +*@return AbstractTask */ public function getTask() { diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index 19745f2a2..a2e08238a 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -9,14 +9,14 @@ */ namespace Rocketeer\Plugins; -use Rocketeer\Abstracts\Plugin; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractPlugin; +use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Services\TasksHandler; /** * A base class for notification services to extends */ -abstract class Notifier extends Plugin +abstract class Notifier extends AbstractPlugin { /** * Register Tasks with Rocketeer @@ -92,13 +92,15 @@ abstract protected function getMessageFormat($message); /** * Prepare and send a message + * - * @param Task $task +*@param AbstractTask $task * @param string $message + * - * @return void +*@return void */ - public function prepareThenSend(Task $task, $message) + public function prepareThenSend(AbstractTask $task, $message) { // Don't send a notification if pretending to deploy if ($task->command->option('pretend')) { diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index 807828340..add09f84a 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Scm; -use Rocketeer\Abstracts\Scm; +use Rocketeer\Abstracts\AbstractScm; use Rocketeer\Interfaces\ScmInterface; /** @@ -17,7 +17,7 @@ * * @author Maxime Fabre */ -class Git extends Scm implements ScmInterface +class Git extends AbstractScm implements ScmInterface { /** * The core binary diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index e09613621..f3fbb6b65 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Scm; -use Rocketeer\Abstracts\Scm; +use Rocketeer\Abstracts\AbstractScm; use Rocketeer\Interfaces\ScmInterface; /** @@ -18,7 +18,7 @@ * @author Maxime Fabre * @author Gasillo */ -class Svn extends Scm implements ScmInterface +class Svn extends AbstractScm implements ScmInterface { /** * The core binary diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index f238b00be..412849d8d 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -11,7 +11,7 @@ use Exception; use Illuminate\Container\Container; -use Rocketeer\Abstracts\Storage; +use Rocketeer\Abstracts\AbstractStorage; use Rocketeer\Interfaces\StorageInterface; /** @@ -19,7 +19,7 @@ * * @author Maxime Fabre */ -class LocalStorage extends Storage implements StorageInterface +class LocalStorage extends AbstractStorage implements StorageInterface { /** * The current hash in use diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index a458a2445..06fccfcd9 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -9,7 +9,7 @@ */ namespace Rocketeer\Services\Storages; -use Rocketeer\Abstracts\Storage; +use Rocketeer\Abstracts\AbstractStorage; use Rocketeer\Interfaces\StorageInterface; /** @@ -17,7 +17,7 @@ * * @author Maxime Fabre */ -class ServerStorage extends Storage implements StorageInterface +class ServerStorage extends AbstractStorage implements StorageInterface { /** * Destroy the file diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 2d0e34804..8499575b7 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -63,16 +63,16 @@ public function __call($method, $parameters) //////////////////////////////////////////////////////////////////// /** - * Register a custom Task with Rocketeer + * Register a custom AbstractTask with Rocketeer * - * @param Task|string $task + * @param AbstractTask|string $task * @param string $name * * @return Container */ public function add($task, $name = null) { - // Build Task if necessary + // Build task if necessary $task = $this->queue->buildTask($task, $name); $slug = 'rocketeer.tasks.'.$task->getSlug(); @@ -106,10 +106,10 @@ public function task($name, $task) //////////////////////////////////////////////////////////////////// /** - * Execute a Task before another one + * Execute a task before another one * * @param string $task - * @param string|Closure|Task $listeners + * @param string|Closure|AbstractTask $listeners * @param integer $priority * * @return void @@ -120,10 +120,10 @@ public function before($task, $listeners, $priority = 0) } /** - * Execute a Task after another one + * Execute a task after another one * * @param string $task - * @param string|Closure|Task $listeners + * @param string|Closure|AbstractTask $listeners * @param integer $priority * * @return void diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index 537b1abca..f35e914f1 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -13,7 +13,7 @@ use Exception; use KzykHys\Parallel\Parallel; use Rocketeer\Abstracts\AbstractLocatorClass; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Connection; use Rocketeer\Traits\HasLocator; use string; @@ -123,11 +123,13 @@ public function run(array $tasks) /** * Run the queue, taking into account the stage + * - * @param \Rocketeer\Abstracts\Task[] $tasks +*@param \Rocketeer\Abstracts\AbstractTask[] $tasks * @param string $stage + * - * @return boolean +*@return boolean */ protected function runQueue($tasks, $stage = null) { @@ -208,7 +210,7 @@ protected function buildPipeline(array $queue) /** * Build a queue from a list of tasks * Here we will take the various Tasks names, closures and string tasks - * and unify all of those to actual Task instances + * and unify all of those to actual AbstractTask instances * * @param array $tasks * @@ -225,11 +227,13 @@ public function buildQueue(array $tasks) /** * Build a task from anything + * - * @param mixed $task +*@param mixed $task * @param string $name + * - * @return Task +*@return AbstractTask */ public function buildTask($task, $name = null) { @@ -247,7 +251,7 @@ public function buildTask($task, $name = null) } // Build remaining tasks - if (!$task instanceof Task) { + if (!$task instanceof AbstractTask) { $task = $this->buildTaskFromClass($task); } @@ -260,11 +264,13 @@ public function buildTask($task, $name = null) } /** - * Build a Task from a Closure or a string command + * Build a task from a Closure or a string command + * - * @param Closure|string $task +*@param Closure|string $task + * - * @return Task +*@return AbstractTask */ public function buildTaskFromClosure($task) { @@ -281,7 +287,7 @@ public function buildTaskFromClosure($task) } // Now that we unified it all to a Closure, we build - // a Closure Task from there + // a Closure AbstractTask from there $task = $this->buildTaskFromClass('Rocketeer\Tasks\Closure'); $task->setClosure($closure); @@ -295,15 +301,19 @@ public function buildTaskFromClosure($task) } /** - * Build a Task from its name - * - * @param string|Task $task - * - * @return Task + * Build a task from its name + + +* +*@param string|AbstractTask $task + + +* + * @return AbstractTask */ public function buildTaskFromClass($task) { - if (is_object($task) and $task instanceof Task) { + if (is_object($task) and $task instanceof AbstractTask) { return $task; } diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php index 2e9220e87..0f38b5ae4 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -1,10 +1,10 @@ */ -class Check extends Task +class Check extends AbstractTask { /** * The PHP extensions loaded on server @@ -26,21 +26,21 @@ class Check extends Task protected $extensions = array(); /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Check if the server is ready to receive the application'; /** - * Whether the Task needs to be run on each stage or globally + * Whether the task needs to be run on each stage or globally * * @var boolean */ public $usesStages = false; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index 7915ba5e9..dc914dd63 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -10,24 +10,24 @@ namespace Rocketeer\Tasks; use Illuminate\Support\Str; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Clean up old releases from the server * * @author Maxime Fabre */ -class Cleanup extends Task +class Cleanup extends AbstractTask { /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Clean up old releases from the server'; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Closure.php b/src/Rocketeer/Tasks/Closure.php index e26ce5485..45629c7a8 100644 --- a/src/Rocketeer/Tasks/Closure.php +++ b/src/Rocketeer/Tasks/Closure.php @@ -10,14 +10,14 @@ namespace Rocketeer\Tasks; use Closure as AnonymousFunction; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** - * A Task that wraps around a closure and execute it + * a task that wraps around a closure and execute it * * @author Maxime Fabre */ -class Closure extends Task +class Closure extends AbstractTask { /** * A Closure to execute at runtime @@ -34,7 +34,7 @@ class Closure extends Task protected $stringTask; /** - * Create a Task from a Closure + * Create a task from a Closure * * @param AnonymousFunction $closure */ @@ -44,7 +44,7 @@ public function setClosure(AnonymousFunction $closure) } /** - * Get the Task's Closure + * Get the task's Closure * * @return Closure */ @@ -74,7 +74,7 @@ public function setStringTask($task) } /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index 150a6cdea..fe74dd6cf 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -10,14 +10,14 @@ namespace Rocketeer\Tasks; use DateTime; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Display what the current release is * * @author Maxime Fabre */ -class CurrentRelease extends Task +class CurrentRelease extends AbstractTask { /** * The slug of the task @@ -27,14 +27,14 @@ class CurrentRelease extends Task protected $name = 'current'; /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Display what the current release is'; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 938bdaf64..678a9f7ca 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -9,14 +9,14 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Deploy the website * * @author Maxime Fabre */ -class Deploy extends Task +class Deploy extends AbstractTask { /** * Methods that can halt deployment @@ -26,7 +26,7 @@ class Deploy extends Task protected $halting = array(); /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index 3fe66b3af..df3a24166 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -9,17 +9,17 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * A task to ignite Rocketeer * * @author Maxime Fabre */ -class Ignite extends Task +class Ignite extends AbstractTask { /** - * A description of what the Task does + * A description of what the task does * * @var string */ diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 1d742fa25..76beac15d 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -9,17 +9,17 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Rollback to the previous release, or to a specific one * * @author Maxime Fabre */ -class Rollback extends Task +class Rollback extends AbstractTask { /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index ffbd068a9..3ace01ee7 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -9,31 +9,31 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Set up the remote server for deployment * * @author Maxime Fabre */ -class Setup extends Task +class Setup extends AbstractTask { /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Set up the remote server for deployment'; /** - * Whether the Task needs to be run on each stage or globally + * Whether the task needs to be run on each stage or globally * * @var boolean */ public $usesStages = false; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 602d5dafb..00201ae99 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -9,31 +9,31 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Remove the remote applications and existing caches * * @author Maxime Fabre */ -class Teardown extends Task +class Teardown extends AbstractTask { /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Remove the remote applications and existing caches'; /** - * Whether the Task needs to be run on each stage or globally + * Whether the task needs to be run on each stage or globally * * @var boolean */ public $usesStages = false; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index db861ec18..8a3bf7c47 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -9,24 +9,24 @@ */ namespace Rocketeer\Tasks; -use Rocketeer\Abstracts\Task; +use Rocketeer\Abstracts\AbstractTask; /** * Run the tests on the server and displays the output * * @author Maxime Fabre */ -class Test extends Task +class Test extends AbstractTask { /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Run the tests on the server and displays the output'; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 1088f35b2..4208bdd36 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -17,14 +17,14 @@ class Update extends Deploy { /** - * A description of what the Task does + * A description of what the task does * * @var string */ protected $description = 'Update the remote server without doing a new release'; /** - * Run the Task + * Run the task * * @return void */ diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 28dbdd06e..0b61e2b68 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -17,7 +17,7 @@ trait Flow { /** - * Whether the Task needs to be run on each stage or globally + * Whether the task needs to be run on each stage or globally * * @var boolean */ @@ -34,7 +34,7 @@ public function isSetup() } /** - * Check if the Task uses stages + * Check if the task uses stages * * @return boolean */ diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 6de65494e..f9eb60712 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -44,7 +44,7 @@ trait HasLocator protected $app; /** - * Build a new Task + * Build a new AbstractTask * * @param Container $app */ diff --git a/src/config/hooks.php b/src/config/hooks.php index c5a7c6300..c2bdb9bbb 100644 --- a/src/config/hooks.php +++ b/src/config/hooks.php @@ -5,7 +5,7 @@ // Here you can define in the `before` and `after` array, Tasks to execute // before or after the core Rocketeer Tasks. You can either put a simple command, // a closure which receives a $task object, or the name of a class extending - // the Rocketeer\Abstracts\Task class + // the Rocketeer\Abstracts\AbstractTask class // // In the `custom` array you can list custom Tasks classes to be added // to Rocketeer. Those will then be available in the command line diff --git a/tests/Dummies/MyCustomTask.php b/tests/Dummies/MyCustomTask.php index c1e10146f..bff08b8f6 100644 --- a/tests/Dummies/MyCustomTask.php +++ b/tests/Dummies/MyCustomTask.php @@ -1,9 +1,9 @@ tasksQueue()->buildTaskFromClass('Rocketeer\Tasks\Deploy'); - $this->assertInstanceOf('Rocketeer\Abstracts\Task', $task); + $this->assertInstanceOf('Rocketeer\Abstracts\AbstractTask', $task); } public function testCanBuildCustomTaskByName() diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 888246fbf..91fe5905f 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -24,9 +24,10 @@ abstract class RocketeerTestCase extends ContainerTestCase protected $deploymentsFile; /** - * A dummy Task to use for helpers tests + * A dummy AbstractTask to use for helpers tests + * - * @var \Rocketeer\Abstracts\Task +*@var \Rocketeer\Abstracts\AbstractTask */ protected $task; @@ -48,7 +49,7 @@ public function setUp() return new LocalStorage($app, 'deployments', $folder); }); - // Bind dummy Task + // Bind dummy AbstractTask $this->task = $this->task('Cleanup'); $this->recreateVirtualServer(); } @@ -179,13 +180,15 @@ protected function pretend($options = array(), $expectations = array()) } /** - * Get a pretend Task to run bogus commands + * Get a pretend AbstractTask to run bogus commands + * - * @param string $task +*@param string $task * @param array $options * @param array $expectations + * - * @return \Rocketeer\Abstracts\Task +*@return \Rocketeer\Abstracts\AbstractTask */ protected function pretendTask($task = 'Deploy', $options = array(), array $expectations = array()) { @@ -195,12 +198,14 @@ protected function pretendTask($task = 'Deploy', $options = array(), array $expe } /** - * Get Task instance + * Get AbstractTask instance + * - * @param string $task +*@param string $task * @param array $options + * - * @return \Rocketeer\Abstracts\Task +*@return \Rocketeer\Abstracts\AbstractTask */ protected function task($task = null, $options = array()) { diff --git a/tests/_meta/coverage.txt b/tests/_meta/coverage.txt index cfc9dc1c1..46a49e7e7 100644 --- a/tests/_meta/coverage.txt +++ b/tests/_meta/coverage.txt @@ -24,7 +24,7 @@ Code Coverage Report: Methods: 63.64% ( 7/11) Lines: 89.33% ( 67/ 75) \Rocketeer\Plugins::Notifier Methods: 75.00% ( 3/ 4) Lines: 87.50% ( 21/ 24) -\Rocketeer\Scm::Git +\Rocketeer\AbstractScm::Git Methods: 100.00% ( 7/ 7) Lines: 100.00% ( 10/ 10) \Rocketeer\Tasks::Check Methods: 75.00% ( 6/ 8) Lines: 92.65% ( 63/ 68) @@ -50,11 +50,11 @@ Code Coverage Report: Methods: 100.00% ( 1/ 1) Lines: 100.00% ( 10/ 10) \Rocketeer\Abstracts::AbstractLocatorClass Methods: 100.00% ( 4/ 4) Lines: 100.00% ( 19/ 19) -\Rocketeer\Abstracts::Plugin +\Rocketeer\Abstracts::AbstractPlugin Methods: 100.00% ( 2/ 2) Lines: 100.00% ( 5/ 5) -\Rocketeer\Abstracts::Scm +\Rocketeer\Abstracts::AbstractScm Methods: 100.00% ( 3/ 3) Lines: 100.00% ( 9/ 9) -\Rocketeer\Abstracts::Task +\Rocketeer\Abstracts::AbstractTask Methods: 72.73% ( 8/11) Lines: 88.89% ( 32/ 36) \Rocketeer\Abstracts\BashModules::Binaries Methods: 50.00% ( 4/ 8) Lines: 89.09% ( 49/ 55) @@ -64,5 +64,5 @@ Code Coverage Report: Methods: 80.00% ( 8/10) Lines: 94.12% ( 32/ 34) \Rocketeer\Abstracts\BashModules::Flow Methods: 100.00% ( 6/ 6) Lines: 100.00% ( 22/ 22) -\Rocketeer\Abstracts\BashModules::Scm +\Rocketeer\Abstracts\BashModules::AbstractScm Methods: 66.67% ( 2/ 3) Lines: 96.88% ( 31/ 32) From 91dca5b6613e901f9e01d90facc9bc954e267353 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 00:12:25 +0200 Subject: [PATCH 094/424] Use original count instead of alias --- src/Rocketeer/Abstracts/AbstractStorage.php | 2 +- .../Commands/AbstractDeployCommand.php | 4 +-- .../Console/Commands/BaseTaskCommand.php | 11 +++---- src/Rocketeer/Console/Console.php | 10 +++--- src/Rocketeer/Igniter.php | 1 - src/Rocketeer/Plugins/Notifier.php | 8 ++--- src/Rocketeer/Services/ConnectionsHandler.php | 4 +-- src/Rocketeer/Services/ReleasesManager.php | 2 ++ src/Rocketeer/Services/TasksHandler.php | 16 +++++----- src/Rocketeer/Services/TasksQueue.php | 32 +++++++------------ src/Rocketeer/Tasks/Cleanup.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 2 +- src/Rocketeer/Traits/HasHistory.php | 2 +- tests/TestCases/RocketeerTestCase.php | 15 +++------ 14 files changed, 45 insertions(+), 66 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 624331c42..1542f22e6 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -68,7 +68,7 @@ public function set($key, $value = null) { // Set the value on the contents $contents = $this->getContents(); - if (is_null($value)) { + if (!is_string($value)) { $contents = $key; } else { Arr::set($contents, $key, $value); diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index 72742dfbd..b75a57bd6 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -104,7 +104,7 @@ protected function fireTasksQueue($tasks) /** * Time an operation and display it afterwards * - * @param callable $callback + * @param Closure $callback */ protected function time(Closure $callback) { @@ -165,7 +165,7 @@ protected function getServerCredentials() $availableConnections = $this->laravel['rocketeer.connections']->getAvailableConnections(); $activeConnections = $this->laravel['rocketeer.connections']->getConnections(); - if (sizeof($activeConnections) <= 0) { + if (count($activeConnections) <= 0) { $connectionName = $this->ask('No connections have been set, please create one : (production)', 'production'); $this->storeServerCredentials($availableConnections, $connectionName); } else { diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index d6012b0cb..80498aac4 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -28,18 +28,16 @@ class BaseTaskCommand extends AbstractDeployCommand /** * the task to execute on fire - * -*@var AbstractTask + * @var AbstractTask */ protected $task; /** * Build a new custom command - * -*@param AbstractTask $task - * @param string|null $name A name for the command + * @param AbstractTask $task + * @param string|null $name A name for the command */ public function __construct(AbstractTask $task, $name = null) { @@ -67,9 +65,8 @@ public function fire() /** * Get the task this command executes - * -*@return AbstractTask + * @return AbstractTask */ public function getTask() { diff --git a/src/Rocketeer/Console/Console.php b/src/Rocketeer/Console/Console.php index 86b1ddf7f..830259645 100644 --- a/src/Rocketeer/Console/Console.php +++ b/src/Rocketeer/Console/Console.php @@ -25,13 +25,11 @@ class Console extends Application */ public function getHelp() { - $help = str_replace($this->getLongVersion(), null, parent::getHelp()); + $help = str_replace($this->getLongVersion(), null, parent::getHelp()); + $state = $this->buildBlock('Current state', $this->getCurrentState()); + $help = sprintf('%s'.PHP_EOL.PHP_EOL.'%s%s', $this->getLongVersion(), $state, $help); - return - $this->getLongVersion(). - PHP_EOL.PHP_EOL. - $this->buildBlock('Current state', $this->getCurrentState()). - $help; + return $help; } /** diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index c05fb295d..79e78bf82 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -9,7 +9,6 @@ */ namespace Rocketeer; -use Illuminate\Container\Container; use Rocketeer\Traits\HasLocator; /** diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/Notifier.php index a2e08238a..9705e6648 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/Notifier.php @@ -92,13 +92,11 @@ abstract protected function getMessageFormat($message); /** * Prepare and send a message - * -*@param AbstractTask $task - * @param string $message - + * @param AbstractTask $task + * @param string $message * -*@return void + * @return void */ public function prepareThenSend(AbstractTask $task, $message) { diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index 4a4304ccf..bc77dc40b 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -291,8 +291,8 @@ public function setConnection($connection, $server = 0) $credentials = $this->getServerCredentials($connection, $server); // Set the connection - $this->connection = $connection; - $this->localStorage = $server; + $this->connection = $connection; + $this->localStorage = $server; // Register it with SSH component $name = $connection.'#'.$server; diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 6a6807777..3da94dbb7 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -259,6 +259,8 @@ protected function sanitizeRelease($release) */ protected function isRelease($release) { + $release = (string) $release; + return (bool) preg_match('#[0-9]{14}#', $release); } diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 8499575b7..f7d2f6238 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -65,8 +65,8 @@ public function __call($method, $parameters) /** * Register a custom AbstractTask with Rocketeer * - * @param AbstractTask|string $task - * @param string $name + * @param string|Closure|AbstractTask $task + * @param string $name * * @return Container */ @@ -91,8 +91,8 @@ public function add($task, $name = null) /** * Register a task with Rocketeer * - * @param string $name - * @param mixed $task + * @param string $name + * @param string|Closure|AbstractTask $task * * @return void */ @@ -108,9 +108,9 @@ public function task($name, $task) /** * Execute a task before another one * - * @param string $task + * @param string $task * @param string|Closure|AbstractTask $listeners - * @param integer $priority + * @param integer $priority * * @return void */ @@ -122,9 +122,9 @@ public function before($task, $listeners, $priority = 0) /** * Execute a task after another one * - * @param string $task + * @param string $task * @param string|Closure|AbstractTask $listeners - * @param integer $priority + * @param integer $priority * * @return void */ diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index f35e914f1..95da534bc 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -123,13 +123,11 @@ public function run(array $tasks) /** * Run the queue, taking into account the stage - * -*@param \Rocketeer\Abstracts\AbstractTask[] $tasks - * @param string $stage - + * @param \Rocketeer\Abstracts\AbstractTask[] $tasks + * @param string $stage * -*@return boolean + * @return boolean */ protected function runQueue($tasks, $stage = null) { @@ -227,13 +225,11 @@ public function buildQueue(array $tasks) /** * Build a task from anything - * -*@param mixed $task - * @param string $name - + * @param string|Closure|AbstractTask $task + * @param string $name * -*@return AbstractTask + * @return AbstractTask */ public function buildTask($task, $name = null) { @@ -265,12 +261,10 @@ public function buildTask($task, $name = null) /** * Build a task from a Closure or a string command - * -*@param Closure|string $task - + * @param Closure|string $task * -*@return AbstractTask + * @return AbstractTask */ public function buildTaskFromClosure($task) { @@ -302,13 +296,9 @@ public function buildTaskFromClosure($task) /** * Build a task from its name - - -* -*@param string|AbstractTask $task - - -* + * + * @param string|AbstractTask $task + * * @return AbstractTask */ public function buildTaskFromClass($task) diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index dc914dd63..ca41aa914 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -44,7 +44,7 @@ public function execute() } // Create final message - $trash = sizeof($trash); + $trash = count($trash); $message = sprintf('Removing %d %s from the server', $trash, Str::plural('release', $trash)); // Delete state file diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 26e269006..a47db5f64 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -52,7 +52,7 @@ public function run($commands, $silent = false, $array = false) $this->toOutput($commands); $this->command->line(implode(PHP_EOL, $commands)); - return sizeof($commands) == 1 ? $commands[0] : $commands; + return count($commands) == 1 ? $commands[0] : $commands; } // Run commands diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index db0c60997..49a848fdb 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -83,7 +83,7 @@ protected function appendTo($type, $command) { // Flatten one-liners $command = (array) $command; - $command = sizeof($command) == 1 ? $command[0] : $command; + $command = count($command) == 1 ? $command[0] : $command; // Get the various handles $handle = $this->getHistoryHandle(); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 91fe5905f..5f4de3573 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -25,9 +25,8 @@ abstract class RocketeerTestCase extends ContainerTestCase /** * A dummy AbstractTask to use for helpers tests - * -*@var \Rocketeer\Abstracts\AbstractTask + * @var \Rocketeer\Abstracts\AbstractTask */ protected $task; @@ -181,14 +180,12 @@ protected function pretend($options = array(), $expectations = array()) /** * Get a pretend AbstractTask to run bogus commands - * -*@param string $task + * @param string $task * @param array $options * @param array $expectations - * -*@return \Rocketeer\Abstracts\AbstractTask + * @return \Rocketeer\Abstracts\AbstractTask */ protected function pretendTask($task = 'Deploy', $options = array(), array $expectations = array()) { @@ -199,13 +196,11 @@ protected function pretendTask($task = 'Deploy', $options = array(), array $expe /** * Get AbstractTask instance - * -*@param string $task + * @param string $task * @param array $options - * -*@return \Rocketeer\Abstracts\AbstractTask + * @return \Rocketeer\Abstracts\AbstractTask */ protected function task($task = null, $options = array()) { From 1e54db11a7202f23c3565db4130194f60269c7d0 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 00:17:52 +0200 Subject: [PATCH 095/424] Fix tests --- src/Rocketeer/Abstracts/AbstractStorage.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 1542f22e6..96536cb50 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -67,8 +67,8 @@ public function get($key = null, $fallback = null) public function set($key, $value = null) { // Set the value on the contents - $contents = $this->getContents(); - if (!is_string($value)) { + $contents = (array) $this->getContents(); + if (is_array($key)) { $contents = $key; } else { Arr::set($contents, $key, $value); From 9c7d401dd2de22d9f508e64559541fb54619935c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 00:39:13 +0200 Subject: [PATCH 096/424] Docblocks --- src/Rocketeer/Services/TasksHandler.php | 7 ++++--- src/Rocketeer/Services/TasksQueue.php | 6 +++--- tests/TestCases/RocketeerAssertions.php | 6 +++--- 3 files changed, 10 insertions(+), 9 deletions(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index f7d2f6238..95c2f8f99 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -12,6 +12,7 @@ use Closure; use Illuminate\Container\Container; use Rocketeer\Abstracts\AbstractLocatorClass; +use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Console\Commands\BaseTaskCommand; use Rocketeer\Task; use Rocketeer\Tasks; @@ -66,7 +67,7 @@ public function __call($method, $parameters) * Register a custom AbstractTask with Rocketeer * * @param string|Closure|AbstractTask $task - * @param string $name + * @param string|null $name * * @return Container */ @@ -182,7 +183,7 @@ public function listenTo($event, $listeners, $priority = 0) /** * Bind a listener to a task * - * @param string $task + * @param string|array $task * @param string $event * @param array|callable $listeners * @param integer $priority @@ -210,7 +211,7 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) /** * Get all of a task's listeners * - * @param string|Task $task + * @param string|AbstractTask $task * @param string $event * @param boolean $flatten * diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index 95da534bc..9de4ce892 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -227,7 +227,7 @@ public function buildQueue(array $tasks) * Build a task from anything * * @param string|Closure|AbstractTask $task - * @param string $name + * @param string|null $name * * @return AbstractTask */ @@ -352,12 +352,12 @@ protected function getStage() /** * Check if a string is a command or a task * - * @param Closure|string $string + * @param AbstractTask|Closure|string $string * * @return boolean */ protected function isStringCommand($string) { - return is_string($string) and !class_exists($string) and !$this->app->bound('rocketeer.tasks.'.$string); + return is_string($string) && !class_exists($string) && !$this->app->bound('rocketeer.tasks.'.$string); } } diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index 729dfad39..83b57e85c 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -55,9 +55,9 @@ protected function assertTaskOutput($task, $output, $command = null) /** * Assert a task's history matches an array * - * @param string|Task $task - * @param array $expectedHistory - * @param array $options + * @param string|AbstractTask $task + * @param array $expectedHistory + * @param array $options * * @return string */ From e89e805d8903f8c55656fcd8f2ca86c6fc8d5061 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 00:42:35 +0200 Subject: [PATCH 097/424] Rename Notifier --- src/Rocketeer/Plugins/{Notifier.php => AbstractNotifier.php} | 2 +- tests/Dummies/DummyNotifier.php | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) rename src/Rocketeer/Plugins/{Notifier.php => AbstractNotifier.php} (98%) diff --git a/src/Rocketeer/Plugins/Notifier.php b/src/Rocketeer/Plugins/AbstractNotifier.php similarity index 98% rename from src/Rocketeer/Plugins/Notifier.php rename to src/Rocketeer/Plugins/AbstractNotifier.php index 9705e6648..ebd75a0ea 100644 --- a/src/Rocketeer/Plugins/Notifier.php +++ b/src/Rocketeer/Plugins/AbstractNotifier.php @@ -16,7 +16,7 @@ /** * A base class for notification services to extends */ -abstract class Notifier extends AbstractPlugin +abstract class AbstractNotifier extends AbstractPlugin { /** * Register Tasks with Rocketeer diff --git a/tests/Dummies/DummyNotifier.php b/tests/Dummies/DummyNotifier.php index 21b5fa53d..c30f7f06f 100644 --- a/tests/Dummies/DummyNotifier.php +++ b/tests/Dummies/DummyNotifier.php @@ -1,9 +1,9 @@ Date: Fri, 8 Aug 2014 00:51:25 +0200 Subject: [PATCH 098/424] Small fixes --- src/Rocketeer/Services/ConnectionsHandler.php | 2 +- src/Rocketeer/Tasks/CurrentRelease.php | 5 ++++- src/Rocketeer/Tasks/Ignite.php | 2 +- src/Rocketeer/Tasks/Teardown.php | 5 ++++- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- 5 files changed, 11 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index bc77dc40b..4f22bc52f 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -355,7 +355,7 @@ public function getRepository() if ($username or $password) { // Build credentials chain - $credentials = $password ? $username.':'.$password : $username; + $credentials = $password ? $username.':'.$password : $username; $credentials .= '@'; // Add them in chain diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index fe74dd6cf..588a5caab 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -53,7 +53,10 @@ public function execute() // Create state message $date = DateTime::createFromFormat('YmdHis', $currentRelease)->format('Y-m-d H:i:s'); $state = $this->runForCurrentRelease($this->scm->currentState()); - $message = sprintf('The current release'.$stage.' is %s (%s deployed at %s)', $currentRelease, $state, $date); + $message = sprintf( + 'The current release'.$stage.' is %s (%s deployed at %s)', + $currentRelease, $state, $date + ); // Display current and past releases $this->command->line($message); diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index df3a24166..c4904319d 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -88,7 +88,7 @@ protected function getConfigurationInformations() 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], - 'application_name' => $this->command->ask("What is your application's name ? (".$name.")", $name), + 'application_name' => $this->command->ask('What is your application\'s name ? ('.$name.")", $name), ) ); } diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 00201ae99..90b81e6fd 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -40,7 +40,10 @@ class Teardown extends AbstractTask public function execute() { // Ask confirmation - $confirm = $this->command->confirm('This will remove all folders on the server, not just releases. Do you want to proceed ?'); + $confirm = $this->command->confirm( + 'This will remove all folders on the server, not just releases. Do you want to proceed ?' + ); + if (!$confirm) { return $this->command->info('Teardown aborted'); } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index a961714df..2b703b775 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -47,7 +47,7 @@ public function php($command = null) */ public function artisan($command = null, $flags = array()) { - $artisan = $this->which('artisan', $this->releasesManager->getCurrentReleasePath()."/artisan") ?: 'artisan'; + $artisan = $this->which('artisan', $this->releasesManager->getCurrentReleasePath().'/artisan') ?: 'artisan'; foreach ($flags as $name => $value) { $command .= ' --'.$name; $command .= $value ? '="'.$value.'"' : ''; From 65b59a4c20c07902565a2c5d3e908eee0bd21566 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 00:58:00 +0200 Subject: [PATCH 099/424] Tweaks --- src/Rocketeer/Abstracts/AbstractStorage.php | 2 +- src/Rocketeer/Tasks/Ignite.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 96536cb50..dcd94ea4e 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -49,7 +49,7 @@ public function setFile($file) * @param string|null $key * @param string|Closure|null $fallback * - * @return mixed + * @return string|integer|array */ public function get($key = null, $fallback = null) { diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index c4904319d..decf1051f 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -88,7 +88,7 @@ protected function getConfigurationInformations() 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], - 'application_name' => $this->command->ask('What is your application\'s name ? ('.$name.")", $name), + 'application_name' => $this->command->ask('What is your application\'s name ? ('.$name.')', $name), ) ); } From 4ee667f87ad2e8e623c283d07053281ca3819af1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 01:10:14 +0200 Subject: [PATCH 100/424] Fix some return types --- src/Rocketeer/Abstracts/AbstractStorage.php | 2 -- src/Rocketeer/Services/ReleasesManager.php | 4 ++-- .../Services/Storages/ServerStorage.php | 2 ++ src/Rocketeer/Services/TasksHandler.php | 8 ++++---- src/Rocketeer/Services/TasksQueue.php | 6 +++--- src/Rocketeer/Tasks/Check.php | 2 +- src/Rocketeer/Tasks/Closure.php | 2 +- src/Rocketeer/Tasks/CurrentRelease.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 2 ++ src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Tasks/Test.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 20 +++++++++---------- src/Rocketeer/Traits/BashModules/Core.php | 10 +++++----- .../Traits/BashModules/Filesystem.php | 6 +++--- 14 files changed, 36 insertions(+), 34 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index dcd94ea4e..74e7f3eab 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -81,8 +81,6 @@ public function set($key, $value = null) * Forget a value from the repository file * * @param string $key - * - * @return array */ public function forget($key) { diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 3da94dbb7..12c5599da 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -243,7 +243,7 @@ public function checkReleaseState($release) * * @param string|integer $release * - * @return string|null + * @return string|integer|null */ protected function sanitizeRelease($release) { @@ -287,7 +287,7 @@ protected function getCurrentReleaseKey() /** * Get the current release * - * @return string|null + * @return string|integer|null */ public function getCurrentRelease() { diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index 06fccfcd9..779c34e54 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -27,6 +27,8 @@ class ServerStorage extends AbstractStorage implements StorageInterface public function destroy() { $this->bash->removeFolder($this->getFilepath()); + + return true; } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 95c2f8f99..89fc39f5b 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -64,12 +64,12 @@ public function __call($method, $parameters) //////////////////////////////////////////////////////////////////// /** - * Register a custom AbstractTask with Rocketeer + * Register a custom task with Rocketeer * * @param string|Closure|AbstractTask $task * @param string|null $name * - * @return Container + * @return BaseTaskCommand */ public function add($task, $name = null) { @@ -95,7 +95,7 @@ public function add($task, $name = null) * @param string $name * @param string|Closure|AbstractTask $task * - * @return void + * @return BaseTaskCommand */ public function task($name, $task) { @@ -188,7 +188,7 @@ public function listenTo($event, $listeners, $priority = 0) * @param array|callable $listeners * @param integer $priority * - * @return string + * @return string|null */ public function addTaskListeners($task, $event, $listeners, $priority = 0) { diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index 9de4ce892..d944722d5 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -56,7 +56,7 @@ class TasksQueue * Execute Tasks on the default connection * * @param string|array|Closure $queue - * @param string|string[] $connections + * @param string|string[]|null $connections * * @return array */ @@ -125,7 +125,7 @@ public function run(array $tasks) * Run the queue, taking into account the stage * * @param \Rocketeer\Abstracts\AbstractTask[] $tasks - * @param string $stage + * @param string|null $stage * * @return boolean */ @@ -299,7 +299,7 @@ public function buildTaskFromClosure($task) * * @param string|AbstractTask $task * - * @return AbstractTask + * @return AbstractTask|string */ public function buildTaskFromClass($task) { diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index aebe10533..da20ac1c5 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -42,7 +42,7 @@ class Check extends AbstractTask /** * Run the task * - * @return void + * @return boolean|null */ public function execute() { diff --git a/src/Rocketeer/Tasks/Closure.php b/src/Rocketeer/Tasks/Closure.php index 45629c7a8..9688deb5a 100644 --- a/src/Rocketeer/Tasks/Closure.php +++ b/src/Rocketeer/Tasks/Closure.php @@ -46,7 +46,7 @@ public function setClosure(AnonymousFunction $closure) /** * Get the task's Closure * - * @return Closure + * @return AnonymousFunction */ public function getClosure() { diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index 588a5caab..4e4e7ec05 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -36,7 +36,7 @@ class CurrentRelease extends AbstractTask /** * Run the task * - * @return void + * @return string|null */ public function execute() { diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 678a9f7ca..029345d39 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -97,6 +97,8 @@ protected function checkTestsResults() /** * Run migrations and seed database + * + * @return boolean|null */ protected function runMigrationsAndSeed() { diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 3ace01ee7..897457f7d 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -35,7 +35,7 @@ class Setup extends AbstractTask /** * Run the task * - * @return void + * @return false|null */ public function execute() { diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index 8a3bf7c47..4774cae48 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -28,7 +28,7 @@ class Test extends AbstractTask /** * Run the task * - * @return void + * @return boolean */ public function execute() { diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 2b703b775..fc2fe0d70 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -23,7 +23,7 @@ trait Binaries /** * Prefix a command with the right path to PHP * - * @param string $command + * @param string|null $command * * @return string */ @@ -40,8 +40,8 @@ public function php($command = null) /** * Prefix a command with the right path to Artisan * - * @param string $command - * @param array $flags + * @param string|null $command + * @param array $flags * * @return string */ @@ -59,8 +59,8 @@ public function artisan($command = null, $flags = array()) /** * Run an artisan command * - * @param string $command - * @param array $flags + * @param string|null $command + * @param array $flags * * @return string */ @@ -96,7 +96,7 @@ public function runMigrations($seed = false) /** * Seed the database * - * @param string $class A class to seed + * @param string|null $class A class to seed * * @return string */ @@ -114,7 +114,7 @@ public function runSeed($class = null) /** * Run the application's tests * - * @param string $arguments Additional arguments to pass to PHPUnit + * @param string|null $arguments Additional arguments to pass to PHPUnit * * @return boolean */ @@ -141,7 +141,7 @@ public function runTests($arguments = null) /** * Prefix a command with the right path to Composer * - * @param string $command + * @param string|null $command * * @return string */ @@ -202,8 +202,8 @@ public function runComposer($force = false) /** * Get a binary * - * @param string $binary The name of the binary - * @param string $fallback A fallback location + * @param string $binary The name of the binary + * @param string|null $fallback A fallback location * * @return string */ diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index a47db5f64..cc99b99e6 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -118,7 +118,7 @@ public function runRaw($commands, $array = false, $trim = false) * @param string|array $commands * @param boolean $array * - * @return string + * @return string|string[] */ public function runSilently($commands, $array = false) { @@ -128,7 +128,7 @@ public function runSilently($commands, $array = false) /** * Run commands in a folder * - * @param string $folder + * @param string|null $folder * @param string|array $tasks * * @return string @@ -149,9 +149,9 @@ public function runInFolder($folder = null, $tasks = array()) /** * Check the status of the last run command, return an error if any * - * @param string $error The message to display on error - * @param string $output The command's output - * @param string $success The message to display on success + * @param string $error The message to display on error + * @param string|null $output The command's output + * @param string|null $success The message to display on success * * @return boolean|string */ diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index a379b09cb..6a5ed28b8 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -176,8 +176,8 @@ public function upload($file, $destination = null) /** * Create a folder in the application's folder * - * @param string $folder The folder to create - * @param boolean $recursive + * @param string|null $folder The folder to create + * @param boolean $recursive * * @return string The task */ @@ -191,7 +191,7 @@ public function createFolder($folder = null, $recursive = false) /** * Remove a folder in the application's folder * - * @param string $folder The folder to remove + * @param string|null $folder The folder to remove * * @return string The task */ From dfe495efda90aa5d32e36d09acb0ce7ac0a19ffa Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 01:21:07 +0200 Subject: [PATCH 101/424] Realign stuff --- src/Rocketeer/Services/ConnectionsHandler.php | 2 +- src/Rocketeer/Services/TasksHandler.php | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index 4f22bc52f..bc77dc40b 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -355,7 +355,7 @@ public function getRepository() if ($username or $password) { // Build credentials chain - $credentials = $password ? $username.':'.$password : $username; + $credentials = $password ? $username.':'.$password : $username; $credentials .= '@'; // Add them in chain diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 89fc39f5b..d264f3b83 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -212,8 +212,8 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) * Get all of a task's listeners * * @param string|AbstractTask $task - * @param string $event - * @param boolean $flatten + * @param string $event + * @param boolean $flatten * * @return array */ From 12cd6555ec029f8768b189d97ec9f4ce56af59e8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 01:30:20 +0200 Subject: [PATCH 102/424] Add SVN tests --- src/Rocketeer/Scm/Svn.php | 6 +-- tests/Scm/GitTest.php | 2 +- tests/Scm/SvnTest.php | 95 +++++++++++++++++++++++++++++++++++++++ 3 files changed, 99 insertions(+), 4 deletions(-) create mode 100644 tests/Scm/SvnTest.php diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index f3fbb6b65..97a385db7 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -74,8 +74,8 @@ public function currentBranch() */ public function checkout($destination) { - $branch = $this->app['rocketeer.rocketeer']->getRepositoryBranch(); - $repository = $this->app['rocketeer.connections']->getRepository(); + $branch = $this->connections->getRepositoryBranch(); + $repository = $this->connections->getRepository(); $repository = rtrim($repository, '/').'/'.ltrim($branch, '/'); return $this->getCommand('co %s %s %s', $this->getCredentials(), $repository, $destination); @@ -109,7 +109,7 @@ public function update() protected function getCredentials() { $options = array('--non-interactive'); - $credentials = $this->app['rocketeer.rocketeer']->getCredentials(); + $credentials = $this->connections->getCredentials(); // Build command if ($user = array_get($credentials, 'username')) { diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index b203c7e97..5204982b7 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -8,7 +8,7 @@ class GitTest extends RocketeerTestCase /** * The current SCM instance * - * @var Rocketeer\Scm\Git + * @var Git */ protected $scm; diff --git a/tests/Scm/SvnTest.php b/tests/Scm/SvnTest.php new file mode 100644 index 000000000..070dad865 --- /dev/null +++ b/tests/Scm/SvnTest.php @@ -0,0 +1,95 @@ +scm = new Svn($this->app); + } + + //////////////////////////////////////////////////////////////////// + //////////////////////////////// TESTS ///////////////////////////// + //////////////////////////////////////////////////////////////////// + + public function testCanGetCheck() + { + $command = $this->scm->check(); + + $this->assertEquals('svn --version', $command); + } + + public function testCanGetCurrentState() + { + $command = $this->scm->currentState(); + + $this->assertEquals('svn info -r "HEAD" | grep "Revision"', $command); + } + + public function testCanGetCurrentBranch() + { + $command = $this->scm->currentBranch(); + + $this->assertEquals('echo trunk', $command); + } + + public function testCanGetCheckout() + { + $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { + return $mock + ->shouldReceive('getCredentials')->once()->andReturn(['username' => 'foo', 'password' => 'bar']) + ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') + ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); + }); + + $command = $this->scm->checkout($this->server); + + $this->assertEquals('svn co --non-interactive --username=foo --password=bar http://github.com/my/repository/develop '.$this->server, $command); + } + + public function testCanGetDeepClone() + { + $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { + return $mock + ->shouldReceive('getCredentials')->once()->andReturn(['username' => 'foo', 'password' => 'bar']) + ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') + ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); + }); + + $command = $this->scm->checkout($this->server); + + $this->assertEquals('svn co --non-interactive --username=foo --password=bar http://github.com/my/repository/develop '.$this->server, $command); + } + + public function testCanGetReset() + { + $command = $this->scm->reset(); + + $this->assertEquals("svn status -q | grep -v '^[~XI ]' | awk '{print $2;}' | xargs svn revert", $command); + } + + public function testCanGetUpdate() + { + $command = $this->scm->update(); + + $this->assertEquals('svn up --non-interactive', $command); + } + + public function testCanGetSubmodules() + { + $command = $this->scm->submodules(); + + $this->assertEmpty($command); + } +} From 9ef49bae995fe70f4b99938784386f64ad830185 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 01:39:03 +0200 Subject: [PATCH 103/424] Add ask notifier test --- src/Rocketeer/Plugins/AbstractNotifier.php | 10 +++----- ...ifierTest.php => AbstractNotifierTest.php} | 25 ++++++++++++++++++- 2 files changed, 28 insertions(+), 7 deletions(-) rename tests/Plugins/{NotifierTest.php => AbstractNotifierTest.php} (58%) diff --git a/src/Rocketeer/Plugins/AbstractNotifier.php b/src/Rocketeer/Plugins/AbstractNotifier.php index ebd75a0ea..77e209f67 100644 --- a/src/Rocketeer/Plugins/AbstractNotifier.php +++ b/src/Rocketeer/Plugins/AbstractNotifier.php @@ -27,14 +27,12 @@ abstract class AbstractNotifier extends AbstractPlugin */ public function onQueue(TasksHandler $queue) { - $me = $this; - - $queue->before('deploy', function ($task) use ($me) { - $me->prepareThenSend($task, 'before_deploy'); + $queue->before('deploy', function ($task) { + $this->prepareThenSend($task, 'before_deploy'); }, -10); - $queue->after('deploy', function ($task) use ($me) { - $me->prepareThenSend($task, 'after_deploy'); + $queue->after('deploy', function ($task) { + $this->prepareThenSend($task, 'after_deploy'); }, -10); } diff --git a/tests/Plugins/NotifierTest.php b/tests/Plugins/AbstractNotifierTest.php similarity index 58% rename from tests/Plugins/NotifierTest.php rename to tests/Plugins/AbstractNotifierTest.php index bc6538521..34dc3384d 100644 --- a/tests/Plugins/NotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -4,7 +4,7 @@ use Rocketeer\Dummies\DummyNotifier; use Rocketeer\TestCases\RocketeerTestCase; -class NotifierTest extends RocketeerTestCase +class AbstractNotifierTest extends RocketeerTestCase { public function setUp() { @@ -25,6 +25,29 @@ public function setUp() $this->tasks->plugin($this->notifier); } + public function testCanAskForNameIfNoneProvided() + { + $this->expectOutputString('foobar finished deploying branch "master" on "staging@production" (foo.bar.com)'); + + $this->mockCommand([], ['ask' => 'foobar']); + $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { + return $mock + ->shouldReceive('get')->with('connections') + ->shouldReceive('get')->with('notifier.name')->andReturn(null) + ->shouldReceive('set')->once()->with('notifier.name', 'foobar'); + }); + $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { + return $mock + ->shouldReceive('getRepositoryBranch')->andReturn('master') + ->shouldReceive('getStage')->andReturn('staging') + ->shouldReceive('getConnection')->andReturn('production') + ->shouldReceive('getServer')->andReturn('0') + ->shouldReceive('getServerCredentials')->andReturn(['host' => 'foo.bar.com']); + }); + + $this->task('Deploy')->fireEvent('before'); + } + public function testCanAppendStageToDetails() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "staging@production" (foo.bar.com)'); From 9d1e08b9d6beb1a1486c796af4ac0dd9111100c4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 01:54:24 +0200 Subject: [PATCH 104/424] Add some tests --- src/Rocketeer/Igniter.php | 66 +++++++++++++++++++-------------------- tests/IgniterTest.php | 35 +++++++++++++++++++++ tests/RocketeerTest.php | 46 +++++++++++++++++++++++++++ 3 files changed, 114 insertions(+), 33 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 79e78bf82..a7a57e1e4 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -92,6 +92,39 @@ public function updateConfiguration($folder, array $values = array()) //////////////////////////////// PATHS ///////////////////////////// //////////////////////////////////////////////////////////////////// + /** + * Get the base path + * + * @return string + */ + public function getBasePath() + { + $base = $this->app['path.base'] ? $this->app['path.base'].'/' : ''; + $base = $this->unifySlashes($base); + + return $base; + } + + /** + * Get path to the storage folder + * + * @return string + */ + public function getStoragePath() + { + // If no path is bound, default to the Rocketeer folder + if (!$this->app->bound('path.storage')) { + return '.rocketeer'; + } + + // Unify slashes + $storage = $this->app['path.storage']; + $storage = $this->unifySlashes($storage); + $storage = str_replace($this->getBasePath(), null, $storage); + + return $storage; + } + /** * Bind the base path to the Container */ @@ -147,39 +180,6 @@ protected function bindConfiguration() /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Get the base path - * - * @return string - */ - protected function getBasePath() - { - $base = $this->app['path.base'] ? $this->app['path.base'].'/' : ''; - $base = $this->unifySlashes($base); - - return $base; - } - - /** - * Get path to the storage folder - * - * @return string - */ - protected function getStoragePath() - { - // If no path is bound, default to the Rocketeer folder - if (!$this->app->bound('path.storage')) { - return '.rocketeer'; - } - - // Unify slashes - $storage = $this->app['path.storage']; - $storage = $this->unifySlashes($storage); - $storage = str_replace($this->getBasePath(), null, $storage); - - return $storage; - } - /** * Unify the slashes to the UNIX mode (forward slashes) * diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index 290003850..9a100b829 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -98,4 +98,39 @@ public function testCanSetCurrentApplication() $this->assertFileExists(__DIR__.'/../.rocketeer'); $this->assertContains('foobar', file_get_contents(__DIR__.'/../.rocketeer/config.php')); } + + public function testCanGetStoragePathWhenNoneBound() + { + unset($this->app['path.storage']); + + $storage = $this->igniter->getStoragePath(); + $this->assertEquals('.rocketeer', $storage); + } + + public function testCanGetStoragePathIfUnix() + { + $this->app['path.base'] = '/app'; + $this->app['path.storage'] = '/app/local/folder'; + + $storage = $this->igniter->getStoragePath(); + $this->assertEquals('local/folder', $storage); + } + + public function testCanGetStorageIfWindows() + { + $this->app['path.base'] = 'C:\Sites\app'; + $this->app['path.storage'] = 'C:\Sites\app\local\folder'; + + $storage = $this->igniter->getStoragePath(); + $this->assertEquals('local/folder', $storage); + } + + public function testCanGetStorageWhenBothForSomeReason() + { + $this->app['path.base'] = 'C:\Sites\app'; + $this->app['path.storage'] = 'C:/Sites/app/local/folder'; + + $storage = $this->igniter->getStoragePath(); + $this->assertEquals('local/folder', $storage); + } } diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 1720f6860..7ba1e59a2 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -88,4 +88,50 @@ public function testRocketeerCanGuessWhichStageHesIn() $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals(false, $stage); } + + public function testCanGetUserHomeFolder() + { + $_SERVER['HOME'] = '/some/folder'; + $home = $this->rocketeer->getUserHomeFolder(); + + $this->assertEquals('/some/folder', $home); + } + + public function testCanGetWindowsHomeFolder() + { + $_SERVER['HOME'] = null; + $_SERVER['HOMEDRIVE'] = 'C:'; + $_SERVER['HOMEPATH'] = '\Users\someuser'; + $home = $this->rocketeer->getUserHomeFolder(); + + $this->assertEquals('C:\Users\someuser', $home); + } + + public function testCancelsIfNoHomeFolder() + { + $this->setExpectedException('Exception'); + + $_SERVER['HOME'] = null; + $_SERVER['HOMEDRIVE'] = 'C:'; + $_SERVER['HOMEPATH'] = null; + $this->rocketeer->getUserHomeFolder(); + } + + public function testCanGetRocketeerFolder() + { + $_SERVER['HOME'] = '/some/folder'; + $rocketeer = $this->rocketeer->getRocketeerConfigFolder(); + + $this->assertEquals('/some/folder/.rocketeer', $rocketeer); + } + + public function testCanGetBoundPath() + { + $this->swapConfig(array( + 'rocketeer::paths.php' => '/bin/php', + )); + $path = $this->rocketeer->getPath('php'); + + $this->assertEquals('/bin/php', $path); + } } From fe92b8b04590738b5cddcc0bc3c7b0b2d498cb8b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 02:20:00 +0200 Subject: [PATCH 105/424] More tests --- tests/Services/History/HistoryTest.php | 27 +++++++++++++++++++ tests/Services/Storages/LocalStorageTest.php | 27 ++++++++++++++++--- tests/Services/Storages/ServerStorageTest.php | 17 ++++++++++++ tests/TestCases/RocketeerTestCase.php | 14 ++++++++++ 4 files changed, 81 insertions(+), 4 deletions(-) create mode 100644 tests/Services/History/HistoryTest.php create mode 100644 tests/Services/Storages/ServerStorageTest.php diff --git a/tests/Services/History/HistoryTest.php b/tests/Services/History/HistoryTest.php new file mode 100644 index 000000000..97a456ee3 --- /dev/null +++ b/tests/Services/History/HistoryTest.php @@ -0,0 +1,27 @@ +bash->toHistory('foo'); + sleep(1); + $this->bash->toHistory(['bar', 'baz']); + + $history = $this->history->getFlattenedHistory(); + $this->assertEquals(['foo', ['bar', 'baz']], $history); + } + + public function testCanGetFlattenedOutput() + { + $this->bash->toOutput('foo'); + sleep(1); + $this->bash->toOutput(['bar', 'baz']); + + $history = $this->history->getFlattenedOutput(); + $this->assertEquals(['foo', ['bar', 'baz']], $history); + } +} diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 0a85a71c4..bb2aacd2b 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -9,6 +9,14 @@ class LocalStorageTest extends RocketeerTestCase //////////////////////////////// TESTS ///////////////////////////// //////////////////////////////////////////////////////////////////// + public function testCanDestroyFile() + { + $file = $this->localStorage->getFilepath(); + $this->localStorage->destroy(); + + $this->assertFileNotExists($file); + } + public function testCanCreateDeploymentsFileAnywhere() { $this->app['path.storage'] = null; @@ -42,12 +50,13 @@ public function testCanComputeHashAccordingToContentsOfFiles() return $mock ->shouldReceive('put')->once() ->shouldReceive('exists')->twice()->andReturn(false) - ->shouldReceive('glob')->once()->andReturn(array('foo', 'bar')) - ->shouldReceive('getRequire')->once()->with('foo')->andReturn(array('foo')) - ->shouldReceive('getRequire')->once()->with('bar')->andReturn(array('bar')); + ->shouldReceive('glob')->once()->andReturn(['foo', 'bar']) + ->shouldReceive('getRequire')->once()->with('foo')->andReturn(['foo']) + ->shouldReceive('getRequire')->once()->with('bar')->andReturn(['bar']); }); - $hash = $this->localStorage->getHash(); + $storage = new LocalStorage($this->app, 'deployments', $this->server); + $hash = $storage->getHash(); $this->assertEquals(md5('["foo"]["bar"]'), $hash); } @@ -60,4 +69,14 @@ public function testCanCheckIfComposerIsNeeded() $this->usesComposer(false); $this->assertFalse($this->localStorage->usesComposer()); } + + public function testCanSwitchFolder() + { + $storage = new LocalStorage($this->app, 'foo', '/foo'); + $storage->setFolder($this->server); + $file = $storage->getFilepath(); + + $this->assertEquals($this->server, $storage->getFolder()); + $this->assertEquals($this->server.'/foo.json', $file); + } } diff --git a/tests/Services/Storages/ServerStorageTest.php b/tests/Services/Storages/ServerStorageTest.php new file mode 100644 index 000000000..46350bc3e --- /dev/null +++ b/tests/Services/Storages/ServerStorageTest.php @@ -0,0 +1,17 @@ +app, 'test'); + $file = $server->getFilepath(); + $server->destroy(); + + $this->assertFileNotExists($file); + } +} diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 5f4de3573..b0799e996 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -53,6 +53,17 @@ public function setUp() $this->recreateVirtualServer(); } + /** + * Cleanup tests + */ + public function tearDown() + { + parent::tearDown(); + + // Restore superglobals + $_SERVER['HOME'] = $this->home; + } + /** * Recreates the local file server * @@ -60,6 +71,9 @@ public function setUp() */ protected function recreateVirtualServer() { + // Save superglobals + $this->home = $_SERVER['HOME']; + // Recreate deployments file $this->app['files']->put($this->deploymentsFile, json_encode(array( 'foo' => 'bar', From 204fbd199e137a7ae5dcec8d1f896fed32eb8266 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 02:28:22 +0200 Subject: [PATCH 106/424] Decouble base command from credentials gathering --- .../Commands/AbstractDeployCommand.php | 142 +----------------- src/Rocketeer/RocketeerServiceProvider.php | 17 ++- .../Services/CredentialsGatherer.php | 137 +++++++++++++++++ src/Rocketeer/Traits/HasLocator.php | 3 +- tests/TestCases/ContainerTestCase.php | 3 +- 5 files changed, 159 insertions(+), 143 deletions(-) create mode 100644 src/Rocketeer/Services/CredentialsGatherer.php diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php index b75a57bd6..80037602a 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Console/Commands/AbstractDeployCommand.php @@ -80,18 +80,18 @@ public function isInsideLaravel() */ protected function fireTasksQueue($tasks) { + // Bind command to container + $this->laravel->instance('rocketeer.command', $this); + // Check for credentials - $this->getServerCredentials(); - $this->getRepositoryCredentials(); + $this->laravel['rocketeer.credentials']->getServerCredentials(); + $this->laravel['rocketeer.credentials']->getRepositoryCredentials(); // Convert tasks to array if necessary if (!is_array($tasks)) { $tasks = array($tasks); } - // Bind command to container - $this->laravel->instance('rocketeer.command', $this); - // Run tasks and display timer $this->time(function () use ($tasks) { $this->laravel['rocketeer.tasks']->run($tasks, $this); @@ -115,136 +115,4 @@ protected function time(Closure $callback) $this->line('Execution time: '.$time.'s'); } - - //////////////////////////////////////////////////////////////////// - ///////////////////////////// CREDENTIALS ////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Get the Repository's credentials - * - * @return void - */ - protected function getRepositoryCredentials() - { - // Check for repository credentials - $repositoryInfos = $this->laravel['rocketeer.connections']->getCredentials(); - $credentials = array('repository'); - if (!array_get($repositoryInfos, 'repository') or $this->laravel['rocketeer.connections']->needsCredentials()) { - $credentials = array('repository', 'username', 'password'); - } - - // Gather credentials - foreach ($credentials as $credential) { - ${$credential} = $this->getCredential($repositoryInfos, $credential); - if (!${$credential}) { - ${$credential} = $this->ask('No '.$credential.' is set for the repository, please provide one :'); - } - } - - // Save them - $credentials = compact($credentials); - $this->laravel['rocketeer.storage.local']->set('credentials', $credentials); - foreach ($credentials as $key => $credential) { - $this->laravel['config']->set('rocketeer::scm.'.$key, $credential); - } - } - - /** - * Get the LocalStorage's credentials - * - * @return void - */ - protected function getServerCredentials() - { - if ($connections = $this->option('on')) { - $this->laravel['rocketeer.connections']->setConnections($connections); - } - - // Check for configured connections - $availableConnections = $this->laravel['rocketeer.connections']->getAvailableConnections(); - $activeConnections = $this->laravel['rocketeer.connections']->getConnections(); - - if (count($activeConnections) <= 0) { - $connectionName = $this->ask('No connections have been set, please create one : (production)', 'production'); - $this->storeServerCredentials($availableConnections, $connectionName); - } else { - foreach ($activeConnections as $connectionName) { - $servers = array_get($availableConnections, $connectionName.'.servers'); - $servers = array_keys($servers); - foreach ($servers as $server) { - $this->storeServerCredentials($availableConnections, $connectionName, $server); - } - } - } - } - - /** - * Verifies and stores credentials for the given connection name - * - * @param array $connections - * @param string $connectionName - * @param integer|null $server - */ - protected function storeServerCredentials($connections, $connectionName, $server = null) - { - // Check for server credentials - $connection = $connectionName.'.servers'; - $connection = !is_null($server) ? $connection.'.'.$server : $connection; - $connection = array_get($connections, $connection, array()); - $credentials = array( - 'host' => true, - 'username' => true, - 'password' => false, - 'keyphrase' => null, - 'key' => false, - 'agent' => false - ); - - // Update connection name - $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; - - // Gather credentials - foreach ($credentials as $credential => $required) { - ${$credential} = $this->getCredential($connection, $credential); - if ($required and !${$credential}) { - ${$credential} = $this->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); - } - } - - // Get password or key - if (!$password and !$key) { - $type = $this->ask('No password or SSH key is set for ['.$handle.'], which would you use ? [key/password]', 'key'); - if ($type == 'key') { - $default = $this->laravel['rocketeer.rocketeer']->getUserHomeFolder().'/.ssh/id_rsa'; - $key = $this->ask('Please enter the full path to your key ('.$default.')', $default); - $keyphrase = $this->ask('If a keyphrase is required, provide it'); - } else { - $password = $this->ask('Please enter your password'); - } - } - - // Save credentials - $credentials = compact(array_keys($credentials)); - $this->laravel['rocketeer.connections']->syncConnectionCredentials($connectionName, $credentials, $server); - $this->laravel['rocketeer.connections']->setConnection($connectionName); - } - - /** - * Check if a credential needs to be filled - * - * @param array $credentials - * @param string $credential - * - * @return string - */ - protected function getCredential($credentials, $credential) - { - $credential = array_get($credentials, $credential); - if (substr($credential, 0, 1) === '{') { - return; - } - - return $credential; - } } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 8442eb4e0..90ad91aaa 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -19,6 +19,7 @@ use Monolog\Logger; use Rocketeer\Console\Commands\BaseTaskCommand; use Rocketeer\Services\ConnectionsHandler; +use Rocketeer\Services\CredentialsGatherer; use Rocketeer\Services\History\History; use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; @@ -63,10 +64,11 @@ public function register() public function boot() { $this->bindPaths(); - $this->bindCoreClasses(); + $this->bindThirdPartyServices(); // Bind Rocketeer's classes - $this->bindClasses(); + $this->bindCoreClasses(); + $this->bindConsoleClasses(); $this->bindStrategies(); // Load the user's events and tasks @@ -107,7 +109,7 @@ public function bindPaths() /** * Bind the core classes */ - public function bindCoreClasses() + public function bindThirdPartyServices() { $this->app->bindIf('files', 'Illuminate\Filesystem\Filesystem'); @@ -140,7 +142,7 @@ public function bindCoreClasses() /** * Bind the Rocketeer classes to the Container */ - public function bindClasses() + public function bindCoreClasses() { $this->app->singleton('rocketeer.rocketeer', function ($app) { return new Rocketeer($app); @@ -180,6 +182,13 @@ public function bindClasses() $this->app->singleton('rocketeer.logs', function ($app) { return new LogsHandler($app); }); + } + + public function bindConsoleClasses() + { + $this->app->singleton('rocketeer.credentials', function ($app) { + return new CredentialsGatherer($app); + }); $this->app->singleton('rocketeer.console', function () { return new Console\Console('Rocketeer', Rocketeer::VERSION); diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php new file mode 100644 index 000000000..ec42446ca --- /dev/null +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -0,0 +1,137 @@ +app['rocketeer.connections']->getCredentials(); + $credentials = array('repository'); + if (!array_get($repositoryInfos, 'repository') or $this->app['rocketeer.connections']->needsCredentials()) { + $credentials = array('repository', 'username', 'password'); + } + + // Gather credentials + foreach ($credentials as $credential) { + ${$credential} = $this->getCredential($repositoryInfos, $credential); + if (!${$credential}) { + ${$credential} = $this->command->ask('No '.$credential.' is set for the repository, please provide one :'); + } + } + + // Save them + $credentials = compact($credentials); + $this->app['rocketeer.storage.local']->set('credentials', $credentials); + foreach ($credentials as $key => $credential) { + $this->app['config']->set('rocketeer::scm.'.$key, $credential); + } + } + + /** + * Get the LocalStorage's credentials + * + * @return void + */ + public function getServerCredentials() + { + if ($connections = $this->command->option('on')) { + $this->app['rocketeer.connections']->setConnections($connections); + } + + // Check for configured connections + $availableConnections = $this->app['rocketeer.connections']->getAvailableConnections(); + $activeConnections = $this->app['rocketeer.connections']->getConnections(); + + if (count($activeConnections) <= 0) { + $connectionName = $this->command->ask('No connections have been set, please create one : (production)', 'production'); + $this->storeServerCredentials($availableConnections, $connectionName); + } else { + foreach ($activeConnections as $connectionName) { + $servers = array_get($availableConnections, $connectionName.'.servers'); + $servers = array_keys($servers); + foreach ($servers as $server) { + $this->storeServerCredentials($availableConnections, $connectionName, $server); + } + } + } + } + + /** + * Verifies and stores credentials for the given connection name + * + * @param array $connections + * @param string $connectionName + * @param integer|null $server + */ + protected function storeServerCredentials($connections, $connectionName, $server = null) + { + // Check for server credentials + $connection = $connectionName.'.servers'; + $connection = !is_null($server) ? $connection.'.'.$server : $connection; + $connection = array_get($connections, $connection, array()); + $credentials = array( + 'host' => true, + 'username' => true, + 'password' => false, + 'keyphrase' => null, + 'key' => false, + 'agent' => false + ); + + // Update connection name + $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; + + // Gather credentials + foreach ($credentials as $credential => $required) { + ${$credential} = $this->getCredential($connection, $credential); + if ($required and !${$credential}) { + ${$credential} = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); + } + } + + // Get password or key + if (!$password and !$key) { + $type = $this->command->ask('No password or SSH key is set for ['.$handle.'], which would you use ? [key/password]', 'key'); + if ($type == 'key') { + $default = $this->app['rocketeer.rocketeer']->getUserHomeFolder().'/.ssh/id_rsa'; + $key = $this->command->ask('Please enter the full path to your key ('.$default.')', $default); + $keyphrase = $this->command->ask('If a keyphrase is required, provide it'); + } else { + $password = $this->command->ask('Please enter your password'); + } + } + + // Save credentials + $credentials = compact(array_keys($credentials)); + $this->app['rocketeer.connections']->syncConnectionCredentials($connectionName, $credentials, $server); + $this->app['rocketeer.connections']->setConnection($connectionName); + } + + /** + * Check if a credential needs to be filled + * + * @param array $credentials + * @param string $credential + * + * @return string + */ + protected function getCredential($credentials, $credential) + { + $credential = array_get($credentials, $credential); + if (substr($credential, 0, 1) === '{') { + return; + } + + return $credential; + } +} diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index f9eb60712..78a62b7c4 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -16,17 +16,18 @@ * a few shortcuts to Rocketeer classes * * @property \Illuminate\Config\Repository config - * @property \Rocketeer\Console\Commands\AbstractDeployCommand command * @property \Illuminate\Events\Dispatcher events * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Log\Writer log * @property \Illuminate\Remote\Connection remote * @property \Rocketeer\Bash bash + * @property \Rocketeer\Console\Commands\AbstractDeployCommand command * @property \Rocketeer\Console\Console console * @property \Rocketeer\Interfaces\ScmInterface scm * @property \Rocketeer\Interfaces\StrategyInterface strategy * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\CredentialsGatherer credentials * @property \Rocketeer\Services\History\History history * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Services\Storages\LocalStorage localStorage diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 9a5eb39dd..b7c5f97a3 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -51,8 +51,9 @@ public function setUp() $serviceProvider = new RocketeerServiceProvider($this->app); $serviceProvider->bindPaths(); + $serviceProvider->bindThirdPartyServices(); $serviceProvider->bindCoreClasses(); - $serviceProvider->bindClasses(); + $serviceProvider->bindConsoleClasses(); $serviceProvider->bindStrategies(); } From a8c9784c83751647f220fa3fd6f50b03ca3b2a4c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 02:31:00 +0200 Subject: [PATCH 107/424] Rename some methods --- src/Rocketeer/Scm/Git.php | 6 +++--- src/Rocketeer/Scm/Svn.php | 4 ++-- src/Rocketeer/Services/ConnectionsHandler.php | 8 ++++---- .../Services/CredentialsGatherer.php | 20 +++++++++---------- src/Rocketeer/Tasks/Ignite.php | 2 +- tests/Scm/GitTest.php | 4 ++-- tests/Scm/SvnTest.php | 8 ++++---- tests/TestCases/RocketeerAssertions.php | 2 +- 8 files changed, 27 insertions(+), 27 deletions(-) diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index add09f84a..9ef0ffbdc 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -73,9 +73,9 @@ public function currentBranch() */ public function checkout($destination) { - $branch = $this->app['rocketeer.connections']->getRepositoryBranch(); - $repository = $this->app['rocketeer.connections']->getRepository(); - $shallow = $this->app['rocketeer.rocketeer']->getOption('scm.shallow') ? ' --depth 1' : ''; + $branch = $this->connections->getRepositoryBranch(); + $repository = $this->connections->getRepositoryEndpoint(); + $shallow = $this->rocketeer->getOption('scm.shallow') ? ' --depth 1' : ''; return $this->getCommand('clone%s -b %s "%s" %s', $shallow, $branch, $repository, $destination); } diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index 97a385db7..ae3ce8178 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -75,7 +75,7 @@ public function currentBranch() public function checkout($destination) { $branch = $this->connections->getRepositoryBranch(); - $repository = $this->connections->getRepository(); + $repository = $this->connections->getRepositoryEndpoint(); $repository = rtrim($repository, '/').'/'.ltrim($branch, '/'); return $this->getCommand('co %s %s %s', $this->getCredentials(), $repository, $destination); @@ -109,7 +109,7 @@ public function update() protected function getCredentials() { $options = array('--non-interactive'); - $credentials = $this->connections->getCredentials(); + $credentials = $this->connections->getRepositoryCredentials(); // Build command if ($user = array_get($credentials, 'username')) { diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index bc77dc40b..17344e4a1 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -114,7 +114,7 @@ public function getStages() */ public function needsCredentials() { - return Str::contains($this->getRepository(), 'https://'); + return Str::contains($this->getRepositoryEndpoint(), 'https://'); } /** @@ -321,7 +321,7 @@ public function disconnect() * * @return string[] */ - public function getCredentials() + public function getRepositoryCredentials() { $credentials = $this->localStorage->get('credentials'); if (!$credentials) { @@ -343,10 +343,10 @@ public function getCredentials() * * @return string */ - public function getRepository() + public function getRepositoryEndpoint() { // Get credentials - $repository = $this->getCredentials(); + $repository = $this->getRepositoryCredentials(); $username = array_get($repository, 'username'); $password = array_get($repository, 'password'); $repository = array_get($repository, 'repository'); diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index ec42446ca..6e063e9bb 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -15,10 +15,10 @@ class CredentialsGatherer public function getRepositoryCredentials() { // Check for repository credentials - $repositoryInfos = $this->app['rocketeer.connections']->getCredentials(); - $credentials = array('repository'); - if (!array_get($repositoryInfos, 'repository') or $this->app['rocketeer.connections']->needsCredentials()) { - $credentials = array('repository', 'username', 'password'); + $repositoryInfos = $this->connections->getRepositoryCredentials(); + $credentials = ['repository']; + if (!array_get($repositoryInfos, 'repository') or $this->connections->needsCredentials()) { + $credentials = ['repository', 'username', 'password']; } // Gather credentials @@ -33,7 +33,7 @@ public function getRepositoryCredentials() $credentials = compact($credentials); $this->app['rocketeer.storage.local']->set('credentials', $credentials); foreach ($credentials as $key => $credential) { - $this->app['config']->set('rocketeer::scm.'.$key, $credential); + $this->config->set('rocketeer::scm.'.$key, $credential); } } @@ -45,12 +45,12 @@ public function getRepositoryCredentials() public function getServerCredentials() { if ($connections = $this->command->option('on')) { - $this->app['rocketeer.connections']->setConnections($connections); + $this->connections->setConnections($connections); } // Check for configured connections - $availableConnections = $this->app['rocketeer.connections']->getAvailableConnections(); - $activeConnections = $this->app['rocketeer.connections']->getConnections(); + $availableConnections = $this->connections->getAvailableConnections(); + $activeConnections = $this->connections->getConnections(); if (count($activeConnections) <= 0) { $connectionName = $this->command->ask('No connections have been set, please create one : (production)', 'production'); @@ -113,8 +113,8 @@ protected function storeServerCredentials($connections, $connectionName, $server // Save credentials $credentials = compact(array_keys($credentials)); - $this->app['rocketeer.connections']->syncConnectionCredentials($connectionName, $credentials, $server); - $this->app['rocketeer.connections']->setConnection($connectionName); + $this->connections->syncConnectionCredentials($connectionName, $credentials, $server); + $this->connections->setConnection($connectionName); } /** diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index decf1051f..2940e05f7 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -78,7 +78,7 @@ protected function createOutsideConfiguration() protected function getConfigurationInformations() { // Replace credentials - $repositoryCredentials = $this->connections->getCredentials(); + $repositoryCredentials = $this->connections->getRepositoryCredentials(); $name = basename($this->app['path.base']); return array_merge( diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index 5204982b7..774b25335 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -51,7 +51,7 @@ public function testCanGetCheckout() }); $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { return $mock - ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') + ->shouldReceive('getRepositoryEndpoint')->once()->andReturn('http://github.com/my/repository') ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); @@ -67,7 +67,7 @@ public function testCanGetDeepClone() }); $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { return $mock - ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') + ->shouldReceive('getRepositoryEndpoint')->once()->andReturn('http://github.com/my/repository') ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); diff --git a/tests/Scm/SvnTest.php b/tests/Scm/SvnTest.php index 070dad865..cf2f98d69 100644 --- a/tests/Scm/SvnTest.php +++ b/tests/Scm/SvnTest.php @@ -48,8 +48,8 @@ public function testCanGetCheckout() { $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { return $mock - ->shouldReceive('getCredentials')->once()->andReturn(['username' => 'foo', 'password' => 'bar']) - ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') + ->shouldReceive('getRepositoryCredentials')->once()->andReturn(['username' => 'foo', 'password' => 'bar']) + ->shouldReceive('getRepositoryEndpoint')->once()->andReturn('http://github.com/my/repository') ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); @@ -62,8 +62,8 @@ public function testCanGetDeepClone() { $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { return $mock - ->shouldReceive('getCredentials')->once()->andReturn(['username' => 'foo', 'password' => 'bar']) - ->shouldReceive('getRepository')->once()->andReturn('http://github.com/my/repository') + ->shouldReceive('getRepositoryCredentials')->once()->andReturn(['username' => 'foo', 'password' => 'bar']) + ->shouldReceive('getRepositoryEndpoint')->once()->andReturn('http://github.com/my/repository') ->shouldReceive('getRepositoryBranch')->once()->andReturn('develop'); }); diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index 83b57e85c..c2bb1f293 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -20,7 +20,7 @@ protected function assertConnectionEquals($connection) */ protected function assertRepositoryEquals($repository) { - $this->assertEquals($repository, $this->connections->getRepository()); + $this->assertEquals($repository, $this->connections->getRepositoryEndpoint()); } /** From 8a44f1c3a125f25dcd9665b919c14857f4a7aaad Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 02:43:53 +0200 Subject: [PATCH 108/424] Work on CredentialsGatherer refactor --- src/Rocketeer/Rocketeer.php | 11 ++ .../Services/CredentialsGatherer.php | 122 ++++++++++-------- 2 files changed, 82 insertions(+), 51 deletions(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 88ccd7e23..f46439db3 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -187,6 +187,17 @@ public function getHomeFolder() return $rootDirectory.$appDirectory; } + /** + * Get the default path for the SSH key + * + * @return string + * @throws \Exception + */ + public function getDefaultKeyPath() + { + return $this->getUserHomeFolder().'/.ssh/id_rsa'; + } + /** * Get the path to the Rocketeer config folder in the users home * diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 6e063e9bb..37545180b 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -9,29 +9,23 @@ class CredentialsGatherer /** * Get the Repository's credentials - * - * @return void */ public function getRepositoryCredentials() { // Check for repository credentials - $repositoryInfos = $this->connections->getRepositoryCredentials(); - $credentials = ['repository']; - if (!array_get($repositoryInfos, 'repository') or $this->connections->needsCredentials()) { - $credentials = ['repository', 'username', 'password']; + $repositoryCredentials = $this->connections->getRepositoryCredentials(); + $credentials = ['repository' => true]; + + // If we didn't specify a login/password and the repository uses HTTP, ask for them too + if (!array_get($repositoryCredentials, 'repository') or $this->connections->needsCredentials()) { + $credentials += ['username' => true, 'password' => false]; } // Gather credentials - foreach ($credentials as $credential) { - ${$credential} = $this->getCredential($repositoryInfos, $credential); - if (!${$credential}) { - ${$credential} = $this->command->ask('No '.$credential.' is set for the repository, please provide one :'); - } - } + $credentials = $this->gatherCredentials($credentials, $repositoryCredentials, 'repository'); - // Save them - $credentials = compact($credentials); - $this->app['rocketeer.storage.local']->set('credentials', $credentials); + // Save them to local storage and runtime configuration + $this->localStorage->set('credentials', $credentials); foreach ($credentials as $key => $credential) { $this->config->set('rocketeer::scm.'.$key, $credential); } @@ -39,8 +33,6 @@ public function getRepositoryCredentials() /** * Get the LocalStorage's credentials - * - * @return void */ public function getServerCredentials() { @@ -52,16 +44,20 @@ public function getServerCredentials() $availableConnections = $this->connections->getAvailableConnections(); $activeConnections = $this->connections->getConnections(); - if (count($activeConnections) <= 0) { + // If we didn't set any connection, ask for them + if (!$activeConnections) { $connectionName = $this->command->ask('No connections have been set, please create one : (production)', 'production'); - $this->storeServerCredentials($availableConnections, $connectionName); - } else { - foreach ($activeConnections as $connectionName) { - $servers = array_get($availableConnections, $connectionName.'.servers'); - $servers = array_keys($servers); - foreach ($servers as $server) { - $this->storeServerCredentials($availableConnections, $connectionName, $server); - } + $this->getConnectionCredentials($connectionName); + + return; + } + + // Else loop through the connections and fill in credentials + foreach ($activeConnections as $connectionName) { + $servers = array_get($availableConnections, $connectionName.'.servers'); + $servers = array_keys($servers); + foreach ($servers as $server) { + $this->getConnectionCredentials($connectionName, $server); } } } @@ -69,54 +65,78 @@ public function getServerCredentials() /** * Verifies and stores credentials for the given connection name * - * @param array $connections * @param string $connectionName * @param integer|null $server */ - protected function storeServerCredentials($connections, $connectionName, $server = null) + protected function getConnectionCredentials($connectionName, $server = null) { - // Check for server credentials - $connection = $connectionName.'.servers'; - $connection = !is_null($server) ? $connection.'.'.$server : $connection; - $connection = array_get($connections, $connection, array()); - $credentials = array( + // Get the available connections + $connections = $this->connections->getAvailableConnections(); + + // Get the credentials for the asked connection + $connection = $connectionName.'.servers'; + $connection = !is_null($server) ? $connection.'.'.$server : $connection; + $connection = array_get($connections, $connection, array()); + + // Update connection name + $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; + + // Gather credentials + $credentials = $this->gatherCredentials(array( 'host' => true, 'username' => true, 'password' => false, 'keyphrase' => null, 'key' => false, 'agent' => false - ); - - // Update connection name - $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; - - // Gather credentials - foreach ($credentials as $credential => $required) { - ${$credential} = $this->getCredential($connection, $credential); - if ($required and !${$credential}) { - ${$credential} = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); - } - } + ), $connection, $handle); // Get password or key - if (!$password and !$key) { + if (!$credentials['password'] and !$credentials['key']) { $type = $this->command->ask('No password or SSH key is set for ['.$handle.'], which would you use ? [key/password]', 'key'); if ($type == 'key') { - $default = $this->app['rocketeer.rocketeer']->getUserHomeFolder().'/.ssh/id_rsa'; - $key = $this->command->ask('Please enter the full path to your key ('.$default.')', $default); - $keyphrase = $this->command->ask('If a keyphrase is required, provide it'); + $default = $this->rocketeer->getDefaultKeyPath(); + $credentials['key'] = $this->command->ask('Please enter the full path to your key ('.$default.')', $default); + $credentials['keyphrase'] = $this->command->ask('If a keyphrase is required, provide it'); } else { - $password = $this->command->ask('Please enter your password'); + $credentials['password'] = $this->command->ask('Please enter your password'); } } // Save credentials - $credentials = compact(array_keys($credentials)); $this->connections->syncConnectionCredentials($connectionName, $credentials, $server); $this->connections->setConnection($connectionName); } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Loop through credentials and store the missing ones + * + * @param string[] $credentials + * @param string $current + * @param string $handle + * + * @return array + */ + protected function gatherCredentials($credentials, $current, $handle) + { + // Loop throguh credentials and ask missing ones + foreach ($credentials as $credential => $required) { + ${$credential} = $this->getCredential($current, $credential); + if ($required and !${$credential}) { + ${$credential} = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); + } + } + + // Reform array + $credentials = compact(array_keys($credentials)); + + return $credentials; + } + /** * Check if a credential needs to be filled * From 3bc8b6e3c4f51453dd92f0b6dc1108d4e882b3bc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 02:45:16 +0200 Subject: [PATCH 109/424] Use 91428 for variable interpolation --- src/Rocketeer/Services/CredentialsGatherer.php | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 37545180b..e100d8dab 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -125,9 +125,9 @@ protected function gatherCredentials($credentials, $current, $handle) { // Loop throguh credentials and ask missing ones foreach ($credentials as $credential => $required) { - ${$credential} = $this->getCredential($current, $credential); - if ($required and !${$credential}) { - ${$credential} = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); + $$credentials = $this->getCredential($current, $credential); + if ($required and !$$credentials) { + $$credentials = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); } } From 0dd6f0b580d55bac6dd99d79eac13df544c90127 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 03:14:08 +0200 Subject: [PATCH 110/424] Add some tests for CredentialsGatherer --- .../Services/CredentialsGatherer.php | 14 +- src/Rocketeer/Traits/HasLocator.php | 1 + tests/Services/CredentialsGathererTest.php | 131 ++++++++++++++++++ 3 files changed, 141 insertions(+), 5 deletions(-) create mode 100644 tests/Services/CredentialsGathererTest.php diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index e100d8dab..b25c34e4e 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -16,8 +16,12 @@ public function getRepositoryCredentials() $repositoryCredentials = $this->connections->getRepositoryCredentials(); $credentials = ['repository' => true]; - // If we didn't specify a login/password and the repository uses HTTP, ask for them too - if (!array_get($repositoryCredentials, 'repository') or $this->connections->needsCredentials()) { + // If we didn't specify a login/password ask for both the first time + if (!$this->getCredential($repositoryCredentials, 'repository')) { + $credentials += ['username' => true, 'password' => true]; + + } elseif($this->connections->needsCredentials()) { + // Else assume the repository is passwordless and only ask again for username $credentials += ['username' => true, 'password' => false]; } @@ -125,9 +129,9 @@ protected function gatherCredentials($credentials, $current, $handle) { // Loop throguh credentials and ask missing ones foreach ($credentials as $credential => $required) { - $$credentials = $this->getCredential($current, $credential); - if ($required and !$$credentials) { - $$credentials = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); + $$credential = $this->getCredential($current, $credential); + if ($required and !$$credential) { + $$credential = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); } } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 78a62b7c4..1e22db147 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -66,6 +66,7 @@ public function __get($key) $shortcuts = array( 'bash' => 'rocketeer.bash', 'command' => 'rocketeer.command', + 'credentials' => 'rocketeer.credentials', 'connections' => 'rocketeer.connections', 'console' => 'rocketeer.console', 'history' => 'rocketeer.history', diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php new file mode 100644 index 000000000..34a49483a --- /dev/null +++ b/tests/Services/CredentialsGathererTest.php @@ -0,0 +1,131 @@ +repository = 'git@github.com:Anahkiasen/rocketeer.git'; + $this->username = 'Anahkiasen'; + $this->password = 'foobar'; + } + + public function testIgnoresPlaceholdersWhenFillingCredentials() + { + $this->mockAnswers(array( + 'No repository is set for [repository]' => $this->repository, + 'No username is set for [repository]' => $this->username, + 'No password is set for [repository]' => $this->password, + )); + + $this->givenConfiguredCredentials(['repository' => '{foobar}']); + + $this->assertStoredCredentialsEquals(array( + 'repository' => $this->repository, + 'username' => $this->username, + 'password' => $this->password + )); + + $this->credentials->getRepositoryCredentials(); + } + + public function testCanGetRepositoryCredentials() + { + $this->mockAnswers(array( + 'No repository is set for [repository]' => $this->repository, + 'No username is set for [repository]' => $this->username, + 'No password is set for [repository]' => $this->password, + )); + + $this->givenConfiguredCredentials([]); + + $this->assertStoredCredentialsEquals(array( + 'repository' => $this->repository, + 'username' => $this->username, + 'password' => $this->password + )); + + $this->credentials->getRepositoryCredentials(); + } + + public function testDoesntAskForRepositoryCredentialsIfUneeded() + { + $this->mockAnswers(); + $this->givenConfiguredCredentials(['repository' => $this->repository], false); + $this->assertStoredCredentialsEquals(array( + 'repository' => $this->repository, + )); + + $this->credentials->getRepositoryCredentials(); + } + + public function testCanFillRepositoryCredentialsIfNeeded() + { + $this->mockAnswers(array( + 'No username is set for [repository]' => $this->username, + )); + + $this->givenConfiguredCredentials(['repository' => $this->repository], true); + + $this->assertStoredCredentialsEquals(array( + 'repository' => $this->repository, + 'username' => 'Anahkiasen', + 'password' => null, + )); + + $this->credentials->getRepositoryCredentials(); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Mock a set of question/answers + * + * @param array $answers + */ + protected function mockAnswers($answers = array()) + { + $this->mock('rocketeer.command', 'Command', function ($mock) use ($answers) { + if (!$answers) { + return $mock->shouldReceive('ask')->never(); + } + + foreach ($answers as $question => $answer) { + $mock = $mock->shouldReceive('ask')->with($question.', please provide one :')->andReturn($answer); + } + + return $mock; + }); + } + + /** + * Assert a certain set of credentials are saved to storage + * + * @param array $credentials + */ + protected function assertStoredCredentialsEquals(array $credentials) + { + $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) use ($credentials) { + return $mock->shouldReceive('set')->with('credentials', $credentials); + }); + } + + /** + * @param array $credentials + * @param boolean $need + */ + protected function givenConfiguredCredentials(array $credentials, $need = false) + { + $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) use ($need, $credentials) { + return $mock + ->shouldReceive('needsCredentials')->andReturn($need) + ->shouldReceive('getRepositoryCredentials')->andReturn($credentials); + }); + } +} From b895a872b1747d5bdd518bbdc2834a9108ed628a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 03:31:58 +0200 Subject: [PATCH 111/424] Move AbstractDeployCommand to AbstractCommand --- .../AbstractCommand.php} | 34 +++++++++++++++++-- .../Console/Commands/BaseTaskCommand.php | 3 +- .../Console/Commands/CleanupCommand.php | 3 +- .../Console/Commands/DeployCommand.php | 3 +- .../Console/Commands/FlushCommand.php | 4 ++- .../Console/Commands/RollbackCommand.php | 3 +- .../Console/Commands/TestCommand.php | 4 ++- .../Console/Commands/UpdateCommand.php | 3 +- .../Services/CredentialsGatherer.php | 22 ++++++------ src/Rocketeer/Traits/HasLocator.php | 2 +- tests/Services/CredentialsGathererTest.php | 3 +- 11 files changed, 61 insertions(+), 23 deletions(-) rename src/Rocketeer/{Console/Commands/AbstractDeployCommand.php => Abstracts/AbstractCommand.php} (77%) diff --git a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php similarity index 77% rename from src/Rocketeer/Console/Commands/AbstractDeployCommand.php rename to src/Rocketeer/Abstracts/AbstractCommand.php index 80037602a..ac16060f8 100644 --- a/src/Rocketeer/Console/Commands/AbstractDeployCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Console\Commands; +namespace Rocketeer\Abstracts; use Closure; use Illuminate\Console\Command; @@ -19,7 +19,7 @@ * * @author Maxime Fabre */ -abstract class AbstractDeployCommand extends Command +abstract class AbstractCommand extends Command { /** * Run the tasks @@ -101,12 +101,40 @@ protected function fireTasksQueue($tasks) unset($this->laravel['rocketeer.command']); } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Ask a question to the user + * + * @param string $question + * @param string|null $default + * @param array $choices + * + * @return string + */ + public function askWith($question, $default = null, $choices = array()) + { + // If multiple choices, show them + if ($choices) { + $question .= ' ['.implode('/', $choices).']'; + } + + // If default, show it in the question + if ($default) { + $question .= ' ('.$default.')'; + } + + return $this->ask($question, $default); + } + /** * Time an operation and display it afterwards * * @param Closure $callback */ - protected function time(Closure $callback) + public function time(Closure $callback) { // Start timer, execute callback, close timer $timerStart = microtime(true); diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index 80498aac4..d6d45aa0d 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; use Rocketeer\Abstracts\AbstractTask; /** @@ -17,7 +18,7 @@ * * @author Maxime Fabre */ -class BaseTaskCommand extends AbstractDeployCommand +class BaseTaskCommand extends AbstractCommand { /** * The default name diff --git a/src/Rocketeer/Console/Commands/CleanupCommand.php b/src/Rocketeer/Console/Commands/CleanupCommand.php index 91397f4d4..f789a9a7f 100644 --- a/src/Rocketeer/Console/Commands/CleanupCommand.php +++ b/src/Rocketeer/Console/Commands/CleanupCommand.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputOption; /** @@ -16,7 +17,7 @@ * * @author Maxime Fabre */ -class CleanupCommand extends AbstractDeployCommand +class CleanupCommand extends AbstractCommand { /** * The console command name. diff --git a/src/Rocketeer/Console/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php index 18eb4ad50..c0bb3c3b2 100644 --- a/src/Rocketeer/Console/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputOption; /** @@ -16,7 +17,7 @@ * * @author Maxime Fabre */ -class DeployCommand extends AbstractDeployCommand +class DeployCommand extends AbstractCommand { /** * The console command name. diff --git a/src/Rocketeer/Console/Commands/FlushCommand.php b/src/Rocketeer/Console/Commands/FlushCommand.php index 21d9cdfb6..8ae2f9c1d 100644 --- a/src/Rocketeer/Console/Commands/FlushCommand.php +++ b/src/Rocketeer/Console/Commands/FlushCommand.php @@ -9,12 +9,14 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; + /** * Flushes any custom storage Rocketeer has created * * @author Maxime Fabre */ -class FlushCommand extends AbstractDeployCommand +class FlushCommand extends AbstractCommand { /** * The console command name. diff --git a/src/Rocketeer/Console/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php index 6b0a766d0..d576e4fac 100644 --- a/src/Rocketeer/Console/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputOption; @@ -17,7 +18,7 @@ * * @author Maxime Fabre */ -class RollbackCommand extends AbstractDeployCommand +class RollbackCommand extends AbstractCommand { /** * The console command name. diff --git a/src/Rocketeer/Console/Commands/TestCommand.php b/src/Rocketeer/Console/Commands/TestCommand.php index 60232e52b..facb3f005 100644 --- a/src/Rocketeer/Console/Commands/TestCommand.php +++ b/src/Rocketeer/Console/Commands/TestCommand.php @@ -9,12 +9,14 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; + /** * Run the tests on the server and displays the output * * @author Maxime Fabre */ -class TestCommand extends AbstractDeployCommand +class TestCommand extends AbstractCommand { /** * The console command name. diff --git a/src/Rocketeer/Console/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php index 3b6e936f1..1df33db74 100644 --- a/src/Rocketeer/Console/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Console\Commands; +use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputOption; /** @@ -16,7 +17,7 @@ * * @author Maxime Fabre */ -class UpdateCommand extends AbstractDeployCommand +class UpdateCommand extends AbstractCommand { /** * The console command name. diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index b25c34e4e..d5ff24ec5 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -19,8 +19,7 @@ public function getRepositoryCredentials() // If we didn't specify a login/password ask for both the first time if (!$this->getCredential($repositoryCredentials, 'repository')) { $credentials += ['username' => true, 'password' => true]; - - } elseif($this->connections->needsCredentials()) { + } elseif ($this->connections->needsCredentials()) { // Else assume the repository is passwordless and only ask again for username $credentials += ['username' => true, 'password' => false]; } @@ -50,7 +49,7 @@ public function getServerCredentials() // If we didn't set any connection, ask for them if (!$activeConnections) { - $connectionName = $this->command->ask('No connections have been set, please create one : (production)', 'production'); + $connectionName = $this->command->askWith('No connections have been set, please create one:', 'production'); $this->getConnectionCredentials($connectionName); return; @@ -97,13 +96,14 @@ protected function getConnectionCredentials($connectionName, $server = null) // Get password or key if (!$credentials['password'] and !$credentials['key']) { - $type = $this->command->ask('No password or SSH key is set for ['.$handle.'], which would you use ? [key/password]', 'key'); + $types = ['key', 'password']; + $type = $this->command->askWith('No password or SSH key is set for ['.$handle.'], which would you use?', 'key', $types); if ($type == 'key') { $default = $this->rocketeer->getDefaultKeyPath(); - $credentials['key'] = $this->command->ask('Please enter the full path to your key ('.$default.')', $default); - $credentials['keyphrase'] = $this->command->ask('If a keyphrase is required, provide it'); + $credentials['key'] = $this->command->askWith('Please enter the full path to your key', $default); + $credentials['keyphrase'] = $this->command->askWith('If a keyphrase is required, provide it'); } else { - $credentials['password'] = $this->command->ask('Please enter your password'); + $credentials['password'] = $this->command->askWith('Please enter your password'); } } @@ -119,9 +119,9 @@ protected function getConnectionCredentials($connectionName, $server = null) /** * Loop through credentials and store the missing ones * - * @param string[] $credentials - * @param string $current - * @param string $handle + * @param boolean[] $credentials + * @param string $current + * @param string $handle * * @return array */ @@ -131,7 +131,7 @@ protected function gatherCredentials($credentials, $current, $handle) foreach ($credentials as $credential => $required) { $$credential = $this->getCredential($current, $credential); if ($required and !$$credential) { - $$credential = $this->command->ask('No '.$credential.' is set for ['.$handle.'], please provide one :'); + $$credential = $this->command->askWith('No '.$credential.' is set for ['.$handle.'], please provide one:'); } } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 1e22db147..e4dd504bc 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -20,8 +20,8 @@ * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Log\Writer log * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\AbstractCommand command * @property \Rocketeer\Bash bash - * @property \Rocketeer\Console\Commands\AbstractDeployCommand command * @property \Rocketeer\Console\Console console * @property \Rocketeer\Interfaces\ScmInterface scm * @property \Rocketeer\Interfaces\StrategyInterface strategy diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index 34a49483a..b0c9bddbc 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -1,6 +1,7 @@ $answer) { - $mock = $mock->shouldReceive('ask')->with($question.', please provide one :')->andReturn($answer); + $mock = $mock->shouldReceive('askWith')->with($question.', please provide one:')->andReturn($answer); } return $mock; From 1e94939a35a7573d10a0ad30a1f3c3ff18d220fc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 03:34:39 +0200 Subject: [PATCH 112/424] More work on questions --- src/Rocketeer/Abstracts/AbstractCommand.php | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index ac16060f8..b23c565c5 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -106,7 +106,7 @@ protected function fireTasksQueue($tasks) ////////////////////////////////////////////////////////////////////// /** - * Ask a question to the user + * Ask a question to the user, with default and/or multiple choices * * @param string $question * @param string|null $default @@ -116,14 +116,16 @@ protected function fireTasksQueue($tasks) */ public function askWith($question, $default = null, $choices = array()) { + // If default, show it in the question + if ($default) { + $question .= ' ('.$default.')'; + } + // If multiple choices, show them if ($choices) { $question .= ' ['.implode('/', $choices).']'; - } - // If default, show it in the question - if ($default) { - $question .= ' ('.$default.')'; + return $this->askWithCompletion($question, $choices, $default); } return $this->ask($question, $default); From 2bf49943337b2218cc2d3f42d1383cea88a59906 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 03:35:20 +0200 Subject: [PATCH 113/424] Remove wtf uses --- src/Rocketeer/Services/ConnectionsHandler.php | 1 - src/Rocketeer/Services/TasksQueue.php | 1 - 2 files changed, 2 deletions(-) diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index 17344e4a1..06715eead 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -12,7 +12,6 @@ use Illuminate\Support\Arr; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; -use string; /** * Handles, get and return, the various connections/stages diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index d944722d5..7e48e086b 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -16,7 +16,6 @@ use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Connection; use Rocketeer\Traits\HasLocator; -use string; /** * Handles the building and execution of tasks From a653e2849c5b8a2ea04da69130734c165afa8e72 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 8 Aug 2014 03:35:54 +0200 Subject: [PATCH 114/424] CS fixes --- tests/IgniterTest.php | 6 +++--- tests/RocketeerTest.php | 14 +++++++------- tests/Services/Storages/LocalStorageTest.php | 2 +- tests/Services/Storages/ServerStorageTest.php | 2 +- 4 files changed, 12 insertions(+), 12 deletions(-) diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index 9a100b829..9fb2521c7 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -109,7 +109,7 @@ public function testCanGetStoragePathWhenNoneBound() public function testCanGetStoragePathIfUnix() { - $this->app['path.base'] = '/app'; + $this->app['path.base'] = '/app'; $this->app['path.storage'] = '/app/local/folder'; $storage = $this->igniter->getStoragePath(); @@ -118,7 +118,7 @@ public function testCanGetStoragePathIfUnix() public function testCanGetStorageIfWindows() { - $this->app['path.base'] = 'C:\Sites\app'; + $this->app['path.base'] = 'C:\Sites\app'; $this->app['path.storage'] = 'C:\Sites\app\local\folder'; $storage = $this->igniter->getStoragePath(); @@ -127,7 +127,7 @@ public function testCanGetStorageIfWindows() public function testCanGetStorageWhenBothForSomeReason() { - $this->app['path.base'] = 'C:\Sites\app'; + $this->app['path.base'] = 'C:\Sites\app'; $this->app['path.storage'] = 'C:/Sites/app/local/folder'; $storage = $this->igniter->getStoragePath(); diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 7ba1e59a2..3b6d6e2e4 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -92,17 +92,17 @@ public function testRocketeerCanGuessWhichStageHesIn() public function testCanGetUserHomeFolder() { $_SERVER['HOME'] = '/some/folder'; - $home = $this->rocketeer->getUserHomeFolder(); + $home = $this->rocketeer->getUserHomeFolder(); $this->assertEquals('/some/folder', $home); } public function testCanGetWindowsHomeFolder() { - $_SERVER['HOME'] = null; + $_SERVER['HOME'] = null; $_SERVER['HOMEDRIVE'] = 'C:'; - $_SERVER['HOMEPATH'] = '\Users\someuser'; - $home = $this->rocketeer->getUserHomeFolder(); + $_SERVER['HOMEPATH'] = '\Users\someuser'; + $home = $this->rocketeer->getUserHomeFolder(); $this->assertEquals('C:\Users\someuser', $home); } @@ -111,16 +111,16 @@ public function testCancelsIfNoHomeFolder() { $this->setExpectedException('Exception'); - $_SERVER['HOME'] = null; + $_SERVER['HOME'] = null; $_SERVER['HOMEDRIVE'] = 'C:'; - $_SERVER['HOMEPATH'] = null; + $_SERVER['HOMEPATH'] = null; $this->rocketeer->getUserHomeFolder(); } public function testCanGetRocketeerFolder() { $_SERVER['HOME'] = '/some/folder'; - $rocketeer = $this->rocketeer->getRocketeerConfigFolder(); + $rocketeer = $this->rocketeer->getRocketeerConfigFolder(); $this->assertEquals('/some/folder/.rocketeer', $rocketeer); } diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index bb2aacd2b..3b12e2993 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -56,7 +56,7 @@ public function testCanComputeHashAccordingToContentsOfFiles() }); $storage = new LocalStorage($this->app, 'deployments', $this->server); - $hash = $storage->getHash(); + $hash = $storage->getHash(); $this->assertEquals(md5('["foo"]["bar"]'), $hash); } diff --git a/tests/Services/Storages/ServerStorageTest.php b/tests/Services/Storages/ServerStorageTest.php index 46350bc3e..e66ddc09c 100644 --- a/tests/Services/Storages/ServerStorageTest.php +++ b/tests/Services/Storages/ServerStorageTest.php @@ -9,7 +9,7 @@ class ServerStorageTest extends RocketeerTestCase public function testCanDestroyRemoteFile() { $server = new ServerStorage($this->app, 'test'); - $file = $server->getFilepath(); + $file = $server->getFilepath(); $server->destroy(); $this->assertFileNotExists($file); From 64119f098dc29360123ef04dd1a5fef4ab39f31a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 14:20:35 +0200 Subject: [PATCH 115/424] Add a few tests --- composer.lock | 142 ++++++++++++++++-- .../Services/CredentialsGatherer.php | 2 +- tests/Services/CredentialsGathererTest.php | 79 +++++++++- 3 files changed, 202 insertions(+), 21 deletions(-) diff --git a/composer.lock b/composer.lock index 21f8f40cc..4511f2e06 100644 --- a/composer.lock +++ b/composer.lock @@ -874,6 +874,119 @@ ], "time": "2014-07-18 03:44:47" }, + { + "name": "ocramius/instantiator", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/Ocramius/Instantiator.git", + "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Ocramius/Instantiator/zipball/cc754c2289ffd4483c319f6ed6ee88ce21676f64", + "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64", + "shasum": "" + }, + "require": { + "ocramius/lazy-map": "1.0.*", + "php": "~5.3" + }, + "require-dev": { + "athletic/athletic": "~0.1.8", + "ext-phar": "*", + "phpunit/phpunit": "~4.0", + "squizlabs/php_codesniffer": "2.0.*@ALPHA" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "psr-0": { + "Instantiator\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Marco Pivetta", + "email": "ocramius@gmail.com", + "homepage": "http://ocramius.github.com/", + "role": "Developer" + } + ], + "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors", + "homepage": "https://github.com/Ocramius/Instantiator", + "keywords": [ + "constructor", + "instantiate" + ], + "time": "2014-06-15 11:44:46" + }, + { + "name": "ocramius/lazy-map", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/Ocramius/LazyMap.git", + "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Ocramius/LazyMap/zipball/7fe3d347f5e618bcea7d39345ff83f3651d8b752", + "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "athletic/athletic": "~0.1.6", + "phpmd/phpmd": "1.5.*", + "phpunit/phpunit": ">=3.7", + "satooshi/php-coveralls": "~0.6", + "squizlabs/php_codesniffer": "1.4.*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-0": { + "LazyMap\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Marco Pivetta", + "email": "ocramius@gmail.com", + "homepage": "http://ocramius.github.com/", + "role": "Developer" + } + ], + "description": "A library that provides lazy instantiation logic for a map of objects", + "homepage": "https://github.com/Ocramius/LazyMap", + "keywords": [ + "lazy", + "lazy instantiation", + "lazy loading", + "map", + "service location" + ], + "time": "2013-11-09 22:30:54" + }, { "name": "patchwork/utf8", "version": "v1.1.25", @@ -1283,16 +1396,16 @@ }, { "name": "phpunit/phpunit", - "version": "4.1.5", + "version": "4.2.0", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "e0de628ff849e1804c7d644cbaa16d0a5504807a" + "reference": "58db726aa45fe26bca93f692cb3d77e9a46b7830" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/e0de628ff849e1804c7d644cbaa16d0a5504807a", - "reference": "e0de628ff849e1804c7d644cbaa16d0a5504807a", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/58db726aa45fe26bca93f692cb3d77e9a46b7830", + "reference": "58db726aa45fe26bca93f692cb3d77e9a46b7830", "shasum": "" }, "require": { @@ -1306,7 +1419,7 @@ "phpunit/php-file-iterator": "~1.3.1", "phpunit/php-text-template": "~1.2", "phpunit/php-timer": "~1.0.2", - "phpunit/phpunit-mock-objects": "2.1.5", + "phpunit/phpunit-mock-objects": "~2.2", "sebastian/comparator": "~1.0", "sebastian/diff": "~1.1", "sebastian/environment": "~1.0", @@ -1323,7 +1436,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-master": "4.1.x-dev" + "dev-master": "4.2.x-dev" } }, "autoload": { @@ -1353,28 +1466,29 @@ "testing", "xunit" ], - "time": "2014-08-07 05:43:51" + "time": "2014-08-08 05:13:30" }, { "name": "phpunit/phpunit-mock-objects", - "version": "2.1.5", + "version": "2.2.0", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", - "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a" + "reference": "42e589e08bc86e3e9bdf20d385e948347788505b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/7878b9c41edb3afab92b85edf5f0981014a2713a", - "reference": "7878b9c41edb3afab92b85edf5f0981014a2713a", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/42e589e08bc86e3e9bdf20d385e948347788505b", + "reference": "42e589e08bc86e3e9bdf20d385e948347788505b", "shasum": "" }, "require": { + "ocramius/instantiator": "~1.0", "php": ">=5.3.3", "phpunit/php-text-template": "~1.2" }, "require-dev": { - "phpunit/phpunit": "~4.1" + "phpunit/phpunit": "4.2.*@dev" }, "suggest": { "ext-soap": "*" @@ -1382,7 +1496,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-master": "2.1.x-dev" + "dev-master": "2.2.x-dev" } }, "autoload": { @@ -1410,7 +1524,7 @@ "mock", "xunit" ], - "time": "2014-06-12 07:22:15" + "time": "2014-08-02 13:50:58" }, { "name": "raveren/kint", diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index d5ff24ec5..8b64c026f 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -48,7 +48,7 @@ public function getServerCredentials() $activeConnections = $this->connections->getConnections(); // If we didn't set any connection, ask for them - if (!$activeConnections) { + if (!$activeConnections or empty($availableConnections)) { $connectionName = $this->command->askWith('No connections have been set, please create one:', 'production'); $this->getConnectionCredentials($connectionName); diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index b0c9bddbc..d70363345 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -6,6 +6,8 @@ class CredentialsGathererTest extends RocketeerTestCase { + protected $key = '/.ssh/id_rsa'; + public function setUp() { parent::setUp(); @@ -13,6 +15,7 @@ public function setUp() $this->repository = 'git@github.com:Anahkiasen/rocketeer.git'; $this->username = 'Anahkiasen'; $this->password = 'foobar'; + $this->host = 'some.host'; } public function testIgnoresPlaceholdersWhenFillingCredentials() @@ -23,7 +26,7 @@ public function testIgnoresPlaceholdersWhenFillingCredentials() 'No password is set for [repository]' => $this->password, )); - $this->givenConfiguredCredentials(['repository' => '{foobar}']); + $this->givenConfiguredRepositoryCredentials(['repository' => '{foobar}']); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, @@ -42,7 +45,7 @@ public function testCanGetRepositoryCredentials() 'No password is set for [repository]' => $this->password, )); - $this->givenConfiguredCredentials([]); + $this->givenConfiguredRepositoryCredentials([]); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, @@ -56,7 +59,7 @@ public function testCanGetRepositoryCredentials() public function testDoesntAskForRepositoryCredentialsIfUneeded() { $this->mockAnswers(); - $this->givenConfiguredCredentials(['repository' => $this->repository], false); + $this->givenConfiguredRepositoryCredentials(['repository' => $this->repository], false); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, )); @@ -70,7 +73,7 @@ public function testCanFillRepositoryCredentialsIfNeeded() 'No username is set for [repository]' => $this->username, )); - $this->givenConfiguredCredentials(['repository' => $this->repository], true); + $this->givenConfiguredRepositoryCredentials(['repository' => $this->repository], true); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, @@ -81,6 +84,69 @@ public function testCanFillRepositoryCredentialsIfNeeded() $this->credentials->getRepositoryCredentials(); } + public function testCanGetServerCredentialsIfNoneDefined() + { + $this->swapConfig(array( + 'remote.connections' => [], + )); + + $this->mockAnswers(array( + 'No host is set for [production]' => $this->host, + 'No username is set for [production]' => $this->username, + 'Please enter your password' => $this->password, + )); + + $this->command->shouldReceive('askWith')->with('No connections have been set, please create one:', 'production')->andReturn('production'); + $this->command->shouldReceive('askWith')->with( + 'No password or SSH key is set for [production], which would you use?', + 'key', ['key', 'password'] + )->andReturn('password'); + $this->command->shouldReceive('option')->andReturn(null); + + $this->credentials->getServerCredentials(); + + $credentials = $this->connections->getServerCredentials('production', 0); + $this->assertEquals(array( + 'host' => $this->host, + 'username' => $this->username, + 'password' => $this->password, + 'keyphrase' => null, + 'key' => null, + 'agent' => null, + ), $credentials); + } + + public function testCanGetCredentialsForSpecifiedConnection() + { + $key = $this->rocketeer->getDefaultKeyPath(); + $this->mockAnswers(array( + 'No host is set for [staging#0]' => $this->host, + 'No username is set for [staging#0]' => $this->username, + 'If a keyphrase is required, provide it' => 'KEYPHRASE', + )); + + $this->command->shouldReceive('option')->with('on')->andReturn('staging'); + $this->command->shouldReceive('askWith')->with( + 'Please enter the full path to your key', $key + )->andReturn($key); + $this->command->shouldReceive('askWith')->with( + 'No password or SSH key is set for [staging#0], which would you use?', + 'key', ['key', 'password'] + )->andReturn('key'); + + $this->credentials->getServerCredentials(); + + $credentials = $this->connections->getServerCredentials('staging', 0); + $this->assertEquals(array( + 'host' => $this->host, + 'username' => $this->username, + 'password' => null, + 'keyphrase' => 'KEYPHRASE', + 'key' => $key, + 'agent' => null, + ), $credentials); + } + ////////////////////////////////////////////////////////////////////// ////////////////////////////// HELPERS /////////////////////////////// ////////////////////////////////////////////////////////////////////// @@ -98,7 +164,8 @@ protected function mockAnswers($answers = array()) } foreach ($answers as $question => $answer) { - $mock = $mock->shouldReceive('askWith')->with($question.', please provide one:')->andReturn($answer); + $question = strpos($question, 'is set for') !== false ? $question.', please provide one:' : $question; + $mock = $mock->shouldReceive('askWith')->with($question)->andReturn($answer); } return $mock; @@ -121,7 +188,7 @@ protected function assertStoredCredentialsEquals(array $credentials) * @param array $credentials * @param boolean $need */ - protected function givenConfiguredCredentials(array $credentials, $need = false) + protected function givenConfiguredRepositoryCredentials(array $credentials, $need = false) { $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) use ($need, $credentials) { return $mock From 4a555fc306ddaa5ae4805f9691f28ea5dd496230 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 15:03:53 +0200 Subject: [PATCH 116/424] Add some queue tests --- src/Rocketeer/Services/TasksQueue.php | 30 ++++++++++++++++++------ tests/Dummies/MyCustomHaltingTask.php | 12 ++++++++++ tests/Services/TasksQueueTest.php | 33 +++++++++++++++++++++++++++ tests/TestCases/RocketeerTestCase.php | 12 ++++++---- 4 files changed, 75 insertions(+), 12 deletions(-) create mode 100644 tests/Dummies/MyCustomHaltingTask.php diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index 7e48e086b..05cb73225 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -26,6 +26,11 @@ class TasksQueue { use HasLocator; + /** + * @type Parallel + */ + protected $parallel; + /** * A list of Tasks to execute * @@ -47,6 +52,14 @@ class TasksQueue */ protected $output = array(); + /** + * @param Parallel $parallel + */ + public function setParallel($parallel) + { + $this->parallel = $parallel; + } + //////////////////////////////////////////////////////////////////// ////////////////////////////// SHORTCUTS /////////////////////////// //////////////////////////////////////////////////////////////////// @@ -109,12 +122,14 @@ public function run(array $tasks) throw new Exception('Parallel jobs require the PCNTL extension'); } - $parallel = new Parallel(); - $parallel->run($pipeline); + $this->parallel = $this->parallel ?: new Parallel(); + $this->parallel->run($pipeline); } else { - foreach ($pipeline as $job) { - $job(); - } + $key = 0; + do { + $continue = $pipeline[$key](); + $key++; + } while($continue and isset($pipeline[$key])); } return $this->output; @@ -139,7 +154,7 @@ protected function runQueue($tasks, $stage = null) $state = $task->fire(); $this->output[] = $state; if ($task->wasHalted() or $state === false) { - $this->command->error('Deployment was canceled by task "'.$task->getName().'"'); + $this->command->error('The tasks que was canceled by task "'.$task->getName().'"'); return false; } @@ -193,7 +208,8 @@ protected function buildPipeline(array $queue) foreach ($pipeline as $key => $job) { $pipeline[$key] = function () use ($job) { $this->connections->setConnection($job['connection'], $job['server']); - $this->runQueue($job['queue'], $job['stage']); + + return $this->runQueue($job['queue'], $job['stage']); }; } diff --git a/tests/Dummies/MyCustomHaltingTask.php b/tests/Dummies/MyCustomHaltingTask.php new file mode 100644 index 000000000..8d5a411b4 --- /dev/null +++ b/tests/Dummies/MyCustomHaltingTask.php @@ -0,0 +1,12 @@ +halt(); + } +} diff --git a/tests/Services/TasksQueueTest.php b/tests/Services/TasksQueueTest.php index 58122b26d..f5eec8337 100644 --- a/tests/Services/TasksQueueTest.php +++ b/tests/Services/TasksQueueTest.php @@ -1,6 +1,9 @@ shouldReceive('run')->once()->with(Mockery::type('array')) + ->mock(); + + $this->mockCommand(['parallel' => true]); + $this->tasksQueue()->setParallel($parallel); + + $this->tasksQueue()->execute(['ls', 'ls']); + } + + public function testCanCancelQueueIfTaskFails() + { + $this->expectOutputString('The tasks que was canceled by task "MyCustomHaltingTask"'); + + $this->mockCommand([], array( + 'error' => function ($error) { + echo $error; + }, + )); + + $output = $this->tasksQueue()->execute(array( + 'Rocketeer\Dummies\MyCustomHaltingTask', + 'Rocketeer\Dummies\MyCustomTask', + )); + + $this->assertEquals([false], $output); + } } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index b0799e996..78ad5e37d 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -142,11 +142,13 @@ protected function mockCommand($options = array(), $expectations = array()) { // Default options $options = array_merge(array( - 'pretend' => false, - 'verbose' => false, - 'tests' => false, - 'migrate' => false, - 'seed' => false, + 'pretend' => false, + 'verbose' => false, + 'tests' => false, + 'migrate' => false, + 'seed' => false, + 'stage' => false, + 'parallel' => false, ), $options); $this->app['rocketeer.command'] = $this->getCommand($expectations, $options); From b1a178efd36ba44c1a997e7d9ab4048259df6a8e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 15:18:27 +0200 Subject: [PATCH 117/424] Add some more tests --- phpunit.xml | 4 +-- .../{ScmTest.php => AbstractScmTest.php} | 2 +- ...torageTest.php => AbstractStorageTest.php} | 3 +-- .../{TaskTest.php => AbstractTaskTest.php} | 25 ++++++++++++++++++- 4 files changed, 27 insertions(+), 7 deletions(-) rename tests/Abstracts/{ScmTest.php => AbstractScmTest.php} (94%) rename tests/Abstracts/{StorageTest.php => AbstractStorageTest.php} (94%) rename tests/Abstracts/{TaskTest.php => AbstractTaskTest.php} (69%) diff --git a/phpunit.xml b/phpunit.xml index 93129fcc9..92384b66b 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -16,10 +16,8 @@ src/Rocketeer src/Rocketeer/RocketeerServiceProvider.php - src/Rocketeer/Console/WhitespaceCompactor.php - src/Rocketeer/Console/Compiler.php src/Rocketeer/Console - src/Rocketeer/Commands + src/Rocketeer/Interfaces src/Rocketeer/Facades diff --git a/tests/Abstracts/ScmTest.php b/tests/Abstracts/AbstractScmTest.php similarity index 94% rename from tests/Abstracts/ScmTest.php rename to tests/Abstracts/AbstractScmTest.php index e906787ad..4ff715c50 100644 --- a/tests/Abstracts/ScmTest.php +++ b/tests/Abstracts/AbstractScmTest.php @@ -4,7 +4,7 @@ use Rocketeer\Scm\Git; use Rocketeer\TestCases\RocketeerTestCase; -class ScmTest extends RocketeerTestCase +class AbstractScmTest extends RocketeerTestCase { public function testCanGetSprintfCommand() { diff --git a/tests/Abstracts/StorageTest.php b/tests/Abstracts/AbstractStorageTest.php similarity index 94% rename from tests/Abstracts/StorageTest.php rename to tests/Abstracts/AbstractStorageTest.php index 9ac8e077c..4fb94860f 100644 --- a/tests/Abstracts/StorageTest.php +++ b/tests/Abstracts/AbstractStorageTest.php @@ -3,9 +3,8 @@ use Rocketeer\TestCases\RocketeerTestCase; -class StorageTest extends RocketeerTestCase +class AbstractStorageTest extends RocketeerTestCase { - public function testCanSwapContents() { $matcher = ['foo' => 'caca']; diff --git a/tests/Abstracts/TaskTest.php b/tests/Abstracts/AbstractTaskTest.php similarity index 69% rename from tests/Abstracts/TaskTest.php rename to tests/Abstracts/AbstractTaskTest.php index 20680492f..c98621ebc 100644 --- a/tests/Abstracts/TaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -3,7 +3,7 @@ use Rocketeer\TestCases\RocketeerTestCase; -class TaskTest extends RocketeerTestCase +class AbstractTaskTest extends RocketeerTestCase { public function testCanDisplayOutputOfCommandsIfVerbose() { @@ -57,4 +57,27 @@ public function testCanFireEventsDuringTasks() $task->fireEvent('test.foobar'); }, 'staging'); } + + public function testTaskCancelsIfEventHalts() + { + $this->expectOutputString('before'); + + $this->swapConfig(array( + 'rocketeer::hooks' => [], + )); + + $this->tasksQueue()->registerConfiguredEvents(); + $this->tasksQueue()->listenTo('deploy.before', function () { + echo 'before'; + return false; + }); + $this->tasksQueue()->listenTo('deploy.after', function () { + echo 'after'; + }); + + $task = $this->task('Deploy'); + $results = $task->fire(); + + $this->assertFalse($results); + } } From 36e263f23c6e3a95374e7c5bd5e68a838ad6fb28 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 15:32:46 +0200 Subject: [PATCH 118/424] Remove leftover multiserver test --- src/config/config.php | 23 ----------------------- 1 file changed, 23 deletions(-) diff --git a/src/config/config.php b/src/config/config.php index 8584914a0..b60c38618 100644 --- a/src/config/config.php +++ b/src/config/config.php @@ -34,29 +34,6 @@ 'keyphrase' => '{keyphrase}', 'agent' => '{agent}', ), - - // You can also deploy to multiple servers as part - // of one connection - 'multiservers' => array( - 'servers' => array( - 'first' => array( - 'host' => '{host}', - 'username' => '{username}', - 'password' => '{password}', - 'key' => '{key}', - 'keyphrase' => '{keyphrase}', - 'agent' => '{agent}', - ), - 'second' => array( - 'host' => '{host}', - 'username' => '{username}', - 'password' => '{password}', - 'key' => '{key}', - 'keyphrase' => '{keyphrase}', - 'agent' => '{agent}', - ), - ), - ) ), // Contextual options From 7f4276158208771568bc8a1f8336aff03b8ba0ce Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 16:51:10 +0200 Subject: [PATCH 119/424] Close #259 - Autoload contextual config files/folders --- src/Rocketeer/Rocketeer.php | 60 ++++++++++++++++++---- src/Rocketeer/RocketeerServiceProvider.php | 31 ++++++----- 2 files changed, 70 insertions(+), 21 deletions(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index f46439db3..111b5431a 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -12,6 +12,8 @@ use Exception; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; +use Symfony\Component\Finder\Finder; +use Symfony\Component\Finder\SplFileInfo; /** * Handles interaction between the User provided informations @@ -30,6 +32,26 @@ class Rocketeer */ const VERSION = '2.0.0'; + /** + * Returns what stage Rocketeer thinks he's in + * + * @param string $application + * @param string|null $path + * + * @return string|false + */ + public static function getDetectedStage($application = 'application', $path = null) + { + $current = $path ?: realpath(__DIR__); + preg_match('/'.$application.'\/([a-zA-Z0-9_-]+)\/releases\/([0-9]{14})/', $current, $matches); + + return isset($matches[1]) ? $matches[1] : false; + } + + ////////////////////////////////////////////////////////////////////// + //////////////////////////// CONFIGURATION /////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** * Get the name of the application to deploy * @@ -98,19 +120,39 @@ protected function getContextualOption($option, $type, $original = null) } /** - * Returns what stage Rocketeer thinks he's in - * - * @param string $application - * @param string|null $path + * Merge the various contextual configurations defined in userland + */ + public function mergeContextualConfigurations() + { + $finder = new Finder(); + $storage = $this->app['path.rocketeer.config']; + $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); + $files = iterator_to_array($files); + + foreach ($files as $file) { + $contents = include $file->getPathname(); + $handle = $this->computeHandleFromPath($file); + + $this->config->set($handle, $contents); + } + } + + /** + * @param SplFileInfo $file * - * @return string|false + * @return string */ - public static function getDetectedStage($application = 'application', $path = null) + protected function computeHandleFromPath(SplFileInfo $file) { - $current = $path ?: realpath(__DIR__); - preg_match('/'.$application.'\/([a-zA-Z0-9_-]+)\/releases\/([0-9]{14})/', $current, $matches); + // Get realpath + $handle = $file->getRealpath(); - return isset($matches[1]) ? $matches[1] : false; + // Format appropriately + $handle = str_replace($this->app['path.rocketeer.config'].DIRECTORY_SEPARATOR, null, $handle); + $handle = str_replace('.php', null, $handle); + $handle = str_replace(DIRECTORY_SEPARATOR, '.', $handle); + + return sprintf('rocketeer::on.%s', $handle); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 90ad91aaa..b7436565c 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -77,6 +77,9 @@ public function boot() // Bind commands $this->bindCommands(); + + // Load contextual configurations + $this->app['rocketeer.rocketeer']->mergeContextualConfigurations(); } /** @@ -147,7 +150,6 @@ public function bindCoreClasses() $this->app->singleton('rocketeer.rocketeer', function ($app) { return new Rocketeer($app); }); - $this->app->singleton('rocketeer.connections', function ($app) { return new ConnectionsHandler($app); }); @@ -184,6 +186,9 @@ public function bindCoreClasses() }); } + /** + * Bind the CredentialsGatherer and Console application + */ public function bindConsoleClasses() { $this->app->singleton('rocketeer.credentials', function ($app) { @@ -304,19 +309,21 @@ protected function registerConfig() $this->app['config']->getLoader(); // Register custom config - $custom = $this->app['path.rocketeer.config']; - if (file_exists($custom)) { - $this->app['config']->afterLoading('rocketeer', function ($me, $group, $items) use ($custom) { - $customItems = $custom.'/'.$group.'.php'; - if (!file_exists($customItems)) { - return $items; - } + $set = $this->app['path.rocketeer.config']; + if (!file_exists($set)) { + return; + } - $customItems = include $customItems; + $this->app['config']->afterLoading('rocketeer', function ($me, $group, $items) use ($set) { + $customItems = $set.'/'.$group.'.php'; + if (!file_exists($customItems)) { + return $items; + } - return array_replace($items, $customItems); - }); - } + $customItems = include $customItems; + + return array_replace($items, $customItems); + }); } /** From 9140379fa5faa4c5d78842919fcaf4331694d189 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 16:52:07 +0200 Subject: [PATCH 120/424] Use DS --- src/Rocketeer/Rocketeer.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 111b5431a..136118bed 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -148,9 +148,9 @@ protected function computeHandleFromPath(SplFileInfo $file) $handle = $file->getRealpath(); // Format appropriately - $handle = str_replace($this->app['path.rocketeer.config'].DIRECTORY_SEPARATOR, null, $handle); + $handle = str_replace($this->app['path.rocketeer.config'].DS, null, $handle); $handle = str_replace('.php', null, $handle); - $handle = str_replace(DIRECTORY_SEPARATOR, '.', $handle); + $handle = str_replace(DS, '.', $handle); return sprintf('rocketeer::on.%s', $handle); } From 2e50be8a8bb52c7948925f01f7d7ae5a60464ed9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 16:54:59 +0200 Subject: [PATCH 121/424] Fix tests --- src/Rocketeer/Rocketeer.php | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 136118bed..047bcd576 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -124,11 +124,18 @@ protected function getContextualOption($option, $type, $original = null) */ public function mergeContextualConfigurations() { - $finder = new Finder(); + // Cancel if not ignited yet $storage = $this->app['path.rocketeer.config']; + if (!is_dir($storage)) { + return; + } + + // Gather custom files + $finder = new Finder(); $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); $files = iterator_to_array($files); + // Bind their contents to the "on" array foreach ($files as $file) { $contents = include $file->getPathname(); $handle = $this->computeHandleFromPath($file); From c03eab602f4485dc3e6207f0f3e8e5c1b18e1aca Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 17:11:55 +0200 Subject: [PATCH 122/424] Add test for config merging --- tests/RocketeerTest.php | 16 ++++++++++++++++ tests/TestCases/RocketeerTestCase.php | 7 +++++++ 2 files changed, 23 insertions(+) diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 3b6d6e2e4..543157ee6 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -1,6 +1,7 @@ assertEquals('/bin/php', $path); } + + public function testCanUseFilesAndFoldersForContextualConfig() + { + $this->mock('config', 'Config', function ($mock) { + return $mock->shouldReceive('set')->once()->with('rocketeer::on.connections.production.scm', ['scm' => 'svn']); + }); + + $file = $this->customConfig.'/connections/production/scm.php'; + $this->files->makeDirectory(dirname($file), 0755, true); + $this->app['path.rocketeer.config'] = realpath($this->customConfig); + + file_put_contents($file, ' "svn");'); + + $this->rocketeer->mergeContextualConfigurations(); + } } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 78ad5e37d..dc3ec4716 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -16,6 +16,11 @@ abstract class RocketeerTestCase extends ContainerTestCase */ protected $server; + /** + * @type string + */ + protected $customConfig; + /** * The path to the local deployments file * @@ -38,6 +43,7 @@ public function setUp() parent::setUp(); // Setup local server + $this->customConfig = __DIR__.'/../_meta/config'; $this->server = __DIR__.'/../_server/foobar'; $this->deploymentsFile = __DIR__.'/../_meta/deployments.json'; @@ -114,6 +120,7 @@ protected function recreateVirtualServer() // Delete rocketeer config $binary = $rootPath.'/.rocketeer'; $this->app['files']->deleteDirectory($binary); + $this->app['files']->deleteDirectory($this->customConfig); } //////////////////////////////////////////////////////////////////// From a3485284bec0dec370c89ecd679420878ffe28d2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 17:18:09 +0200 Subject: [PATCH 123/424] Small fixes --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- src/Rocketeer/Abstracts/AbstractScm.php | 3 --- src/Rocketeer/Abstracts/AbstractStorage.php | 2 +- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- src/Rocketeer/Rocketeer.php | 2 +- src/Rocketeer/Services/ConnectionsHandler.php | 2 +- src/Rocketeer/Services/ReleasesManager.php | 2 +- src/Rocketeer/Services/TasksHandler.php | 6 ++---- src/Rocketeer/Services/TasksQueue.php | 3 +-- src/Rocketeer/Strategies/CloneStrategy.php | 2 +- src/Rocketeer/Strategies/CopyStrategy.php | 2 +- src/Rocketeer/Tasks/Check.php | 4 ++-- src/Rocketeer/Tasks/Cleanup.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 4 ++-- src/Rocketeer/Traits/BashModules/Core.php | 7 +++---- 15 files changed, 19 insertions(+), 26 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index b23c565c5..c82ac387f 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -110,7 +110,7 @@ protected function fireTasksQueue($tasks) * * @param string $question * @param string|null $default - * @param array $choices + * @param string[] $choices * * @return string */ diff --git a/src/Rocketeer/Abstracts/AbstractScm.php b/src/Rocketeer/Abstracts/AbstractScm.php index 0be4aff11..595f66c0c 100644 --- a/src/Rocketeer/Abstracts/AbstractScm.php +++ b/src/Rocketeer/Abstracts/AbstractScm.php @@ -44,7 +44,6 @@ public function getBinary() /** * Returns a command with the SCM's binary * - * @param string $commands,... * * @return string */ @@ -59,8 +58,6 @@ public function getCommand() /** * Execute one of the commands * - * @param string $command - * @param string $arguments,... * * @return string|string[] */ diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 74e7f3eab..cc85b008f 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -47,7 +47,7 @@ public function setFile($file) * Get a value on the server * * @param string|null $key - * @param string|Closure|null $fallback + * @param Closure $fallback * * @return string|integer|array */ diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index e23f50b90..c9e911a86 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -98,7 +98,7 @@ abstract public function execute(); /** * Fire the command * - * @return string|boolean + * @return string|false */ public function fire() { diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 047bcd576..dcc312e85 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -67,7 +67,7 @@ public function getApplicationName() * * @param string $option * - * @return mixed + * @return string */ public function getOption($option) { diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index 06715eead..7bce1c87a 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -95,7 +95,7 @@ public function getStage() /** * Get the various stages provided by the User * - * @return string[] + * @return string */ public function getStages() { diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 12c5599da..0b458d8c5 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -209,7 +209,7 @@ public function saveValidationFile(array $validation) /** * Mark a release as valid * - * @param integer|string|null $release + * @param string $release */ public function markReleaseAsValid($release = null) { diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index d264f3b83..e8ef2a6b2 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -11,10 +11,8 @@ use Closure; use Illuminate\Container\Container; -use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Console\Commands\BaseTaskCommand; -use Rocketeer\Task; use Rocketeer\Tasks; use Rocketeer\Traits\HasLocator; @@ -110,7 +108,7 @@ public function task($name, $task) * Execute a task before another one * * @param string $task - * @param string|Closure|AbstractTask $listeners + * @param Closure $listeners * @param integer $priority * * @return void @@ -124,7 +122,7 @@ public function before($task, $listeners, $priority = 0) * Execute a task after another one * * @param string $task - * @param string|Closure|AbstractTask $listeners + * @param Closure $listeners * @param integer $priority * * @return void diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index 05cb73225..d33828ad8 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -12,7 +12,6 @@ use Closure; use Exception; use KzykHys\Parallel\Parallel; -use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Connection; use Rocketeer\Traits\HasLocator; @@ -168,7 +167,7 @@ protected function runQueue($tasks, $stage = null) * * @param array $queue * - * @return array + * @return callable[] */ protected function buildPipeline(array $queue) { diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php index 0f38b5ae4..b63c857de 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -45,7 +45,7 @@ public function deploy($destination = null) * * @param boolean $reset * - * @return boolean + * @return string */ public function update($reset = true) { diff --git a/src/Rocketeer/Strategies/CopyStrategy.php b/src/Rocketeer/Strategies/CopyStrategy.php index 9edec5177..2245af4d4 100644 --- a/src/Rocketeer/Strategies/CopyStrategy.php +++ b/src/Rocketeer/Strategies/CopyStrategy.php @@ -10,7 +10,7 @@ class CopyStrategy extends CloneStrategy implements StrategyInterface * * @param string|null $destination * - * @return boolean + * @return boolean|string */ public function deploy($destination = null) { diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index da20ac1c5..1f0d4fc2f 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -117,7 +117,7 @@ public function checkScm() /** * Check if Composer is on the server * - * @return boolean + * @return boolean|string */ public function checkComposer() { @@ -191,7 +191,7 @@ public function checkDatabaseDriver($database) * * @param string $cache * - * @return boolean + * @return boolean|string */ public function checkCacheDriver($cache) { diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index ca41aa914..891f0e773 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -59,7 +59,7 @@ public function execute() /** * Get an array of releases to prune * - * @return array + * @return \integer[] */ protected function getReleasesToCleanup() { diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 029345d39..68903970d 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -28,7 +28,7 @@ class Deploy extends AbstractTask /** * Run the task * - * @return void + * @return boolean|null */ public function execute() { @@ -98,7 +98,7 @@ protected function checkTestsResults() /** * Run migrations and seed database * - * @return boolean|null + * @return string|null */ protected function runMigrationsAndSeed() { diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index cc99b99e6..3ed9a9e56 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -10,7 +10,6 @@ namespace Rocketeer\Traits\BashModules; use Illuminate\Support\Str; -use Rocketeer\Abstracts\AbstractLocatorClass; use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; @@ -35,7 +34,7 @@ trait Core * @param boolean $silent Whether the command should stay silent no matter what * @param boolean $array Whether the output should be returned as an array * - * @return string|string[] + * @return string|null */ public function run($commands, $silent = false, $array = false) { @@ -76,7 +75,7 @@ public function run($commands, $silent = false, $array = false) * Run a command get the last line output to * prevent noise * - * @param string|array $commands + * @param string $commands * * @return string */ @@ -153,7 +152,7 @@ public function runInFolder($folder = null, $tasks = array()) * @param string|null $output The command's output * @param string|null $success The message to display on success * - * @return boolean|string + * @return boolean */ public function checkStatus($error, $output = null, $success = null) { From 813c297cbd67f20f53fcdb68251a4b21f78a5e42 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 17:26:11 +0200 Subject: [PATCH 124/424] Fixes --- src/Rocketeer/Abstracts/AbstractScm.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractScm.php b/src/Rocketeer/Abstracts/AbstractScm.php index 595f66c0c..e7f4e1d8c 100644 --- a/src/Rocketeer/Abstracts/AbstractScm.php +++ b/src/Rocketeer/Abstracts/AbstractScm.php @@ -59,7 +59,7 @@ public function getCommand() * Execute one of the commands * * - * @return string|string[] + * @return string|null */ public function execute() { diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 3ed9a9e56..01354c4a8 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -91,7 +91,7 @@ public function runLast($commands) * Run a raw command, without any processing, and * get its output as a string or array * - * @param string|array $commands + * @param string $commands * @param boolean $array Whether the output should be returned as an array * @param boolean $trim Whether the output should be trimmed * @@ -117,7 +117,7 @@ public function runRaw($commands, $array = false, $trim = false) * @param string|array $commands * @param boolean $array * - * @return string|string[] + * @return string|null */ public function runSilently($commands, $array = false) { From bec8b06d993cb3313bc95bcb98c7b84a37efd4c0 Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Sat, 9 Aug 2014 16:37:27 +0100 Subject: [PATCH 125/424] Improved version constraints --- composer.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/composer.json b/composer.json index 8c285284b..0b92caec2 100644 --- a/composer.json +++ b/composer.json @@ -23,16 +23,16 @@ "illuminate/events": "~4.2", "illuminate/remote": "~4.2", "illuminate/log": "~4.2", - "kzykhys/parallel": "dev-master" + "kzykhys/parallel": "~0.1.0" }, "require-dev": { "phpunit/phpunit": "~4.0", "mockery/mockery": "~0.9", "nesbot/carbon": "~1.4", - "patchwork/utf8": "~1.1.18", + "patchwork/utf8": "~1.1", "herrera-io/box": "~1.5.3", "phpseclib/phpseclib": "~0.3.5", - "raveren/kint": "dev-master" + "raveren/kint": "~1.0.0@dev" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", From 5c6cacaf857b5e0c45ce58878d139ba7bd9ef3e8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 17:40:05 +0200 Subject: [PATCH 126/424] Unused uses --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- src/Rocketeer/Abstracts/AbstractScm.php | 2 -- src/Rocketeer/Abstracts/AbstractStorage.php | 4 ++-- src/Rocketeer/Rocketeer.php | 6 +++--- src/Rocketeer/Services/TasksHandler.php | 8 ++++---- src/Rocketeer/Services/TasksQueue.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 6 +++--- tests/Abstracts/AbstractTaskTest.php | 1 + tests/RocketeerTest.php | 1 - tests/Services/CredentialsGathererTest.php | 5 ++--- tests/Services/TasksQueueTest.php | 6 ++---- 11 files changed, 19 insertions(+), 24 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index c82ac387f..b2321132e 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -110,7 +110,7 @@ protected function fireTasksQueue($tasks) * * @param string $question * @param string|null $default - * @param string[] $choices + * @param string[] $choices * * @return string */ diff --git a/src/Rocketeer/Abstracts/AbstractScm.php b/src/Rocketeer/Abstracts/AbstractScm.php index e7f4e1d8c..b0ce04096 100644 --- a/src/Rocketeer/Abstracts/AbstractScm.php +++ b/src/Rocketeer/Abstracts/AbstractScm.php @@ -44,7 +44,6 @@ public function getBinary() /** * Returns a command with the SCM's binary * - * * @return string */ public function getCommand() @@ -58,7 +57,6 @@ public function getCommand() /** * Execute one of the commands * - * * @return string|null */ public function execute() diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index cc85b008f..72d15807d 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -46,8 +46,8 @@ public function setFile($file) /** * Get a value on the server * - * @param string|null $key - * @param Closure $fallback + * @param string|null $key + * @param Closure $fallback * * @return string|integer|array */ diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index dcc312e85..291e174d1 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -131,9 +131,9 @@ public function mergeContextualConfigurations() } // Gather custom files - $finder = new Finder(); - $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); - $files = iterator_to_array($files); + $finder = new Finder(); + $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); + $files = iterator_to_array($files); // Bind their contents to the "on" array foreach ($files as $file) { diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index e8ef2a6b2..f2e9d151b 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -107,9 +107,9 @@ public function task($name, $task) /** * Execute a task before another one * - * @param string $task + * @param string $task * @param Closure $listeners - * @param integer $priority + * @param integer $priority * * @return void */ @@ -121,9 +121,9 @@ public function before($task, $listeners, $priority = 0) /** * Execute a task after another one * - * @param string $task + * @param string $task * @param Closure $listeners - * @param integer $priority + * @param integer $priority * * @return void */ diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/TasksQueue.php index d33828ad8..69d8e980b 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/TasksQueue.php @@ -128,7 +128,7 @@ public function run(array $tasks) do { $continue = $pipeline[$key](); $key++; - } while($continue and isset($pipeline[$key])); + } while ($continue and isset($pipeline[$key])); } return $this->output; diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 01354c4a8..916e2a495 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -91,9 +91,9 @@ public function runLast($commands) * Run a raw command, without any processing, and * get its output as a string or array * - * @param string $commands - * @param boolean $array Whether the output should be returned as an array - * @param boolean $trim Whether the output should be trimmed + * @param string $commands + * @param boolean $array Whether the output should be returned as an array + * @param boolean $trim Whether the output should be trimmed * * @return string|string[] */ diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index c98621ebc..faef4036f 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -69,6 +69,7 @@ public function testTaskCancelsIfEventHalts() $this->tasksQueue()->registerConfiguredEvents(); $this->tasksQueue()->listenTo('deploy.before', function () { echo 'before'; + return false; }); $this->tasksQueue()->listenTo('deploy.after', function () { diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 543157ee6..ebf94afb1 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -1,7 +1,6 @@ rocketeer->getDefaultKeyPath(); $this->mockAnswers(array( - 'No host is set for [staging#0]' => $this->host, - 'No username is set for [staging#0]' => $this->username, + 'No host is set for [staging#0]' => $this->host, + 'No username is set for [staging#0]' => $this->username, 'If a keyphrase is required, provide it' => 'KEYPHRASE', )); diff --git a/tests/Services/TasksQueueTest.php b/tests/Services/TasksQueueTest.php index f5eec8337..5302e5197 100644 --- a/tests/Services/TasksQueueTest.php +++ b/tests/Services/TasksQueueTest.php @@ -1,9 +1,7 @@ shouldReceive('run')->once()->with(Mockery::type('array')) - ->mock(); + ->shouldReceive('run')->once()->with(Mockery::type('array')) + ->mock(); $this->mockCommand(['parallel' => true]); $this->tasksQueue()->setParallel($parallel); From 5bda278fc40f89e620a8915d6d7ff59215e34473 Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Sat, 9 Aug 2014 16:40:51 +0100 Subject: [PATCH 127/424] Improved the travis composer install --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 5f70e65a9..8b2db29a2 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,7 +8,7 @@ php: before_script: - travis_retry composer self-update - - travis_retry composer install --dev --prefer-dist + - travis_retry composer install --no-interaction --prefer-source --dev matrix: allow_failures: From fe43454470efb2043b896c201ddf7bf7ae7c0097 Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Sat, 9 Aug 2014 16:47:54 +0100 Subject: [PATCH 128/424] Changed the raveren/kint dependency --- composer.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/composer.json b/composer.json index 0b92caec2..16253addc 100644 --- a/composer.json +++ b/composer.json @@ -32,7 +32,7 @@ "patchwork/utf8": "~1.1", "herrera-io/box": "~1.5.3", "phpseclib/phpseclib": "~0.3.5", - "raveren/kint": "~1.0.0@dev" + "raveren/kint": "~0.9.0@dev" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", From 45f4dc6f3829e89d7077c91013bf38eeec9805db Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 17:48:55 +0200 Subject: [PATCH 129/424] #262 - Constraint Parallel --- composer.json | 4 ++-- composer.lock | 5 ++--- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/composer.json b/composer.json index 8c285284b..657b14cbc 100644 --- a/composer.json +++ b/composer.json @@ -23,13 +23,13 @@ "illuminate/events": "~4.2", "illuminate/remote": "~4.2", "illuminate/log": "~4.2", - "kzykhys/parallel": "dev-master" + "kzykhys/parallel": "~0.1.0" }, "require-dev": { "phpunit/phpunit": "~4.0", "mockery/mockery": "~0.9", "nesbot/carbon": "~1.4", - "patchwork/utf8": "~1.1.18", + "patchwork/utf8": "~1.1", "herrera-io/box": "~1.5.3", "phpseclib/phpseclib": "~0.3.5", "raveren/kint": "dev-master" diff --git a/composer.lock b/composer.lock index 4511f2e06..978192a3d 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "c3144b2ca3ff23f1c805405f66e1e1c2", + "hash": "3630214752af24d69196da37197c7f9e", "packages": [ { "name": "illuminate/config", @@ -361,7 +361,7 @@ }, { "name": "kzykhys/parallel", - "version": "dev-master", + "version": "v0.1.0", "source": { "type": "git", "url": "https://github.com/kzykhys/Parallel.php.git", @@ -1891,7 +1891,6 @@ "aliases": [], "minimum-stability": "stable", "stability-flags": { - "kzykhys/parallel": 20, "raveren/kint": 20 }, "prefer-stable": false, From 858fde3c079053a7b7a2dd6297ddd4f2df3f4b9d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 17:55:31 +0200 Subject: [PATCH 130/424] Remove lockfile --- .gitignore | 3 +- composer.lock | 1901 ------------------------------------------------- 2 files changed, 2 insertions(+), 1902 deletions(-) delete mode 100644 composer.lock diff --git a/.gitignore b/.gitignore index a5de3e44c..a2cda783d 100644 --- a/.gitignore +++ b/.gitignore @@ -3,6 +3,7 @@ .rocketeer bin/phar bin/rocketeer.phar +composer.lock storage # Plugins @@ -12,4 +13,4 @@ rocketeer-campfire tests/_meta/coverage # Dependencies -vendor \ No newline at end of file +vendor diff --git a/composer.lock b/composer.lock deleted file mode 100644 index 978192a3d..000000000 --- a/composer.lock +++ /dev/null @@ -1,1901 +0,0 @@ -{ - "_readme": [ - "This file locks the dependencies of your project to a known state", - "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", - "This file is @generated automatically" - ], - "hash": "3630214752af24d69196da37197c7f9e", - "packages": [ - { - "name": "illuminate/config", - "version": "v4.2.8", - "target-dir": "Illuminate/Config", - "source": { - "type": "git", - "url": "https://github.com/illuminate/config.git", - "reference": "03de040d413800bd3c672a484202bc8b355b6f9b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/config/zipball/03de040d413800bd3c672a484202bc8b355b6f9b", - "reference": "03de040d413800bd3c672a484202bc8b355b6f9b", - "shasum": "" - }, - "require": { - "illuminate/filesystem": "4.2.*", - "illuminate/support": "4.2.*", - "php": ">=5.4.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Config": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-07-15 11:11:21" - }, - { - "name": "illuminate/console", - "version": "v4.2.8", - "target-dir": "Illuminate/Console", - "source": { - "type": "git", - "url": "https://github.com/illuminate/console.git", - "reference": "26ab2d3f5223851ac537668c778f13cad8742e4c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/console/zipball/26ab2d3f5223851ac537668c778f13cad8742e4c", - "reference": "26ab2d3f5223851ac537668c778f13cad8742e4c", - "shasum": "" - }, - "require": { - "php": ">=5.4.0", - "symfony/console": "2.5.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Console": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-08-01 12:29:44" - }, - { - "name": "illuminate/container", - "version": "v4.2.8", - "target-dir": "Illuminate/Container", - "source": { - "type": "git", - "url": "https://github.com/illuminate/container.git", - "reference": "33f3dbfc21eafa2a71f64c156955e618142afc3c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/container/zipball/33f3dbfc21eafa2a71f64c156955e618142afc3c", - "reference": "33f3dbfc21eafa2a71f64c156955e618142afc3c", - "shasum": "" - }, - "require": { - "php": ">=5.4.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Container": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-07-18 22:26:34" - }, - { - "name": "illuminate/events", - "version": "v4.2.8", - "target-dir": "Illuminate/Events", - "source": { - "type": "git", - "url": "https://github.com/illuminate/events.git", - "reference": "3fd59a0dd07d2b569487d99a37011f33fc01aafd" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/events/zipball/3fd59a0dd07d2b569487d99a37011f33fc01aafd", - "reference": "3fd59a0dd07d2b569487d99a37011f33fc01aafd", - "shasum": "" - }, - "require": { - "illuminate/container": "4.2.*", - "illuminate/support": "4.2.*", - "php": ">=5.4.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Events": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-08-03 15:26:23" - }, - { - "name": "illuminate/filesystem", - "version": "v4.2.8", - "target-dir": "Illuminate/Filesystem", - "source": { - "type": "git", - "url": "https://github.com/illuminate/filesystem.git", - "reference": "1e517251a924b5f90b1ed10966e38ff0798ddc24" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/filesystem/zipball/1e517251a924b5f90b1ed10966e38ff0798ddc24", - "reference": "1e517251a924b5f90b1ed10966e38ff0798ddc24", - "shasum": "" - }, - "require": { - "illuminate/support": "4.2.*", - "php": ">=5.4.0", - "symfony/finder": "2.5.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Filesystem": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-08-01 20:11:25" - }, - { - "name": "illuminate/log", - "version": "v4.2.8", - "target-dir": "Illuminate/Log", - "source": { - "type": "git", - "url": "https://github.com/illuminate/log.git", - "reference": "da1d827118dbc30ce77e3a1b8e9dab4306302ee9" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/log/zipball/da1d827118dbc30ce77e3a1b8e9dab4306302ee9", - "reference": "da1d827118dbc30ce77e3a1b8e9dab4306302ee9", - "shasum": "" - }, - "require": { - "illuminate/support": "4.2.*", - "monolog/monolog": "~1.6", - "php": ">=5.4.0" - }, - "require-dev": { - "illuminate/events": "4.2.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Log": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-08-03 15:26:23" - }, - { - "name": "illuminate/remote", - "version": "v4.2.8", - "target-dir": "Illuminate/Remote", - "source": { - "type": "git", - "url": "https://github.com/illuminate/remote.git", - "reference": "2d170349d127e85aac08d850c823c2029e60af36" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/remote/zipball/2d170349d127e85aac08d850c823c2029e60af36", - "reference": "2d170349d127e85aac08d850c823c2029e60af36", - "shasum": "" - }, - "require": { - "illuminate/filesystem": "4.2.*", - "illuminate/support": "4.2.*", - "php": ">=5.4.0", - "phpseclib/phpseclib": "0.3.*" - }, - "require-dev": { - "illuminate/console": "4.2.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Remote": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-07-17 20:08:16" - }, - { - "name": "illuminate/support", - "version": "v4.2.8", - "target-dir": "Illuminate/Support", - "source": { - "type": "git", - "url": "https://github.com/illuminate/support.git", - "reference": "8702d655da1f7502037a2206df38399656ff35ae" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/illuminate/support/zipball/8702d655da1f7502037a2206df38399656ff35ae", - "reference": "8702d655da1f7502037a2206df38399656ff35ae", - "shasum": "" - }, - "require": { - "php": ">=5.4.0" - }, - "require-dev": { - "jeremeamia/superclosure": "~1.0", - "patchwork/utf8": "1.1.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2-dev" - } - }, - "autoload": { - "psr-0": { - "Illuminate\\Support": "" - }, - "files": [ - "Illuminate/Support/helpers.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Taylor Otwell", - "email": "taylorotwell@gmail.com" - } - ], - "time": "2014-08-05 12:08:34" - }, - { - "name": "kzykhys/parallel", - "version": "v0.1.0", - "source": { - "type": "git", - "url": "https://github.com/kzykhys/Parallel.php.git", - "reference": "d15bc88f06d279112a0facb6607072dfb48dfc6f" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/kzykhys/Parallel.php/zipball/d15bc88f06d279112a0facb6607072dfb48dfc6f", - "reference": "d15bc88f06d279112a0facb6607072dfb48dfc6f", - "shasum": "" - }, - "require-dev": { - "phpunit/php-code-coverage": "1.2.*" - }, - "type": "library", - "autoload": { - "psr-0": { - "": "src/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Kazuyuki Hayashi", - "email": "hayashi@valnur.net" - } - ], - "description": "Simple multitasking library", - "time": "2014-02-04 13:24:07" - }, - { - "name": "monolog/monolog", - "version": "1.10.0", - "source": { - "type": "git", - "url": "https://github.com/Seldaek/monolog.git", - "reference": "25b16e801979098cb2f120e697bfce454b18bf23" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/Seldaek/monolog/zipball/25b16e801979098cb2f120e697bfce454b18bf23", - "reference": "25b16e801979098cb2f120e697bfce454b18bf23", - "shasum": "" - }, - "require": { - "php": ">=5.3.0", - "psr/log": "~1.0" - }, - "require-dev": { - "aws/aws-sdk-php": "~2.4, >2.4.8", - "doctrine/couchdb": "~1.0@dev", - "graylog2/gelf-php": "~1.0", - "phpunit/phpunit": "~3.7.0", - "raven/raven": "~0.5", - "ruflin/elastica": "0.90.*" - }, - "suggest": { - "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB", - "doctrine/couchdb": "Allow sending log messages to a CouchDB server", - "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)", - "ext-mongo": "Allow sending log messages to a MongoDB server", - "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server", - "raven/raven": "Allow sending log messages to a Sentry server", - "rollbar/rollbar": "Allow sending log messages to Rollbar", - "ruflin/elastica": "Allow sending log messages to an Elastic Search server" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.10.x-dev" - } - }, - "autoload": { - "psr-4": { - "Monolog\\": "src/Monolog" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Jordi Boggiano", - "email": "j.boggiano@seld.be", - "homepage": "http://seld.be", - "role": "Developer" - } - ], - "description": "Sends your logs to files, sockets, inboxes, databases and various web services", - "homepage": "http://github.com/Seldaek/monolog", - "keywords": [ - "log", - "logging", - "psr-3" - ], - "time": "2014-06-04 16:30:04" - }, - { - "name": "phpseclib/phpseclib", - "version": "0.3.7", - "source": { - "type": "git", - "url": "https://github.com/phpseclib/phpseclib.git", - "reference": "8b8c62f278e363b75ddcacaf5803710232fbd3e4" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/phpseclib/phpseclib/zipball/8b8c62f278e363b75ddcacaf5803710232fbd3e4", - "reference": "8b8c62f278e363b75ddcacaf5803710232fbd3e4", - "shasum": "" - }, - "require": { - "php": ">=5.0.0" - }, - "require-dev": { - "phing/phing": "2.7.*", - "phpunit/phpunit": "4.0.*", - "squizlabs/php_codesniffer": "1.*" - }, - "suggest": { - "ext-gmp": "Install the GMP (GNU Multiple Precision) extension in order to speed up arbitrary precision integer arithmetic operations.", - "ext-mcrypt": "Install the Mcrypt extension in order to speed up a wide variety of cryptographic operations.", - "pear-pear/PHP_Compat": "Install PHP_Compat to get phpseclib working on PHP < 4.3.3." - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "0.3-dev" - } - }, - "autoload": { - "psr-0": { - "Crypt": "phpseclib/", - "File": "phpseclib/", - "Math": "phpseclib/", - "Net": "phpseclib/", - "System": "phpseclib/" - }, - "files": [ - "phpseclib/Crypt/Random.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "phpseclib/" - ], - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Jim Wigginton", - "email": "terrafrost@php.net", - "role": "Lead Developer" - }, - { - "name": "Patrick Monnerat", - "email": "pm@datasphere.ch", - "role": "Developer" - }, - { - "name": "Andreas Fischer", - "email": "bantu@phpbb.com", - "role": "Developer" - }, - { - "name": "Hans-Jürgen Petrich", - "email": "petrich@tronic-media.com", - "role": "Developer" - } - ], - "description": "PHP Secure Communications Library - Pure-PHP implementations of RSA, AES, SSH2, SFTP, X.509 etc.", - "homepage": "http://phpseclib.sourceforge.net", - "keywords": [ - "BigInteger", - "aes", - "asn.1", - "asn1", - "blowfish", - "crypto", - "cryptography", - "encryption", - "rsa", - "security", - "sftp", - "signature", - "signing", - "ssh", - "twofish", - "x.509", - "x509" - ], - "time": "2014-07-05 16:36:21" - }, - { - "name": "psr/log", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/log.git", - "reference": "fe0936ee26643249e916849d48e3a51d5f5e278b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/log/zipball/fe0936ee26643249e916849d48e3a51d5f5e278b", - "reference": "fe0936ee26643249e916849d48e3a51d5f5e278b", - "shasum": "" - }, - "type": "library", - "autoload": { - "psr-0": { - "Psr\\Log\\": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" - } - ], - "description": "Common interface for logging libraries", - "keywords": [ - "log", - "psr", - "psr-3" - ], - "time": "2012-12-21 11:40:51" - }, - { - "name": "symfony/console", - "version": "v2.5.3", - "target-dir": "Symfony/Component/Console", - "source": { - "type": "git", - "url": "https://github.com/symfony/Console.git", - "reference": "cd2d1e4bac2206b337326b0140ff475fe9ad5f63" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/Console/zipball/cd2d1e4bac2206b337326b0140ff475fe9ad5f63", - "reference": "cd2d1e4bac2206b337326b0140ff475fe9ad5f63", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "psr/log": "~1.0", - "symfony/event-dispatcher": "~2.1" - }, - "suggest": { - "psr/log": "For using the console logger", - "symfony/event-dispatcher": "" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.5-dev" - } - }, - "autoload": { - "psr-0": { - "Symfony\\Component\\Console\\": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Symfony Community", - "homepage": "http://symfony.com/contributors" - }, - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com" - } - ], - "description": "Symfony Console Component", - "homepage": "http://symfony.com", - "time": "2014-08-05 09:00:40" - }, - { - "name": "symfony/finder", - "version": "v2.5.3", - "target-dir": "Symfony/Component/Finder", - "source": { - "type": "git", - "url": "https://github.com/symfony/Finder.git", - "reference": "090fe4eaff414d8f2171c7a4748ea868d530775f" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/Finder/zipball/090fe4eaff414d8f2171c7a4748ea868d530775f", - "reference": "090fe4eaff414d8f2171c7a4748ea868d530775f", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.5-dev" - } - }, - "autoload": { - "psr-0": { - "Symfony\\Component\\Finder\\": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Symfony Community", - "homepage": "http://symfony.com/contributors" - }, - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com" - } - ], - "description": "Symfony Finder Component", - "homepage": "http://symfony.com", - "time": "2014-07-28 13:20:46" - } - ], - "packages-dev": [ - { - "name": "herrera-io/box", - "version": "1.5.3", - "source": { - "type": "git", - "url": "https://github.com/herrera-io/php-box.git", - "reference": "b5432951f85a56df6012f503881174e7aeec6611" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/herrera-io/php-box/zipball/b5432951f85a56df6012f503881174e7aeec6611", - "reference": "b5432951f85a56df6012f503881174e7aeec6611", - "shasum": "" - }, - "require": { - "ext-phar": "*", - "phine/path": "~1.0", - "php": ">=5.3.3" - }, - "require-dev": { - "herrera-io/annotations": "~1.0", - "herrera-io/phpunit-test-case": "1.*", - "mikey179/vfsstream": "1.1.0", - "phpseclib/phpseclib": "~0.3", - "phpunit/phpunit": "3.7.*" - }, - "suggest": { - "herrera-io/annotations": "For compacting annotated docblocks.", - "phpseclib/phpseclib": "For verifying OpenSSL signed phars without the phar extension." - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, - "autoload": { - "psr-0": { - "Herrera\\Box": "src/lib" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Kevin Herrera", - "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io/", - "role": "Developer" - } - ], - "description": "A library for simplifying the PHAR build process.", - "homepage": "http://herrera-io.github.com/php-box", - "keywords": [ - "phar" - ], - "time": "2014-02-07 15:48:46" - }, - { - "name": "mockery/mockery", - "version": "0.9.1", - "source": { - "type": "git", - "url": "https://github.com/padraic/mockery.git", - "reference": "17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/padraic/mockery/zipball/17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1", - "reference": "17f63ee40ed14a8afb7ba1f0ae15cc4491d719d1", - "shasum": "" - }, - "require": { - "lib-pcre": ">=7.0", - "php": ">=5.3.2" - }, - "require-dev": { - "hamcrest/hamcrest-php": "~1.1", - "phpunit/phpunit": "~4.0", - "satooshi/php-coveralls": "~0.7@dev" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "0.9.x-dev" - } - }, - "autoload": { - "psr-0": { - "Mockery": "library/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Pádraic Brady", - "email": "padraic.brady@gmail.com", - "homepage": "http://blog.astrumfutura.com" - }, - { - "name": "Dave Marshall", - "email": "dave.marshall@atstsolutions.co.uk", - "homepage": "http://davedevelopment.co.uk" - } - ], - "description": "Mockery is a simple yet flexible PHP mock object framework for use in unit testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a test double framework with a succint API capable of clearly defining all possible object operations and interactions using a human readable Domain Specific Language (DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with PHPUnit and can operate alongside phpunit-mock-objects without the World ending.", - "homepage": "http://github.com/padraic/mockery", - "keywords": [ - "BDD", - "TDD", - "library", - "mock", - "mock objects", - "mockery", - "stub", - "test", - "test double", - "testing" - ], - "time": "2014-05-02 12:16:45" - }, - { - "name": "nesbot/carbon", - "version": "1.10.0", - "source": { - "type": "git", - "url": "https://github.com/briannesbitt/Carbon.git", - "reference": "9b42a1aec56011c2ac4d75c0ddad0794762344fc" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/9b42a1aec56011c2ac4d75c0ddad0794762344fc", - "reference": "9b42a1aec56011c2ac4d75c0ddad0794762344fc", - "shasum": "" - }, - "require": { - "php": ">=5.3.0" - }, - "require-dev": { - "phpunit/phpunit": "~4.0" - }, - "type": "library", - "autoload": { - "psr-0": { - "Carbon": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Brian Nesbitt", - "email": "brian@nesbot.com", - "homepage": "http://nesbot.com" - } - ], - "description": "A simple API extension for DateTime.", - "homepage": "https://github.com/briannesbitt/Carbon", - "keywords": [ - "date", - "datetime", - "time" - ], - "time": "2014-07-18 03:44:47" - }, - { - "name": "ocramius/instantiator", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/Ocramius/Instantiator.git", - "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/Ocramius/Instantiator/zipball/cc754c2289ffd4483c319f6ed6ee88ce21676f64", - "reference": "cc754c2289ffd4483c319f6ed6ee88ce21676f64", - "shasum": "" - }, - "require": { - "ocramius/lazy-map": "1.0.*", - "php": "~5.3" - }, - "require-dev": { - "athletic/athletic": "~0.1.8", - "ext-phar": "*", - "phpunit/phpunit": "~4.0", - "squizlabs/php_codesniffer": "2.0.*@ALPHA" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0.x-dev" - } - }, - "autoload": { - "psr-0": { - "Instantiator\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Marco Pivetta", - "email": "ocramius@gmail.com", - "homepage": "http://ocramius.github.com/", - "role": "Developer" - } - ], - "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors", - "homepage": "https://github.com/Ocramius/Instantiator", - "keywords": [ - "constructor", - "instantiate" - ], - "time": "2014-06-15 11:44:46" - }, - { - "name": "ocramius/lazy-map", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/Ocramius/LazyMap.git", - "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/Ocramius/LazyMap/zipball/7fe3d347f5e618bcea7d39345ff83f3651d8b752", - "reference": "7fe3d347f5e618bcea7d39345ff83f3651d8b752", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "athletic/athletic": "~0.1.6", - "phpmd/phpmd": "1.5.*", - "phpunit/phpunit": ">=3.7", - "satooshi/php-coveralls": "~0.6", - "squizlabs/php_codesniffer": "1.4.*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "autoload": { - "psr-0": { - "LazyMap\\": "src" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Marco Pivetta", - "email": "ocramius@gmail.com", - "homepage": "http://ocramius.github.com/", - "role": "Developer" - } - ], - "description": "A library that provides lazy instantiation logic for a map of objects", - "homepage": "https://github.com/Ocramius/LazyMap", - "keywords": [ - "lazy", - "lazy instantiation", - "lazy loading", - "map", - "service location" - ], - "time": "2013-11-09 22:30:54" - }, - { - "name": "patchwork/utf8", - "version": "v1.1.25", - "source": { - "type": "git", - "url": "https://github.com/nicolas-grekas/Patchwork-UTF8.git", - "reference": "2d43bd047b120279511d45e76e61c5a9812d9a83" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/nicolas-grekas/Patchwork-UTF8/zipball/2d43bd047b120279511d45e76e61c5a9812d9a83", - "reference": "2d43bd047b120279511d45e76e61c5a9812d9a83", - "shasum": "" - }, - "require": { - "lib-pcre": ">=7.3", - "php": ">=5.3.0" - }, - "suggest": { - "ext-iconv": "Use iconv for best performance", - "ext-intl": "Use Intl for best performance", - "ext-mbstring": "Use Mbstring for best performance" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.1-dev" - } - }, - "autoload": { - "psr-0": { - "Patchwork": "class/", - "Normalizer": "class/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "(Apache-2.0 or GPL-2.0)" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com", - "role": "Developer" - } - ], - "description": "Extensive, portable and performant handling of UTF-8 and grapheme clusters for PHP", - "homepage": "https://github.com/nicolas-grekas/Patchwork-UTF8", - "keywords": [ - "i18n", - "unicode", - "utf-8", - "utf8" - ], - "time": "2014-08-05 08:00:32" - }, - { - "name": "phine/exception", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/phine/lib-exception.git", - "reference": "150c6b6090b2ebc53c60e87cb20c7f1287b7b68a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/phine/lib-exception/zipball/150c6b6090b2ebc53c60e87cb20c7f1287b7b68a", - "reference": "150c6b6090b2ebc53c60e87cb20c7f1287b7b68a", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "league/phpunit-coverage-listener": "~1.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, - "autoload": { - "psr-0": { - "Phine\\Exception": "src/lib" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Kevin Herrera", - "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io/", - "role": "Developer" - } - ], - "description": "A PHP library for improving the use of exceptions.", - "homepage": "https://github.com/phine/lib-exception", - "keywords": [ - "exception" - ], - "time": "2013-08-27 17:43:25" - }, - { - "name": "phine/path", - "version": "1.1.0", - "source": { - "type": "git", - "url": "https://github.com/phine/lib-path.git", - "reference": "cbe1a5eb6cf22958394db2469af9b773508abddd" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/phine/lib-path/zipball/cbe1a5eb6cf22958394db2469af9b773508abddd", - "reference": "cbe1a5eb6cf22958394db2469af9b773508abddd", - "shasum": "" - }, - "require": { - "phine/exception": "~1.0", - "php": ">=5.3.3" - }, - "require-dev": { - "league/phpunit-coverage-listener": "~1.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, - "autoload": { - "psr-0": { - "Phine\\Path": "src/lib" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Kevin Herrera", - "email": "kevin@herrera.io", - "homepage": "http://kevin.herrera.io/", - "role": "Developer" - } - ], - "description": "A PHP library for improving the use of file system paths.", - "homepage": "https://github.com/phine/lib-path", - "keywords": [ - "file", - "path", - "system" - ], - "time": "2013-10-15 22:58:04" - }, - { - "name": "phpunit/php-code-coverage", - "version": "2.0.10", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-code-coverage.git", - "reference": "6d196af48e8c100a3ae881940123e693da5a9217" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/6d196af48e8c100a3ae881940123e693da5a9217", - "reference": "6d196af48e8c100a3ae881940123e693da5a9217", - "shasum": "" - }, - "require": { - "php": ">=5.3.3", - "phpunit/php-file-iterator": "~1.3.1", - "phpunit/php-text-template": "~1.2.0", - "phpunit/php-token-stream": "~1.2.2", - "sebastian/environment": "~1.0.0", - "sebastian/version": "~1.0.3" - }, - "require-dev": { - "ext-xdebug": ">=2.1.4", - "phpunit/phpunit": "~4.0.14" - }, - "suggest": { - "ext-dom": "*", - "ext-xdebug": ">=2.2.1", - "ext-xmlwriter": "*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" - } - ], - "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", - "homepage": "https://github.com/sebastianbergmann/php-code-coverage", - "keywords": [ - "coverage", - "testing", - "xunit" - ], - "time": "2014-08-06 06:39:42" - }, - { - "name": "phpunit/php-file-iterator", - "version": "1.3.4", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-file-iterator.git", - "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/acd690379117b042d1c8af1fafd61bde001bf6bb", - "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "type": "library", - "autoload": { - "classmap": [ - "File/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" - } - ], - "description": "FilterIterator implementation that filters files based on a list of suffixes.", - "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", - "keywords": [ - "filesystem", - "iterator" - ], - "time": "2013-10-10 15:34:57" - }, - { - "name": "phpunit/php-text-template", - "version": "1.2.0", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-text-template.git", - "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", - "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "type": "library", - "autoload": { - "classmap": [ - "Text/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" - } - ], - "description": "Simple template engine.", - "homepage": "https://github.com/sebastianbergmann/php-text-template/", - "keywords": [ - "template" - ], - "time": "2014-01-30 17:20:04" - }, - { - "name": "phpunit/php-timer", - "version": "1.0.5", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-timer.git", - "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/19689d4354b295ee3d8c54b4f42c3efb69cbc17c", - "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "type": "library", - "autoload": { - "classmap": [ - "PHP/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" - } - ], - "description": "Utility class for timing", - "homepage": "https://github.com/sebastianbergmann/php-timer/", - "keywords": [ - "timer" - ], - "time": "2013-08-02 07:42:54" - }, - { - "name": "phpunit/php-token-stream", - "version": "1.2.2", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-token-stream.git", - "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/ad4e1e23ae01b483c16f600ff1bebec184588e32", - "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32", - "shasum": "" - }, - "require": { - "ext-tokenizer": "*", - "php": ">=5.3.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.2-dev" - } - }, - "autoload": { - "classmap": [ - "PHP/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" - } - ], - "description": "Wrapper around PHP's tokenizer extension.", - "homepage": "https://github.com/sebastianbergmann/php-token-stream/", - "keywords": [ - "tokenizer" - ], - "time": "2014-03-03 05:10:30" - }, - { - "name": "phpunit/phpunit", - "version": "4.2.0", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "58db726aa45fe26bca93f692cb3d77e9a46b7830" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/58db726aa45fe26bca93f692cb3d77e9a46b7830", - "reference": "58db726aa45fe26bca93f692cb3d77e9a46b7830", - "shasum": "" - }, - "require": { - "ext-dom": "*", - "ext-json": "*", - "ext-pcre": "*", - "ext-reflection": "*", - "ext-spl": "*", - "php": ">=5.3.3", - "phpunit/php-code-coverage": "~2.0", - "phpunit/php-file-iterator": "~1.3.1", - "phpunit/php-text-template": "~1.2", - "phpunit/php-timer": "~1.0.2", - "phpunit/phpunit-mock-objects": "~2.2", - "sebastian/comparator": "~1.0", - "sebastian/diff": "~1.1", - "sebastian/environment": "~1.0", - "sebastian/exporter": "~1.0", - "sebastian/version": "~1.0", - "symfony/yaml": "~2.0" - }, - "suggest": { - "phpunit/php-invoker": "~1.1" - }, - "bin": [ - "phpunit" - ], - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.2.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "", - "../../symfony/yaml/" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "The PHP Unit Testing framework.", - "homepage": "http://www.phpunit.de/", - "keywords": [ - "phpunit", - "testing", - "xunit" - ], - "time": "2014-08-08 05:13:30" - }, - { - "name": "phpunit/phpunit-mock-objects", - "version": "2.2.0", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git", - "reference": "42e589e08bc86e3e9bdf20d385e948347788505b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/42e589e08bc86e3e9bdf20d385e948347788505b", - "reference": "42e589e08bc86e3e9bdf20d385e948347788505b", - "shasum": "" - }, - "require": { - "ocramius/instantiator": "~1.0", - "php": ">=5.3.3", - "phpunit/php-text-template": "~1.2" - }, - "require-dev": { - "phpunit/phpunit": "4.2.*@dev" - }, - "suggest": { - "ext-soap": "*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.2.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "include-path": [ - "" - ], - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sb@sebastian-bergmann.de", - "role": "lead" - } - ], - "description": "Mock Object library for PHPUnit", - "homepage": "https://github.com/sebastianbergmann/phpunit-mock-objects/", - "keywords": [ - "mock", - "xunit" - ], - "time": "2014-08-02 13:50:58" - }, - { - "name": "raveren/kint", - "version": "dev-master", - "source": { - "type": "git", - "url": "https://github.com/raveren/kint.git", - "reference": "cd801406b28cfa74d257bbd4f9e9fdddf59390c5" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/raveren/kint/zipball/cd801406b28cfa74d257bbd4f9e9fdddf59390c5", - "reference": "cd801406b28cfa74d257bbd4f9e9fdddf59390c5", - "shasum": "" - }, - "require": { - "php": ">=5.2.0" - }, - "type": "library", - "autoload": { - "files": [ - "Kint.class.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Rokas Šleinius", - "homepage": "https://github.com/raveren" - }, - { - "name": "Contributors", - "homepage": "https://github.com/raveren/kint/contributors" - } - ], - "description": "Kint - debugging helper for PHP developers", - "homepage": "https://github.com/raveren/kint", - "keywords": [ - "debug", - "kint", - "php" - ], - "time": "2014-08-04 19:57:55" - }, - { - "name": "sebastian/comparator", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/comparator.git", - "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", - "reference": "f7069ee51fa9fb6c038e16a9d0e3439f5449dcf2", - "shasum": "" - }, - "require": { - "php": ">=5.3.3", - "sebastian/diff": "~1.1", - "sebastian/exporter": "~1.0" - }, - "require-dev": { - "phpunit/phpunit": "~4.1" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Volker Dusch", - "email": "github@wallbash.com" - }, - { - "name": "Bernhard Schussek", - "email": "bschussek@2bepublished.at" - } - ], - "description": "Provides the functionality to compare PHP values for equality", - "homepage": "http://www.github.com/sebastianbergmann/comparator", - "keywords": [ - "comparator", - "compare", - "equality" - ], - "time": "2014-05-02 07:05:58" - }, - { - "name": "sebastian/diff", - "version": "1.1.0", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/diff.git", - "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", - "reference": "1e091702a5a38e6b4c1ba9ca816e3dd343df2e2d", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.1-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - }, - { - "name": "Kore Nordmann", - "email": "mail@kore-nordmann.de" - } - ], - "description": "Diff implementation", - "homepage": "http://www.github.com/sebastianbergmann/diff", - "keywords": [ - "diff" - ], - "time": "2013-08-03 16:46:33" - }, - { - "name": "sebastian/environment", - "version": "1.0.0", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/environment.git", - "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/79517609ec01139cd7e9fded0dd7ce08c952ef6a", - "reference": "79517609ec01139cd7e9fded0dd7ce08c952ef6a", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "phpunit/phpunit": "4.0.*@dev" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Provides functionality to handle HHVM/PHP environments", - "homepage": "http://www.github.com/sebastianbergmann/environment", - "keywords": [ - "Xdebug", - "environment", - "hhvm" - ], - "time": "2014-02-18 16:17:19" - }, - { - "name": "sebastian/exporter", - "version": "1.0.1", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/exporter.git", - "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", - "reference": "1f9a98e6f5dfe0524cb8c6166f7c82f3e9ae1529", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "require-dev": { - "phpunit/phpunit": "4.0.*@dev" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Volker Dusch", - "email": "github@wallbash.com" - }, - { - "name": "Adam Harvey", - "email": "aharvey@php.net", - "role": "Lead" - }, - { - "name": "Bernhard Schussek", - "email": "bschussek@2bepublished.at" - } - ], - "description": "Provides the functionality to export PHP variables for visualization", - "homepage": "http://www.github.com/sebastianbergmann/exporter", - "keywords": [ - "export", - "exporter" - ], - "time": "2014-02-16 08:26:31" - }, - { - "name": "sebastian/version", - "version": "1.0.3", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/version.git", - "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", - "reference": "b6e1f0cf6b9e1ec409a0d3e2f2a5fb0998e36b43", - "shasum": "" - }, - "type": "library", - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Library that helps with managing the version number of Git-hosted PHP projects", - "homepage": "https://github.com/sebastianbergmann/version", - "time": "2014-03-07 15:35:33" - }, - { - "name": "symfony/yaml", - "version": "v2.5.3", - "target-dir": "Symfony/Component/Yaml", - "source": { - "type": "git", - "url": "https://github.com/symfony/Yaml.git", - "reference": "5a75366ae9ca8b4792cd0083e4ca4dff9fe96f1f" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/Yaml/zipball/5a75366ae9ca8b4792cd0083e4ca4dff9fe96f1f", - "reference": "5a75366ae9ca8b4792cd0083e4ca4dff9fe96f1f", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.5-dev" - } - }, - "autoload": { - "psr-0": { - "Symfony\\Component\\Yaml\\": "" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Symfony Community", - "homepage": "http://symfony.com/contributors" - }, - { - "name": "Fabien Potencier", - "email": "fabien@symfony.com" - } - ], - "description": "Symfony Yaml Component", - "homepage": "http://symfony.com", - "time": "2014-08-05 09:00:40" - } - ], - "aliases": [], - "minimum-stability": "stable", - "stability-flags": { - "raveren/kint": 20 - }, - "prefer-stable": false, - "platform": { - "php": ">=5.4.0" - }, - "platform-dev": [] -} From ae17bfa64f6923f51abb2e6e7bbce88bb7610b02 Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Sat, 9 Aug 2014 17:04:34 +0100 Subject: [PATCH 131/424] Test on hhvm nightly --- .travis.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.travis.yml b/.travis.yml index 8b2db29a2..9ed1f8c0e 100644 --- a/.travis.yml +++ b/.travis.yml @@ -4,7 +4,7 @@ php: - 5.4 - 5.5 - 5.6 - - hhvm + - hhvm-nightly before_script: - travis_retry composer self-update @@ -12,7 +12,7 @@ before_script: matrix: allow_failures: - - php: hhvm + - php: hhvm-nightly fast_finish: true script: phpunit --verbose From 2b258e3880eeebe6360e83a276765dbded21175f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 18:18:35 +0200 Subject: [PATCH 132/424] Add tinker binary --- bin/tinker | 22 ++++++++++++++++++++++ composer.json | 1 + 2 files changed, 23 insertions(+) create mode 100644 bin/tinker diff --git a/bin/tinker b/bin/tinker new file mode 100644 index 000000000..9c2678e93 --- /dev/null +++ b/bin/tinker @@ -0,0 +1,22 @@ +#!/usr/bin/env php +boot(); + +$app = Rocketeer::getFacadeApplication(); + +// Compile new phar and extract it +$boris = new Boris('rocketeer> '); +$boris->setLocal(array( + 'app' => $app, +)); + +$boris->start(); diff --git a/composer.json b/composer.json index 16253addc..92c6403fb 100644 --- a/composer.json +++ b/composer.json @@ -32,6 +32,7 @@ "patchwork/utf8": "~1.1", "herrera-io/box": "~1.5.3", "phpseclib/phpseclib": "~0.3.5", + "d11wtq/boris": "~1.0.8", "raveren/kint": "~0.9.0@dev" }, "suggest": { From 84ea1468a8ea1573d707ce9d75cc171c342de71c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 18:18:39 +0200 Subject: [PATCH 133/424] Work on binaries --- src/Rocketeer/Abstracts/AbstractBinary.php | 161 +++++++++++++++++++++ src/Rocketeer/Abstracts/AbstractScm.php | 70 --------- src/Rocketeer/Scm/Git.php | 28 ++-- src/Rocketeer/Scm/Svn.php | 19 ++- tests/Scm/GitTest.php | 4 +- tests/Scm/SvnTest.php | 4 +- 6 files changed, 194 insertions(+), 92 deletions(-) create mode 100644 src/Rocketeer/Abstracts/AbstractBinary.php delete mode 100644 src/Rocketeer/Abstracts/AbstractScm.php diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php new file mode 100644 index 000000000..3c1163a90 --- /dev/null +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -0,0 +1,161 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Abstracts; + +use Illuminate\Support\Str; +use Rocketeer\Traits\HasLocator; + +/** + * A generic class to represent a binary as a class + * + * @author Maxime Fabre + */ +class AbstractBinary +{ + use HasLocator; + + /** + * The core binary + * + * @var string + */ + protected $binary; + + /** + * Get the current binary name + * + * @return string + */ + public function getBinary() + { + return $this->binary; + } + + /** + * Execute a command on the Binary + * + * @param string $name + * @param array $arguments + * + * @return string|null + */ + public function __call($name, $arguments) + { + // Check whether we want the command executed or not + $execute = strpos($name, 'execute') !== false; + $name = str_replace('execute', null, $name); + + // Format name + $name = Str::snake($name, '-'); + + // Prepend command name to arguments and call + array_unshift($arguments, $name); + $command = call_user_func_array([$this, 'getCommand'], $arguments); + + return $execute ? $this->bash->run($command) : $command; + } + + /** + * Execute one of the commands + * + * @return string|null + */ + public function execute() + { + $arguments = func_get_args(); + $command = array_shift($arguments); + $command = call_user_func_array(array($this, $command), $arguments); + + return $this->bash->run($command); + } + + //////////////////////////////////////////////////////////////////// + //////////////////////////////// HELPERS /////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Returns a command with the SCM's binary + * + * @param string $command + * @param string[] $arguments + * @param string[] $flags + * + * @return string + */ + public function getCommand($command, $arguments = array(), $flags = array()) + { + // Format arguments + $arguments = $this->buildArguments($arguments); + $options = $this->buildOptions($flags); + + // Build command + $command = $this->binary.' '.$command; + if ($arguments) { + $command .= ' '.$arguments; + } + if ($options) { + $command .= ' '.$options; + } + + return trim($command); + } + + /** + * @param $flags + * + * @return array|string + */ + protected function buildOptions($flags) + { + $options = []; + $flags = (array) $flags; + + // Flip array if necessary + $firstKey = array_get(array_keys($flags), 0); + if (!is_null($firstKey) and is_int($firstKey)) { + $flags = array_combine( + array_values($flags), + array_fill(0, sizeof($flags), null) + ); + } + + // Build flags + foreach ($flags as $flag => $value) { + $options[] = $value ? $flag.'="'.$value.'"' : $flag; + } + + return implode(' ', $options); + } + + /** + * @param $arguments + * + * @return array|string + */ + protected function buildArguments($arguments) + { + $arguments = (array) $arguments; + $arguments = implode(' ', $arguments); + + return $arguments; + } + + /** + * Quote a string + * + * @param string $string + * + * @return string + */ + protected function quote($string) + { + return '"'.$string.'"'; + } +} diff --git a/src/Rocketeer/Abstracts/AbstractScm.php b/src/Rocketeer/Abstracts/AbstractScm.php deleted file mode 100644 index b0ce04096..000000000 --- a/src/Rocketeer/Abstracts/AbstractScm.php +++ /dev/null @@ -1,70 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ -namespace Rocketeer\Abstracts; - -use Rocketeer\Traits\HasLocator; - -/** - * An abstract class with helpers for SCM implementations - * - * @author Maxime Fabre - */ -abstract class AbstractScm -{ - use HasLocator; - - /** - * The core binary - * - * @var string - */ - protected $binary; - - /** - * Get the current binary name - * - * @return string - */ - public function getBinary() - { - return $this->binary; - } - - //////////////////////////////////////////////////////////////////// - //////////////////////////////// HELPERS /////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Returns a command with the SCM's binary - * - * @return string - */ - public function getCommand() - { - $arguments = func_get_args(); - $arguments[0] = $this->binary.' '.$arguments[0]; - - return call_user_func_array('sprintf', $arguments); - } - - /** - * Execute one of the commands - * - * @return string|null - */ - public function execute() - { - $arguments = func_get_args(); - $command = array_shift($arguments); - $command = call_user_func_array(array($this, $command), $arguments); - - return $this->bash->run($command); - } -} diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index 9ef0ffbdc..d6cf3f77f 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Scm; +use Rocketeer\Abstracts\AbstractBinary; use Rocketeer\Abstracts\AbstractScm; use Rocketeer\Interfaces\ScmInterface; @@ -17,7 +18,7 @@ * * @author Maxime Fabre */ -class Git extends AbstractScm implements ScmInterface +class Git extends AbstractBinary implements ScmInterface { /** * The core binary @@ -47,7 +48,7 @@ public function check() */ public function currentState() { - return $this->getCommand('rev-parse HEAD'); + return $this->revParse('HEAD'); } /** @@ -57,7 +58,7 @@ public function currentState() */ public function currentBranch() { - return $this->getCommand('rev-parse --abbrev-ref HEAD'); + return $this->revParse('--abbrev-ref HEAD'); } //////////////////////////////////////////////////////////////////// @@ -73,11 +74,18 @@ public function currentBranch() */ public function checkout($destination) { - $branch = $this->connections->getRepositoryBranch(); - $repository = $this->connections->getRepositoryEndpoint(); - $shallow = $this->rocketeer->getOption('scm.shallow') ? ' --depth 1' : ''; + $arguments = array_map([$this, 'quote'], array( + $this->connections->getRepositoryEndpoint(), + $destination, + )); - return $this->getCommand('clone%s -b %s "%s" %s', $shallow, $branch, $repository, $destination); + // Build flags + $flags = ['--branch' => $this->connections->getRepositoryBranch()]; + if ($this->rocketeer->getOption('scm.shallow')) { + $flags['--depth'] = 1; + } + + return $this->clone($arguments, $flags); } /** @@ -87,7 +95,7 @@ public function checkout($destination) */ public function reset() { - return $this->getCommand('reset --hard'); + return $this->getCommand('reset', null, ['--hard']); } /** @@ -97,7 +105,7 @@ public function reset() */ public function update() { - return $this->getCommand('pull'); + return $this->pull(); } /** @@ -107,6 +115,6 @@ public function update() */ public function submodules() { - return $this->getCommand('submodule update --init --recursive'); + return $this->submodule('update', ['--init', '--recursive']); } } diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index ae3ce8178..b4a9c49b8 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Scm; +use Rocketeer\Abstracts\AbstractBinary; use Rocketeer\Abstracts\AbstractScm; use Rocketeer\Interfaces\ScmInterface; @@ -18,7 +19,7 @@ * @author Maxime Fabre * @author Gasillo */ -class Svn extends AbstractScm implements ScmInterface +class Svn extends AbstractBinary implements ScmInterface { /** * The core binary @@ -78,7 +79,7 @@ public function checkout($destination) $repository = $this->connections->getRepositoryEndpoint(); $repository = rtrim($repository, '/').'/'.ltrim($branch, '/'); - return $this->getCommand('co %s %s %s', $this->getCredentials(), $repository, $destination); + return $this->co([$repository, $destination], $this->getCredentials()); } /** @@ -88,7 +89,9 @@ public function checkout($destination) */ public function reset() { - return $this->getCommand('status -q | grep -v \'^[~XI ]\' | awk \'{print $2;}\' | xargs %s revert', $this->binary); + $command = sprintf('status -q | grep -v \'^[~XI ]\' | awk \'{print $2;}\' | xargs %s revert', $this->binary); + + return $this->getCommand($command); } /** @@ -98,7 +101,7 @@ public function reset() */ public function update() { - return $this->getCommand('up %s', $this->getCredentials()); + return $this->up(null, $this->getCredentials()); } /** @@ -108,18 +111,18 @@ public function update() */ protected function getCredentials() { - $options = array('--non-interactive'); + $options = ['--non-interactive' => null]; $credentials = $this->connections->getRepositoryCredentials(); // Build command if ($user = array_get($credentials, 'username')) { - $options[] = '--username='.$user; + $options['--username'] = $user; } if ($pass = array_get($credentials, 'password')) { - $options[] = '--password='.$pass; + $options['--password'] = $pass; } - return implode(' ', $options); + return $options; } /** diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index 774b25335..c0b8ea087 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -57,7 +57,7 @@ public function testCanGetCheckout() $command = $this->scm->checkout($this->server); - $this->assertEquals('git clone --depth 1 -b develop "http://github.com/my/repository" '.$this->server, $command); + $this->assertEquals('git clone "http://github.com/my/repository" "' .$this->server. '" --branch="develop" --depth="1"', $command); } public function testCanGetDeepClone() @@ -73,7 +73,7 @@ public function testCanGetDeepClone() $command = $this->scm->checkout($this->server); - $this->assertEquals('git clone -b develop "http://github.com/my/repository" '.$this->server, $command); + $this->assertEquals('git clone "http://github.com/my/repository" "' .$this->server. '" --branch="develop"', $command); } public function testCanGetReset() diff --git a/tests/Scm/SvnTest.php b/tests/Scm/SvnTest.php index cf2f98d69..322f58a48 100644 --- a/tests/Scm/SvnTest.php +++ b/tests/Scm/SvnTest.php @@ -55,7 +55,7 @@ public function testCanGetCheckout() $command = $this->scm->checkout($this->server); - $this->assertEquals('svn co --non-interactive --username=foo --password=bar http://github.com/my/repository/develop '.$this->server, $command); + $this->assertEquals('svn co http://github.com/my/repository/develop ' .$this->server. ' --non-interactive --username="foo" --password="bar"', $command); } public function testCanGetDeepClone() @@ -69,7 +69,7 @@ public function testCanGetDeepClone() $command = $this->scm->checkout($this->server); - $this->assertEquals('svn co --non-interactive --username=foo --password=bar http://github.com/my/repository/develop '.$this->server, $command); + $this->assertEquals('svn co http://github.com/my/repository/develop ' .$this->server. ' --non-interactive --username="foo" --password="bar"', $command); } public function testCanGetReset() From 4fe5bce58df5673a93caf621003739a738168d42 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 19:19:21 +0200 Subject: [PATCH 134/424] Fix some tests --- .../{AbstractScmTest.php => AbstractBinaryTest.php} | 12 ++---------- tests/Strategies/CloneStrategyTest.php | 2 +- tests/Strategies/CopyStrategyTest.php | 4 ++-- tests/Tasks/DeployTest.php | 6 +++--- tests/TestCases/RocketeerAssertions.php | 12 +++++++++--- 5 files changed, 17 insertions(+), 19 deletions(-) rename tests/Abstracts/{AbstractScmTest.php => AbstractBinaryTest.php} (59%) diff --git a/tests/Abstracts/AbstractScmTest.php b/tests/Abstracts/AbstractBinaryTest.php similarity index 59% rename from tests/Abstracts/AbstractScmTest.php rename to tests/Abstracts/AbstractBinaryTest.php index 4ff715c50..d0b70ea28 100644 --- a/tests/Abstracts/AbstractScmTest.php +++ b/tests/Abstracts/AbstractBinaryTest.php @@ -4,16 +4,8 @@ use Rocketeer\Scm\Git; use Rocketeer\TestCases\RocketeerTestCase; -class AbstractScmTest extends RocketeerTestCase +class AbstractBinaryTest extends RocketeerTestCase { - public function testCanGetSprintfCommand() - { - $scm = new Git($this->app); - $command = $scm->getCommand('foo %s', 'bar'); - - $this->assertEquals('git foo bar', $command); - } - public function testCanExecuteMethod() { $this->mock('rocketeer.bash', 'Bash', function ($mock) { @@ -24,7 +16,7 @@ public function testCanExecuteMethod() $scm = new Git($this->app); $command = $scm->execute('checkout', $this->server); - $expected = $this->replaceHistoryPlaceholders(['git clone --depth 1 -b master "{repository}" {server}']); + $expected = $this->replaceHistoryPlaceholders(['git clone "{repository}" "{server}" --branch="master" --depth="1"']); $this->assertEquals($expected[0], $command); } diff --git a/tests/Strategies/CloneStrategyTest.php b/tests/Strategies/CloneStrategyTest.php index 32f53bb30..3a07eedff 100644 --- a/tests/Strategies/CloneStrategyTest.php +++ b/tests/Strategies/CloneStrategyTest.php @@ -11,7 +11,7 @@ public function testCanDeployRepository() $task->strategy->deploy(); $matcher = array( - 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", "git submodule update --init --recursive" diff --git a/tests/Strategies/CopyStrategyTest.php b/tests/Strategies/CopyStrategyTest.php index db98a1baa..4985ef57d 100644 --- a/tests/Strategies/CopyStrategyTest.php +++ b/tests/Strategies/CopyStrategyTest.php @@ -44,7 +44,7 @@ public function testClonesIfNoPreviousRelease() $this->strategy->deploy(); $matcher = array( - 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", "git submodule update --init --recursive" @@ -66,7 +66,7 @@ public function testCanCloneIfPreviousReleaseIsInvalid() $this->strategy->deploy(); $matcher = array( - 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", "git submodule update --init --recursive" diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index f7d57e91c..5f5dc584f 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -14,7 +14,7 @@ public function testCanDeployToServer() )); $matcher = array( - 'git clone --depth 1 -b master "https://github.com/Anahkiasen/html-object.git" {server}/releases/{release}', + 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", "git submodule update --init --recursive" @@ -60,7 +60,7 @@ public function testCanDisableGitOptions() )); $matcher = array( - 'git clone -b master "https://github.com/Anahkiasen/html-object.git" {server}/releases/{release}', + 'git clone "{repository}" "{server}/releases/{release}" --branch="master"', array( "cd {server}/releases/{release}", exec('which phpunit')." --stop-on-failure " @@ -168,7 +168,7 @@ public function testCanUseCopyStrategy() public function testCanRunDeployWithSeed() { $matcher = array( - 'git clone --depth 1 -b master "{repository}" {server}/releases/{release}', + 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", "git submodule update --init --recursive" diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index c2bb1f293..67ad09d19 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -120,14 +120,20 @@ public function assertHistory(array $expected, array $obtained) protected function replaceHistoryPlaceholders($history, $release = null) { $release = $release ?: date('YmdHis'); + $hhvm = defined('HHVM_VERSION'); + $replaced = []; foreach ($history as $key => $entries) { + if ($hhvm and $entries == '{php} -m') { + continue; + } + if (is_array($entries)) { - $history[$key] = $this->replaceHistoryPlaceholders($entries, $release); + $replaced[$key] = $this->replaceHistoryPlaceholders($entries, $release); continue; } - $history[$key] = strtr($entries, array( + $replaced[$key] = strtr($entries, array( '{php}' => exec('which php'), '{phpunit}' => exec('which phpunit'), '{repository}' => 'https://github.com/'.$this->repository, @@ -137,6 +143,6 @@ protected function replaceHistoryPlaceholders($history, $release = null) )); } - return $history; + return $replaced; } } From 14ac5aeda52f45e74cb8ca2d3cae0b0da2242d80 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 19:45:39 +0200 Subject: [PATCH 135/424] Fix wrong replace --- src/Rocketeer/Tasks/Deploy.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 68903970d..52a296abe 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -37,7 +37,7 @@ public function execute() // Setup if necessary if (!$this->isSetup()) { - $this->command->error('LocalStorage is not ready, running Setup task'); + $this->command->error('Server is not ready, running Setup task'); $this->executeTask('Setup'); } From f25306d7eee0d9b028d9b20d4b53ceeff5f88707 Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Sat, 9 Aug 2014 19:03:14 +0100 Subject: [PATCH 136/424] Suppress output during the tests This should solve the issue where we have blank lines generated dumped while the test suite it running. --- tests/Tasks/CleanupTest.php | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/tests/Tasks/CleanupTest.php b/tests/Tasks/CleanupTest.php index 795d17bf3..1fca6c40a 100644 --- a/tests/Tasks/CleanupTest.php +++ b/tests/Tasks/CleanupTest.php @@ -30,11 +30,15 @@ public function testCanPruneAllReleasesIfCleanAll() }); }); + ob_start(); + $this->assertTaskOutput('Cleanup', 'Removing 2 releases from the server', $this->getCommand(array(), array( 'clean-all' => true, 'verbose' => true, 'pretend' => false, ))); + + ob_end_clean(); } public function testPrintsMessageIfNoCleanup() From 31b0aa7ab897f0f15277b9d17b46a9dd9d85ec55 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 9 Aug 2014 20:07:57 +0200 Subject: [PATCH 137/424] Fix #217 - Listeners being canceled if *anything* was returned, not just false --- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- tests/Abstracts/AbstractTaskTest.php | 33 ++++++++++++++---------- 2 files changed, 21 insertions(+), 14 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index c9e911a86..b2f2c9d27 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -157,7 +157,7 @@ public function fireEvent($event) { // Fire the event $event = $this->getQualifiedEvent($event); - $result = $this->app['events']->fire($event, array($this), true); + $result = $this->events->fire($event, [$this]); // If the event returned a strict false, halt the task if ($result === false) { diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index faef4036f..ccd2ee3c8 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -60,25 +60,32 @@ public function testCanFireEventsDuringTasks() public function testTaskCancelsIfEventHalts() { - $this->expectOutputString('before'); + $this->expectOutputString('abc'); $this->swapConfig(array( 'rocketeer::hooks' => [], )); $this->tasksQueue()->registerConfiguredEvents(); - $this->tasksQueue()->listenTo('deploy.before', function () { - echo 'before'; - - return false; - }); - $this->tasksQueue()->listenTo('deploy.after', function () { - echo 'after'; - }); - - $task = $this->task('Deploy'); - $results = $task->fire(); + $this->tasksQueue()->listenTo('deploy.before', array( + function () { + echo 'a'; + return true; + }, + function () { + echo 'b'; + return 'lol'; + }, + function () { + echo 'c'; + return false; + }, + function () { + echo 'd'; + }, + )); - $this->assertFalse($results); + $task = $this->pretendTask('Deploy'); + $task->fire(); } } From 3d161b7818363b7a4595812a4e9314b2cf77a9b2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 01:03:42 +0200 Subject: [PATCH 138/424] Work on CLI status codes --- src/Rocketeer/Abstracts/AbstractCommand.php | 14 +++- .../Console/Commands/BaseTaskCommand.php | 4 +- .../Console/Commands/CleanupCommand.php | 4 +- .../Console/Commands/DeployCommand.php | 4 +- .../Console/Commands/FlushCommand.php | 6 ++ .../Console/Commands/RollbackCommand.php | 4 +- .../Console/Commands/TestCommand.php | 4 +- .../Console/Commands/UpdateCommand.php | 4 +- src/Rocketeer/RocketeerServiceProvider.php | 2 +- src/Rocketeer/Services/History/History.php | 8 ++ src/Rocketeer/Services/Tasks/Job.php | 26 +++++++ .../Services/{ => Tasks}/TasksQueue.php | 77 ++++++++----------- src/Rocketeer/Traits/HasLocator.php | 8 +- tests/MetaTest.php | 4 +- tests/Services/TasksQueueTest.php | 13 ++-- 15 files changed, 118 insertions(+), 64 deletions(-) create mode 100644 src/Rocketeer/Services/Tasks/Job.php rename src/Rocketeer/Services/{ => Tasks}/TasksQueue.php (84%) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index b2321132e..0e0dd24d0 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -77,6 +77,8 @@ public function isInsideLaravel() * Fire a Tasks Queue * * @param string|string[]|\Rocketeer\Abstracts\AbstractTask[] $tasks + * + * @return integer */ protected function fireTasksQueue($tasks) { @@ -93,12 +95,14 @@ protected function fireTasksQueue($tasks) } // Run tasks and display timer - $this->time(function () use ($tasks) { - $this->laravel['rocketeer.tasks']->run($tasks, $this); + $status = $this->time(function () use ($tasks) { + return $this->laravel['rocketeer.tasks']->run($tasks, $this); }); // Remove command instance unset($this->laravel['rocketeer.command']); + + return $status ? 0 : 1; } ////////////////////////////////////////////////////////////////////// @@ -135,14 +139,18 @@ public function askWith($question, $default = null, $choices = array()) * Time an operation and display it afterwards * * @param Closure $callback + * + * @return integer; */ public function time(Closure $callback) { // Start timer, execute callback, close timer $timerStart = microtime(true); - $callback(); + $results = $callback(); $time = round(microtime(true) - $timerStart, 4); $this->line('Execution time: '.$time.'s'); + + return $results; } } diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index d6d45aa0d..2b16bbe51 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -58,10 +58,12 @@ public function __construct(AbstractTask $task, $name = null) /** * Fire the custom Task + * + * @return integer */ public function fire() { - $this->fireTasksQueue($this->task->getSlug()); + return $this->fireTasksQueue($this->task->getSlug()); } /** diff --git a/src/Rocketeer/Console/Commands/CleanupCommand.php b/src/Rocketeer/Console/Commands/CleanupCommand.php index f789a9a7f..549a0a237 100644 --- a/src/Rocketeer/Console/Commands/CleanupCommand.php +++ b/src/Rocketeer/Console/Commands/CleanupCommand.php @@ -35,10 +35,12 @@ class CleanupCommand extends AbstractCommand /** * Execute the tasks + * + * @return integer */ public function fire() { - $this->fireTasksQueue('cleanup'); + return $this->fireTasksQueue('cleanup'); } /** diff --git a/src/Rocketeer/Console/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php index c0bb3c3b2..a1adb3ab1 100644 --- a/src/Rocketeer/Console/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -35,10 +35,12 @@ class DeployCommand extends AbstractCommand /** * Execute the tasks + * + * @return integer */ public function fire() { - $this->fireTasksQueue(array( + return $this->fireTasksQueue(array( 'deploy', 'cleanup', )); diff --git a/src/Rocketeer/Console/Commands/FlushCommand.php b/src/Rocketeer/Console/Commands/FlushCommand.php index 8ae2f9c1d..83cc3b902 100644 --- a/src/Rocketeer/Console/Commands/FlushCommand.php +++ b/src/Rocketeer/Console/Commands/FlushCommand.php @@ -34,10 +34,16 @@ class FlushCommand extends AbstractCommand /** * Execute the tasks + * + * @return integer */ public function fire() { + // Clear the cache of credentials $this->laravel['rocketeer.storage.local']->destroy(); + $this->info("Rocketeer's cache has been properly flushed"); + + return 0; } } diff --git a/src/Rocketeer/Console/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php index d576e4fac..b0a5a38c4 100644 --- a/src/Rocketeer/Console/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -36,10 +36,12 @@ class RollbackCommand extends AbstractCommand /** * The tasks to execute + * + * @return integer */ public function fire() { - $this->fireTasksQueue('rollback'); + return $this->fireTasksQueue('rollback'); } /** diff --git a/src/Rocketeer/Console/Commands/TestCommand.php b/src/Rocketeer/Console/Commands/TestCommand.php index facb3f005..74bcfe7f8 100644 --- a/src/Rocketeer/Console/Commands/TestCommand.php +++ b/src/Rocketeer/Console/Commands/TestCommand.php @@ -34,11 +34,13 @@ class TestCommand extends AbstractCommand /** * The tasks to execute + * + * @return integer */ public function fire() { $this->input->setOption('verbose', true); - $this->fireTasksQueue('test'); + return $this->fireTasksQueue('test'); } } diff --git a/src/Rocketeer/Console/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php index 1df33db74..519360ec3 100644 --- a/src/Rocketeer/Console/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -35,10 +35,12 @@ class UpdateCommand extends AbstractCommand /** * Execute the tasks + * + * @return integer */ public function fire() { - $this->fireTasksQueue('update'); + return $this->fireTasksQueue('update'); } /** diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b7436565c..c6fde181a 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -24,8 +24,8 @@ use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; use Rocketeer\Services\Storages\LocalStorage; +use Rocketeer\Services\Tasks\TasksQueue; use Rocketeer\Services\TasksHandler; -use Rocketeer\Services\TasksQueue; // Define DS if (!defined('DS')) { diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 375c75c6f..5c67b25fc 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -5,6 +5,14 @@ class History extends Collection { + /** + * Clear the history + */ + public function clear() + { + $this->items = []; + } + /** * Get the history, flattened * diff --git a/src/Rocketeer/Services/Tasks/Job.php b/src/Rocketeer/Services/Tasks/Job.php new file mode 100644 index 000000000..488bf9e21 --- /dev/null +++ b/src/Rocketeer/Services/Tasks/Job.php @@ -0,0 +1,26 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Tasks; + +use Illuminate\Support\Fluent; + +/** + * A job storing where a task/multiple tasks need to be executed + * + * @property string connection + * @property integer server + * @property string|null stage + * @property \Rocketeer\Abstracts\AbstractTask[] queue + * @author Maxime Fabre + */ +class Job extends Fluent +{ + // ... +} diff --git a/src/Rocketeer/Services/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php similarity index 84% rename from src/Rocketeer/Services/TasksQueue.php rename to src/Rocketeer/Services/Tasks/TasksQueue.php index 69d8e980b..d9178e4be 100644 --- a/src/Rocketeer/Services/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -7,13 +7,14 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Services; +namespace Rocketeer\Services\Tasks; use Closure; use Exception; use KzykHys\Parallel\Parallel; use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Connection; +use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; /** @@ -24,6 +25,7 @@ class TasksQueue { use HasLocator; + use HasHistory; /** * @type Parallel @@ -44,13 +46,6 @@ class TasksQueue */ protected $remote; - /** - * The output of the queue - * - * @var array - */ - protected $output = array(); - /** * @param Parallel $parallel */ @@ -66,8 +61,8 @@ public function setParallel($parallel) /** * Execute Tasks on the default connection * - * @param string|array|Closure $queue - * @param string|string[]|null $connections + * @param string|array|Closure $queue + * @param string|string[]|null $connections * * @return array */ @@ -77,17 +72,14 @@ public function execute($queue, $connections = null) $this->connections->setConnections($connections); } - $queue = (array) $queue; - $queue = $this->buildQueue($queue); - return $this->run($queue); } /** * Execute Tasks on various connections * - * @param string|string[] $connections - * @param string|array|Closure $queue + * @param string|string[] $connections + * @param string|array|Closure $queue * * @return array */ @@ -105,15 +97,17 @@ public function on($connections, $queue) * Run an array of Tasks instances on the various * connections and stages provided * - * @param array $tasks An array of tasks + * @param string|array $tasks An array of tasks * * @throws Exception * @return array An array of output */ - public function run(array $tasks) + public function run($tasks) { + $tasks = (array) $tasks; $queue = $this->buildQueue($tasks); $pipeline = $this->buildPipeline($queue); + $status = true; // Run pipeline if ($this->command->option('parallel')) { @@ -124,37 +118,40 @@ public function run(array $tasks) $this->parallel = $this->parallel ?: new Parallel(); $this->parallel->run($pipeline); } else { - $key = 0; + $key = 0; do { - $continue = $pipeline[$key](); + $status = $pipeline[$key](); $key++; - } while ($continue and isset($pipeline[$key])); + } while ($status and isset($pipeline[$key])); } - return $this->output; + return $status; } /** * Run the queue, taking into account the stage * - * @param \Rocketeer\Abstracts\AbstractTask[] $tasks - * @param string|null $stage + * @param Job $job * * @return boolean */ - protected function runQueue($tasks, $stage = null) + protected function executeJob(Job $job) { - foreach ($tasks as $task) { - $currentStage = $task->usesStages() ? $stage : null; + // Set proper server + $this->connections->setConnection($job->connection, $job->server); + + foreach ($job->queue as $task) { + $currentStage = $task->usesStages() ? $job->stage : null; $this->connections->setStage($currentStage); - // Here we fire the task and if it was halted - // at any point, we cancel the whole queue - $state = $task->fire(); - $this->output[] = $state; - if ($task->wasHalted() or $state === false) { - $this->command->error('The tasks que was canceled by task "'.$task->getName().'"'); + // Here we fire the task, save its + // output and return its status + $state = $task->fire(); + $this->toOutput($state); + // If the task didn't finish, display what the error was + if ($task->wasHalted() or $state === false) { + $this->command->error('The tasks queue was canceled by task "'.$task->getName().'"'); return false; } } @@ -193,12 +190,12 @@ protected function buildPipeline(array $queue) // Add job to pipeline foreach ($stages as $stage) { - $pipeline[] = array( + $pipeline[] = new Job(array( 'connection' => $connection, 'server' => $server, 'stage' => $stage, 'queue' => $queue, - ); + )); } } } @@ -206,9 +203,7 @@ protected function buildPipeline(array $queue) // Build pipeline foreach ($pipeline as $key => $job) { $pipeline[$key] = function () use ($job) { - $this->connections->setConnection($job['connection'], $job['server']); - - return $this->runQueue($job['queue'], $job['stage']); + return $this->executeJob($job); }; } @@ -224,17 +219,13 @@ protected function buildPipeline(array $queue) * Here we will take the various Tasks names, closures and string tasks * and unify all of those to actual AbstractTask instances * - * @param array $tasks + * @param array $tasks * * @return array */ public function buildQueue(array $tasks) { - foreach ($tasks as &$task) { - $task = $this->buildTask($task); - } - - return $tasks; + return array_map([$this, 'buildTask'], $tasks); } /** diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index e4dd504bc..a430b5a7f 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -14,8 +14,10 @@ /** * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes - * - * @property \Illuminate\Config\Repository config + + +* +*@property \Illuminate\Config\Repository config * @property \Illuminate\Events\Dispatcher events * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Log\Writer log @@ -32,7 +34,7 @@ * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Services\Storages\LocalStorage localStorage * @property \Rocketeer\Services\TasksHandler tasks - * @property \Rocketeer\Services\TasksQueue queue + * @property \Rocketeer\Services\Tasks\TasksQueue queue * @author Maxime Fabre */ trait HasLocator diff --git a/tests/MetaTest.php b/tests/MetaTest.php index 94b3d4dfd..23f670418 100644 --- a/tests/MetaTest.php +++ b/tests/MetaTest.php @@ -12,7 +12,7 @@ public function testCanOverwriteTasksViaContainer() return new MyCustomTask($app); }); - $queue = $this->tasks->on('production', array('cleanup'), $this->getCommand()); - $this->assertEquals(['foobar'], $queue); + $this->tasks->on('production', ['cleanup'], $this->getCommand()); + $this->assertEquals(['foobar'], $this->history->getFlattenedOutput()); } } diff --git a/tests/Services/TasksQueueTest.php b/tests/Services/TasksQueueTest.php index 5302e5197..6a9ded3f3 100644 --- a/tests/Services/TasksQueueTest.php +++ b/tests/Services/TasksQueueTest.php @@ -110,13 +110,14 @@ public function testCanRunQueueViaExecute() 'rocketeer::default' => 'production', )); - $output = $this->tasksQueue()->execute(array( + $this->tasksQueue()->run(array( 'ls -a', function () { return 'JOEY DOESNT SHARE FOOD'; } )); + $output = array_slice($this->history->getFlattenedOutput(), 2, 3); $this->assertEquals(array( '.'.PHP_EOL.'..'.PHP_EOL.'.gitkeep', 'JOEY DOESNT SHARE FOOD', @@ -129,7 +130,7 @@ public function testCanRunOnMultipleConnectionsViaOn() 'rocketeer::stages.stages' => array('first', 'second'), )); - $output = $this->tasksQueue()->on(array('staging', 'production'), function ($task) { + $this->tasksQueue()->on(array('staging', 'production'), function ($task) { return $task->connections->getConnection().' - '.$task->connections->getStage(); }); @@ -138,7 +139,7 @@ public function testCanRunOnMultipleConnectionsViaOn() 'staging - second', 'production - first', 'production - second', - ), $output); + ), $this->history->getFlattenedOutput()); } public function testCanRunTasksInParallel() @@ -155,7 +156,7 @@ public function testCanRunTasksInParallel() public function testCanCancelQueueIfTaskFails() { - $this->expectOutputString('The tasks que was canceled by task "MyCustomHaltingTask"'); + $this->expectOutputString('The tasks queue was canceled by task "MyCustomHaltingTask"'); $this->mockCommand([], array( 'error' => function ($error) { @@ -163,11 +164,11 @@ public function testCanCancelQueueIfTaskFails() }, )); - $output = $this->tasksQueue()->execute(array( + $this->tasksQueue()->run(array( 'Rocketeer\Dummies\MyCustomHaltingTask', 'Rocketeer\Dummies\MyCustomTask', )); - $this->assertEquals([false], $output); + $this->assertEquals([false], $this->history->getFlattenedOutput()); } } From 613011fd5b98c9e2e561840c6d48927b8ac25ccf Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 01:05:51 +0200 Subject: [PATCH 139/424] CS fixes --- src/Rocketeer/Abstracts/AbstractCommand.php | 4 +-- src/Rocketeer/Services/Tasks/TasksQueue.php | 5 +-- src/Rocketeer/Traits/HasLocator.php | 38 ++++++++++----------- tests/Abstracts/AbstractTaskTest.php | 5 ++- tests/Scm/GitTest.php | 4 +-- tests/Scm/SvnTest.php | 4 +-- 6 files changed, 31 insertions(+), 29 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 0e0dd24d0..77060eabe 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -146,8 +146,8 @@ public function time(Closure $callback) { // Start timer, execute callback, close timer $timerStart = microtime(true); - $results = $callback(); - $time = round(microtime(true) - $timerStart, 4); + $results = $callback(); + $time = round(microtime(true) - $timerStart, 4); $this->line('Execution time: '.$time.'s'); diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index d9178e4be..dfc33f660 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -107,7 +107,7 @@ public function run($tasks) $tasks = (array) $tasks; $queue = $this->buildQueue($tasks); $pipeline = $this->buildPipeline($queue); - $status = true; + $status = true; // Run pipeline if ($this->command->option('parallel')) { @@ -118,7 +118,7 @@ public function run($tasks) $this->parallel = $this->parallel ?: new Parallel(); $this->parallel->run($pipeline); } else { - $key = 0; + $key = 0; do { $status = $pipeline[$key](); $key++; @@ -152,6 +152,7 @@ protected function executeJob(Job $job) // If the task didn't finish, display what the error was if ($task->wasHalted() or $state === false) { $this->command->error('The tasks queue was canceled by task "'.$task->getName().'"'); + return false; } } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index a430b5a7f..996796188 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -14,26 +14,24 @@ /** * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes - - -* -*@property \Illuminate\Config\Repository config - * @property \Illuminate\Events\Dispatcher events - * @property \Illuminate\Filesystem\Filesystem files - * @property \Illuminate\Log\Writer log - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Abstracts\AbstractCommand command - * @property \Rocketeer\Bash bash - * @property \Rocketeer\Console\Console console - * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\StrategyInterface strategy - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Services\CredentialsGatherer credentials - * @property \Rocketeer\Services\History\History history - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\TasksHandler tasks + * + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Events\Dispatcher events + * @property \Illuminate\Filesystem\Filesystem files + * @property \Illuminate\Log\Writer log + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\AbstractCommand command + * @property \Rocketeer\Bash bash + * @property \Rocketeer\Console\Console console + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\CredentialsGatherer credentials + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage localStorage + * @property \Rocketeer\Services\TasksHandler tasks * @property \Rocketeer\Services\Tasks\TasksQueue queue * @author Maxime Fabre */ diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index ccd2ee3c8..6b0cd2d93 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -70,14 +70,17 @@ public function testTaskCancelsIfEventHalts() $this->tasksQueue()->listenTo('deploy.before', array( function () { echo 'a'; + return true; }, function () { echo 'b'; + return 'lol'; }, function () { echo 'c'; + return false; }, function () { @@ -85,7 +88,7 @@ function () { }, )); - $task = $this->pretendTask('Deploy'); + $task = $this->pretendTask('Deploy'); $task->fire(); } } diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index c0b8ea087..2f54d929e 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -57,7 +57,7 @@ public function testCanGetCheckout() $command = $this->scm->checkout($this->server); - $this->assertEquals('git clone "http://github.com/my/repository" "' .$this->server. '" --branch="develop" --depth="1"', $command); + $this->assertEquals('git clone "http://github.com/my/repository" "'.$this->server.'" --branch="develop" --depth="1"', $command); } public function testCanGetDeepClone() @@ -73,7 +73,7 @@ public function testCanGetDeepClone() $command = $this->scm->checkout($this->server); - $this->assertEquals('git clone "http://github.com/my/repository" "' .$this->server. '" --branch="develop"', $command); + $this->assertEquals('git clone "http://github.com/my/repository" "'.$this->server.'" --branch="develop"', $command); } public function testCanGetReset() diff --git a/tests/Scm/SvnTest.php b/tests/Scm/SvnTest.php index 322f58a48..0490ee661 100644 --- a/tests/Scm/SvnTest.php +++ b/tests/Scm/SvnTest.php @@ -55,7 +55,7 @@ public function testCanGetCheckout() $command = $this->scm->checkout($this->server); - $this->assertEquals('svn co http://github.com/my/repository/develop ' .$this->server. ' --non-interactive --username="foo" --password="bar"', $command); + $this->assertEquals('svn co http://github.com/my/repository/develop '.$this->server.' --non-interactive --username="foo" --password="bar"', $command); } public function testCanGetDeepClone() @@ -69,7 +69,7 @@ public function testCanGetDeepClone() $command = $this->scm->checkout($this->server); - $this->assertEquals('svn co http://github.com/my/repository/develop ' .$this->server. ' --non-interactive --username="foo" --password="bar"', $command); + $this->assertEquals('svn co http://github.com/my/repository/develop '.$this->server.' --non-interactive --username="foo" --password="bar"', $command); } public function testCanGetReset() From 03c0bcb246c89e4ff430b950ab8995b76aef8b69 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 02:29:19 +0200 Subject: [PATCH 140/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractBinary.php | 8 ++++---- src/Rocketeer/Scm/Git.php | 1 - src/Rocketeer/Scm/Svn.php | 1 - 3 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 3c1163a90..d2d44a548 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -108,9 +108,9 @@ public function getCommand($command, $arguments = array(), $flags = array()) } /** - * @param $flags + * @param string[] $flags * - * @return array|string + * @return string */ protected function buildOptions($flags) { @@ -135,9 +135,9 @@ protected function buildOptions($flags) } /** - * @param $arguments + * @param string[] $arguments * - * @return array|string + * @return string */ protected function buildArguments($arguments) { diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index d6cf3f77f..390af4e34 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -10,7 +10,6 @@ namespace Rocketeer\Scm; use Rocketeer\Abstracts\AbstractBinary; -use Rocketeer\Abstracts\AbstractScm; use Rocketeer\Interfaces\ScmInterface; /** diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index b4a9c49b8..bcc5137cf 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -10,7 +10,6 @@ namespace Rocketeer\Scm; use Rocketeer\Abstracts\AbstractBinary; -use Rocketeer\Abstracts\AbstractScm; use Rocketeer\Interfaces\ScmInterface; /** From 164c38cf8dbd40dc396a6937f8fc12cf20930a5a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 02:29:19 +0200 Subject: [PATCH 141/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractBinary.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index d2d44a548..582d1081a 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -122,7 +122,7 @@ protected function buildOptions($flags) if (!is_null($firstKey) and is_int($firstKey)) { $flags = array_combine( array_values($flags), - array_fill(0, sizeof($flags), null) + array_fill(0, count($flags), null) ); } From abdea341d4c80c3269be7cee3dc009914e46efdd Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 15:51:14 +0200 Subject: [PATCH 142/424] Dead code --- src/Rocketeer/Abstracts/AbstractBinary.php | 10 +++------- src/Rocketeer/Strategies/CloneStrategy.php | 2 +- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 582d1081a..7d350d846 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -39,7 +39,7 @@ public function getBinary() } /** - * Execute a command on the Binary + * Call or execute a command on the Binary * * @param string $name * @param array $arguments @@ -48,10 +48,6 @@ public function getBinary() */ public function __call($name, $arguments) { - // Check whether we want the command executed or not - $execute = strpos($name, 'execute') !== false; - $name = str_replace('execute', null, $name); - // Format name $name = Str::snake($name, '-'); @@ -59,7 +55,7 @@ public function __call($name, $arguments) array_unshift($arguments, $name); $command = call_user_func_array([$this, 'getCommand'], $arguments); - return $execute ? $this->bash->run($command) : $command; + return $command; } /** @@ -71,7 +67,7 @@ public function execute() { $arguments = func_get_args(); $command = array_shift($arguments); - $command = call_user_func_array(array($this, $command), $arguments); + $command = call_user_func_array([$this, $command], $arguments); return $this->bash->run($command); } diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php index b63c857de..8ee4fb2ff 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -21,7 +21,7 @@ public function deploy($destination = null) // Executing checkout $this->command->info('Cloning repository in "'.$destination.'"'); - $output = $this->bash->run($this->scm->checkout($destination)); + $output = $this->scm->execute('checkout', $destination); // Cancel if failed and forget credentials $success = $this->bash->checkStatus('Unable to clone the repository', $output) !== false; From f37ff4084db2b0b7e87bf007a63ff2845add4ade Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 16:32:45 +0200 Subject: [PATCH 143/424] Add some tests --- tests/Services/TasksQueueTest.php | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/tests/Services/TasksQueueTest.php b/tests/Services/TasksQueueTest.php index 6a9ded3f3..8a9ce4a80 100644 --- a/tests/Services/TasksQueueTest.php +++ b/tests/Services/TasksQueueTest.php @@ -93,9 +93,9 @@ function ($task) use (&$output) { } ); - $queue = $this->tasksQueue()->buildQueue($queue); - $this->tasksQueue()->run($queue, $this->getCommand()); + $status = $this->tasksQueue()->run($queue); + $this->assertTrue($status); $this->assertEquals(array( 'staging - first', 'staging - second', @@ -110,7 +110,7 @@ public function testCanRunQueueViaExecute() 'rocketeer::default' => 'production', )); - $this->tasksQueue()->run(array( + $status = $this->tasksQueue()->run(array( 'ls -a', function () { return 'JOEY DOESNT SHARE FOOD'; @@ -118,6 +118,7 @@ function () { )); $output = array_slice($this->history->getFlattenedOutput(), 2, 3); + $this->assertTrue($status); $this->assertEquals(array( '.'.PHP_EOL.'..'.PHP_EOL.'.gitkeep', 'JOEY DOESNT SHARE FOOD', @@ -130,10 +131,11 @@ public function testCanRunOnMultipleConnectionsViaOn() 'rocketeer::stages.stages' => array('first', 'second'), )); - $this->tasksQueue()->on(array('staging', 'production'), function ($task) { + $status = $this->tasksQueue()->on(array('staging', 'production'), function ($task) { return $task->connections->getConnection().' - '.$task->connections->getStage(); }); + $this->assertTrue($status); $this->assertEquals(array( 'staging - first', 'staging - second', @@ -164,11 +166,12 @@ public function testCanCancelQueueIfTaskFails() }, )); - $this->tasksQueue()->run(array( + $status = $this->tasksQueue()->run(array( 'Rocketeer\Dummies\MyCustomHaltingTask', 'Rocketeer\Dummies\MyCustomTask', )); + $this->assertFalse($status); $this->assertEquals([false], $this->history->getFlattenedOutput()); } } From 74df2e9611fc06052138a7e864621545ed8d0b94 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 19:25:55 +0200 Subject: [PATCH 144/424] Split TasksQueue and TasksBuilder --- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- src/Rocketeer/RocketeerServiceProvider.php | 7 +- src/Rocketeer/Services/Tasks/TasksBuilder.php | 154 ++++++++++++++++++ src/Rocketeer/Services/Tasks/TasksQueue.php | 136 +--------------- src/Rocketeer/Services/TasksHandler.php | 10 +- src/Rocketeer/Traits/HasLocator.php | 42 ++--- tests/Dummies/DummyNotifier.php | 2 + tests/Plugins/AbstractNotifierTest.php | 3 +- tests/Services/Tasks/TasksBuilderTest.php | 66 ++++++++ tests/Services/{ => Tasks}/TasksQueueTest.php | 59 +------ tests/Services/TasksHandlerTest.php | 2 +- tests/TestCases/RocketeerTestCase.php | 2 +- tests/Traits/BashModules/FilesystemTest.php | 2 +- 13 files changed, 264 insertions(+), 223 deletions(-) create mode 100644 src/Rocketeer/Services/Tasks/TasksBuilder.php create mode 100644 tests/Services/Tasks/TasksBuilderTest.php rename tests/Services/{ => Tasks}/TasksQueueTest.php (62%) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index b2f2c9d27..8d9ae8c9f 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -214,6 +214,6 @@ protected function displayReleases() */ public function executeTask($task) { - return $this->app['rocketeer.tasks']->buildTaskFromClass($task)->fire(); + return $this->app['rocketeer.builder']->buildTaskFromClass($task)->fire(); } } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index c6fde181a..42a86c493 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -24,6 +24,7 @@ use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; use Rocketeer\Services\Storages\LocalStorage; +use Rocketeer\Services\Tasks\TasksBuilder; use Rocketeer\Services\Tasks\TasksQueue; use Rocketeer\Services\TasksHandler; @@ -173,6 +174,10 @@ public function bindCoreClasses() return new TasksQueue($app); }); + $this->app->bind('rocketeer.builder', function ($app) { + return new TasksBuilder($app); + }); + $this->app->singleton('rocketeer.tasks', function ($app) { return new TasksHandler($app); }); @@ -258,7 +263,7 @@ public function bindCommands() $fakeCommand = !class_exists($commandClass); // Build command slug - $taskInstance = $this->app['rocketeer.tasks']->buildTaskFromClass($task); + $taskInstance = $this->app['rocketeer.builder']->buildTaskFromClass($task); if (is_numeric($slug)) { $slug = $taskInstance->getSlug(); } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php new file mode 100644 index 000000000..a89614c27 --- /dev/null +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -0,0 +1,154 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Tasks; + +use Closure; +use Rocketeer\Abstracts\AbstractTask; +use Rocketeer\Traits\HasLocator; + +/** + * Handles creating tasks from strings, closures, AbstractTask children, etc. + * + * @author Maxime Fabre + */ +class TasksBuilder +{ + use HasLocator; + + //////////////////////////////////////////////////////////////////// + /////////////////////////////// BUILDING /////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Build an array of tasks + * + * @param array $tasks + * + * @return array + */ + public function buildTasks(array $tasks) + { + return array_map([$this, 'buildTask'], $tasks); + } + + /** + * Build a task from anything + * + * @param string|Closure|AbstractTask $task + * @param string|null $name + * + * @return AbstractTask + */ + public function buildTask($task, $name = null) + { + // Check the handle if possible + if (is_string($task)) { + $handle = 'rocketeer.tasks.'.$task; + } + + // If we provided a Closure or a string command, build it + if ($task instanceof Closure or $this->isStringCommand($task)) { + $task = $this->buildTaskFromClosure($task); + } // Check for an existing container binding + elseif (isset($handle) and $this->app->bound($handle)) { + return $this->app[$handle]; + } + + // Build remaining tasks + if (!$task instanceof AbstractTask) { + $task = $this->buildTaskFromClass($task); + } + + // Set the task's name + if ($name) { + $task->setName($name); + } + + return $task; + } + + /** + * Build a task from a Closure or a string command + * + * @param Closure|string $task + * + * @return AbstractTask + */ + public function buildTaskFromClosure($task) + { + // If the User provided a string to execute + // We'll build a closure from it + if ($this->isStringCommand($task)) { + $stringTask = $task; + $closure = function ($task) use ($stringTask) { + return $task->runForCurrentRelease($stringTask); + }; + // If the User provided a Closure + } else { + $closure = $task; + } + + // Now that we unified it all to a Closure, we build + // a Closure AbstractTask from there + $task = $this->buildTaskFromClass('Rocketeer\Tasks\Closure'); + $task->setClosure($closure); + + // If we had an original string used, store it on + // the task for easier reflection + if (isset($stringTask)) { + $task->setStringTask($stringTask); + } + + return $task; + } + + /** + * Build a task from its name + * + * @param string|AbstractTask $task + * + * @return AbstractTask|string + */ + public function buildTaskFromClass($task) + { + if (is_object($task) and $task instanceof AbstractTask) { + return $task; + } + + // Shortcut for calling Rocketeer Tasks + if (class_exists('Rocketeer\Tasks\\'.ucfirst($task))) { + $task = 'Rocketeer\Tasks\\'.ucfirst($task); + } + + // Cancel if class doesn't exist + if (!class_exists($task)) { + return $task; + } + + return new $task($this->app); + } + + + //////////////////////////////////////////////////////////////////// + /////////////////////////////// HELPERS //////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Check if a string is a command or a task + * + * @param AbstractTask|Closure|string $string + * + * @return boolean + */ + protected function isStringCommand($string) + { + return is_string($string) && !class_exists($string) && !$this->app->bound('rocketeer.tasks.'.$string); + } +} diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index dfc33f660..2567858c3 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -18,7 +18,8 @@ use Rocketeer\Traits\HasLocator; /** - * Handles the building and execution of tasks + * Handles running an array of tasks sequentially + * or in parallel * * @author Maxime Fabre */ @@ -105,7 +106,7 @@ public function on($connections, $queue) public function run($tasks) { $tasks = (array) $tasks; - $queue = $this->buildQueue($tasks); + $queue = $this->builder->buildTasks($tasks); $pipeline = $this->buildPipeline($queue); $status = true; @@ -211,121 +212,6 @@ protected function buildPipeline(array $queue) return $pipeline; } - //////////////////////////////////////////////////////////////////// - /////////////////////////////// BUILDING /////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Build a queue from a list of tasks - * Here we will take the various Tasks names, closures and string tasks - * and unify all of those to actual AbstractTask instances - * - * @param array $tasks - * - * @return array - */ - public function buildQueue(array $tasks) - { - return array_map([$this, 'buildTask'], $tasks); - } - - /** - * Build a task from anything - * - * @param string|Closure|AbstractTask $task - * @param string|null $name - * - * @return AbstractTask - */ - public function buildTask($task, $name = null) - { - // Check the handle if possible - if (is_string($task)) { - $handle = 'rocketeer.tasks.'.$task; - } - - // If we provided a Closure or a string command, build it - if ($task instanceof Closure or $this->isStringCommand($task)) { - $task = $this->buildTaskFromClosure($task); - } // Check for an existing container binding - elseif (isset($handle) and $this->app->bound($handle)) { - return $this->app[$handle]; - } - - // Build remaining tasks - if (!$task instanceof AbstractTask) { - $task = $this->buildTaskFromClass($task); - } - - // Set the task's name - if ($name) { - $task->setName($name); - } - - return $task; - } - - /** - * Build a task from a Closure or a string command - * - * @param Closure|string $task - * - * @return AbstractTask - */ - public function buildTaskFromClosure($task) - { - // If the User provided a string to execute - // We'll build a closure from it - if ($this->isStringCommand($task)) { - $stringTask = $task; - $closure = function ($task) use ($stringTask) { - return $task->runForCurrentRelease($stringTask); - }; - // If the User provided a Closure - } else { - $closure = $task; - } - - // Now that we unified it all to a Closure, we build - // a Closure AbstractTask from there - $task = $this->buildTaskFromClass('Rocketeer\Tasks\Closure'); - $task->setClosure($closure); - - // If we had an original string used, store it on - // the task for easier reflection - if (isset($stringTask)) { - $task->setStringTask($stringTask); - } - - return $task; - } - - /** - * Build a task from its name - * - * @param string|AbstractTask $task - * - * @return AbstractTask|string - */ - public function buildTaskFromClass($task) - { - if (is_object($task) and $task instanceof AbstractTask) { - return $task; - } - - // Shortcut for calling Rocketeer Tasks - if (class_exists('Rocketeer\Tasks\\'.ucfirst($task))) { - $task = 'Rocketeer\Tasks\\'.ucfirst($task); - } - - // Cancel if class doesn't exist - if (!class_exists($task)) { - return $task; - } - - return new $task($this->app); - } - //////////////////////////////////////////////////////////////////// //////////////////////////////// STAGES //////////////////////////// //////////////////////////////////////////////////////////////////// @@ -350,20 +236,4 @@ protected function getStage() return $stage; } - - //////////////////////////////////////////////////////////////////// - /////////////////////////////// HELPERS //////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Check if a string is a command or a task - * - * @param AbstractTask|Closure|string $string - * - * @return boolean - */ - protected function isStringCommand($string) - { - return is_string($string) && !class_exists($string) && !$this->app->bound('rocketeer.tasks.'.$string); - } } diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index f2e9d151b..7619e38b1 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -17,7 +17,7 @@ use Rocketeer\Traits\HasLocator; /** - * Handles the registering and relating of tasks + * Handles the registering and firing of tasks and their events * * @author Maxime Fabre */ @@ -72,7 +72,7 @@ public function __call($method, $parameters) public function add($task, $name = null) { // Build task if necessary - $task = $this->queue->buildTask($task, $name); + $task = $this->builder->buildTask($task, $name); $slug = 'rocketeer.tasks.'.$task->getSlug(); // Add the task to Rocketeer @@ -168,7 +168,7 @@ public function registerConfiguredEvents() public function listenTo($event, $listeners, $priority = 0) { // Create array if it doesn't exist - $listeners = $this->queue->buildQueue((array) $listeners); + $listeners = $this->builder->buildTasks((array) $listeners); // Register events foreach ($listeners as $listener) { @@ -200,7 +200,7 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) } // Get event name and register listeners - $event = $this->queue->buildTaskFromClass($task)->getSlug().'.'.$event; + $event = $this->builder->buildTaskFromClass($task)->getSlug().'.'.$event; $event = $this->listenTo($event, $listeners, $priority); return $event; @@ -218,7 +218,7 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) public function getTasksListeners($task, $event, $flatten = false) { // Get events - $task = $this->queue->buildTaskFromClass($task)->getSlug(); + $task = $this->builder->buildTaskFromClass($task)->getSlug(); $events = $this->events->getListeners('rocketeer.'.$task.'.'.$event); // Flatten the queue if requested diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 996796188..70f2a9c38 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,24 +15,25 @@ * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Config\Repository config - * @property \Illuminate\Events\Dispatcher events - * @property \Illuminate\Filesystem\Filesystem files - * @property \Illuminate\Log\Writer log - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Abstracts\AbstractCommand command - * @property \Rocketeer\Bash bash - * @property \Rocketeer\Console\Console console - * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\StrategyInterface strategy - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Services\CredentialsGatherer credentials - * @property \Rocketeer\Services\History\History history - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\TasksHandler tasks - * @property \Rocketeer\Services\Tasks\TasksQueue queue + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Events\Dispatcher events + * @property \Illuminate\Filesystem\Filesystem files + * @property \Illuminate\Log\Writer log + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\AbstractCommand command + * @property \Rocketeer\Bash bash + * @property \Rocketeer\Console\Console console + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\CredentialsGatherer credentials + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage localStorage + * @property \Rocketeer\Services\Tasks\TasksBuilder builder + * @property \Rocketeer\Services\Tasks\TasksQueue queue + * @property \Rocketeer\Services\TasksHandler tasks * @author Maxime Fabre */ trait HasLocator @@ -65,17 +66,18 @@ public function __get($key) { $shortcuts = array( 'bash' => 'rocketeer.bash', + 'builder' => 'rocketeer.builder', 'command' => 'rocketeer.command', - 'credentials' => 'rocketeer.credentials', 'connections' => 'rocketeer.connections', 'console' => 'rocketeer.console', + 'credentials' => 'rocketeer.credentials', 'history' => 'rocketeer.history', + 'localStorage' => 'rocketeer.storage.local', 'logs' => 'rocketeer.logs', 'queue' => 'rocketeer.queue', 'releasesManager' => 'rocketeer.releases', 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', - 'localStorage' => 'rocketeer.storage.local', 'strategy' => 'rocketeer.strategy', 'tasks' => 'rocketeer.tasks', ); diff --git a/tests/Dummies/DummyNotifier.php b/tests/Dummies/DummyNotifier.php index c30f7f06f..03ac797a1 100644 --- a/tests/Dummies/DummyNotifier.php +++ b/tests/Dummies/DummyNotifier.php @@ -8,6 +8,8 @@ class DummyNotifier extends AbstractNotifier /** * Get the default message format * + * @param string $message + * * @return string */ protected function getMessageFormat($message) diff --git a/tests/Plugins/AbstractNotifierTest.php b/tests/Plugins/AbstractNotifierTest.php index 34dc3384d..8393aceec 100644 --- a/tests/Plugins/AbstractNotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -54,9 +54,8 @@ public function testCanAppendStageToDetails() $this->localStorage->set('notifier.name', 'Jean Eude'); $this->connections->setStage('staging'); $this->notifier = new DummyNotifier($this->app); - $this->tasks->plugin($this->notifier); - $this->task('Deploy')->fireEvent('after'); + $this->task('Deploy')->fireEvent('before'); } public function testCanSendDeploymentsNotifications() diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php new file mode 100644 index 000000000..2bf80bb86 --- /dev/null +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -0,0 +1,66 @@ +builder->buildTaskFromClass('Rocketeer\Tasks\Deploy'); + + $this->assertInstanceOf('Rocketeer\Abstracts\AbstractTask', $task); + } + + public function testCanBuildCustomTaskByName() + { + $tasks = $this->builder->buildTasks(array('Rocketeer\Tasks\Check')); + + $this->assertInstanceOf('Rocketeer\Tasks\Check', $tasks[0]); + } + + public function testCanBuildTaskFromString() + { + $string = 'echo "I love ducks"'; + + $string = $this->builder->buildTaskFromClosure($string); + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $string); + + $closure = $string->getClosure(); + $this->assertInstanceOf('Closure', $closure); + + $closureReflection = new ReflectionFunction($closure); + $this->assertEquals(array('stringTask' => 'echo "I love ducks"'), $closureReflection->getStaticVariables()); + + $this->assertEquals('I love ducks', $string->execute()); + } + + public function testCanBuildTaskFromClosure() + { + $originalClosure = function ($task) { + return $task->getCommand()->info('echo "I love ducks"'); + }; + + $closure = $this->builder->buildTaskFromClosure($originalClosure); + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $closure); + $this->assertEquals($originalClosure, $closure->getClosure()); + } + + public function testCanBuildTasks() + { + $queue = array( + 'foobar', + function () { + return 'lol'; + }, + 'Rocketeer\Tasks\Deploy' + ); + + $queue = $this->builder->buildTasks($queue); + + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[0]); + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[1]); + $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $queue[2]); + } +} diff --git a/tests/Services/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php similarity index 62% rename from tests/Services/TasksQueueTest.php rename to tests/Services/Tasks/TasksQueueTest.php index 8a9ce4a80..95d029f7e 100644 --- a/tests/Services/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -1,5 +1,5 @@ tasksQueue()->buildTaskFromClass('Rocketeer\Tasks\Deploy'); - - $this->assertInstanceOf('Rocketeer\Abstracts\AbstractTask', $task); - } - - public function testCanBuildCustomTaskByName() - { - $tasks = $this->tasksQueue()->buildQueue(array('Rocketeer\Tasks\Check')); - - $this->assertInstanceOf('Rocketeer\Tasks\Check', $tasks[0]); - } - - public function testCanBuildTaskFromString() - { - $string = 'echo "I love ducks"'; - - $string = $this->tasksQueue()->buildTaskFromClosure($string); - $this->assertInstanceOf('Rocketeer\Tasks\Closure', $string); - - $closure = $string->getClosure(); - $this->assertInstanceOf('Closure', $closure); - - $closureReflection = new ReflectionFunction($closure); - $this->assertEquals(array('stringTask' => 'echo "I love ducks"'), $closureReflection->getStaticVariables()); - - $this->assertEquals('I love ducks', $string->execute()); - } - - public function testCanBuildTaskFromClosure() - { - $originalClosure = function ($task) { - return $task->getCommand()->info('echo "I love ducks"'); - }; - - $closure = $this->tasksQueue()->buildTaskFromClosure($originalClosure); - $this->assertInstanceOf('Rocketeer\Tasks\Closure', $closure); - $this->assertEquals($originalClosure, $closure->getClosure()); - } - - public function testCanBuildQueue() - { - $queue = array( - 'foobar', - function () { - return 'lol'; - }, - 'Rocketeer\Tasks\Deploy' - ); - - $queue = $this->tasksQueue()->buildQueue($queue); - - $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[0]); - $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[1]); - $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $queue[2]); - } public function testCanRunQueue() { diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index d22051e3f..24cc557b7 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -102,7 +102,7 @@ public function testCanExecuteContextualEvents() $this->assertEquals([], $this->tasksQueue()->getTasksListeners('check', 'before', true)); } - public function testCanBuildQueueFromConfigHook() + public function testCanbuildTasksFromConfigHook() { $tasks = array( 'npm install', diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index dc3ec4716..e6b3bcc21 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -235,7 +235,7 @@ protected function task($task = null, $options = array()) return $this->task; } - return $this->tasksQueue()->buildTaskFromClass('Rocketeer\Tasks\\'.$task); + return $this->builder->buildTaskFromClass('Rocketeer\Tasks\\'.$task); } /** diff --git a/tests/Traits/BashModules/FilesystemTest.php b/tests/Traits/BashModules/FilesystemTest.php index afed9c49a..c8000fccd 100644 --- a/tests/Traits/BashModules/FilesystemTest.php +++ b/tests/Traits/BashModules/FilesystemTest.php @@ -33,7 +33,7 @@ public function testCanListContentsOfAFolder() { $contents = $this->task->listContents($this->server); - $this->assertEquals(array('current', 'releases', 'shared', 'state.json'), $contents); + $this->assertEquals(['current', 'releases', 'shared', 'state.json'], $contents); } public function testCanCheckIfFileExists() From 628ed5a39f1055da0596bd983049143f8131bdda Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 19:39:24 +0200 Subject: [PATCH 145/424] Split closure/string task builder --- src/Rocketeer/Abstracts/AbstractTask.php | 20 +++--- src/Rocketeer/Services/Tasks/TasksBuilder.php | 61 +++++++++++-------- tests/Services/Tasks/TasksBuilderTest.php | 4 +- 3 files changed, 48 insertions(+), 37 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 8d9ae8c9f..dec2abca5 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -45,23 +45,27 @@ abstract class AbstractTask extends Bash //////////////////////////////////////////////////////////////////// /** - * Get the name of the task + * Change the task's name * - * @return string + * @param string $name + * + * @return $this */ - public function getName() + public function setName($name) { - return $this->name ?: class_basename($this); + $this->name = $name ?: $this->name; + + return $this; } /** - * Change the task's name + * Get the name of the task * - * @param string $name + * @return string */ - public function setName($name) + public function getName() { - $this->name = $name; + return $this->name ?: class_basename($this); } /** diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index a89614c27..41c4310b0 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -53,48 +53,56 @@ public function buildTask($task, $name = null) $handle = 'rocketeer.tasks.'.$task; } - // If we provided a Closure or a string command, build it - if ($task instanceof Closure or $this->isStringCommand($task)) { + // If we provided a Closure, build a ClosureTask + if ($task instanceof Closure) { $task = $this->buildTaskFromClosure($task); - } // Check for an existing container binding + } + + // If we passed a command, build a ClosureTask + elseif ($this->isStringCommand($task)) { + $task = $this->buildTaskFromString($task); + } + + // If we passed a task handle, return it elseif (isset($handle) and $this->app->bound($handle)) { - return $this->app[$handle]; + $task = $this->app[$handle]; } - // Build remaining tasks - if (!$task instanceof AbstractTask) { + // Else it's a class name, get the appropriated task + elseif (!$task instanceof AbstractTask) { $task = $this->buildTaskFromClass($task); } - // Set the task's name - if ($name) { - $task->setName($name); - } + return $task->setName($name); + } - return $task; + /** + * Build a task from a string + * + * @param string $task + * + * @return AbstractTask + */ + public function buildTaskFromString($task) + { + $stringTask = $task; + $closure = function ($task) use ($stringTask) { + return $task->runForCurrentRelease($stringTask); + }; + + return $this->buildTaskFromClosure($closure, $stringTask); } /** * Build a task from a Closure or a string command * - * @param Closure|string $task + * @param Closure $closure + * @param string|null $stringTask * * @return AbstractTask */ - public function buildTaskFromClosure($task) + public function buildTaskFromClosure(Closure $closure, $stringTask = null) { - // If the User provided a string to execute - // We'll build a closure from it - if ($this->isStringCommand($task)) { - $stringTask = $task; - $closure = function ($task) use ($stringTask) { - return $task->runForCurrentRelease($stringTask); - }; - // If the User provided a Closure - } else { - $closure = $task; - } - // Now that we unified it all to a Closure, we build // a Closure AbstractTask from there $task = $this->buildTaskFromClass('Rocketeer\Tasks\Closure'); @@ -102,7 +110,7 @@ public function buildTaskFromClosure($task) // If we had an original string used, store it on // the task for easier reflection - if (isset($stringTask)) { + if ($stringTask) { $task->setStringTask($stringTask); } @@ -135,7 +143,6 @@ public function buildTaskFromClass($task) return new $task($this->app); } - //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php index 2bf80bb86..5f129916c 100644 --- a/tests/Services/Tasks/TasksBuilderTest.php +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -15,7 +15,7 @@ public function testCanBuildTaskByName() public function testCanBuildCustomTaskByName() { - $tasks = $this->builder->buildTasks(array('Rocketeer\Tasks\Check')); + $tasks = $this->builder->buildTasks(['Rocketeer\Tasks\Check']); $this->assertInstanceOf('Rocketeer\Tasks\Check', $tasks[0]); } @@ -24,7 +24,7 @@ public function testCanBuildTaskFromString() { $string = 'echo "I love ducks"'; - $string = $this->builder->buildTaskFromClosure($string); + $string = $this->builder->buildTaskFromString($string); $this->assertInstanceOf('Rocketeer\Tasks\Closure', $string); $closure = $string->getClosure(); From 1039f4812cca39cacead5fa4459a3adb7eafcaaf Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 19:41:02 +0200 Subject: [PATCH 146/424] Unused uses --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 18 ++++++------------ src/Rocketeer/Services/Tasks/TasksQueue.php | 1 - tests/Services/Tasks/TasksQueueTest.php | 1 - 3 files changed, 6 insertions(+), 14 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 41c4310b0..f83a3b61d 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -56,20 +56,14 @@ public function buildTask($task, $name = null) // If we provided a Closure, build a ClosureTask if ($task instanceof Closure) { $task = $this->buildTaskFromClosure($task); - } - - // If we passed a command, build a ClosureTask - elseif ($this->isStringCommand($task)) { + } elseif ($this->isStringCommand($task)) { + // If we passed a command, build a ClosureTask $task = $this->buildTaskFromString($task); - } - - // If we passed a task handle, return it - elseif (isset($handle) and $this->app->bound($handle)) { + } elseif (isset($handle) and $this->app->bound($handle)) { + // If we passed a task handle, return it $task = $this->app[$handle]; - } - - // Else it's a class name, get the appropriated task - elseif (!$task instanceof AbstractTask) { + } elseif (!$task instanceof AbstractTask) { + // Else it's a class name, get the appropriated task $task = $this->buildTaskFromClass($task); } diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 2567858c3..a0ddc772b 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -12,7 +12,6 @@ use Closure; use Exception; use KzykHys\Parallel\Parallel; -use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Connection; use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 95d029f7e..50df4f4dc 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -2,7 +2,6 @@ namespace Rocketeer\Services\Tasks; use Mockery; -use ReflectionFunction; use Rocketeer\TestCases\RocketeerTestCase; class TasksQueueTest extends RocketeerTestCase From 0e6c191071a7bd00ad242d679352e16190586d24 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:13:46 +0200 Subject: [PATCH 147/424] Work on small code refactor --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- src/Rocketeer/Services/Tasks/TasksQueue.php | 115 ++++++++++++------ src/config/stages.php | 1 + tests/Services/Tasks/TasksQueueTest.php | 10 +- 4 files changed, 83 insertions(+), 45 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index f83a3b61d..ebffd2ad8 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -53,8 +53,8 @@ public function buildTask($task, $name = null) $handle = 'rocketeer.tasks.'.$task; } - // If we provided a Closure, build a ClosureTask if ($task instanceof Closure) { + // If we provided a Closure, build a ClosureTask $task = $this->buildTaskFromClosure($task); } elseif ($this->isStringCommand($task)) { // If we passed a command, build a ClosureTask diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index a0ddc772b..ffe9a8323 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -64,7 +64,7 @@ public function setParallel($parallel) * @param string|array|Closure $queue * @param string|string[]|null $connections * - * @return array + * @return boolean */ public function execute($queue, $connections = null) { @@ -81,7 +81,7 @@ public function execute($queue, $connections = null) * @param string|string[] $connections * @param string|array|Closure $queue * - * @return array + * @return boolean */ public function on($connections, $queue) { @@ -100,32 +100,19 @@ public function on($connections, $queue) * @param string|array $tasks An array of tasks * * @throws Exception - * @return array An array of output + * @return boolean */ public function run($tasks) { $tasks = (array) $tasks; $queue = $this->builder->buildTasks($tasks); $pipeline = $this->buildPipeline($queue); - $status = true; - // Run pipeline if ($this->command->option('parallel')) { - if (!extension_loaded('pcntl')) { - throw new Exception('Parallel jobs require the PCNTL extension'); - } - - $this->parallel = $this->parallel ?: new Parallel(); - $this->parallel->run($pipeline); + return $this->runAsynchronously($pipeline); } else { - $key = 0; - do { - $status = $pipeline[$key](); - $key++; - } while ($status and isset($pipeline[$key])); + return $this->runSynchronously($pipeline); } - - return $status; } /** @@ -176,20 +163,10 @@ protected function buildPipeline(array $queue) $connections = (array) $this->connections->getConnections(); foreach ($connections as $connection) { $servers = $this->connections->getConnectionCredentials($connection); - foreach ($servers as $server => $credentials) { - // Sanitize stage - $stage = $this->getStage(); - $stages = $this->connections->getStages(); - if ($stage and in_array($stage, $stages)) { - $stages = array($stage); - } + $stages = $this->getStages($connection); - // Default to no stages - if (empty($stages)) { - $stages = [null]; - } - - // Add job to pipeline + // Add job to pipeline + foreach ($servers as $server => $credentials) { foreach ($stages as $stage) { $pipeline[] = new Job(array( 'connection' => $connection, @@ -201,7 +178,7 @@ protected function buildPipeline(array $queue) } } - // Build pipeline + // Wrap job in closure pipeline foreach ($pipeline as $key => $job) { $pipeline[$key] = function () use ($job) { return $this->executeJob($job); @@ -211,28 +188,88 @@ protected function buildPipeline(array $queue) return $pipeline; } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// RUNNERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Run the pipeline in order. + * As long as the previous entry didn't fail, continue + * + * @param array $pipeline + * + * @return boolean + */ + protected function runSynchronously(array $pipeline) + { + foreach ($pipeline as $task) { + if (!$task()) { + return false; + } + } + + return true; + } + + /** + * @param array $pipeline + * + * @return boolean + * @throws \Exception + */ + protected function runAsynchronously(array $pipeline) + { + if (!extension_loaded('pcntl')) { + throw new Exception('Parallel jobs require the PCNTL extension'); + } + + $this->parallel = $this->parallel ?: new Parallel(); + $this->parallel->run($pipeline); + + return true; + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// STAGES //////////////////////////// //////////////////////////////////////////////////////////////////// /** - * Get the stage to execute Tasks in - * If null, execute on all stages + * Get the stages of a connection * - * @return string + * @param string $connection + * + * @return array */ - protected function getStage() + public function getStages($connection) { + $this->connections->setConnection($connection); + $stage = $this->rocketeer->getOption('stages.default'); if ($this->hasCommand()) { $stage = $this->command->option('stage') ?: $stage; } // Return all stages if "all" - if ($stage == 'all') { - $stage = null; + if ($stage == 'all' or !$stage) { + $stage = $this->connections->getStages(); } - return $stage; + // Sanitize and filter + $stages = (array) $stage; + $stages = array_filter($stages, [$this, 'isValidStage']); + + return $stages ?: [null]; + } + + /** + * Check if a stage is valid + * + * @param string $stage + * + * @return boolean + */ + public function isValidStage($stage) + { + return in_array($stage, $this->connections->getStages()); } } diff --git a/src/config/stages.php b/src/config/stages.php index 20ffb77d4..57c43cee2 100644 --- a/src/config/stages.php +++ b/src/config/stages.php @@ -11,6 +11,7 @@ 'stages' => array(), // The default stage to execute tasks on when --stage is not provided + // Falsey means all of them 'default' => '', ); diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 50df4f4dc..3a8c9b7e2 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -14,7 +14,7 @@ public function testCanRunQueue() )); $this->expectOutputString('JOEY DOESNT SHARE FOOD'); - $this->tasksQueue()->run(array( + $this->queue->run(array( function () { print 'JOEY DOESNT SHARE FOOD'; } @@ -35,7 +35,7 @@ function ($task) use (&$output) { } ); - $status = $this->tasksQueue()->run($queue); + $status = $this->queue->run($queue); $this->assertTrue($status); $this->assertEquals(array( @@ -52,7 +52,7 @@ public function testCanRunQueueViaExecute() 'rocketeer::default' => 'production', )); - $status = $this->tasksQueue()->run(array( + $status = $this->queue->run(array( 'ls -a', function () { return 'JOEY DOESNT SHARE FOOD'; @@ -73,7 +73,7 @@ public function testCanRunOnMultipleConnectionsViaOn() 'rocketeer::stages.stages' => array('first', 'second'), )); - $status = $this->tasksQueue()->on(array('staging', 'production'), function ($task) { + $status = $this->queue->on(array('staging', 'production'), function ($task) { return $task->connections->getConnection().' - '.$task->connections->getStage(); }); @@ -108,7 +108,7 @@ public function testCanCancelQueueIfTaskFails() }, )); - $status = $this->tasksQueue()->run(array( + $status = $this->queue->run(array( 'Rocketeer\Dummies\MyCustomHaltingTask', 'Rocketeer\Dummies\MyCustomTask', )); From a8dc2ef2028da28e7d936aff6c8904025f9b5ce5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:20:15 +0200 Subject: [PATCH 148/424] Ignore AbstractCommand in coverage --- phpunit.xml | 1 + 1 file changed, 1 insertion(+) diff --git a/phpunit.xml b/phpunit.xml index 92384b66b..fd43d7ff2 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -15,6 +15,7 @@ src/Rocketeer + src/Rocketeer/Abstracts/AbstractCommand.php src/Rocketeer/RocketeerServiceProvider.php src/Rocketeer/Console src/Rocketeer/Interfaces From e87ebc8fcaeacb0c34f9494d5edcefba97090e5b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:36:54 +0200 Subject: [PATCH 149/424] Add some Rollback tests --- src/Rocketeer/Abstracts/AbstractTask.php | 6 ++--- src/Rocketeer/Tasks/Rollback.php | 8 +++--- tests/Tasks/RollbackTest.php | 32 ++++++++++++++++++++++++ 3 files changed, 38 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index dec2abca5..a4e15b3c2 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -189,15 +189,13 @@ public function getQualifiedEvent($event) /** * Display a list of releases and their status - * - * @return void */ protected function displayReleases() { $releases = $this->releasesManager->getValidationFile(); $this->command->comment('Here are the available releases :'); - $key = 0; + $key = 0; foreach ($releases as $name => $state) { $name = DateTime::createFromFormat('YmdHis', $name); $name = $name->format('Y-m-d H:i:s'); @@ -218,6 +216,6 @@ protected function displayReleases() */ public function executeTask($task) { - return $this->app['rocketeer.builder']->buildTaskFromClass($task)->fire(); + return $this->builder->buildTaskFromClass($task)->fire(); } } diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 76beac15d..4bc7c807c 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -28,16 +28,16 @@ public function execute() // Get previous release $rollbackRelease = $this->getRollbackRelease(); if (!$rollbackRelease) { - $this->command->error('Rocketeer could not rollback as no releases have yet been deployed'); + return $this->command->error('Rocketeer could not rollback as no releases have yet been deployed'); } // If no release specified, display the available ones - if (array_get($this->command->option(), 'list')) { + if ($this->command->option('list')) { $releases = $this->releasesManager->getReleases(); $this->displayReleases(); // Get actual release name from date - $rollbackRelease = $this->command->ask('Which one do you want to go back to ? (0)', 0); + $rollbackRelease = $this->command->askWith('Which one do you want to go back to ?', 0); $rollbackRelease = $releases[$rollbackRelease]; } @@ -57,7 +57,7 @@ public function execute() */ protected function getRollbackRelease() { - $release = array_get($this->command->argument(), 'release'); + $release = $this->command->argument('release'); if (!$release) { $release = $this->releasesManager->getPreviousRelease(); } diff --git a/tests/Tasks/RollbackTest.php b/tests/Tasks/RollbackTest.php index db05ee70e..6fc7cd6ec 100644 --- a/tests/Tasks/RollbackTest.php +++ b/tests/Tasks/RollbackTest.php @@ -1,6 +1,8 @@ assertEquals(10000000000000, $this->releasesManager->getCurrentRelease()); } + + public function testCanRollbackToSpecificRelease() + { + $this->mockCommand([], ['argument' => 15000000000000]); + $this->command->shouldReceive('option')->andReturn([]); + + $this->task('Rollback')->execute(); + + $this->assertEquals(15000000000000, $this->releasesManager->getCurrentRelease()); + } + + public function testCanGetShownAvailableReleases() + { + $this->command = $this->mockCommand(['list' => true]); + $this->command->shouldReceive('askWith')->andReturn(1); + + $this->task('Rollback')->execute(); + + $this->assertEquals(15000000000000, $this->releasesManager->getCurrentRelease()); + } + + public function testCantRollbackIfNoPreviousRelease() + { + $this->mockReleases(function ($mock) { + return $mock->shouldReceive('getPreviousRelease')->andReturn(null); + }); + + $status = $this->task('Rollback')->execute(); + $this->assertEquals('Rocketeer could not rollback as no releases have yet been deployed', $status); + } } From fc24609ddf93b3abe7e31852566791cf7724915f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:41:30 +0200 Subject: [PATCH 150/424] Fix some bugs --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 77060eabe..b5ed4a2e0 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -121,7 +121,7 @@ protected function fireTasksQueue($tasks) public function askWith($question, $default = null, $choices = array()) { // If default, show it in the question - if ($default) { + if (!is_null($default)) { $question .= ' ('.$default.')'; } diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index a4e15b3c2..438492c78 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -202,8 +202,8 @@ protected function displayReleases() $method = $state ? 'info' : 'error'; $state = $state ? '✓' : '✘'; - $key++; $this->command->$method(sprintf('[%d] %s %s', $key, $name, $state)); + $key++; } } From 8d47d1760c39e1e03d16bbe1f9a10f1a0a52c8b8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:48:12 +0200 Subject: [PATCH 151/424] Dead code --- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- src/Rocketeer/Services/History/History.php | 8 -------- src/Rocketeer/Services/Tasks/TasksQueue.php | 4 ++-- src/Rocketeer/Tasks/Rollback.php | 2 +- 4 files changed, 4 insertions(+), 12 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 438492c78..3dacf9a1c 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -195,7 +195,7 @@ protected function displayReleases() $releases = $this->releasesManager->getValidationFile(); $this->command->comment('Here are the available releases :'); - $key = 0; + $key = 0; foreach ($releases as $name => $state) { $name = DateTime::createFromFormat('YmdHis', $name); $name = $name->format('Y-m-d H:i:s'); diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 5c67b25fc..375c75c6f 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -5,14 +5,6 @@ class History extends Collection { - /** - * Clear the history - */ - public function clear() - { - $this->items = []; - } - /** * Get the history, flattened * diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index ffe9a8323..bc1e9e177 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -196,7 +196,7 @@ protected function buildPipeline(array $queue) * Run the pipeline in order. * As long as the previous entry didn't fail, continue * - * @param array $pipeline + * @param callable[] $pipeline * * @return boolean */ @@ -212,7 +212,7 @@ protected function runSynchronously(array $pipeline) } /** - * @param array $pipeline + * @param callable[] $pipeline * * @return boolean * @throws \Exception diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 4bc7c807c..c63f74050 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -53,7 +53,7 @@ public function execute() /** * Get the release to rollback to * - * @return integer + * @return integer|null */ protected function getRollbackRelease() { From 18979d9d7c31185167136e4757ab3233df310ec4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:48:45 +0200 Subject: [PATCH 152/424] Superfluous ; --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index b5ed4a2e0..1e30ad527 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -140,7 +140,7 @@ public function askWith($question, $default = null, $choices = array()) * * @param Closure $callback * - * @return integer; + * @return integer */ public function time(Closure $callback) { From 517c2cde922536d7e3c27e7ddff38a69a5eb6292 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 20:49:17 +0200 Subject: [PATCH 153/424] Actually nope --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 1e30ad527..33eba5bdc 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -140,7 +140,7 @@ public function askWith($question, $default = null, $choices = array()) * * @param Closure $callback * - * @return integer + * @return boolean */ public function time(Closure $callback) { From 8addb3a62687750338538d6b3a4f23c46a6bc092 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 22:12:22 +0200 Subject: [PATCH 154/424] Close #256 - Stop caching current release --- src/Rocketeer/Services/ReleasesManager.php | 154 ++++++++++----------- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Traits/BashModules/Flow.php | 2 +- tests/Services/ReleasesManagerTest.php | 10 -- tests/TestCases/RocketeerTestCase.php | 1 - 5 files changed, 74 insertions(+), 95 deletions(-) diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 0b458d8c5..6a4f52fa6 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -37,6 +37,13 @@ class ReleasesManager */ public $releases; + /** + * The next release to come + * + * @type string + */ + protected $nextRelease; + /** * The storage * @@ -79,49 +86,49 @@ public function getReleases() rsort($releases); - $this->releases = $releases; + $this->releases = (array) $releases; } return $this->releases; } /** - * Get an array of deprecated releases + * Get an array of non-current releases * * @return integer[] */ - public function getDeprecatedReleases() + public function getNonCurrentReleases() { - $releases = (array) $this->getReleases(); - $maxReleases = $this->config->get('rocketeer::remote.keep_releases'); - - return array_slice($releases, $maxReleases); + return $this->getDeprecatedReleases(1); } /** - * Get an array of invalid releases + * Get an array of deprecated releases + * + * @param null $treshold * * @return integer[] */ - public function getInvalidReleases() + public function getDeprecatedReleases($treshold = null) { - $releases = (array) $this->getReleases(); - $invalid = array_diff($this->state, array_filter($this->state)); - $invalid = array_keys($invalid); + $releases = $this->getReleases(); + $treshold = $treshold ?: $this->config->get('rocketeer::remote.keep_releases'); - return array_intersect($releases, $invalid); + return array_slice($releases, $treshold); } /** - * Get an array of non-current releases + * Get an array of invalid releases * * @return integer[] */ - public function getNonCurrentReleases() + public function getInvalidReleases() { - $releases = (array) $this->getReleases(); + $releases = $this->getReleases(); + $invalid = array_diff($this->state, array_filter($this->state)); + $invalid = array_keys($invalid); - return array_slice($releases, 1); + return array_intersect($releases, $invalid); } //////////////////////////////////////////////////////////////////// @@ -180,7 +187,7 @@ public function getValidationFile() $file = $this->storage->get(); // Fill the missing releases - $releases = (array) $this->getReleases(); + $releases = $this->getReleases(); $releases = array_fill_keys($releases, false); // Sort entries @@ -238,52 +245,6 @@ public function checkReleaseState($release) /////////////////////////// CURRENT RELEASE //////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Sanitize a possible release - * - * @param string|integer $release - * - * @return string|integer|null - */ - protected function sanitizeRelease($release) - { - return $this->isRelease($release) ? $release : null; - } - - /** - * Check if it quacks like a duck - * - * @param string|integer $release - * - * @return bool - */ - protected function isRelease($release) - { - $release = (string) $release; - - return (bool) preg_match('#[0-9]{14}#', $release); - } - - /** - * Get where to store the current release - * - * @return string - */ - protected function getCurrentReleaseKey() - { - $key = 'current_release'; - - // Get the scopes - $connection = $this->connections->getConnection(); - $stage = $this->connections->getStage(); - $scopes = array($connection, $stage); - foreach ($scopes as $scope) { - $key .= $scope ? '.'.$scope : ''; - } - - return $key; - } - /** * Get the current release * @@ -291,17 +252,10 @@ protected function getCurrentReleaseKey() */ public function getCurrentRelease() { - // If we have saved the last deployed release, return that - $cached = $this->localStorage->get($this->getCurrentReleaseKey()); - if ($cached) { - return $this->sanitizeRelease($cached); - } - - // Else get and save last deployed release - $lastDeployed = array_get($this->getReleases(), 0); - $this->updateCurrentRelease($lastDeployed); + $current = array_get($this->getReleases(), 0); + $current = $this->sanitizeRelease($current); - return $this->sanitizeRelease($lastDeployed); + return $this->nextRelease ?: $current; } /** @@ -330,20 +284,56 @@ public function getPreviousRelease($release = null) } /** - * Update the current release - * - * @param string|null $release A release name + * Get the next release to come * * @return string */ - public function updateCurrentRelease($release = null) + public function getNextRelease() { - if (!$release) { - $release = $this->bash->getTimestamp(); + if (!$this->nextRelease) { + $this->nextRelease = $this->bash->getTimestamp(); } - $this->localStorage->set($this->getCurrentReleaseKey(), $release); + return $this->nextRelease; + } + + /** + * Change the release to come + * + * @param string $release + */ + public function setNextRelease($release) + { + $this->nextRelease = $release; + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// - return $release; + /** + * Sanitize a possible release + * + * @param string|integer $release + * + * @return string|integer|null + */ + protected function sanitizeRelease($release) + { + return $this->isRelease($release) ? $release : null; + } + + /** + * Check if it quacks like a duck + * + * @param string|integer $release + * + * @return bool + */ + protected function isRelease($release) + { + $release = (string) $release; + + return (bool) preg_match('#[0-9]{14}#', $release); } } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 52a296abe..fcd4e7aef 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -42,7 +42,7 @@ public function execute() } // Update current release - $release = $this->releasesManager->updateCurrentRelease(); + $release = $this->releasesManager->getNextRelease(); // Run halting methods foreach ($this->halting as $method) { diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 0b61e2b68..4ce362216 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -85,7 +85,7 @@ public function updateSymlink($release = null) { // If the release is specified, update to make it the current one if ($release) { - $this->releasesManager->updateCurrentRelease($release); + $this->releasesManager->setNextRelease($release); } // Get path to current/ folder and latest release diff --git a/tests/Services/ReleasesManagerTest.php b/tests/Services/ReleasesManagerTest.php index 991ce9137..e9329d105 100644 --- a/tests/Services/ReleasesManagerTest.php +++ b/tests/Services/ReleasesManagerTest.php @@ -59,8 +59,6 @@ public function testCanGetCurrentReleaseFromServerIfUncached() { $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock - ->shouldReceive('get')->with('current_release.production')->once()->andReturn(null) - ->shouldReceive('set')->with('current_release.production', '20000000000000')->once() ->shouldReceive('getSeparator')->andReturn('/') ->shouldReceive('getLineEndings')->andReturn(PHP_EOL); }); @@ -135,19 +133,11 @@ public function testReturnsCorrectPreviousReleaseIfUpdatedBeforehand() '20000000000000' => true, )); - $this->releasesManager->updateCurrentRelease(); $currentRelease = $this->releasesManager->getPreviousRelease(); $this->assertEquals(20000000000000, $currentRelease); } - public function testCanUpdateCurrentRelease() - { - $this->releasesManager->updateCurrentRelease(30000000000000); - - $this->assertEquals(30000000000000, $this->app['rocketeer.storage.local']->get('current_release.production')); - } - public function testCanGetFolderInRelease() { $folder = $this->releasesManager->getCurrentReleasePath('{path.storage}'); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index e6b3bcc21..355abbd12 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -83,7 +83,6 @@ protected function recreateVirtualServer() // Recreate deployments file $this->app['files']->put($this->deploymentsFile, json_encode(array( 'foo' => 'bar', - 'current_release' => array('production' => 20000000000000), 'directory_separator' => '/', 'is_setup' => true, 'webuser' => array('username' => 'www-data', 'group' => 'www-data'), From 88d3d0c60b459a61a3a5ffcf180ea94971f0fdd3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 22:46:32 +0200 Subject: [PATCH 155/424] Close #53 - Allow most credentials to be passed as flags --- src/Rocketeer/Abstracts/AbstractCommand.php | 12 +++++- .../Services/CredentialsGatherer.php | 31 +++++++++++---- tests/Services/CredentialsGathererTest.php | 38 ++++++++++++++++++- 3 files changed, 72 insertions(+), 9 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 33eba5bdc..de148ced3 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -36,10 +36,20 @@ abstract public function fire(); protected function getOptions() { return array( + // Options ['parallel', 'P', InputOption::VALUE_NONE, 'Run the tasks asynchronously instead of sequentially'], ['pretend', 'p', InputOption::VALUE_NONE, 'Shows which command would execute without actually doing anything'], ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], - ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'] + ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'], + + // Credentials + ['host', null, InputOption::VALUE_REQUIRED, 'The host to use if asked'], + ['username', null, InputOption::VALUE_REQUIRED, 'The username to use if asked'], + ['password', null, InputOption::VALUE_REQUIRED, 'The password to use if asked'], + ['key', null, InputOption::VALUE_REQUIRED, 'The key to use if asked'], + ['keyphrase', null, InputOption::VALUE_REQUIRED, 'The keyphrase to use if asked'], + ['agent', null, InputOption::VALUE_REQUIRED, 'The agent to use if asked'], + ['repository', null, InputOption::VALUE_REQUIRED, 'The repository to use if asked'], ); } diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 8b64c026f..6106406cf 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -100,10 +100,10 @@ protected function getConnectionCredentials($connectionName, $server = null) $type = $this->command->askWith('No password or SSH key is set for ['.$handle.'], which would you use?', 'key', $types); if ($type == 'key') { $default = $this->rocketeer->getDefaultKeyPath(); - $credentials['key'] = $this->command->askWith('Please enter the full path to your key', $default); - $credentials['keyphrase'] = $this->command->askWith('If a keyphrase is required, provide it'); + $credentials['key'] = $this->command->option('key') ?: $this->command->askWith('Please enter the full path to your key', $default); + $credentials['keyphrase'] = $this->gatherCredential($handle, 'keyphrase', 'If a keyphrase is required, provide it'); } else { - $credentials['password'] = $this->command->askWith('Please enter your password'); + $credentials['password'] = $this->gatherCredential($handle, 'password'); } } @@ -131,7 +131,7 @@ protected function gatherCredentials($credentials, $current, $handle) foreach ($credentials as $credential => $required) { $$credential = $this->getCredential($current, $credential); if ($required and !$$credential) { - $$credential = $this->command->askWith('No '.$credential.' is set for ['.$handle.'], please provide one:'); + $$credential = $this->gatherCredential($handle, $credential); } } @@ -141,6 +141,23 @@ protected function gatherCredentials($credentials, $current, $handle) return $credentials; } + /** + * Look for a credential in the flags or ask for it + * + * @param string $handle + * @param string $credential + * @param string|null $question + * + * @return string + */ + protected function gatherCredential($handle, $credential, $question = null) + { + $question = $question ?: 'No '.$credential.' is set for ['.$handle.'], please provide one:'; + $option = $this->command->option($credential); + + return $option ?: $this->command->askWith($question); + } + /** * Check if a credential needs to be filled * @@ -151,11 +168,11 @@ protected function gatherCredentials($credentials, $current, $handle) */ protected function getCredential($credentials, $credential) { - $credential = array_get($credentials, $credential); - if (substr($credential, 0, 1) === '{') { + $value = array_get($credentials, $credential); + if (substr($value, 0, 1) === '{') { return; } - return $credential; + return $value ?: $this->command->option($credential); } } diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index d935732c7..407a1909b 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -24,6 +24,7 @@ public function testIgnoresPlaceholdersWhenFillingCredentials() 'No username is set for [repository]' => $this->username, 'No password is set for [repository]' => $this->password, )); + $this->command->shouldReceive('option')->andReturn(null); $this->givenConfiguredRepositoryCredentials(['repository' => '{foobar}']); @@ -43,6 +44,7 @@ public function testCanGetRepositoryCredentials() 'No username is set for [repository]' => $this->username, 'No password is set for [repository]' => $this->password, )); + $this->command->shouldReceive('option')->andReturn(null); $this->givenConfiguredRepositoryCredentials([]); @@ -71,6 +73,7 @@ public function testCanFillRepositoryCredentialsIfNeeded() $this->mockAnswers(array( 'No username is set for [repository]' => $this->username, )); + $this->command->shouldReceive('option')->andReturn(null); $this->givenConfiguredRepositoryCredentials(['repository' => $this->repository], true); @@ -92,7 +95,7 @@ public function testCanGetServerCredentialsIfNoneDefined() $this->mockAnswers(array( 'No host is set for [production]' => $this->host, 'No username is set for [production]' => $this->username, - 'Please enter your password' => $this->password, + 'No password is set for [production]' => $this->password, )); $this->command->shouldReceive('askWith')->with('No connections have been set, please create one:', 'production')->andReturn('production'); @@ -115,6 +118,38 @@ public function testCanGetServerCredentialsIfNoneDefined() ), $credentials); } + public function testCanPassCredentialsAsFlags() + { + $this->swapConfig(array( + 'remote.connections' => [], + )); + + $this->mockAnswers(array( + 'No username is set for [production]' => $this->username, + )); + + $this->command->shouldReceive('askWith')->with('No connections have been set, please create one:', 'production')->andReturn('production'); + $this->command->shouldReceive('askWith')->with( + 'No password or SSH key is set for [production], which would you use?', + 'key', ['key', 'password'] + )->andReturn('password'); + $this->command->shouldReceive('option')->with('host')->andReturn($this->host); + $this->command->shouldReceive('option')->with('password')->andReturn($this->password); + $this->command->shouldReceive('option')->andReturn(null); + + $this->credentials->getServerCredentials(); + + $credentials = $this->connections->getServerCredentials('production', 0); + $this->assertEquals(array( + 'host' => $this->host, + 'username' => $this->username, + 'password' => $this->password, + 'keyphrase' => null, + 'key' => null, + 'agent' => null, + ), $credentials); + } + public function testCanGetCredentialsForSpecifiedConnection() { $key = $this->rocketeer->getDefaultKeyPath(); @@ -125,6 +160,7 @@ public function testCanGetCredentialsForSpecifiedConnection() )); $this->command->shouldReceive('option')->with('on')->andReturn('staging'); + $this->command->shouldReceive('option')->andReturn(null); $this->command->shouldReceive('askWith')->with( 'Please enter the full path to your key', $key )->andReturn($key); From 80c7d9921ed572e4df81aa3df0ef32dcf6c2d057 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 23:05:43 +0200 Subject: [PATCH 156/424] Use table to display past releases --- src/Rocketeer/Abstracts/AbstractTask.php | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 3dacf9a1c..b80435472 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -11,6 +11,7 @@ use DateTime; use Rocketeer\Bash; +use Symfony\Component\Console\Helper\Table; /** * An abstract AbstractTask with common helpers, from which all Tasks derive @@ -195,16 +196,25 @@ protected function displayReleases() $releases = $this->releasesManager->getValidationFile(); $this->command->comment('Here are the available releases :'); + $table = new Table($this->command->getOutput()); + $table->setHeaders(['#', 'Path', 'Deployed at', 'Status']); + $key = 0; foreach ($releases as $name => $state) { - $name = DateTime::createFromFormat('YmdHis', $name); - $name = $name->format('Y-m-d H:i:s'); - $method = $state ? 'info' : 'error'; - $state = $state ? '✓' : '✘'; + $date = DateTime::createFromFormat('YmdHis', $name); + $date = $date->format('Y-m-d H:i:s'); + $icon = $state ? '✓' : '✘'; + $color = $state ? 'green' : 'red'; + + // Add color to row + $row = [$key, $name, $date, $icon]; + $row[3] = sprintf('%s', $color, $row[3], $color); - $this->command->$method(sprintf('[%d] %s %s', $key, $name, $state)); + $table->addRow($row); $key++; } + + $table->render(); } /** @@ -219,3 +229,4 @@ public function executeTask($task) return $this->builder->buildTaskFromClass($task)->fire(); } } + From 8583b006c4f7fab3c8656c41c0e722dce746ba3e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 10 Aug 2014 23:42:26 +0200 Subject: [PATCH 157/424] Fix tests --- src/Rocketeer/Abstracts/AbstractTask.php | 9 ++++++++- tests/TestCases/ContainerTestCase.php | 1 + 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index b80435472..bcc0c621a 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -196,9 +196,16 @@ protected function displayReleases() $releases = $this->releasesManager->getValidationFile(); $this->command->comment('Here are the available releases :'); - $table = new Table($this->command->getOutput()); + $output = $this->command->getOutput(); + if (!$output) { + return; + } + + // Build table + $table = new Table($output); $table->setHeaders(['#', 'Path', 'Deployed at', 'Status']); + // Append the reows $key = 0; foreach ($releases as $name => $state) { $date = DateTime::createFromFormat('YmdHis', $name); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index b7c5f97a3..e5f54f83d 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -105,6 +105,7 @@ protected function getCommand(array $expectations = array(), array $options = ar }; $command = Mockery::mock('Command'); + $command->shouldReceive('getOutput')->andReturn(null); // Bind the output expectations $types = ['comment', 'error', 'line', 'info']; From 9f7e75c714369327b6190b2944ed43cc2b79cbe8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 11 Aug 2014 14:10:10 +0200 Subject: [PATCH 158/424] Fix crash if no contextual subfolder --- src/Rocketeer/Rocketeer.php | 2 +- tests/RocketeerTest.php | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 291e174d1..b4d9a0a03 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -126,7 +126,7 @@ public function mergeContextualConfigurations() { // Cancel if not ignited yet $storage = $this->app['path.rocketeer.config']; - if (!is_dir($storage)) { + if (!is_dir($storage) or (!is_dir($storage.'/stages') and !is_dir($storage.'/connections'))) { return; } diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index ebf94afb1..da54b74f0 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -149,4 +149,12 @@ public function testCanUseFilesAndFoldersForContextualConfig() $this->rocketeer->mergeContextualConfigurations(); } + + public function testDoesntCrashIfNoSubfolder() + { + $this->files->makeDirectory($this->customConfig, 0755, true); + $this->app['path.rocketeer.config'] = realpath($this->customConfig); + + $this->rocketeer->mergeContextualConfigurations(); + } } From 8596727be478b4192a778d8ccbc6f7774d3c530b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 11 Aug 2014 14:37:44 +0200 Subject: [PATCH 159/424] Fix registering of custom tasks via array --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- src/Rocketeer/Services/Tasks/TasksQueue.php | 11 +++---- tests/Services/Tasks/TasksQueueTest.php | 2 +- tests/Services/TasksHandlerTest.php | 29 +++++++++++++++++++ tests/TestCases/RocketeerAssertions.php | 6 +++- 5 files changed, 42 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index ebffd2ad8..7fa470c3e 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -56,7 +56,7 @@ public function buildTask($task, $name = null) if ($task instanceof Closure) { // If we provided a Closure, build a ClosureTask $task = $this->buildTaskFromClosure($task); - } elseif ($this->isStringCommand($task)) { + } elseif (is_array($task) or $this->isStringCommand($task)) { // If we passed a command, build a ClosureTask $task = $this->buildTaskFromString($task); } elseif (isset($handle) and $this->app->bound($handle)) { diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index bc1e9e177..b3107d465 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -11,6 +11,7 @@ use Closure; use Exception; +use Illuminate\Support\Collection; use KzykHys\Parallel\Parallel; use Rocketeer\Connection; use Rocketeer\Traits\HasHistory; @@ -157,7 +158,7 @@ protected function executeJob(Job $job) protected function buildPipeline(array $queue) { // First we'll build the queue - $pipeline = []; + $pipeline = new Collection(); // Get the connections to execute the tasks on $connections = (array) $this->connections->getConnections(); @@ -196,11 +197,11 @@ protected function buildPipeline(array $queue) * Run the pipeline in order. * As long as the previous entry didn't fail, continue * - * @param callable[] $pipeline + * @param Collection $pipeline * * @return boolean */ - protected function runSynchronously(array $pipeline) + protected function runSynchronously(Collection $pipeline) { foreach ($pipeline as $task) { if (!$task()) { @@ -212,12 +213,12 @@ protected function runSynchronously(array $pipeline) } /** - * @param callable[] $pipeline + * @param Collection $pipeline * * @return boolean * @throws \Exception */ - protected function runAsynchronously(array $pipeline) + protected function runAsynchronously(Collection $pipeline) { if (!extension_loaded('pcntl')) { throw new Exception('Parallel jobs require the PCNTL extension'); diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 3a8c9b7e2..323dc3c0f 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -89,7 +89,7 @@ public function testCanRunOnMultipleConnectionsViaOn() public function testCanRunTasksInParallel() { $parallel = Mockery::mock('Parallel') - ->shouldReceive('run')->once()->with(Mockery::type('array')) + ->shouldReceive('run')->once()->with(Mockery::type('Illuminate\Support\Collection')) ->mock(); $this->mockCommand(['parallel' => true]); diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index 24cc557b7..591cdc9ae 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -54,6 +54,35 @@ public function testCanAddMultipleTasksViaFacade() $this->assertEquals($newAfter, $this->tasksQueue()->getTasksListeners($task, 'after', true)); } + public function testCanRegisterCustomTask() + { + $this->swapConfig(array( + 'rocketeer::default' => 'production', + )); + + $this->tasks->task('foobar', function ($task) { + $task->runForCurrentRelease('ls'); + }); + + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $this->builder->buildTask('foobar')); + + $this->tasks->run('foobar'); + $this->assertHistory([['cd {server}/releases/{release}', 'ls']]); + } + + public function testCanRegisterCustomTaskViaArray() + { + $this->swapConfig(array( + 'rocketeer::default' => 'production', + )); + + $this->tasks->task('foobar', ['ls', 'ls']); + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $this->builder->buildTask('foobar')); + + $this->tasks->run('foobar'); + $this->assertHistory([['cd {server}/releases/{release}', 'ls', 'ls']]); + } + public function testCanAddSurroundTasksToNonExistingTasks() { $task = $this->task('Setup'); diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index 67ad09d19..b12aa474f 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -88,8 +88,12 @@ protected function assertTaskHistory($task, array $expectedHistory, array $optio * @param array $expected * @param array $obtained */ - public function assertHistory(array $expected, array $obtained) + public function assertHistory(array $expected, array $obtained = array()) { + if (!$obtained) { + $obtained = $this->history->getFlattenedHistory(); + } + // Look for release in history $release = implode(array_flatten($obtained)); preg_match_all('/[0-9]{14}/', $release, $releases); From b0b02c396e30369d7ffb22763fb69aaff1f04401 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 11 Aug 2014 15:06:13 +0200 Subject: [PATCH 160/424] Disable artisan bindings for now --- src/Rocketeer/Services/TasksHandler.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 7619e38b1..22188da33 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -81,7 +81,7 @@ public function add($task, $name = null) // Bind to Artisan too if ($this->app->bound('artisan')) { - $this->app['artisan']->add(new BaseTaskCommand($task)); + //$this->app['artisan']->add(new BaseTaskCommand($task)); } return $bound; From 107707e033a76606c9440ff1fe21ae2e935f396f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 11 Aug 2014 16:08:06 +0200 Subject: [PATCH 161/424] Move getOption to HasLocator --- src/Rocketeer/Services/Tasks/TasksQueue.php | 4 ++-- src/Rocketeer/Traits/BashModules/Core.php | 12 ------------ src/Rocketeer/Traits/HasLocator.php | 12 ++++++++++++ 3 files changed, 14 insertions(+), 14 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index b3107d465..d24ac147e 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -109,7 +109,7 @@ public function run($tasks) $queue = $this->builder->buildTasks($tasks); $pipeline = $this->buildPipeline($queue); - if ($this->command->option('parallel')) { + if ($this->getOption('parallel')) { return $this->runAsynchronously($pipeline); } else { return $this->runSynchronously($pipeline); @@ -247,7 +247,7 @@ public function getStages($connection) $stage = $this->rocketeer->getOption('stages.default'); if ($this->hasCommand()) { - $stage = $this->command->option('stage') ?: $stage; + $stage = $this->getOption('stage') ?: $stage; } // Return all stages if "all" diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 916e2a495..c9329bb56 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -190,18 +190,6 @@ public function getTimestamp() return $timestamp; } - /** - * Get an option from the Command - * - * @param string $option - * - * @return string - */ - protected function getOption($option) - { - return $this->hasCommand() ? $this->command->option($option) : null; - } - //////////////////////////////////////////////////////////////////// ///////////////////////////// PROCESSORS /////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 70f2a9c38..6efff9328 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -110,4 +110,16 @@ protected function hasCommand() { return $this->app->bound('rocketeer.command'); } + + /** + * Get an option from the Command + * + * @param string $option + * + * @return string + */ + protected function getOption($option) + { + return $this->hasCommand() ? $this->command->option($option) : null; + } } From e0400ce9ec5898f8162c6f0d5fa94b02c1ad5afd Mon Sep 17 00:00:00 2001 From: Graham Campbell Date: Mon, 11 Aug 2014 20:38:14 +0100 Subject: [PATCH 162/424] Updated the kint dependency --- composer.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/composer.json b/composer.json index 92c6403fb..3fb067fe2 100644 --- a/composer.json +++ b/composer.json @@ -33,7 +33,7 @@ "herrera-io/box": "~1.5.3", "phpseclib/phpseclib": "~0.3.5", "d11wtq/boris": "~1.0.8", - "raveren/kint": "~0.9.0@dev" + "raveren/kint": "~0.9.1" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", From 66c1864bca9cdf2ca1ce7fc40e16316ba29093bb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 02:21:44 +0200 Subject: [PATCH 163/424] Fix booting of Artisan tasks under Laravel --- src/Rocketeer/RocketeerServiceProvider.php | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 42a86c493..235edca32 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -73,8 +73,16 @@ public function boot() $this->bindStrategies(); // Load the user's events and tasks - $this->loadFileOrFolder('tasks'); - $this->loadFileOrFolder('events'); + $fileLoaders = function() { + $this->loadFileOrFolder('tasks'); + $this->loadFileOrFolder('events'); + }; + + if (method_exists($this->app, 'booted')) { + $this->app->booted($fileLoaders); + } else { + $fileLoaders(); + } // Bind commands $this->bindCommands(); From 0a5735157bd4d61b115d899348c118904f0aed3b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 02:59:39 +0200 Subject: [PATCH 164/424] Work on status output --- src/Rocketeer/Abstracts/AbstractTask.php | 61 ++++++++++++++----- .../Console/Commands/CleanupCommand.php | 7 --- .../Console/Commands/DeployCommand.php | 7 --- .../Console/Commands/RollbackCommand.php | 7 --- .../Console/Commands/TestCommand.php | 7 --- .../Console/Commands/UpdateCommand.php | 7 --- src/Rocketeer/RocketeerServiceProvider.php | 9 ++- src/Rocketeer/Services/Tasks/TasksBuilder.php | 15 +++-- src/Rocketeer/Services/Tasks/TasksQueue.php | 2 +- src/Rocketeer/Services/TasksHandler.php | 12 ++-- src/Rocketeer/Tasks/Check.php | 8 +-- src/Rocketeer/Tasks/Closure.php | 23 +++++++ src/Rocketeer/Tasks/Deploy.php | 7 +++ src/Rocketeer/Tasks/Rollback.php | 7 +++ src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- 15 files changed, 113 insertions(+), 68 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index bcc0c621a..b4e61b2dd 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -10,6 +10,7 @@ namespace Rocketeer\Abstracts; use DateTime; +use Illuminate\Support\Str; use Rocketeer\Bash; use Symfony\Component\Console\Helper\Table; @@ -45,20 +46,6 @@ abstract class AbstractTask extends Bash ////////////////////////////// REFLECTION ////////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Change the task's name - * - * @param string $name - * - * @return $this - */ - public function setName($name) - { - $this->name = $name ?: $this->name; - - return $this; - } - /** * Get the name of the task * @@ -76,7 +63,10 @@ public function getName() */ public function getSlug() { - return strtolower($this->getName()); + $slug = Str::snake($this->getName(), '-'); + $slug = Str::slug($slug); + + return $slug; } /** @@ -89,6 +79,24 @@ public function getDescription() return $this->description; } + /** + * Change the task's name + * + * @param string $name + */ + public function setName($name) + { + $this->name = ucfirst($name) ?: $this->name; + } + + /** + * @param string $description + */ + public function setDescription($description) + { + $this->description = $description ?: $this->description; + } + //////////////////////////////////////////////////////////////////// ////////////////////////////// EXECUTION /////////////////////////// //////////////////////////////////////////////////////////////////// @@ -107,6 +115,9 @@ abstract public function execute(); */ public function fire() { + // Print status + $this->displayStatus(); + // Fire the task if the before event passes if ($this->fireEvent('before')) { $results = $this->execute(); @@ -235,5 +246,25 @@ public function executeTask($task) { return $this->builder->buildTaskFromClass($task)->fire(); } + + /** + * Display what the command is and does + */ + protected function displayStatus() + { + if (!$this->command) { + return; + } + + $name = $this->getName(); + $description = $this->getDescription(); + $comment = sprintf('-- Running: %s', $name); + if ($description) { + if (!is_string($description)) dd($this); + $comment .= ' ('.$description.')'; + } + + $this->command->comment($comment); + } } diff --git a/src/Rocketeer/Console/Commands/CleanupCommand.php b/src/Rocketeer/Console/Commands/CleanupCommand.php index 549a0a237..aeaa6282b 100644 --- a/src/Rocketeer/Console/Commands/CleanupCommand.php +++ b/src/Rocketeer/Console/Commands/CleanupCommand.php @@ -26,13 +26,6 @@ class CleanupCommand extends AbstractCommand */ protected $name = 'deploy:cleanup'; - /** - * The console command description. - * - * @var string - */ - protected $description = 'Clean up old releases from the server.'; - /** * Execute the tasks * diff --git a/src/Rocketeer/Console/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php index a1adb3ab1..e473d4b40 100644 --- a/src/Rocketeer/Console/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -26,13 +26,6 @@ class DeployCommand extends AbstractCommand */ protected $name = 'deploy:deploy'; - /** - * The console command description. - * - * @var string - */ - protected $description = 'Deploy the website.'; - /** * Execute the tasks * diff --git a/src/Rocketeer/Console/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php index b0a5a38c4..26f57fec1 100644 --- a/src/Rocketeer/Console/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -27,13 +27,6 @@ class RollbackCommand extends AbstractCommand */ protected $name = 'deploy:rollback'; - /** - * The console command description. - * - * @var string - */ - protected $description = 'Rollback to the previous release, or to a specific one'; - /** * The tasks to execute * diff --git a/src/Rocketeer/Console/Commands/TestCommand.php b/src/Rocketeer/Console/Commands/TestCommand.php index 74bcfe7f8..a5a0fdcde 100644 --- a/src/Rocketeer/Console/Commands/TestCommand.php +++ b/src/Rocketeer/Console/Commands/TestCommand.php @@ -25,13 +25,6 @@ class TestCommand extends AbstractCommand */ protected $name = 'deploy:test'; - /** - * The console command description. - * - * @var string - */ - protected $description = 'Run the tests on the server and displays the output'; - /** * The tasks to execute * diff --git a/src/Rocketeer/Console/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php index 519360ec3..d6a258b97 100644 --- a/src/Rocketeer/Console/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -26,13 +26,6 @@ class UpdateCommand extends AbstractCommand */ protected $name = 'deploy:update'; - /** - * The console command description. - * - * @var string - */ - protected $description = 'Update the remote server without doing a new release.'; - /** * Execute the tasks * diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 235edca32..c528ed499 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -288,8 +288,13 @@ public function bindCommands() // Look for an existing command if (!$fakeCommand) { - $this->app->singleton($command, function () use ($commandClass) { - return new $commandClass; + $this->app->singleton($command, function () use ($commandClass, $taskInstance) { + $commandClass = new $commandClass; + if (is_object($taskInstance)) { + $commandClass->setDescription($taskInstance->getDescription()); + } + + return $commandClass; }); // Else create a fake one } else { diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 7fa470c3e..3f38f8bc6 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -43,10 +43,11 @@ public function buildTasks(array $tasks) * * @param string|Closure|AbstractTask $task * @param string|null $name + * @param string|null $description * * @return AbstractTask */ - public function buildTask($task, $name = null) + public function buildTask($task, $name = null, $description = null) { // Check the handle if possible if (is_string($task)) { @@ -56,18 +57,22 @@ public function buildTask($task, $name = null) if ($task instanceof Closure) { // If we provided a Closure, build a ClosureTask $task = $this->buildTaskFromClosure($task); - } elseif (is_array($task) or $this->isStringCommand($task)) { - // If we passed a command, build a ClosureTask - $task = $this->buildTaskFromString($task); } elseif (isset($handle) and $this->app->bound($handle)) { // If we passed a task handle, return it $task = $this->app[$handle]; + } elseif (is_array($task) or $this->isStringCommand($task)) { + // If we passed a command, build a ClosureTask + $task = $this->buildTaskFromString($task); } elseif (!$task instanceof AbstractTask) { // Else it's a class name, get the appropriated task $task = $this->buildTaskFromClass($task); } - return $task->setName($name); + // Set task properties + $task->setName($name); + $task->setDescription($description); + + return $task; } /** diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index d24ac147e..3fc480a92 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -128,7 +128,7 @@ protected function executeJob(Job $job) // Set proper server $this->connections->setConnection($job->connection, $job->server); - foreach ($job->queue as $task) { + foreach ($job->queue as $key => $task) { $currentStage = $task->usesStages() ? $job->stage : null; $this->connections->setStage($currentStage); diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 22188da33..eeedd6e5d 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -66,13 +66,14 @@ public function __call($method, $parameters) * * @param string|Closure|AbstractTask $task * @param string|null $name + * @param string|null $description * * @return BaseTaskCommand */ - public function add($task, $name = null) + public function add($task, $name = null, $description = null) { // Build task if necessary - $task = $this->builder->buildTask($task, $name); + $task = $this->builder->buildTask($task, $name, $description); $slug = 'rocketeer.tasks.'.$task->getSlug(); // Add the task to Rocketeer @@ -92,12 +93,13 @@ public function add($task, $name = null) * * @param string $name * @param string|Closure|AbstractTask $task + * @param string|null $description * * @return BaseTaskCommand */ - public function task($name, $task) + public function task($name, $task, $description = null) { - return $this->add($task, $name); + return $this->add($task, $name, $description); } //////////////////////////////////////////////////////////////////// @@ -172,7 +174,7 @@ public function listenTo($event, $listeners, $priority = 0) // Register events foreach ($listeners as $listener) { - $this->events->listen('rocketeer.'.$event, array($listener, 'execute'), $priority); + $this->events->listen('rocketeer.'.$event, array($listener, 'fire'), $priority); } return $event; diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 1f0d4fc2f..5cf6f4004 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -107,7 +107,7 @@ protected function getChecks() */ public function checkScm() { - $this->command->comment('Checking presence of '.$this->scm->getBinary()); + $this->command->info('Checking presence of '.$this->scm->getBinary()); $results = $this->scm->execute('check'); $this->toOutput($results); @@ -125,7 +125,7 @@ public function checkComposer() return true; } - $this->command->comment('Checking presence of Composer'); + $this->command->info('Checking presence of Composer'); return $this->composer(); } @@ -155,7 +155,7 @@ public function checkPhpVersion() return true; } - $this->command->comment('Checking PHP version'); + $this->command->info('Checking PHP version'); $version = $this->runLast($this->php('-r "print PHP_VERSION;"')); return version_compare($version, $required, '>='); @@ -217,7 +217,7 @@ public function checkCacheDriver($cache) */ public function checkPhpExtension($extension) { - $this->command->comment('Checking presence of '.$extension.' extension'); + $this->command->info('Checking presence of '.$extension.' extension'); // Check for HHVM and built-in extensions if ($this->usesHhvm()) { diff --git a/src/Rocketeer/Tasks/Closure.php b/src/Rocketeer/Tasks/Closure.php index 9688deb5a..899adc172 100644 --- a/src/Rocketeer/Tasks/Closure.php +++ b/src/Rocketeer/Tasks/Closure.php @@ -33,6 +33,29 @@ class Closure extends AbstractTask */ protected $stringTask; + /** + * Get the name of the task + * + * @return string + */ + public function getName() + { + return parent::getName() ?: 'Arbitrary task'; + } + + /** + * Get what the task does + * + * @return string + */ + public function getDescription() + { + $flattened = (array) $this->getStringTask(); + $flattened = implode('/', $flattened); + + return parent::getDescription() ?: $flattened; + } + /** * Create a task from a Closure * diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index fcd4e7aef..8fab20d98 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -25,6 +25,13 @@ class Deploy extends AbstractTask */ protected $halting = array(); + /** + * The console command description. + * + * @var string + */ + protected $description = 'Deploys the website'; + /** * Run the task * diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index c63f74050..d5dd2f27a 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -18,6 +18,13 @@ */ class Rollback extends AbstractTask { + /** + * The console command description. + * + * @var string + */ + protected $description = 'Rollback to the previous release, or to a specific one'; + /** * Run the task * diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index fc2fe0d70..ddea8d7da 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -189,7 +189,7 @@ public function runComposer($force = false) } // Run commands - $this->command->comment('Installing Composer dependencies'); + $this->command->info('Installing Composer dependencies'); $this->runForCurrentRelease($tasks); return $this->checkStatus('Composer could not install dependencies'); From d0a1b85e94dcd1ccadb54c6f0958f0ce83b018c5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 03:01:17 +0200 Subject: [PATCH 165/424] Fix tests --- src/Rocketeer/RocketeerServiceProvider.php | 3 ++- tests/Traits/BashModules/BinariesTest.php | 4 ++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index c528ed499..b7aea2b9e 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -17,6 +17,7 @@ use Illuminate\Remote\RemoteManager; use Illuminate\Support\ServiceProvider; use Monolog\Logger; +use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Console\Commands\BaseTaskCommand; use Rocketeer\Services\ConnectionsHandler; use Rocketeer\Services\CredentialsGatherer; @@ -290,7 +291,7 @@ public function bindCommands() if (!$fakeCommand) { $this->app->singleton($command, function () use ($commandClass, $taskInstance) { $commandClass = new $commandClass; - if (is_object($taskInstance)) { + if ($taskInstance instanceof AbstractTask) { $commandClass->setDescription($taskInstance->getDescription()); } diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 87a969d07..e306f59a1 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -54,7 +54,7 @@ public function testDoesntRunComposerIfNotNeeded() $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock ->shouldReceive('option')->andReturn(array()) - ->shouldReceive('comment')->once(); + ->shouldReceive('info')->once(); }); $this->task->runComposer(); @@ -63,7 +63,7 @@ public function testDoesntRunComposerIfNotNeeded() $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock ->shouldReceive('option')->andReturn(array()) - ->shouldReceive('comment')->never(); + ->shouldReceive('info')->never(); }); $this->task->runComposer(); From 632a01b9fe4869703fbd55ea3a9578edbbe57cbd Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 03:04:37 +0200 Subject: [PATCH 166/424] Move file loading to Igniter --- src/Rocketeer/Igniter.php | 46 +++++++++++++++++++++- src/Rocketeer/RocketeerServiceProvider.php | 34 +--------------- 2 files changed, 46 insertions(+), 34 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index a7a57e1e4..26a8f2ae7 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -31,8 +31,52 @@ public function bindPaths() $this->bindConfiguration(); } + ////////////////////////////////////////////////////////////////////// + //////////////////////////// FILE LOADERS //////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Load the custom files (tasks, events, ...) + */ + public function loadCustomFiles() + { + $fileLoaders = function() { + $this->loadFileOrFolder('tasks'); + $this->loadFileOrFolder('events'); + }; + + if (method_exists($this->app, 'booted')) { + $this->app->booted($fileLoaders); + } else { + $fileLoaders(); + } + } + + /** + * Load a file or its contents if a folder + * + * @param string $handle + */ + public function loadFileOrFolder($handle) + { + // Bind ourselves into the facade to avoid automatic resolution + Facades\Rocketeer::setFacadeApplication($this->app); + + // If we have one unified tasks file, include it + $file = $this->app['path.rocketeer.'.$handle]; + if (!is_dir($file) and file_exists($file)) { + include $file; + } // Else include its contents + elseif (is_dir($file)) { + $folder = glob($file.'/*.php'); + foreach ($folder as $file) { + include $file; + } + } + } + //////////////////////////////////////////////////////////////////// - /////////////////////////////// IGNITION /////////////////////////// + ///////////////////////////// CONFIGURATION //////////////////////// //////////////////////////////////////////////////////////////////// /** diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b7aea2b9e..b991f0087 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -74,16 +74,7 @@ public function boot() $this->bindStrategies(); // Load the user's events and tasks - $fileLoaders = function() { - $this->loadFileOrFolder('tasks'); - $this->loadFileOrFolder('events'); - }; - - if (method_exists($this->app, 'booted')) { - $this->app->booted($fileLoaders); - } else { - $fileLoaders(); - } + $this->app['rocketeer.igniter']->loadCustomFiles(); // Bind commands $this->bindCommands(); @@ -344,27 +335,4 @@ protected function registerConfig() return array_replace($items, $customItems); }); } - - /** - * Load a file or its contents if a folder - * - * @param string $handle - */ - protected function loadFileOrFolder($handle) - { - // Bind ourselves into the facade to avoid automatic resolution - Facades\Rocketeer::setFacadeApplication($this->app); - - // If we have one unified tasks file, include it - $file = $this->app['path.rocketeer.'.$handle]; - if (!is_dir($file) and file_exists($file)) { - include $file; - } // Else include its contents - elseif (is_dir($file)) { - $folder = glob($file.'/*.php'); - foreach ($folder as $file) { - include $file; - } - } - } } From 45903e51853d56186fc452b2ce2d1a5a57360ade Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 03:14:34 +0200 Subject: [PATCH 167/424] Simplify commands registering in ServiceProvider --- src/Rocketeer/Abstracts/AbstractCommand.php | 17 +++++++++++++++ .../Console/Commands/BaseTaskCommand.php | 9 +------- src/Rocketeer/RocketeerServiceProvider.php | 21 +++++-------------- 3 files changed, 23 insertions(+), 24 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index de148ced3..40b288694 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -21,6 +21,23 @@ */ abstract class AbstractCommand extends Command { + /** + * @param AbstractTask $task + */ + public function __construct(AbstractTask $task = null) + { + parent::__construct(); + + // If we passed a Task, bind its properties + // to the command + if ($task) { + $this->task = $task; + $this->task->command = $this; + + $this->setDescription($task->getDescription()); + } + } + /** * Run the tasks * diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index 2b16bbe51..db1e66a6d 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -42,18 +42,11 @@ class BaseTaskCommand extends AbstractCommand */ public function __construct(AbstractTask $task, $name = null) { - parent::__construct(); - - // Set task - $this->task = $task; - $this->task->command = $this; + parent::__construct($task); // Set name $this->name = $name ?: $task->getSlug(); $this->name = 'deploy:'.$this->name; - - // Set description - $this->setDescription($task->getDescription()); } /** diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b991f0087..1fd3a1590 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -264,6 +264,7 @@ public function bindCommands() // Build command slug $taskInstance = $this->app['rocketeer.builder']->buildTaskFromClass($task); + $taskInstance = $taskInstance instanceof AbstractTask ? $taskInstance : null; if (is_numeric($slug)) { $slug = $taskInstance->getSlug(); } @@ -278,22 +279,10 @@ public function bindCommands() $command = trim('deploy.'.$slug, '.'); $this->commands[] = $command; - // Look for an existing command - if (!$fakeCommand) { - $this->app->singleton($command, function () use ($commandClass, $taskInstance) { - $commandClass = new $commandClass; - if ($taskInstance instanceof AbstractTask) { - $commandClass->setDescription($taskInstance->getDescription()); - } - - return $commandClass; - }); - // Else create a fake one - } else { - $this->app->bind($command, function () use ($taskInstance, $slug) { - return new BaseTaskCommand($taskInstance, $slug); - }); - } + // Register command with the container + $this->app->singleton($command, function () use ($fakeCommand, $commandClass, $taskInstance, $slug) { + return !$fakeCommand ? new $commandClass($taskInstance) : new BaseTaskCommand($taskInstance, $slug); + }); } // Add commands to Artisan From 203f6e67d6b6534ecbd7534cc603427f3bd12492 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 03:15:05 +0200 Subject: [PATCH 168/424] Uncomment line --- src/Rocketeer/Services/TasksHandler.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index eeedd6e5d..7d41068c7 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -82,7 +82,7 @@ public function add($task, $name = null, $description = null) // Bind to Artisan too if ($this->app->bound('artisan')) { - //$this->app['artisan']->add(new BaseTaskCommand($task)); + $this->app['artisan']->add(new BaseTaskCommand($task)); } return $bound; From 25a2ff8c8d5c664a0b9350d65d497dea916feb5c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 03:22:32 +0200 Subject: [PATCH 169/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractCommand.php | 1 - src/Rocketeer/Abstracts/AbstractTask.php | 2 -- src/Rocketeer/Igniter.php | 2 +- src/Rocketeer/Services/ReleasesManager.php | 2 +- src/Rocketeer/Services/Tasks/TasksQueue.php | 2 +- tests/RocketeerTest.php | 2 +- tests/Tasks/RollbackTest.php | 1 - 7 files changed, 4 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 40b288694..01fba9250 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -58,7 +58,6 @@ protected function getOptions() ['pretend', 'p', InputOption::VALUE_NONE, 'Shows which command would execute without actually doing anything'], ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'], - // Credentials ['host', null, InputOption::VALUE_REQUIRED, 'The host to use if asked'], ['username', null, InputOption::VALUE_REQUIRED, 'The username to use if asked'], diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index b4e61b2dd..bea5959ad 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -260,11 +260,9 @@ protected function displayStatus() $description = $this->getDescription(); $comment = sprintf('-- Running: %s', $name); if ($description) { - if (!is_string($description)) dd($this); $comment .= ' ('.$description.')'; } $this->command->comment($comment); } } - diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 26a8f2ae7..72aa333a7 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -40,7 +40,7 @@ public function bindPaths() */ public function loadCustomFiles() { - $fileLoaders = function() { + $fileLoaders = function () { $this->loadFileOrFolder('tasks'); $this->loadFileOrFolder('events'); }; diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 6a4f52fa6..ddfe4d1b0 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -105,7 +105,7 @@ public function getNonCurrentReleases() /** * Get an array of deprecated releases * - * @param null $treshold + * @param integer $treshold * * @return integer[] */ diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 3fc480a92..68e686219 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -153,7 +153,7 @@ protected function executeJob(Job $job) * * @param array $queue * - * @return callable[] + * @return Collection */ protected function buildPipeline(array $queue) { diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index da54b74f0..3d4c53f56 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -154,7 +154,7 @@ public function testDoesntCrashIfNoSubfolder() { $this->files->makeDirectory($this->customConfig, 0755, true); $this->app['path.rocketeer.config'] = realpath($this->customConfig); - + $this->rocketeer->mergeContextualConfigurations(); } } diff --git a/tests/Tasks/RollbackTest.php b/tests/Tasks/RollbackTest.php index 6fc7cd6ec..b86c8d805 100644 --- a/tests/Tasks/RollbackTest.php +++ b/tests/Tasks/RollbackTest.php @@ -2,7 +2,6 @@ namespace Rocketeer\Tasks; use Mockery; -use Mockery\Mock; use Rocketeer\TestCases\RocketeerTestCase; class RollbackTest extends RocketeerTestCase From e6ac2bd3ab52a2330255c7740f0d0a06e4a08778 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 13:27:24 +0200 Subject: [PATCH 170/424] Add some tests --- src/Rocketeer/Abstracts/AbstractTask.php | 11 +-- src/Rocketeer/Services/Tasks/TasksQueue.php | 78 ++++++++++----------- tests/Services/Tasks/JobTest.php | 23 ++++++ tests/Tasks/ClosureTest.php | 16 +++++ 4 files changed, 85 insertions(+), 43 deletions(-) create mode 100644 tests/Services/Tasks/JobTest.php create mode 100644 tests/Tasks/ClosureTest.php diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index bea5959ad..13c56f441 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -216,8 +216,9 @@ protected function displayReleases() $table = new Table($output); $table->setHeaders(['#', 'Path', 'Deployed at', 'Status']); - // Append the reows - $key = 0; + // Append the rows + $key = 0; + $rows = []; foreach ($releases as $name => $state) { $date = DateTime::createFromFormat('YmdHis', $name); $date = $date->format('Y-m-d H:i:s'); @@ -227,12 +228,14 @@ protected function displayReleases() // Add color to row $row = [$key, $name, $date, $icon]; $row[3] = sprintf('%s', $color, $row[3], $color); - - $table->addRow($row); + $rows[] = $row; $key++; } + $table->addRows($rows); $table->render(); + + return $rows; } /** diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 68e686219..1293f6842 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -109,6 +109,13 @@ public function run($tasks) $queue = $this->builder->buildTasks($tasks); $pipeline = $this->buildPipeline($queue); + // Wrap job in closure pipeline + foreach ($pipeline as $key => $job) { + $pipeline[$key] = function () use ($job) { + return $this->executeJob($job); + }; + } + if ($this->getOption('parallel')) { return $this->runAsynchronously($pipeline); } else { @@ -116,38 +123,6 @@ public function run($tasks) } } - /** - * Run the queue, taking into account the stage - * - * @param Job $job - * - * @return boolean - */ - protected function executeJob(Job $job) - { - // Set proper server - $this->connections->setConnection($job->connection, $job->server); - - foreach ($job->queue as $key => $task) { - $currentStage = $task->usesStages() ? $job->stage : null; - $this->connections->setStage($currentStage); - - // Here we fire the task, save its - // output and return its status - $state = $task->fire(); - $this->toOutput($state); - - // If the task didn't finish, display what the error was - if ($task->wasHalted() or $state === false) { - $this->command->error('The tasks queue was canceled by task "'.$task->getName().'"'); - - return false; - } - } - - return true; - } - /** * Build a pipeline of jobs for Parallel to execute * @@ -155,7 +130,7 @@ protected function executeJob(Job $job) * * @return Collection */ - protected function buildPipeline(array $queue) + public function buildPipeline(array $queue) { // First we'll build the queue $pipeline = new Collection(); @@ -179,14 +154,39 @@ protected function buildPipeline(array $queue) } } - // Wrap job in closure pipeline - foreach ($pipeline as $key => $job) { - $pipeline[$key] = function () use ($job) { - return $this->executeJob($job); - }; + return $pipeline; + } + + /** + * Run the queue, taking into account the stage + * + * @param Job $job + * + * @return boolean + */ + protected function executeJob(Job $job) + { + // Set proper server + $this->connections->setConnection($job->connection, $job->server); + + foreach ($job->queue as $key => $task) { + $currentStage = $task->usesStages() ? $job->stage : null; + $this->connections->setStage($currentStage); + + // Here we fire the task, save its + // output and return its status + $state = $task->fire(); + $this->toOutput($state); + + // If the task didn't finish, display what the error was + if ($task->wasHalted() or $state === false) { + $this->command->error('The tasks queue was canceled by task "'.$task->getName().'"'); + + return false; + } } - return $pipeline; + return true; } ////////////////////////////////////////////////////////////////////// diff --git a/tests/Services/Tasks/JobTest.php b/tests/Services/Tasks/JobTest.php new file mode 100644 index 000000000..62ed3de72 --- /dev/null +++ b/tests/Services/Tasks/JobTest.php @@ -0,0 +1,23 @@ +queue->buildPipeline(['ls']); + + $this->assertInstanceOf('Illuminate\Support\Collection', $pipeline); + $this->assertCount(2, $pipeline); + $this->assertInstanceOf('Rocketeer\Services\Tasks\Job', $pipeline[0]); + $this->assertInstanceOf('Rocketeer\Services\Tasks\Job', $pipeline[1]); + + $this->assertEquals(['ls'], $pipeline[0]->queue); + $this->assertEquals(['ls'], $pipeline[1]->queue); + + $this->assertEquals('production', $pipeline[0]->connection); + $this->assertEquals('staging', $pipeline[1]->connection); + } +} diff --git a/tests/Tasks/ClosureTest.php b/tests/Tasks/ClosureTest.php new file mode 100644 index 000000000..c0bb188a5 --- /dev/null +++ b/tests/Tasks/ClosureTest.php @@ -0,0 +1,16 @@ +builder->buildTask(['ls', 'ls'], 'FilesLister'); + + $this->assertEquals('FilesLister', $closure->getName()); + $this->assertEquals('files-lister', $closure->getSlug()); + $this->assertEquals('ls/ls', $closure->getDescription()); + } +} From 4a2907c5d5dbd282c57fcfae97f31be930c8f631 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 13:28:25 +0200 Subject: [PATCH 171/424] Add SlowTrap --- composer.json | 3 ++- phpunit.xml | 15 +++++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/composer.json b/composer.json index 3fb067fe2..975beb17f 100644 --- a/composer.json +++ b/composer.json @@ -33,7 +33,8 @@ "herrera-io/box": "~1.5.3", "phpseclib/phpseclib": "~0.3.5", "d11wtq/boris": "~1.0.8", - "raveren/kint": "~0.9.1" + "raveren/kint": "~0.9.1", + "johnkary/phpunit-speedtrap": "dev-master" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", diff --git a/phpunit.xml b/phpunit.xml index fd43d7ff2..5ff0a69fa 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -24,6 +24,21 @@ + + + + + + 500 + + + 10 + + + + + + tests From eb300c84ecce89728cef24b2c5653f502857a1b0 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 13:36:20 +0200 Subject: [PATCH 172/424] Tweak some tests --- tests/Services/History/HistoryTest.php | 9 +++++++-- tests/Tasks/SetupTest.php | 4 ++-- tests/Traits/BashModules/BinariesTest.php | 9 ++++++--- 3 files changed, 15 insertions(+), 7 deletions(-) diff --git a/tests/Services/History/HistoryTest.php b/tests/Services/History/HistoryTest.php index 97a456ee3..e92bc2495 100644 --- a/tests/Services/History/HistoryTest.php +++ b/tests/Services/History/HistoryTest.php @@ -5,10 +5,15 @@ class HistoryTest extends RocketeerTestCase { + /** + * @type integer + */ + protected $sleep = 5; + public function testCanGetFlattenedHistory() { $this->bash->toHistory('foo'); - sleep(1); + usleep($this->sleep); $this->bash->toHistory(['bar', 'baz']); $history = $this->history->getFlattenedHistory(); @@ -18,7 +23,7 @@ public function testCanGetFlattenedHistory() public function testCanGetFlattenedOutput() { $this->bash->toOutput('foo'); - sleep(1); + usleep($this->sleep); $this->bash->toOutput(['bar', 'baz']); $history = $this->history->getFlattenedOutput(); diff --git a/tests/Tasks/SetupTest.php b/tests/Tasks/SetupTest.php index 025f67016..bcb31deef 100644 --- a/tests/Tasks/SetupTest.php +++ b/tests/Tasks/SetupTest.php @@ -47,7 +47,7 @@ public function testCanSetupStages() )); } - public function testRunningSetupKeepsCurrentCongiguredStage() + public function testRunningSetupKeepsCurrentConfiguredStage() { $this->mockReleases(function ($mock) { return $mock @@ -55,7 +55,7 @@ public function testRunningSetupKeepsCurrentCongiguredStage() ->shouldReceive('getCurrentReleasePath')->andReturn('1'); }); $this->swapConfig(array( - 'rocketeer::stages.stages' => array('staging', 'production'), + 'rocketeer::stages.stages' => ['staging', 'production'], )); $this->connections->setStage('staging'); diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index e306f59a1..72669bd9d 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -48,21 +48,24 @@ public function testCanGetFallbackForBinary() $this->assertFalse($this->task->which('fdsf')); } - public function testDoesntRunComposerIfNotNeeded() + public function testCanRunComposer() { $this->usesComposer(true); $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock - ->shouldReceive('option')->andReturn(array()) + ->shouldReceive('option')->andReturn([]) ->shouldReceive('info')->once(); }); $this->task->runComposer(); + } + public function testDoesntRunComposerIfNotNeeded() + { $this->usesComposer(false); $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock - ->shouldReceive('option')->andReturn(array()) + ->shouldReceive('option')->andReturn([]) ->shouldReceive('info')->never(); }); From 7b314d6718f800b6a6bd2dc39cdae21124dcad4a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 14:16:53 +0200 Subject: [PATCH 173/424] Add some tests --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 3 +- src/Rocketeer/Services/TasksHandler.php | 10 +++- tests/Abstracts/AbstractTaskTest.php | 7 ++- tests/IgniterTest.php | 22 +++++++ tests/Plugins/AbstractNotifierTest.php | 2 +- tests/Services/Tasks/TasksQueueTest.php | 4 +- tests/Services/TasksHandlerTest.php | 57 ++++++++----------- tests/TestCases/ContainerTestCase.php | 6 +- tests/TestCases/RocketeerTestCase.php | 2 +- 9 files changed, 65 insertions(+), 48 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 3f38f8bc6..e055c01d8 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -10,6 +10,7 @@ namespace Rocketeer\Services\Tasks; use Closure; +use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Traits\HasLocator; @@ -51,7 +52,7 @@ public function buildTask($task, $name = null, $description = null) { // Check the handle if possible if (is_string($task)) { - $handle = 'rocketeer.tasks.'.$task; + $handle = 'rocketeer.tasks.'.Str::snake($task, '-'); } if ($task instanceof Closure) { diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 7d41068c7..79f9519ff 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -174,7 +174,7 @@ public function listenTo($event, $listeners, $priority = 0) // Register events foreach ($listeners as $listener) { - $this->events->listen('rocketeer.'.$event, array($listener, 'fire'), $priority); + $this->events->listen('rocketeer.'.$event, [$listener, 'fire'], $priority); } return $event; @@ -201,8 +201,14 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) return; } + // Prevent events on anonymous tasks + $slug = $this->builder->buildTask($task)->getSlug(); + if ($slug == 'closure') { + return; + } + // Get event name and register listeners - $event = $this->builder->buildTaskFromClass($task)->getSlug().'.'.$event; + $event = $slug.'.'.$event; $event = $this->listenTo($event, $listeners, $priority); return $event; diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 6b0cd2d93..1d1523a5c 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -48,8 +48,9 @@ public function testCanRunMigrations() public function testCanFireEventsDuringTasks() { $this->expectOutputString('foobar'); + $this->swapConfig(['rocketeer::hooks' => []]); - $this->tasksQueue()->listenTo('closure.test.foobar', function () { + $this->tasks->listenTo('closure.test.foobar', function () { echo 'foobar'; }); @@ -66,8 +67,8 @@ public function testTaskCancelsIfEventHalts() 'rocketeer::hooks' => [], )); - $this->tasksQueue()->registerConfiguredEvents(); - $this->tasksQueue()->listenTo('deploy.before', array( + $this->tasks->registerConfiguredEvents(); + $this->tasks->listenTo('deploy.before', array( function () { echo 'a'; diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index 9fb2521c7..189f0b42e 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -133,4 +133,26 @@ public function testCanGetStorageWhenBothForSomeReason() $storage = $this->igniter->getStoragePath(); $this->assertEquals('local/folder', $storage); } + + public function testCanLoadFilesOrFolder() + { + $config = $this->customConfig; + $this->app['path.base'] = dirname($config); + + $this->files->makeDirectory($config.'/events', 0755, true); + $this->files->put($config.'/tasks.php', 'files->put($config.'/events/some-event.php', 'igniter->bindPaths(); + $this->igniter->loadCustomFiles(); + $this->tasks->registerConfiguredEvents(); + + $task = $this->builder->buildTask('DisplayFiles'); + $this->assertInstanceOf('Rocketeer\Tasks\Closure', $task); + $this->assertEquals('DisplayFiles', $task->getName()); + + $events = $this->tasks->getTasksListeners($task, 'before'); + $this->assertCount(1, $events); + $this->assertEquals('whoami', $events[0][0]->getStringTask()); + } } diff --git a/tests/Plugins/AbstractNotifierTest.php b/tests/Plugins/AbstractNotifierTest.php index 8393aceec..d7b07fcea 100644 --- a/tests/Plugins/AbstractNotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -45,7 +45,7 @@ public function testCanAskForNameIfNoneProvided() ->shouldReceive('getServerCredentials')->andReturn(['host' => 'foo.bar.com']); }); - $this->task('Deploy')->fireEvent('before'); + $this->task('deploy')->fireEvent('before'); } public function testCanAppendStageToDetails() diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 323dc3c0f..460f5ee68 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -24,8 +24,8 @@ function () { public function testCanRunQueueOnDifferentConnectionsAndStages() { $this->swapConfig(array( - 'rocketeer::default' => array('staging', 'production'), - 'rocketeer::stages.stages' => array('first', 'second'), + 'rocketeer::default' => ['staging', 'production'], + 'rocketeer::stages.stages' => ['first', 'second'], )); $output = array(); diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index 591cdc9ae..7d5b269d0 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -8,23 +8,15 @@ class TasksHandlerTest extends RocketeerTestCase { public function testCanAddCommandsToArtisan() { - $command = $this->tasksQueue()->add('Rocketeer\Tasks\Deploy'); + $command = $this->tasks->add('Rocketeer\Tasks\Deploy'); $this->assertInstanceOf('Rocketeer\Console\Commands\BaseTaskCommand', $command); $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $command->getTask()); } - public function testCanUseFacadeOutsideOfLaravel() - { - Rocketeer::before('deploy', 'ls'); - $before = Rocketeer::getTasksListeners('deploy', 'before', true); - - $this->assertEquals(['ls'], $before); - } - public function testCanGetTasksBeforeOrAfterAnotherTask() { $task = $this->task('Deploy'); - $before = $this->tasksQueue()->getTasksListeners($task, 'before', true); + $before = $this->tasks->getTasksListeners($task, 'before', true); $this->assertEquals(['before', 'foobar'], $before); } @@ -32,26 +24,25 @@ public function testCanGetTasksBeforeOrAfterAnotherTask() public function testCanAddTasksViaFacade() { $task = $this->task('Deploy'); - $before = $this->tasksQueue()->getTasksListeners($task, 'before', true); + $before = $this->tasks->getTasksListeners($task, 'before', true); - $this->tasksQueue()->before('deploy', 'composer install'); + $this->tasks->before('deploy', 'composer install'); $newBefore = array_merge($before, array('composer install')); - $this->assertEquals($newBefore, $this->tasksQueue()->getTasksListeners($task, 'before', true)); + $this->assertEquals($newBefore, $this->tasks->getTasksListeners($task, 'before', true)); } public function testCanAddMultipleTasksViaFacade() { $task = $this->task('Deploy'); - $after = $this->tasksQueue()->getTasksListeners($task, 'after', true); - - $this->tasksQueue()->after('deploy', array( + $after = $this->tasks->getTasksListeners($task, 'after', true); + $this->tasks->after('deploy', array( 'composer install', 'bower install' )); $newAfter = array_merge($after, array('composer install', 'bower install')); - $this->assertEquals($newAfter, $this->tasksQueue()->getTasksListeners($task, 'after', true)); + $this->assertEquals($newAfter, $this->tasks->getTasksListeners($task, 'after', true)); } public function testCanRegisterCustomTask() @@ -86,34 +77,34 @@ public function testCanRegisterCustomTaskViaArray() public function testCanAddSurroundTasksToNonExistingTasks() { $task = $this->task('Setup'); - $this->tasksQueue()->after('setup', 'composer install'); + $this->tasks->after('setup', 'composer install'); $after = array('composer install'); - $this->assertEquals($after, $this->tasksQueue()->getTasksListeners($task, 'after', true)); + $this->assertEquals($after, $this->tasks->getTasksListeners($task, 'after', true)); } public function testCanAddSurroundTasksToMultipleTasks() { - $this->tasksQueue()->after(array('cleanup', 'setup'), 'composer install'); + $this->tasks->after(array('cleanup', 'setup'), 'composer install'); $after = array('composer install'); - $this->assertEquals($after, $this->tasksQueue()->getTasksListeners('setup', 'after', true)); - $this->assertEquals($after, $this->tasksQueue()->getTasksListeners('cleanup', 'after', true)); + $this->assertEquals($after, $this->tasks->getTasksListeners('setup', 'after', true)); + $this->assertEquals($after, $this->tasks->getTasksListeners('cleanup', 'after', true)); } public function testCangetTasksListenersOrAfterAnotherTaskBySlug() { - $after = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + $after = $this->tasks->getTasksListeners('deploy', 'after', true); $this->assertEquals(array('after', 'foobar'), $after); } public function testCanAddEventsWithPriority() { - $this->tasksQueue()->before('deploy', 'second', -5); - $this->tasksQueue()->before('deploy', 'first'); + $this->tasks->before('deploy', 'second', -5); + $this->tasks->before('deploy', 'first'); - $listeners = $this->tasksQueue()->getTasksListeners('deploy', 'before', true); + $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); $this->assertEquals(['before', 'foobar', 'first', 'second'], $listeners); } @@ -125,10 +116,10 @@ public function testCanExecuteContextualEvents() )); $this->connections->setStage('hasEvent'); - $this->assertEquals(['ls'], $this->tasksQueue()->getTasksListeners('check', 'before', true)); + $this->assertEquals(['ls'], $this->tasks->getTasksListeners('check', 'before', true)); $this->connections->setStage('noEvent'); - $this->assertEquals([], $this->tasksQueue()->getTasksListeners('check', 'before', true)); + $this->assertEquals([], $this->tasks->getTasksListeners('check', 'before', true)); } public function testCanbuildTasksFromConfigHook() @@ -142,8 +133,8 @@ public function testCanbuildTasksFromConfigHook() 'rocketeer::hooks' => ['after' => ['deploy' => $tasks]], )); - $this->tasksQueue()->registerConfiguredEvents(); - $listeners = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + $this->tasks->registerConfiguredEvents(); + $listeners = $this->tasks->getTasksListeners('deploy', 'after', true); $this->assertEquals($tasks, $listeners); } @@ -160,14 +151,14 @@ public function testCanHaveCustomConnectionHooks() 'rocketeer::hooks' => [], 'rocketeer::on.connections.staging.hooks' => ['after' => ['deploy' => $tasks]], )); - $this->tasksQueue()->registerConfiguredEvents(); + $this->tasks->registerConfiguredEvents(); $this->connections->setConnection('production'); - $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + $events = $this->tasks->getTasksListeners('deploy', 'after', true); $this->assertEmpty($events); $this->connections->setConnection('staging'); - $events = $this->tasksQueue()->getTasksListeners('deploy', 'after', true); + $events = $this->tasks->getTasksListeners('deploy', 'after', true); $this->assertEquals($tasks, $events); } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index e5f54f83d..5e07adea0 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -50,11 +50,7 @@ public function setUp() // Rocketeer classes ------------------------------------------- / $serviceProvider = new RocketeerServiceProvider($this->app); - $serviceProvider->bindPaths(); - $serviceProvider->bindThirdPartyServices(); - $serviceProvider->bindCoreClasses(); - $serviceProvider->bindConsoleClasses(); - $serviceProvider->bindStrategies(); + $serviceProvider->boot(); } /** diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 355abbd12..66724de4e 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -43,7 +43,7 @@ public function setUp() parent::setUp(); // Setup local server - $this->customConfig = __DIR__.'/../_meta/config'; + $this->customConfig = __DIR__.'/../_meta/.rocketeer'; $this->server = __DIR__.'/../_server/foobar'; $this->deploymentsFile = __DIR__.'/../_meta/deployments.json'; From b0ac9401c2c191de8208709d9e362e1b1589d383 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 19:34:34 +0200 Subject: [PATCH 174/424] Move loading of user configuration and events/tasks to Igniter --- src/Rocketeer/Igniter.php | 90 +++++++++++++++++----- src/Rocketeer/Rocketeer.php | 45 ----------- src/Rocketeer/RocketeerServiceProvider.php | 7 +- tests/IgniterTest.php | 25 +++++- tests/RocketeerTest.php | 23 ------ tests/TestCases/ContainerTestCase.php | 3 + 6 files changed, 100 insertions(+), 93 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 72aa333a7..9594606ca 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -10,9 +10,12 @@ namespace Rocketeer; use Rocketeer\Traits\HasLocator; +use Symfony\Component\Finder\Finder; +use Symfony\Component\Finder\SplFileInfo; /** - * Finds configurations and paths + * Ignites Rocketeer's custom configuration, tasks, events and paths + * depending on what Rocketeer is used on * * @author Maxime Fabre */ @@ -32,46 +35,52 @@ public function bindPaths() } ////////////////////////////////////////////////////////////////////// - //////////////////////////// FILE LOADERS //////////////////////////// + ///////////////////////// USER CONFIGURATION ///////////////////////// ////////////////////////////////////////////////////////////////////// /** * Load the custom files (tasks, events, ...) */ - public function loadCustomFiles() + public function loadUserConfiguration() { $fileLoaders = function () { $this->loadFileOrFolder('tasks'); $this->loadFileOrFolder('events'); }; + // Defer loading of tasks and events or not if (method_exists($this->app, 'booted')) { $this->app->booted($fileLoaders); } else { $fileLoaders(); } + + // Merge contextual configurations + $this->mergeContextualConfigurations(); } /** - * Load a file or its contents if a folder - * - * @param string $handle + * Merge the various contextual configurations defined in userland */ - public function loadFileOrFolder($handle) + public function mergeContextualConfigurations() { - // Bind ourselves into the facade to avoid automatic resolution - Facades\Rocketeer::setFacadeApplication($this->app); + // Cancel if not ignited yet + $storage = $this->app['path.rocketeer.config']; + if (!is_dir($storage) or (!is_dir($storage.'/stages') and !is_dir($storage.'/connections'))) { + return; + } - // If we have one unified tasks file, include it - $file = $this->app['path.rocketeer.'.$handle]; - if (!is_dir($file) and file_exists($file)) { - include $file; - } // Else include its contents - elseif (is_dir($file)) { - $folder = glob($file.'/*.php'); - foreach ($folder as $file) { - include $file; - } + // Gather custom files + $finder = new Finder(); + $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); + $files = iterator_to_array($files); + + // Bind their contents to the "on" array + foreach ($files as $file) { + $contents = include $file->getPathname(); + $handle = $this->computeHandleFromPath($file); + + $this->config->set($handle, $contents); } } @@ -224,6 +233,49 @@ protected function bindConfiguration() /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// + /** + * Computes which configuration handle a config file should bind to + * + * @param SplFileInfo $file + * + * @return string + */ + protected function computeHandleFromPath(SplFileInfo $file) + { + // Get realpath + $handle = $file->getRealpath(); + + // Format appropriately + $handle = str_replace($this->app['path.rocketeer.config'].DS, null, $handle); + $handle = str_replace('.php', null, $handle); + $handle = str_replace(DS, '.', $handle); + + return sprintf('rocketeer::on.%s', $handle); + } + + /** + * Load a file or its contents if a folder + * + * @param string $handle + */ + protected function loadFileOrFolder($handle) + { + // Bind ourselves into the facade to avoid automatic resolution + Facades\Rocketeer::setFacadeApplication($this->app); + + // If we have one unified tasks file, include it + $file = $this->app['path.rocketeer.'.$handle]; + if (!is_dir($file) and file_exists($file)) { + include $file; + } // Else include its contents + elseif (is_dir($file)) { + $folder = glob($file.'/*.php'); + foreach ($folder as $file) { + include $file; + } + } + } + /** * Unify the slashes to the UNIX mode (forward slashes) * diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index b4d9a0a03..2bc62dabd 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -12,8 +12,6 @@ use Exception; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; -use Symfony\Component\Finder\Finder; -use Symfony\Component\Finder\SplFileInfo; /** * Handles interaction between the User provided informations @@ -119,49 +117,6 @@ protected function getContextualOption($option, $type, $original = null) return $value; } - /** - * Merge the various contextual configurations defined in userland - */ - public function mergeContextualConfigurations() - { - // Cancel if not ignited yet - $storage = $this->app['path.rocketeer.config']; - if (!is_dir($storage) or (!is_dir($storage.'/stages') and !is_dir($storage.'/connections'))) { - return; - } - - // Gather custom files - $finder = new Finder(); - $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); - $files = iterator_to_array($files); - - // Bind their contents to the "on" array - foreach ($files as $file) { - $contents = include $file->getPathname(); - $handle = $this->computeHandleFromPath($file); - - $this->config->set($handle, $contents); - } - } - - /** - * @param SplFileInfo $file - * - * @return string - */ - protected function computeHandleFromPath(SplFileInfo $file) - { - // Get realpath - $handle = $file->getRealpath(); - - // Format appropriately - $handle = str_replace($this->app['path.rocketeer.config'].DS, null, $handle); - $handle = str_replace('.php', null, $handle); - $handle = str_replace(DS, '.', $handle); - - return sprintf('rocketeer::on.%s', $handle); - } - //////////////////////////////////////////////////////////////////// //////////////////////////////// PATHS ///////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 1fd3a1590..2822ccbae 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -73,14 +73,11 @@ public function boot() $this->bindConsoleClasses(); $this->bindStrategies(); - // Load the user's events and tasks - $this->app['rocketeer.igniter']->loadCustomFiles(); + // Load the user's events, tasks, and configurations + $this->app['rocketeer.igniter']->loadUserConfiguration(); // Bind commands $this->bindCommands(); - - // Load contextual configurations - $this->app['rocketeer.rocketeer']->mergeContextualConfigurations(); } /** diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index 189f0b42e..e5b0a6ce0 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -144,7 +144,7 @@ public function testCanLoadFilesOrFolder() $this->files->put($config.'/events/some-event.php', 'igniter->bindPaths(); - $this->igniter->loadCustomFiles(); + $this->igniter->loadUserConfiguration(); $this->tasks->registerConfiguredEvents(); $task = $this->builder->buildTask('DisplayFiles'); @@ -155,4 +155,27 @@ public function testCanLoadFilesOrFolder() $this->assertCount(1, $events); $this->assertEquals('whoami', $events[0][0]->getStringTask()); } + + public function testCanUseFilesAndFoldersForContextualConfig() + { + $this->mock('config', 'Config', function ($mock) { + return $mock->shouldReceive('set')->once()->with('rocketeer::on.connections.production.scm', ['scm' => 'svn']); + }); + + $file = $this->customConfig.'/connections/production/scm.php'; + $this->files->makeDirectory(dirname($file), 0755, true); + $this->app['path.rocketeer.config'] = realpath($this->customConfig); + + file_put_contents($file, ' "svn");'); + + $this->igniter->mergeContextualConfigurations(); + } + + public function testDoesntCrashIfNoSubfolder() + { + $this->files->makeDirectory($this->customConfig, 0755, true); + $this->app['path.rocketeer.config'] = realpath($this->customConfig); + + $this->igniter->mergeContextualConfigurations(); + } } diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 3d4c53f56..3b6d6e2e4 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -134,27 +134,4 @@ public function testCanGetBoundPath() $this->assertEquals('/bin/php', $path); } - - public function testCanUseFilesAndFoldersForContextualConfig() - { - $this->mock('config', 'Config', function ($mock) { - return $mock->shouldReceive('set')->once()->with('rocketeer::on.connections.production.scm', ['scm' => 'svn']); - }); - - $file = $this->customConfig.'/connections/production/scm.php'; - $this->files->makeDirectory(dirname($file), 0755, true); - $this->app['path.rocketeer.config'] = realpath($this->customConfig); - - file_put_contents($file, ' "svn");'); - - $this->rocketeer->mergeContextualConfigurations(); - } - - public function testDoesntCrashIfNoSubfolder() - { - $this->files->makeDirectory($this->customConfig, 0755, true); - $this->app['path.rocketeer.config'] = realpath($this->customConfig); - - $this->rocketeer->mergeContextualConfigurations(); - } } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 5e07adea0..ff238e167 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -13,6 +13,9 @@ abstract class ContainerTestCase extends PHPUnit_Framework_TestCase { use HasLocator; + /** + * Override the trait constructor + */ public function __construct() { parent::__construct(); From d196932f399e5b08e1cc225e3403961e6ad6369d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 19:43:25 +0200 Subject: [PATCH 175/424] Nicer colors for task statuses --- src/Rocketeer/Abstracts/AbstractTask.php | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 13c56f441..88b16199e 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -261,11 +261,11 @@ protected function displayStatus() $name = $this->getName(); $description = $this->getDescription(); - $comment = sprintf('-- Running: %s', $name); + $comment = sprintf('-- Running: %s', $name); if ($description) { - $comment .= ' ('.$description.')'; + $comment .= ' ('.$description.')'; } - $this->command->comment($comment); + $this->command->line($comment); } } From ab3948f72f32cf23330e88772c255a9dd20db4c9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 20:00:48 +0200 Subject: [PATCH 176/424] Throw Exception on unbuildable task instead of silent fail --- src/Rocketeer/Exceptions/TaskCompositionException.php | 9 +++++++++ src/Rocketeer/RocketeerServiceProvider.php | 10 +++++----- src/Rocketeer/Services/Tasks/TasksBuilder.php | 6 ++++-- 3 files changed, 18 insertions(+), 7 deletions(-) create mode 100644 src/Rocketeer/Exceptions/TaskCompositionException.php diff --git a/src/Rocketeer/Exceptions/TaskCompositionException.php b/src/Rocketeer/Exceptions/TaskCompositionException.php new file mode 100644 index 000000000..a9e2fb813 --- /dev/null +++ b/src/Rocketeer/Exceptions/TaskCompositionException.php @@ -0,0 +1,9 @@ +app['rocketeer.builder']->buildTaskFromClass($task); - $taskInstance = $taskInstance instanceof AbstractTask ? $taskInstance : null; - if (is_numeric($slug)) { - $slug = $taskInstance->getSlug(); + try { + $taskInstance = $this->app['rocketeer.builder']->buildTaskFromClass($task); + } catch (TaskCompositionException $exception) { + $taskInstance = null; } // Bind Task to container diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index e055c01d8..de9fad8d5 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -12,6 +12,7 @@ use Closure; use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractTask; +use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\Traits\HasLocator; /** @@ -122,7 +123,8 @@ public function buildTaskFromClosure(Closure $closure, $stringTask = null) * * @param string|AbstractTask $task * - * @return AbstractTask|string + * @throws TaskCompositionException + * @return AbstractTask */ public function buildTaskFromClass($task) { @@ -137,7 +139,7 @@ public function buildTaskFromClass($task) // Cancel if class doesn't exist if (!class_exists($task)) { - return $task; + throw new TaskCompositionException('Impossible to build task: '.$task); } return new $task($this->app); From 3135fc3ad3739c73b879f39e75386814f78d0fd4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 20:00:55 +0200 Subject: [PATCH 177/424] Docblocks tweaks --- src/Rocketeer/Abstracts/AbstractCommand.php | 5 +++-- src/Rocketeer/Abstracts/AbstractStorage.php | 4 ++-- src/Rocketeer/Console/Commands/RollbackCommand.php | 2 +- src/Rocketeer/Console/Commands/UpdateCommand.php | 2 +- src/Rocketeer/Scm/Git.php | 7 ++++++- src/Rocketeer/Scm/Svn.php | 5 ++++- src/Rocketeer/Services/CredentialsGatherer.php | 2 +- src/Rocketeer/Services/ReleasesManager.php | 1 - tests/Scm/GitTest.php | 4 ++-- 9 files changed, 20 insertions(+), 12 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 01fba9250..068b56380 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -22,7 +22,7 @@ abstract class AbstractCommand extends Command { /** - * @param AbstractTask $task + * @param AbstractTask|null $task */ public function __construct(AbstractTask $task = null) { @@ -48,7 +48,7 @@ abstract public function fire(); /** * Get the console command options. * - * @return string[][] + * @return array> */ protected function getOptions() { @@ -58,6 +58,7 @@ protected function getOptions() ['pretend', 'p', InputOption::VALUE_NONE, 'Shows which command would execute without actually doing anything'], ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'], + // Credentials ['host', null, InputOption::VALUE_REQUIRED, 'The host to use if asked'], ['username', null, InputOption::VALUE_REQUIRED, 'The username to use if asked'], diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 72d15807d..c47d8832c 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -46,8 +46,8 @@ public function setFile($file) /** * Get a value on the server * - * @param string|null $key - * @param Closure $fallback + * @param string|null $key + * @param Closure|null $fallback * * @return string|integer|array */ diff --git a/src/Rocketeer/Console/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php index 26f57fec1..f1b2ba368 100644 --- a/src/Rocketeer/Console/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -52,7 +52,7 @@ protected function getArguments() /** * Get the console command options. * - * @return string[][] + * @return array> */ protected function getOptions() { diff --git a/src/Rocketeer/Console/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php index d6a258b97..434fa11e8 100644 --- a/src/Rocketeer/Console/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -39,7 +39,7 @@ public function fire() /** * Get the console command options. * - * @return string[][] + * @return array> */ protected function getOptions() { diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index 390af4e34..a76d9e6a8 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -15,6 +15,11 @@ /** * The Git implementation of the ScmInterface * + * @method string revParse() + * @method string clone() + * @method string pull() + * @method string submodule() + * * @author Maxime Fabre */ class Git extends AbstractBinary implements ScmInterface @@ -94,7 +99,7 @@ public function checkout($destination) */ public function reset() { - return $this->getCommand('reset', null, ['--hard']); + return $this->getCommand('reset', [], ['--hard']); } /** diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index bcc5137cf..2496b299e 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -15,6 +15,9 @@ /** * The Svn implementation of the ScmInterface * + * @method string co() + * @method string up() + * * @author Maxime Fabre * @author Gasillo */ @@ -106,7 +109,7 @@ public function update() /** * Return credential options * - * @return string + * @return string[]|array */ protected function getCredentials() { diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 6106406cf..19c103a79 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -120,7 +120,7 @@ protected function getConnectionCredentials($connectionName, $server = null) * Loop through credentials and store the missing ones * * @param boolean[] $credentials - * @param string $current + * @param string[] $current * @param string $handle * * @return array diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index ddfe4d1b0..92984891b 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -10,7 +10,6 @@ namespace Rocketeer\Services; use Illuminate\Container\Container; -use integer; use Rocketeer\Services\Storages\ServerStorage; use Rocketeer\Traits\HasLocator; diff --git a/tests/Scm/GitTest.php b/tests/Scm/GitTest.php index 2f54d929e..18aefe09c 100644 --- a/tests/Scm/GitTest.php +++ b/tests/Scm/GitTest.php @@ -46,7 +46,7 @@ public function testCanGetCurrentBranch() public function testCanGetCheckout() { - $this->mock('rocketeer.rocketeer', 'Rocketeer', function ($mock) { + $this->mock('rocketeer.rocketeer', 'Rocketeer\Rocketeer', function ($mock) { return $mock->shouldReceive('getOption')->once()->with('scm.shallow')->andReturn(true); }); $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { @@ -62,7 +62,7 @@ public function testCanGetCheckout() public function testCanGetDeepClone() { - $this->mock('rocketeer.rocketeer', 'Rocketeer', function ($mock) { + $this->mock('rocketeer.rocketeer', 'Rocketeer\Rocketeer', function ($mock) { return $mock->shouldReceive('getOption')->once()->with('scm.shallow')->andReturn(false); }); $this->mock('rocketeer.connections', 'ConnectionsHandler', function ($mock) { From ae2d5924d625cfe589a76187c4328a4034fc4fe8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 20:03:10 +0200 Subject: [PATCH 178/424] Add test for new Exception --- tests/Services/Tasks/TasksBuilderTest.php | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php index 5f129916c..6eb975f18 100644 --- a/tests/Services/Tasks/TasksBuilderTest.php +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -2,6 +2,7 @@ namespace Services\Tasks; use ReflectionFunction; +use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\TestCases\RocketeerTestCase; class TasksBuilderTest extends RocketeerTestCase @@ -63,4 +64,11 @@ function () { $this->assertInstanceOf('Rocketeer\Tasks\Closure', $queue[1]); $this->assertInstanceOf('Rocketeer\Tasks\Deploy', $queue[2]); } + + public function testThrowsExceptionOnUnbuildableTask() + { + $this->setExpectedException(TaskCompositionException::class); + + $this->builder->buildTaskFromClass('Nope'); + } } From 2436f94a059646ff1164f42d986dd5ca141542c5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 20:32:54 +0200 Subject: [PATCH 179/424] More docblock fixes --- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- src/Rocketeer/Scm/Git.php | 6 +++--- src/Rocketeer/Scm/Svn.php | 8 ++++---- src/Rocketeer/Services/ConnectionsHandler.php | 2 +- src/Rocketeer/Services/ReleasesManager.php | 4 ++-- src/Rocketeer/Services/Tasks/TasksBuilder.php | 3 +-- src/Rocketeer/Services/Tasks/TasksQueue.php | 2 +- src/Rocketeer/Tasks/Cleanup.php | 4 +--- src/Rocketeer/Tasks/Rollback.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- tests/Services/Tasks/TasksQueueTest.php | 2 +- 11 files changed, 17 insertions(+), 20 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 88b16199e..0da08e374 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -243,7 +243,7 @@ protected function displayReleases() * * @param string $task * - * @return string the task's output + * @return string|false */ public function executeTask($task) { diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index a76d9e6a8..7c180ebc2 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -15,10 +15,10 @@ /** * The Git implementation of the ScmInterface * - * @method string revParse() - * @method string clone() + * @method string revParse(string $arguments, array $flags = array()) + * @method string clone(string $arguments, array $flags = array()) * @method string pull() - * @method string submodule() + * @method string submodule(string $arguments, array $flags = array()) * * @author Maxime Fabre */ diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index 2496b299e..ec502d23f 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -15,8 +15,8 @@ /** * The Svn implementation of the ScmInterface * - * @method string co() - * @method string up() + * @method string co(array $arguments, array $flags = array()) + * @method string up(array $arguments, array $flags = array()) * * @author Maxime Fabre * @author Gasillo @@ -103,13 +103,13 @@ public function reset() */ public function update() { - return $this->up(null, $this->getCredentials()); + return $this->up([], $this->getCredentials()); } /** * Return credential options * - * @return string[]|array + * @return array|array */ protected function getCredentials() { diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index 7bce1c87a..e28bbf562 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -95,7 +95,7 @@ public function getStage() /** * Get the various stages provided by the User * - * @return string + * @return array */ public function getStages() { diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 92984891b..3b7a6d360 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -104,7 +104,7 @@ public function getNonCurrentReleases() /** * Get an array of deprecated releases * - * @param integer $treshold + * @param integer|null $treshold * * @return integer[] */ @@ -215,7 +215,7 @@ public function saveValidationFile(array $validation) /** * Mark a release as valid * - * @param string $release + * @param string|null $release */ public function markReleaseAsValid($release = null) { diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index de9fad8d5..811b089db 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -104,8 +104,7 @@ public function buildTaskFromString($task) */ public function buildTaskFromClosure(Closure $closure, $stringTask = null) { - // Now that we unified it all to a Closure, we build - // a Closure AbstractTask from there + /** @type \Rocketeer\Tasks\Closure $task */ $task = $this->buildTaskFromClass('Rocketeer\Tasks\Closure'); $task->setClosure($closure); diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 1293f6842..00d4fb7b1 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -225,7 +225,7 @@ protected function runAsynchronously(Collection $pipeline) } $this->parallel = $this->parallel ?: new Parallel(); - $this->parallel->run($pipeline); + $this->parallel->run($pipeline->all()); return true; } diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index 891f0e773..8855dda57 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -28,8 +28,6 @@ class Cleanup extends AbstractTask /** * Run the task - * - * @return void */ public function execute() { @@ -59,7 +57,7 @@ public function execute() /** * Get an array of releases to prune * - * @return \integer[] + * @return integer[] */ protected function getReleasesToCleanup() { diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index d5dd2f27a..75133daa9 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -60,7 +60,7 @@ public function execute() /** * Get the release to rollback to * - * @return integer|null + * @return string|null */ protected function getRollbackRelease() { diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 897457f7d..10f3f8220 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -79,7 +79,7 @@ protected function createStages() $availableStages = $this->connections->getStages(); $originalStage = $this->connections->getStage(); if (empty($availableStages)) { - $availableStages = array(null); + $availableStages = [null]; } // Create folders diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 460f5ee68..5d2567c7c 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -89,7 +89,7 @@ public function testCanRunOnMultipleConnectionsViaOn() public function testCanRunTasksInParallel() { $parallel = Mockery::mock('Parallel') - ->shouldReceive('run')->once()->with(Mockery::type('Illuminate\Support\Collection')) + ->shouldReceive('run')->once()->with(Mockery::type('array')) ->mock(); $this->mockCommand(['parallel' => true]); From 6243e0b51fbf19398126e7964192f7db7e219145 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 12 Aug 2014 23:57:31 +0200 Subject: [PATCH 180/424] Work on binaries and subtasks --- src/Rocketeer/Abstracts/AbstractBinary.php | 88 ++++++--- src/Rocketeer/Abstracts/AbstractTask.php | 13 +- src/Rocketeer/Binaries/AnonymousBinary.php | 12 ++ src/Rocketeer/Binaries/Artisan.php | 67 +++++++ src/Rocketeer/Binaries/Composer.php | 28 +++ src/Rocketeer/Binaries/Php.php | 52 +++++ src/Rocketeer/Binaries/Phpunit.php | 22 +++ src/Rocketeer/RocketeerServiceProvider.php | 1 - src/Rocketeer/Services/Tasks/TasksBuilder.php | 32 ++- src/Rocketeer/Services/Tasks/TasksQueue.php | 12 +- src/Rocketeer/Strategies/CloneStrategy.php | 2 +- src/Rocketeer/Tasks/Check.php | 39 ++-- src/Rocketeer/Tasks/Deploy.php | 68 +------ src/Rocketeer/Tasks/Subtasks/Artisan.php | 28 +++ src/Rocketeer/Tasks/Subtasks/Composer.php | 39 ++++ .../Tasks/Subtasks/CreateRelease.php | 17 ++ src/Rocketeer/Tasks/Subtasks/Phpunit.php | 35 ++++ src/Rocketeer/Tasks/Test.php | 2 +- src/Rocketeer/Tasks/Update.php | 8 +- src/Rocketeer/Traits/BashModules/Binaries.php | 182 +++++------------- src/config/remote.php | 11 +- tests/Abstracts/AbstractBinaryTest.php | 2 +- tests/Abstracts/AbstractTaskTest.php | 12 -- tests/Binaries/ArtisanTest.php | 20 ++ tests/Binaries/PhpTest.php | 17 ++ tests/Services/Tasks/JobTest.php | 2 + tests/Tasks/CheckTest.php | 8 - tests/Tasks/DeployTest.php | 17 +- .../PhpunitTest.php} | 8 +- tests/TestCases/ContainerTestCase.php | 8 +- tests/TestCases/RocketeerTestCase.php | 2 +- tests/Traits/BashModules/BinariesTest.php | 10 +- 32 files changed, 542 insertions(+), 322 deletions(-) create mode 100644 src/Rocketeer/Binaries/AnonymousBinary.php create mode 100644 src/Rocketeer/Binaries/Artisan.php create mode 100644 src/Rocketeer/Binaries/Composer.php create mode 100644 src/Rocketeer/Binaries/Php.php create mode 100644 src/Rocketeer/Binaries/Phpunit.php create mode 100644 src/Rocketeer/Tasks/Subtasks/Artisan.php create mode 100644 src/Rocketeer/Tasks/Subtasks/Composer.php create mode 100644 src/Rocketeer/Tasks/Subtasks/CreateRelease.php create mode 100644 src/Rocketeer/Tasks/Subtasks/Phpunit.php create mode 100644 tests/Binaries/ArtisanTest.php create mode 100644 tests/Binaries/PhpTest.php rename tests/Tasks/{TestTest.php => Subtasks/PhpunitTest.php} (50%) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 7d350d846..80101bc9a 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -28,6 +28,33 @@ class AbstractBinary */ protected $binary; + /** + * A parent binary to call this one with + * + * @type AbstractBinary|string + */ + protected $parent; + + ////////////////////////////////////////////////////////////////////// + ///////////////////////////// PROPERTIES ///////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * @param AbstractBinary|string $parent + */ + public function setParent($parent) + { + $this->parent = $parent; + } + + /** + * @param string $binary + */ + public function setBinary($binary) + { + $this->binary = $binary; + } + /** * Get the current binary name * @@ -48,6 +75,14 @@ public function getBinary() */ public function __call($name, $arguments) { + // Execution aliases + if (Str::startsWith($name, 'run')) { + $command = array_shift($arguments); + $command = call_user_func_array([$this, $command], $arguments); + + return $this->bash->$name($command); + } + // Format name $name = Str::snake($name, '-'); @@ -58,20 +93,6 @@ public function __call($name, $arguments) return $command; } - /** - * Execute one of the commands - * - * @return string|null - */ - public function execute() - { - $arguments = func_get_args(); - $command = array_shift($arguments); - $command = call_user_func_array([$this, $command], $arguments); - - return $this->bash->run($command); - } - //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// //////////////////////////////////////////////////////////////////// @@ -79,37 +100,46 @@ public function execute() /** * Returns a command with the SCM's binary * - * @param string $command - * @param string[] $arguments - * @param string[] $flags + * @param string|null $command + * @param string|string[] $arguments + * @param string|string[] $flags * * @return string */ - public function getCommand($command, $arguments = array(), $flags = array()) + public function getCommand($command = null, $arguments = array(), $flags = array()) { // Format arguments $arguments = $this->buildArguments($arguments); $options = $this->buildOptions($flags); // Build command - $command = $this->binary.' '.$command; - if ($arguments) { - $command .= ' '.$arguments; - } - if ($options) { - $command .= ' '.$options; + $binary = $this->binary; + $components = [$command, $arguments, $options]; + foreach ($components as $component) { + if ($component) { + $binary .= ' '.$component; + } } + // If the binary has a parent, wrap the call with it + $parent = $this->parent instanceof AbstractBinary ? $this->parent->getBinary() : $this->parent; + $command = $parent.' '.$binary; + return trim($command); } /** - * @param string[] $flags + * @param string|string[] $flags * * @return string */ protected function buildOptions($flags) { + // Return if already builts + if (is_string($flags)) { + return $flags; + } + $options = []; $flags = (array) $flags; @@ -131,14 +161,16 @@ protected function buildOptions($flags) } /** - * @param string[] $arguments + * @param string|string[] $arguments * * @return string */ protected function buildArguments($arguments) { - $arguments = (array) $arguments; - $arguments = implode(' ', $arguments); + if (!is_string($arguments)) { + $arguments = (array) $arguments; + $arguments = implode(' ', $arguments); + } return $arguments; } diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 0da08e374..6f8fcfcc6 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -42,6 +42,13 @@ abstract class AbstractTask extends Bash */ protected $halted = false; + /** + * Boolean to bypass certain checks + * + * @type boolean + */ + public $force; + //////////////////////////////////////////////////////////////////// ////////////////////////////// REFLECTION ////////////////////////// //////////////////////////////////////////////////////////////////// @@ -241,13 +248,13 @@ protected function displayReleases() /** * Execute another AbstractTask by name * - * @param string $task + * @param string|string[] $tasks * * @return string|false */ - public function executeTask($task) + public function executeTask($tasks) { - return $this->builder->buildTaskFromClass($task)->fire(); + return $this->queue->run($tasks); } /** diff --git a/src/Rocketeer/Binaries/AnonymousBinary.php b/src/Rocketeer/Binaries/AnonymousBinary.php new file mode 100644 index 000000000..ed608d746 --- /dev/null +++ b/src/Rocketeer/Binaries/AnonymousBinary.php @@ -0,0 +1,12 @@ +binary = $this->bash->which( + 'artisan', + $this->releasesManager->getCurrentReleasePath().'/artisan', + 'artisan' + ); + + // Set PHP as parent + $php = new Php($this->app); + $this->setParent($php); + } + + /** + * Run outstranding migrations + * + * @param bool $seed + * + * @return string + */ + public function migrate($seed = false) + { + $this->command->comment('Running outstanding migrations'); + $flags = $seed ? ['--seed' => null] : []; + + return $this->getCommand('migrate', [], $flags); + } + + /** + * Seed the database + * + * @param string|null $class A class to seed + * + * @return string + */ + public function seed($class = null) + { + $this->command->comment('Seeding database'); + $flags = $class ? ['--class' => $class] : []; + + return $this->getCommand('db:seed', [], $flags); + } + + /** + * Clear the cache + * + * @return string + */ + public function clearCache() + { + return $this->getCommand('cache:clear'); + } +} diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php new file mode 100644 index 000000000..9b3d7e5be --- /dev/null +++ b/src/Rocketeer/Binaries/Composer.php @@ -0,0 +1,28 @@ +binary = $this->bash->which( + 'composer', + $this->releasesManager->getCurrentReleasePath().'/composer.phar' + ); + + // Prepend PHP command if executing from archive + if (strpos($this->getBinary(), 'composer.phar') !== false) { + $php = new Php($this->app); + $this->setParent($php); + } + } +} diff --git a/src/Rocketeer/Binaries/Php.php b/src/Rocketeer/Binaries/Php.php new file mode 100644 index 000000000..948909c46 --- /dev/null +++ b/src/Rocketeer/Binaries/Php.php @@ -0,0 +1,52 @@ +binary = $this->bash->which('php'); + } + + /** + * Get the running version of PHP + * + * @return string + */ + public function version() + { + return $this->getCommand(null, null, ['-r' => 'print PHP_VERSION;']); + } + + /** + * Get the installed extensions + * + * @return string + */ + public function extensions() + { + return $this->getCommand(null, null, ['-m' => null]); + } + + /** + * Whether this PHP installation is an HHVM one or not + * + * @return bool + */ + public function isHhvm() + { + $version = $this->bash->runRaw($this->version(), true); + $version = head($version); + $version = strtolower($version); + + return strpos($version, 'hiphop') !== false; + } +} diff --git a/src/Rocketeer/Binaries/Phpunit.php b/src/Rocketeer/Binaries/Phpunit.php new file mode 100644 index 000000000..40006a940 --- /dev/null +++ b/src/Rocketeer/Binaries/Phpunit.php @@ -0,0 +1,22 @@ +binary = $this->bash->which( + 'phpunit', + $this->releasesManager->getCurrentReleasePath().'/vendor/bin/phpunit' + ); + } +} diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index fe4819a09..d2c16d015 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -17,7 +17,6 @@ use Illuminate\Remote\RemoteManager; use Illuminate\Support\ServiceProvider; use Monolog\Logger; -use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Console\Commands\BaseTaskCommand; use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\Services\ConnectionsHandler; diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 811b089db..836ea7d28 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -131,17 +131,12 @@ public function buildTaskFromClass($task) return $task; } - // Shortcut for calling Rocketeer Tasks - if (class_exists('Rocketeer\Tasks\\'.ucfirst($task))) { - $task = 'Rocketeer\Tasks\\'.ucfirst($task); - } - // Cancel if class doesn't exist - if (!class_exists($task)) { + if (!$class = $this->taskClassExists($task)) { throw new TaskCompositionException('Impossible to build task: '.$task); } - return new $task($this->app); + return new $class($this->app); } //////////////////////////////////////////////////////////////////// @@ -157,6 +152,27 @@ public function buildTaskFromClass($task) */ protected function isStringCommand($string) { - return is_string($string) && !class_exists($string) && !$this->app->bound('rocketeer.tasks.'.$string); + return is_string($string) && !$this->taskClassExists($string) && !$this->app->bound('rocketeer.tasks.'.$string); + } + + /** + * Check if a class with the given task name exists + * + * @param string $task + * + * @return string|false + */ + protected function taskClassExists($task) + { + $class = ucfirst($task); + if (class_exists('Rocketeer\Tasks\\'.$class)) { + return 'Rocketeer\Tasks\\'.$class; + } elseif (class_exists('Rocketeer\Tasks\Subtasks\\'.$class)) { + return 'Rocketeer\Tasks\Subtasks\\'.$class; + } elseif (class_exists($task)) { + return $task; + } + + return false; } } diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 00d4fb7b1..2fbad1224 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -117,10 +117,12 @@ public function run($tasks) } if ($this->getOption('parallel')) { - return $this->runAsynchronously($pipeline); + $results = $this->runAsynchronously($pipeline); } else { - return $this->runSynchronously($pipeline); + $results = $this->runSynchronously($pipeline); } + + return $results; } /** @@ -170,8 +172,10 @@ protected function executeJob(Job $job) $this->connections->setConnection($job->connection, $job->server); foreach ($job->queue as $key => $task) { - $currentStage = $task->usesStages() ? $job->stage : null; - $this->connections->setStage($currentStage); + if ($task->usesStages()) { + $stage = $task->usesStages() ? $job->stage : null; + $this->connections->setStage($stage); + } // Here we fire the task, save its // output and return its status diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneStrategy.php index 8ee4fb2ff..81b2a8756 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneStrategy.php @@ -21,7 +21,7 @@ public function deploy($destination = null) // Executing checkout $this->command->info('Cloning repository in "'.$destination.'"'); - $output = $this->scm->execute('checkout', $destination); + $output = $this->scm->run('checkout', $destination); // Cancel if failed and forget credentials $success = $this->bash->checkStatus('Unable to clone the repository', $output) !== false; diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 5cf6f4004..bede8d79f 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -86,13 +86,13 @@ protected function getChecks() $session = $this->app['config']->get('session.driver'); return array( - array('checkScm', $this->scm->getBinary().' could not be found'), - array('checkPhpVersion', 'The version of PHP on the server does not match Laravel\'s requirements'), - array('checkComposer', 'Composer does not seem to be present on the server'), - array('checkPhpExtension', array('mcrypt', sprintf($extension, 'mcrypt'))), - array('checkDatabaseDriver', array($database, sprintf($extension, $database))), - array('checkCacheDriver', array($cache, sprintf($extension, $cache))), - array('checkCacheDriver', array($session, sprintf($extension, $session))), + ['checkScm', $this->scm->getBinary().' could not be found'], + ['checkPhpVersion', 'The version of PHP on the server does not match Laravel\'s requirements'], + ['checkComposer', 'Composer does not seem to be present on the server'], + ['checkPhpExtension', ['mcrypt', sprintf($extension, 'mcrypt')]], + ['checkDatabaseDriver', [$database, sprintf($extension, $database)]], + ['checkCacheDriver', [$cache, sprintf($extension, $cache)]], + ['checkCacheDriver', [$session, sprintf($extension, $session)]], ); } @@ -108,7 +108,7 @@ protected function getChecks() public function checkScm() { $this->command->info('Checking presence of '.$this->scm->getBinary()); - $results = $this->scm->execute('check'); + $results = $this->scm->run('check'); $this->toOutput($results); return $this->remote->status() == 0; @@ -127,7 +127,7 @@ public function checkComposer() $this->command->info('Checking presence of Composer'); - return $this->composer(); + return $this->composer()->getBinary(); } /** @@ -156,7 +156,7 @@ public function checkPhpVersion() } $this->command->info('Checking PHP version'); - $version = $this->runLast($this->php('-r "print PHP_VERSION;"')); + $version = $this->bash->runLast($this->php()->version()); return version_compare($version, $required, '>='); } @@ -220,7 +220,7 @@ public function checkPhpExtension($extension) $this->command->info('Checking presence of '.$extension.' extension'); // Check for HHVM and built-in extensions - if ($this->usesHhvm()) { + if ($this->php()->isHhvm()) { $this->extensions = array( '_hhvm', 'apache', @@ -265,24 +265,9 @@ public function checkPhpExtension($extension) // Get the PHP extensions available if (!$this->extensions) { - $this->extensions = (array) $this->run($this->php('-m'), false, true); + $this->extensions = (array) $this->bash->run($this->php()->extensions(), false, true); } return in_array($extension, $this->extensions); } - - /** - * Check if we're using HHVM in production - * - * @return bool - */ - public function usesHhvm() - { - $version = $this->php('--version'); - $version = $this->runRaw($version, true); - $version = head($version); - $version = strtolower($version); - - return strpos($version, 'hiphop') !== false; - } } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 8fab20d98..9bedf6e0a 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -39,35 +39,28 @@ class Deploy extends AbstractTask */ public function execute() { - // Create halting events - $this->createEvents(); - // Setup if necessary if (!$this->isSetup()) { $this->command->error('Server is not ready, running Setup task'); $this->executeTask('Setup'); } - // Update current release + // Setup the new release $release = $this->releasesManager->getNextRelease(); - // Run halting methods - foreach ($this->halting as $method) { - if (!$this->fireEvent($method['as'])) { - return false; - } - list ($class, $method) = $method['on']; - if (!$class->$method()) { - return $this->halt(); - } + // Build and execute subtasks + $tasks = ['CreateRelease', 'Composer']; + if ($this->getOption('tests')) { + $tasks[] = 'Phpunit'; } + $this->executeTask($tasks); // Set permissions $this->setApplicationPermissions(); // Run migrations - $this->runMigrationsAndSeed(); + $this->executeTask('Artisan'); // Synchronize shared folders and files $this->syncSharedFolders(); @@ -84,57 +77,10 @@ public function execute() $this->command->info('Successfully deployed release '.$release); } - //////////////////////////////////////////////////////////////////// - /////////////////////////////// SUBTASKS /////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Run PHPUnit tests - */ - protected function checkTestsResults() - { - if ($this->getOption('tests') and !$this->runTests()) { - $this->command->error('Tests failed'); - - return false; - } - - return true; - } - - /** - * Run migrations and seed database - * - * @return string|null - */ - protected function runMigrationsAndSeed() - { - $seed = (bool) $this->getOption('seed'); - - if ($this->getOption('migrate')) { - return $this->runMigrations($seed); - } elseif ($seed) { - return $this->runSeed(); - } - } - //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Create the events Deploy will run - */ - protected function createEvents() - { - $strategy = $this->rocketeer->getOption('remote.strategy'); - $this->halting = array( - ['as' => $strategy.'Repository', 'on' => [$this->strategy, 'deploy']], - ['as' => 'runComposer', 'on' => [$this, 'runComposer']], - ['as' => 'checkTestsResults', 'on' => [$this, 'checkTestsResults']], - ); - } - /** * Set permissions for the folders used by the application * diff --git a/src/Rocketeer/Tasks/Subtasks/Artisan.php b/src/Rocketeer/Tasks/Subtasks/Artisan.php new file mode 100644 index 000000000..dd5f759fa --- /dev/null +++ b/src/Rocketeer/Tasks/Subtasks/Artisan.php @@ -0,0 +1,28 @@ +artisan(); + if (!$artisan->getBinary()) { + return; + } + + $seed = (bool) $this->getOption('seed'); + + if ($this->getOption('migrate')) { + return $artisan->runForCurrentRelease('migrate', $seed); + } elseif ($seed) { + return $artisan->runForCurrentRelease('seed'); + } + } +} diff --git a/src/Rocketeer/Tasks/Subtasks/Composer.php b/src/Rocketeer/Tasks/Subtasks/Composer.php new file mode 100644 index 000000000..8ef2e5570 --- /dev/null +++ b/src/Rocketeer/Tasks/Subtasks/Composer.php @@ -0,0 +1,39 @@ +composer(); + if (!$this->force and (!$composer->getBinary() or !$this->localStorage->usesComposer())) { + return true; + } + + // Get the Composer commands to run + $tasks = $this->rocketeer->getOption('remote.composer'); + if (!is_callable($tasks)) { + return true; + } + + // Cancel if no tasks to execute + $tasks = (array) $tasks($composer, $this); + if (empty($tasks)) { + return true; + } + + // Run commands + $this->command->info('Installing Composer dependencies'); + $this->runForCurrentRelease($tasks); + + return $this->checkStatus('Composer could not install dependencies'); + } +} diff --git a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php new file mode 100644 index 000000000..5720259c7 --- /dev/null +++ b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php @@ -0,0 +1,17 @@ +strategy->deploy(); + } +} diff --git a/src/Rocketeer/Tasks/Subtasks/Phpunit.php b/src/Rocketeer/Tasks/Subtasks/Phpunit.php new file mode 100644 index 000000000..b065bc764 --- /dev/null +++ b/src/Rocketeer/Tasks/Subtasks/Phpunit.php @@ -0,0 +1,35 @@ +phpunit(); + if (!$phpunit->getBinary()) { + return true; + } + + // Run PHPUnit + $this->command->info('Running tests'); + $arguments = ['--stop-on-failure' => null]; + $output = $this->runForCurrentRelease(array( + $phpunit->getCommand(null, [], $arguments), + )); + + $status = $this->checkStatus('Tests failed', $output, 'Tests passed successfully'); + if (!$status) { + $this->command->error('Tests failed'); + } + + return $status; + } +} diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index 4774cae48..58ffeff62 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -35,6 +35,6 @@ public function execute() // Update repository $this->command->info('Testing the application'); - return $this->runTests(); + return $this->executeTask('Phpunit'); } } diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 4208bdd36..e6cfa47ca 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -37,18 +37,16 @@ public function execute() $this->syncSharedFolders(); // Recompile dependencies and stuff - $this->runComposer(); + $this->executeTask('Composer'); // Set permissions $this->setApplicationPermissions(); // Run migrations - if ($this->getOption('migrate')) { - $this->runMigrations($this->getOption('seed')); - } + $this->executeTask('Artisan'); // Clear cache - $this->runForCurrentRelease($this->artisan('cache:clear')); + $this->artisan()->runForCurrentRelease('clearCache'); $this->command->info('Successfully updated application'); } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index ddea8d7da..fe7c1be0a 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -9,6 +9,8 @@ */ namespace Rocketeer\Traits\BashModules; +use Rocketeer\Binaries\AnonymousBinary; + /** * Handles finding and calling binaries * @@ -21,178 +23,83 @@ trait Binaries //////////////////////////////////////////////////////////////////// /** - * Prefix a command with the right path to PHP - * - * @param string|null $command - * - * @return string - */ - public function php($command = null) - { - $php = $this->which('php'); - - return trim($php.' '.$command); - } - - // Artisan - //////////////////////////////////////////////////////////////////// - - /** - * Prefix a command with the right path to Artisan - * - * @param string|null $command - * @param array $flags - * - * @return string - */ - public function artisan($command = null, $flags = array()) - { - $artisan = $this->which('artisan', $this->releasesManager->getCurrentReleasePath().'/artisan') ?: 'artisan'; - foreach ($flags as $name => $value) { - $command .= ' --'.$name; - $command .= $value ? '="'.$value.'"' : ''; - } - - return $this->php($artisan.' '.$command); - } - - /** - * Run an artisan command + * Get an AnonymousBinary instance * - * @param string|null $command - * @param array $flags + * @param string $binary * - * @return string + * @return \Rocketeer\Abstracts\AbstractBinary */ - public function runArtisan($command = null, $flags = array()) + public function binary($binary) { - // Check if the seeds/migration need to be forced - $forced = array('migrate', 'db:seed'); - if (in_array($command, $forced) && $this->versionCheck('4.2.0')) { - $flags['force'] = ''; + // Check for an existing Binary + $existing = sprintf('Rocketeer\Binaries\%s', ucfirst($binary)); + if (class_exists($existing)) { + return new $existing($this->app); } - // Create full command - $command = $this->artisan($command, $flags); + // Else wrap the command in an AnonymousBinary + $anonymous = new AnonymousBinary($this->app); + $anonymous->setBinary($binary); - return $this->runForCurrentRelease($command); + return $binary; } /** - * Run any outstanding migrations - * - * @param boolean $seed Whether the database should also be seeded + * Prefix a command with the right path to PHP * - * @return string + * @return \Rocketeer\Binaries\Php */ - public function runMigrations($seed = false) + public function php() { - $this->command->comment('Running outstanding migrations'); - $flags = $seed ? array('seed' => '') : array(); - - return $this->runArtisan('migrate', $flags); + return $this->binary('php'); } /** - * Seed the database - * - * @param string|null $class A class to seed + * Prefix a command with the right path to Composer * - * @return string + * @return \Rocketeer\Binaries\Composer */ - public function runSeed($class = null) + public function composer() { - $this->command->comment('Seeding database'); - $flags = $class ? array('class' => $class) : array(); - - return $this->runArtisan('db:seed', $flags); + return $this->binary('composer'); } - // PHPUnit - //////////////////////////////////////////////////////////////////// - /** - * Run the application's tests - * - * @param string|null $arguments Additional arguments to pass to PHPUnit - * - * @return boolean + * @return \Rocketeer\Binaries\Phpunit */ - public function runTests($arguments = null) + public function phpunit() { - // Look for PHPUnit - $phpunit = $this->which('phpunit', $this->releasesManager->getCurrentReleasePath().'/vendor/bin/phpunit'); - if (!$phpunit) { - return true; - } - - // Run PHPUnit - $this->command->info('Running tests...'); - $output = $this->runForCurrentRelease(array( - $phpunit.' --stop-on-failure '.$arguments, - )); - - return $this->checkStatus('Tests failed', $output, 'Tests passed successfully'); + return $this->binary('phpunit'); } - // Composer - //////////////////////////////////////////////////////////////////// - /** - * Prefix a command with the right path to Composer - * - * @param string|null $command - * - * @return string + * @return \Rocketeer\Binaries\Artisan */ - public function composer($command = null) + public function artisan() { - $composer = $this->which('composer', $this->releasesManager->getCurrentReleasePath().'/composer.phar'); - - // Prepend PHP command - if (strpos($composer, 'composer.phar') !== false) { - $composer = $this->php($composer); - } - - return trim($composer.' '.$command); + return $this->binary('artisan'); } /** - * Run Composer on the folder + * Run an artisan command * - * @param boolean $force + * @param string|null $command + * @param array $flags * * @return string */ - public function runComposer($force = false) + public function runArtisan($command = null, $flags = array()) { - if (!$this->localStorage->usesComposer() and !$force) { - return true; - } - - // Find Composer - $composer = $this->composer(); - if (!$composer) { - return true; - } - - // Get the Composer commands to run - $tasks = $this->rocketeer->getOption('remote.composer'); - if (!is_callable($tasks)) { - return true; - } - - // Cancel if no tasks to execute - $tasks = (array) $tasks($this); - if (empty($tasks)) { - return true; + // Check if the seeds/migration need to be forced + $forced = array('migrate', 'db:seed'); + if (in_array($command, $forced) && $this->versionCheck('4.2.0')) { + $flags['force'] = ''; } - // Run commands - $this->command->info('Installing Composer dependencies'); - $this->runForCurrentRelease($tasks); + // Create full command + $command = $this->artisan($command, $flags); - return $this->checkStatus('Composer could not install dependencies'); + return $this->runForCurrentRelease($command); } //////////////////////////////////////////////////////////////////// @@ -200,14 +107,15 @@ public function runComposer($force = false) //////////////////////////////////////////////////////////////////// /** - * Get a binary + * Get the path to a binary * - * @param string $binary The name of the binary - * @param string|null $fallback A fallback location + * @param string $binary The name of the binary + * @param string|null $fallback A fallback location + * @param string|boolean $default A last resort place to use as binary * * @return string */ - public function which($binary, $fallback = null) + public function which($binary, $fallback = null, $default = false) { $location = false; $locations = array( @@ -239,7 +147,7 @@ public function which($binary, $fallback = null) // Store found location $this->localStorage->set('paths.'.$binary, $location); - return $location ?: false; + return $location ?: $default; } /** diff --git a/src/config/remote.php b/src/config/remote.php index ee9b05fc3..3baba9c33 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -1,4 +1,7 @@ - function ($task) { + 'composer' => function (Composer $composer, Task $task) { return array( - // $task->composer('self-update'), - $task->composer('install --no-interaction --no-dev --prefer-dist'), + // $composer->selfUpdate(), + $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]), ); }, diff --git a/tests/Abstracts/AbstractBinaryTest.php b/tests/Abstracts/AbstractBinaryTest.php index d0b70ea28..19d08fca6 100644 --- a/tests/Abstracts/AbstractBinaryTest.php +++ b/tests/Abstracts/AbstractBinaryTest.php @@ -15,7 +15,7 @@ public function testCanExecuteMethod() }); $scm = new Git($this->app); - $command = $scm->execute('checkout', $this->server); + $command = $scm->run('checkout', $this->server); $expected = $this->replaceHistoryPlaceholders(['git clone "{repository}" "{server}" --branch="master" --depth="1"']); $this->assertEquals($expected[0], $command); diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 1d1523a5c..9b6e16e84 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -33,18 +33,6 @@ public function testCanGetDescription() $this->assertNotNull($task->getDescription()); } - public function testCanRunMigrations() - { - $task = $this->pretendTask(); - $php = exec('which php'); - - $commands = $task->runMigrations(); - $this->assertEquals($php.' artisan migrate', $commands[1]); - - $commands = $task->runMigrations(true); - $this->assertEquals($php.' artisan migrate --seed', $commands[1]); - } - public function testCanFireEventsDuringTasks() { $this->expectOutputString('foobar'); diff --git a/tests/Binaries/ArtisanTest.php b/tests/Binaries/ArtisanTest.php new file mode 100644 index 000000000..15b1ecb9e --- /dev/null +++ b/tests/Binaries/ArtisanTest.php @@ -0,0 +1,20 @@ +app); + + $commands = $artisan->migrate(); + $this->assertEquals($php.' artisan migrate', $commands); + + $commands = $artisan->migrate(true); + $this->assertEquals($php.' artisan migrate --seed', $commands); + } +} diff --git a/tests/Binaries/PhpTest.php b/tests/Binaries/PhpTest.php new file mode 100644 index 000000000..0fd229553 --- /dev/null +++ b/tests/Binaries/PhpTest.php @@ -0,0 +1,17 @@ +app); + $hhvm = $php->isHhvm(); + $defined = defined('HHVM_VERSION'); + + $this->assertEquals($defined, $hhvm); + } +} diff --git a/tests/Services/Tasks/JobTest.php b/tests/Services/Tasks/JobTest.php index 62ed3de72..5fee74af7 100644 --- a/tests/Services/Tasks/JobTest.php +++ b/tests/Services/Tasks/JobTest.php @@ -7,6 +7,8 @@ class JobTest extends RocketeerTestCase { public function testCanCreateBasicJob() { + $this->swapConfig(['rocketeer::default' => ['production', 'staging']]); + $pipeline = $this->queue->buildPipeline(['ls']); $this->assertInstanceOf('Illuminate\Support\Collection', $pipeline); diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index 03d112c9d..8a540e2f8 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -58,12 +58,4 @@ public function testCanCheckForHhvmExtensions() $this->assertTrue($exists); } - - public function testCanCheckIfUsesHhvm() - { - $hhvm = $this->task('Check')->usesHhvm(); - $defined = defined('HHVM_VERSION'); - - $this->assertEquals($defined, $hhvm); - } } diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 5f5dc584f..00260151a 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -21,7 +21,7 @@ public function testCanDeployToServer() ), array( "cd {server}/releases/{release}", - exec('which phpunit')." --stop-on-failure " + exec('which phpunit')." --stop-on-failure" ), array( "cd {server}/releases/{release}", @@ -63,7 +63,7 @@ public function testCanDisableGitOptions() 'git clone "{repository}" "{server}/releases/{release}" --branch="master"', array( "cd {server}/releases/{release}", - exec('which phpunit')." --stop-on-failure " + exec('which phpunit').' --stop-on-failure' ), array( "cd {server}/releases/{release}", @@ -97,10 +97,10 @@ public function testCanConfigureComposerCommands() 'username' => '', 'password' => '', ), - 'rocketeer::remote.composer' => function ($task) { + 'rocketeer::remote.composer' => function ($composer, $task) { return array( - $task->composer('self-update'), - $task->composer('install --prefer-source'), + $composer->selfUpdate(), + $composer->install([], '--prefer-source'), ); }, )); @@ -113,10 +113,11 @@ public function testCanConfigureComposerCommands() ), ); - $deploy = $this->pretendTask('Deploy'); - $deploy->runComposer(true); + $composer = $this->pretendTask('Composer'); + $composer->force = true; + $composer->fire(); - $this->assertTaskHistory($deploy->history->getFlattenedHistory(), $matcher, array( + $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( 'tests' => false, 'seed' => false, 'migrate' => false diff --git a/tests/Tasks/TestTest.php b/tests/Tasks/Subtasks/PhpunitTest.php similarity index 50% rename from tests/Tasks/TestTest.php rename to tests/Tasks/Subtasks/PhpunitTest.php index 0a0e833da..3ef2c72b2 100644 --- a/tests/Tasks/TestTest.php +++ b/tests/Tasks/Subtasks/PhpunitTest.php @@ -1,16 +1,16 @@ assertTaskHistory('Test', array( + $this->assertTaskHistory('Phpunit', array( array( 'cd {server}/releases/20000000000000', - '{phpunit} --stop-on-failure ', + '{phpunit} --stop-on-failure', ), )); } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index ff238e167..a71c129c7 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -172,7 +172,7 @@ protected function getConfig($expectations = array()) // Rocketeer $config->shouldReceive('get')->with('rocketeer::application_name')->andReturn('foobar'); - $config->shouldReceive('get')->with('rocketeer::default')->andReturn(array('production', 'staging')); + $config->shouldReceive('get')->with('rocketeer::default')->andReturn(array('production')); $config->shouldReceive('get')->with('rocketeer::logs')->andReturn(false); $config->shouldReceive('get')->with('rocketeer::connections')->andReturn(array()); $config->shouldReceive('get')->with('rocketeer::remote.strategy')->andReturn('clone'); @@ -188,10 +188,10 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('rocketeer::remote.root_directory')->andReturn(__DIR__.'/../_server/'); $config->shouldReceive('get')->with('rocketeer::remote.app_directory')->andReturn(null); $config->shouldReceive('get')->with('rocketeer::remote.shared')->andReturn(array('tests/Elements')); - $config->shouldReceive('get')->with('rocketeer::remote.composer')->andReturn(function ($task) { + $config->shouldReceive('get')->with('rocketeer::remote.composer')->andReturn(function ($composer) { return array( - $task->composer('self-update'), - $task->composer('install --no-interaction --no-dev --prefer-dist'), + $composer->selfUpdate(), + $composer->install(null, '--no-interaction --no-dev --prefer-dist'), ); }); $config->shouldReceive('get')->with('rocketeer::stages.default')->andReturn(null); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 66724de4e..eb7071f21 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -234,7 +234,7 @@ protected function task($task = null, $options = array()) return $this->task; } - return $this->builder->buildTaskFromClass('Rocketeer\Tasks\\'.$task); + return $this->builder->buildTaskFromClass($task); } /** diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 72669bd9d..7dd40abf0 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -19,7 +19,7 @@ public function testCanSetPathToPhpAndArtisan() 'rocketeer::paths.artisan' => './laravel/artisan', )); - $this->assertEquals('/usr/local/bin/php ./laravel/artisan migrate', $this->task->artisan('migrate')); + $this->assertEquals('/usr/local/bin/php ./laravel/artisan migrate', $this->task->artisan()->migrate()); } public function testFetchesBinaryIfNotSpecifiedOrNull() @@ -28,7 +28,7 @@ public function testFetchesBinaryIfNotSpecifiedOrNull() 'rocketeer::paths.php' => '/usr/local/bin/php', )); - $this->assertEquals('/usr/local/bin/php artisan migrate', $this->task->artisan('migrate')); + $this->assertEquals('/usr/local/bin/php artisan migrate', $this->task->artisan()->migrate()); } public function testCanGetBinary() @@ -53,11 +53,12 @@ public function testCanRunComposer() $this->usesComposer(true); $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock + ->shouldReceive('line') ->shouldReceive('option')->andReturn([]) ->shouldReceive('info')->once(); }); - $this->task->runComposer(); + $this->task('Composer')->execute(); } public function testDoesntRunComposerIfNotNeeded() @@ -65,10 +66,11 @@ public function testDoesntRunComposerIfNotNeeded() $this->usesComposer(false); $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock + ->shouldReceive('line') ->shouldReceive('option')->andReturn([]) ->shouldReceive('info')->never(); }); - $this->task->runComposer(); + $this->task('Composer')->execute(); } } From c18634ffb4aa914c1cc7240fb4c7a727c38897b3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 00:24:57 +0200 Subject: [PATCH 181/424] Add some tests --- src/Rocketeer/Binaries/Composer.php | 16 +++++- src/Rocketeer/Services/ReleasesManager.php | 12 ----- tests/Abstracts/AbstractTaskTest.php | 17 ++++++ tests/Binaries/AnonymousBinaryTest.php | 16 ++++++ tests/Binaries/ComposerTest.php | 16 ++++++ tests/Tasks/DeployTest.php | 35 ------------ tests/Tasks/Subtasks/ComposerTes.php | 62 ++++++++++++++++++++++ 7 files changed, 125 insertions(+), 49 deletions(-) create mode 100644 tests/Binaries/AnonymousBinaryTest.php create mode 100644 tests/Binaries/ComposerTest.php create mode 100644 tests/Tasks/Subtasks/ComposerTes.php diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php index 9b3d7e5be..e01a1103e 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/Composer.php @@ -13,12 +13,24 @@ public function __construct(Container $app) { parent::__construct($app); - // Set binary path - $this->binary = $this->bash->which( + $binary = $this->bash->which( 'composer', $this->releasesManager->getCurrentReleasePath().'/composer.phar' ); + // Set binary path + $this->setBinary($binary); + } + + /** + * Change Composer's binary + * + * @param string $binary + */ + public function setBinary($binary) + { + parent::setBinary($binary); + // Prepend PHP command if executing from archive if (strpos($this->getBinary(), 'composer.phar') !== false) { $php = new Php($this->app); diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 3b7a6d360..7a2dca52d 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -200,18 +200,6 @@ public function getValidationFile() return $releases; } - /** - * Update the contents of the validation file - * - * @param array $validation - */ - public function saveValidationFile(array $validation) - { - $this->storage->set($validation); - - $this->state = $validation; - } - /** * Mark a release as valid * diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 9b6e16e84..5df9cad41 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -80,4 +80,21 @@ function () { $task = $this->pretendTask('Deploy'); $task->fire(); } + + public function testCanListenToSubtasks() + { + $this->swapConfig(array( + 'rocketeer::hooks' => [], + )); + + $this->tasks->listenTo('composer.before', ['ls']); + + $this->pretendTask('Deploy')->fire(); + + $history = $this->history->getFlattenedOutput(); + $this->assertHistory(array( + 'cd {server}/releases/{release}', + 'ls', + ), $history[4]); + } } diff --git a/tests/Binaries/AnonymousBinaryTest.php b/tests/Binaries/AnonymousBinaryTest.php new file mode 100644 index 000000000..a9e8c8fbd --- /dev/null +++ b/tests/Binaries/AnonymousBinaryTest.php @@ -0,0 +1,16 @@ +app); + $anonymous->setBinary('foobar'); + + $this->assertEquals('foobar foo bar --lol', $anonymous->foo('bar', '--lol')); + } +} diff --git a/tests/Binaries/ComposerTest.php b/tests/Binaries/ComposerTest.php new file mode 100644 index 000000000..b652c074b --- /dev/null +++ b/tests/Binaries/ComposerTest.php @@ -0,0 +1,16 @@ +app); + $composer->setBinary('composer.phar'); + + $this->assertEquals(exec('which php').' composer.phar install', $composer->install()); + } +} diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 00260151a..9b0edd700 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -89,41 +89,6 @@ public function testCanDisableGitOptions() )); } - public function testCanConfigureComposerCommands() - { - $this->swapConfig(array( - 'rocketeer::scm' => array( - 'repository' => 'https://github.com/'.$this->repository, - 'username' => '', - 'password' => '', - ), - 'rocketeer::remote.composer' => function ($composer, $task) { - return array( - $composer->selfUpdate(), - $composer->install([], '--prefer-source'), - ); - }, - )); - - $matcher = array( - array( - "cd {server}/releases/{release}", - "{composer} self-update", - "{composer} install --prefer-source", - ), - ); - - $composer = $this->pretendTask('Composer'); - $composer->force = true; - $composer->fire(); - - $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( - 'tests' => false, - 'seed' => false, - 'migrate' => false - )); - } - public function testCanUseCopyStrategy() { $this->swapConfig(array( diff --git a/tests/Tasks/Subtasks/ComposerTes.php b/tests/Tasks/Subtasks/ComposerTes.php new file mode 100644 index 000000000..cc1618466 --- /dev/null +++ b/tests/Tasks/Subtasks/ComposerTes.php @@ -0,0 +1,62 @@ +swapConfig(array( + 'rocketeer::scm' => array( + 'repository' => 'https://github.com/'.$this->repository, + 'username' => '', + 'password' => '', + ), + 'rocketeer::remote.composer' => function ($composer, $task) { + return array( + $composer->selfUpdate(), + $composer->install([], '--prefer-source'), + ); + }, + )); + + $matcher = array( + array( + "cd {server}/releases/{release}", + "{composer} self-update", + "{composer} install --prefer-source", + ), + ); + + $composer = $this->pretendTask('Composer'); + $composer->force = true; + $composer->fire(); + + $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( + 'tests' => false, + 'seed' => false, + 'migrate' => false + )); + } + + public function testCancelsIfInvalidComposerRoutine() + { + $composer = $this->pretendTask('Composer'); + $composer->force = true; + + $this->swapConfig(array( + 'rocketeer::remote.composer' => 'lol', + )); + + $composer->fire(); + $this->assertEmpty($this->history->getFlattenedHistory()); + + $this->swapConfig(array( + 'rocketeer::remote.composer' => function() { return []; }, + )); + + $composer->fire(); + $this->assertEmpty($this->history->getFlattenedHistory()); + } +} From fa4104333bd9251ae7c48a6ad4bc1ee2814d5284 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 01:32:20 +0200 Subject: [PATCH 182/424] Fix warning --- src/Rocketeer/Services/Tasks/TasksQueue.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 2fbad1224..b3b2c6328 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -207,6 +207,7 @@ protected function executeJob(Job $job) */ protected function runSynchronously(Collection $pipeline) { + /** @type Closure $task */ foreach ($pipeline as $task) { if (!$task()) { return false; From e6c93d6c6e577c39e104db062bf26484989c522d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 02:28:21 +0200 Subject: [PATCH 183/424] Work on decoupling global task from their implementations --- src/Rocketeer/Abstracts/AbstractStrategy.php | 31 +++++++++++-- src/Rocketeer/Abstracts/AbstractTask.php | 43 +++++++++++++------ .../DeployStrategyInterface.php} | 4 +- .../Strategies/MigrateStrategyInterface.php | 24 +++++++++++ .../Strategies/TestStrategyInterface.php | 12 ++++++ src/Rocketeer/RocketeerServiceProvider.php | 15 ++++--- .../Strategies/ArtisanMigrateStrategy.php | 28 ++++++++++++ ...neStrategy.php => CloneDeployStrategy.php} | 4 +- ...opyStrategy.php => CopyDeployStrategy.php} | 4 +- .../PhpunitTestStrategy.php} | 22 +++++++--- src/Rocketeer/Tasks/Deploy.php | 7 ++- src/Rocketeer/Tasks/Migrate.php | 25 +++++++++++ src/Rocketeer/Tasks/Subtasks/Artisan.php | 28 ------------ .../Tasks/Subtasks/CreateRelease.php | 2 +- src/Rocketeer/Tasks/Test.php | 5 +-- src/Rocketeer/Tasks/Update.php | 4 +- src/Rocketeer/Traits/HasLocator.php | 8 ++-- src/config/remote.php | 6 --- src/config/strategies.php | 18 ++++++++ tests/Binaries/ArtisanTest.php | 3 -- tests/Strategies/CloneStrategyTest.php | 4 +- tests/Strategies/CopyStrategyTest.php | 4 +- tests/Tasks/DeployTest.php | 18 ++++++-- tests/Tasks/Subtasks/PhpunitTest.php | 2 +- tests/Tasks/UpdateTest.php | 8 +++- tests/TestCases/ContainerTestCase.php | 6 ++- tests/Traits/BashModules/ScmTest.php | 2 +- 27 files changed, 239 insertions(+), 98 deletions(-) rename src/Rocketeer/Interfaces/{StrategyInterface.php => Strategies/DeployStrategyInterface.php} (89%) create mode 100644 src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php create mode 100644 src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php create mode 100644 src/Rocketeer/Strategies/ArtisanMigrateStrategy.php rename src/Rocketeer/Strategies/{CloneStrategy.php => CloneDeployStrategy.php} (90%) rename src/Rocketeer/Strategies/{CopyStrategy.php => CopyDeployStrategy.php} (86%) rename src/Rocketeer/{Tasks/Subtasks/Phpunit.php => Strategies/PhpunitTestStrategy.php} (63%) create mode 100644 src/Rocketeer/Tasks/Migrate.php delete mode 100644 src/Rocketeer/Tasks/Subtasks/Artisan.php create mode 100644 src/config/strategies.php diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php index d7b9bb60a..64fb895ff 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -1,14 +1,39 @@ command) { + return; + } + + $components = get_class($this); + $components = class_basename($components); + $components = Str::snake($components); + $components = explode('_', $components); + + $name = array_get($components, 0); + $strategy = array_get($components, 1); + $comment = sprintf('==> Running strategy for %s: %s', ucfirst($strategy), ucfirst($name)); + + $this->command->line($comment); + } } diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 6f8fcfcc6..e80be8800 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -202,6 +202,37 @@ public function getQualifiedEvent($event) return 'rocketeer.'.$this->getSlug().'.'.$event; } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// RUNNERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the implementation behind a strategy + * + * @param string $strategy + * + * @return \Rocketeer\Abstracts\AbstractStrategy + */ + public function getStrategy($strategy) + { + $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; + $strategy->displayStatus(); + + return $strategy; + } + + /** + * Execute another AbstractTask by name + * + * @param string|string[] $tasks + * + * @return string|false + */ + public function executeTask($tasks) + { + return $this->queue->run($tasks); + } + //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// @@ -245,18 +276,6 @@ protected function displayReleases() return $rows; } - /** - * Execute another AbstractTask by name - * - * @param string|string[] $tasks - * - * @return string|false - */ - public function executeTask($tasks) - { - return $this->queue->run($tasks); - } - /** * Display what the command is and does */ diff --git a/src/Rocketeer/Interfaces/StrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/DeployStrategyInterface.php similarity index 89% rename from src/Rocketeer/Interfaces/StrategyInterface.php rename to src/Rocketeer/Interfaces/Strategies/DeployStrategyInterface.php index 083802bc4..573e507b2 100644 --- a/src/Rocketeer/Interfaces/StrategyInterface.php +++ b/src/Rocketeer/Interfaces/Strategies/DeployStrategyInterface.php @@ -7,14 +7,14 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Interfaces; +namespace Rocketeer\Interfaces\Strategies; /** * Interface for the various deployment strategies * * @author Maxime Fabre */ -interface StrategyInterface +interface DeployStrategyInterface { /** * Deploy a new clean copy of the application diff --git a/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php new file mode 100644 index 000000000..1e342b637 --- /dev/null +++ b/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php @@ -0,0 +1,24 @@ + + */ +interface MigrateStrategyInterface +{ + /** + * Run outstanding migrations + * + * @return boolean + */ + public function migrate(); + + /** + * Seed the database + * + * @return boolean + */ + public function seed(); +} diff --git a/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php new file mode 100644 index 000000000..c869d4efc --- /dev/null +++ b/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php @@ -0,0 +1,12 @@ +app->bind('rocketeer.strategy', function ($app) { - $strategy = $app['rocketeer.rocketeer']->getOption('remote.strategy'); - $strategy = sprintf('Rocketeer\Strategies\%sStrategy', ucfirst($strategy)); - - return new $strategy($app); - }); + // Bind strategies + $strategies = $this->app['rocketeer.rocketeer']->getOption('strategies'); + foreach ($strategies as $strategy => $implementation) { + $concrete = sprintf('Rocketeer\Strategies\%s%sStrategy', $implementation, ucfirst($strategy)); + $this->app->bind('rocketeer.strategies.'.$strategy, function ($app) use ($strategy, $concrete) { + return new $concrete($app); + }); + } } /** diff --git a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php new file mode 100644 index 000000000..e09366260 --- /dev/null +++ b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php @@ -0,0 +1,28 @@ +artisan()->runForCurrentRelease('migrate'); + } + + /** + * Seed the database + * + * @return boolean + */ + public function seed() + { + $this->artisan()->runForCurrentRelease('db:seed'); + } +} diff --git a/src/Rocketeer/Strategies/CloneStrategy.php b/src/Rocketeer/Strategies/CloneDeployStrategy.php similarity index 90% rename from src/Rocketeer/Strategies/CloneStrategy.php rename to src/Rocketeer/Strategies/CloneDeployStrategy.php index 81b2a8756..7afe088ea 100644 --- a/src/Rocketeer/Strategies/CloneStrategy.php +++ b/src/Rocketeer/Strategies/CloneDeployStrategy.php @@ -2,9 +2,9 @@ namespace Rocketeer\Strategies; use Rocketeer\Abstracts\AbstractStrategy; -use Rocketeer\Interfaces\StrategyInterface; +use Rocketeer\Interfaces\Strategies\DeployStrategyInterface; -class CloneStrategy extends AbstractStrategy implements StrategyInterface +class CloneDeployStrategy extends AbstractStrategy implements DeployStrategyInterface { /** * Deploy a new clean copy of the application diff --git a/src/Rocketeer/Strategies/CopyStrategy.php b/src/Rocketeer/Strategies/CopyDeployStrategy.php similarity index 86% rename from src/Rocketeer/Strategies/CopyStrategy.php rename to src/Rocketeer/Strategies/CopyDeployStrategy.php index 2245af4d4..e0fb6e6cc 100644 --- a/src/Rocketeer/Strategies/CopyStrategy.php +++ b/src/Rocketeer/Strategies/CopyDeployStrategy.php @@ -1,9 +1,9 @@ phpunit(); @@ -19,7 +20,6 @@ public function execute() } // Run PHPUnit - $this->command->info('Running tests'); $arguments = ['--stop-on-failure' => null]; $output = $this->runForCurrentRelease(array( $phpunit->getCommand(null, [], $arguments), @@ -32,4 +32,14 @@ public function execute() return $status; } + + /** + * Run the task + * + * @return string + */ + public function execute() + { + // ... + } } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 9bedf6e0a..38bf2970b 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -50,17 +50,16 @@ public function execute() // Build and execute subtasks - $tasks = ['CreateRelease', 'Composer']; + $this->executeTask(['CreateRelease', 'Composer']); if ($this->getOption('tests')) { - $tasks[] = 'Phpunit'; + $this->executeTask('Test'); } - $this->executeTask($tasks); // Set permissions $this->setApplicationPermissions(); // Run migrations - $this->executeTask('Artisan'); + $this->executeTask('Migrate'); // Synchronize shared folders and files $this->syncSharedFolders(); diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php new file mode 100644 index 000000000..9ab9158a8 --- /dev/null +++ b/src/Rocketeer/Tasks/Migrate.php @@ -0,0 +1,25 @@ +getStrategy('Migrate'); + + if ($this->getOption('migrate')) { + $strategy->migrate(); + } + + if ($this->getOption('seed')) { + $strategy->seed(); + } + } +} diff --git a/src/Rocketeer/Tasks/Subtasks/Artisan.php b/src/Rocketeer/Tasks/Subtasks/Artisan.php deleted file mode 100644 index dd5f759fa..000000000 --- a/src/Rocketeer/Tasks/Subtasks/Artisan.php +++ /dev/null @@ -1,28 +0,0 @@ -artisan(); - if (!$artisan->getBinary()) { - return; - } - - $seed = (bool) $this->getOption('seed'); - - if ($this->getOption('migrate')) { - return $artisan->runForCurrentRelease('migrate', $seed); - } elseif ($seed) { - return $artisan->runForCurrentRelease('seed'); - } - } -} diff --git a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php index 5720259c7..0768f1d43 100644 --- a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php +++ b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php @@ -12,6 +12,6 @@ class CreateRelease extends AbstractTask */ public function execute() { - return $this->strategy->deploy(); + return $this->getStrategy('Deploy')->deploy(); } } diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index 58ffeff62..58ba8f644 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -32,9 +32,6 @@ class Test extends AbstractTask */ public function execute() { - // Update repository - $this->command->info('Testing the application'); - - return $this->executeTask('Phpunit'); + return $this->getStrategy('Test')->test(); } } diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index e6cfa47ca..e1876d340 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -31,7 +31,7 @@ class Update extends Deploy public function execute() { // Update repository - $this->strategy->update(); + $this->getStrategy('Deploy')->update(); // Recreate symlinks if necessary $this->syncSharedFolders(); @@ -43,7 +43,7 @@ public function execute() $this->setApplicationPermissions(); // Run migrations - $this->executeTask('Artisan'); + $this->executeTask('Migrate'); // Clear cache $this->artisan()->runForCurrentRelease('clearCache'); diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 6efff9328..4e7d9e5b6 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -14,8 +14,10 @@ /** * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes - * - * @property \Illuminate\Config\Repository config + + +* +*@property \Illuminate\Config\Repository config * @property \Illuminate\Events\Dispatcher events * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Log\Writer log @@ -24,7 +26,7 @@ * @property \Rocketeer\Bash bash * @property \Rocketeer\Console\Console console * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\StrategyInterface strategy + * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Services\ConnectionsHandler connections * @property \Rocketeer\Services\CredentialsGatherer credentials diff --git a/src/config/remote.php b/src/config/remote.php index 3baba9c33..c3336b78c 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -3,12 +3,6 @@ return array( - // The strategy to deploy with - // Availables are: - // - clone | Clones the repository from scratch on every deploy - // - copy | Copies the previous release and then updates it - 'strategy' => 'clone', - // Remote server ////////////////////////////////////////////////////////////////////// diff --git a/src/config/strategies.php b/src/config/strategies.php new file mode 100644 index 000000000..cf17383c9 --- /dev/null +++ b/src/config/strategies.php @@ -0,0 +1,18 @@ + 'Clone', + + // Which strategy to use to test your application + 'test' => 'Phpunit', + + // Which strategy to use to migrate your database + 'migrate' => 'Artisan', + +); diff --git a/tests/Binaries/ArtisanTest.php b/tests/Binaries/ArtisanTest.php index 15b1ecb9e..ad3988a87 100644 --- a/tests/Binaries/ArtisanTest.php +++ b/tests/Binaries/ArtisanTest.php @@ -13,8 +13,5 @@ public function testCanRunMigrations() $commands = $artisan->migrate(); $this->assertEquals($php.' artisan migrate', $commands); - - $commands = $artisan->migrate(true); - $this->assertEquals($php.' artisan migrate --seed', $commands); } } diff --git a/tests/Strategies/CloneStrategyTest.php b/tests/Strategies/CloneStrategyTest.php index 3a07eedff..85e545fd8 100644 --- a/tests/Strategies/CloneStrategyTest.php +++ b/tests/Strategies/CloneStrategyTest.php @@ -8,7 +8,7 @@ class CloneStrategyTest extends RocketeerTestCase public function testCanDeployRepository() { $task = $this->pretendTask('Deploy'); - $task->strategy->deploy(); + $task->getStrategy('Deploy')->deploy(); $matcher = array( 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', @@ -24,7 +24,7 @@ public function testCanDeployRepository() public function testCanUpdateRepository() { $task = $this->pretendTask('Deploy'); - $task->strategy->update(); + $task->getStrategy('Deploy')->update(); $matcher = array( array( diff --git a/tests/Strategies/CopyStrategyTest.php b/tests/Strategies/CopyStrategyTest.php index 4985ef57d..a6a65ea99 100644 --- a/tests/Strategies/CopyStrategyTest.php +++ b/tests/Strategies/CopyStrategyTest.php @@ -2,7 +2,7 @@ namespace Strategies; use Mockery\MockInterface; -use Rocketeer\Strategies\CopyStrategy; +use Rocketeer\Strategies\CopyDeployStrategy; use Rocketeer\TestCases\RocketeerTestCase; class CopyStrategyTest extends RocketeerTestCase @@ -12,7 +12,7 @@ public function setUp() parent::setUp(); $this->app->bind('rocketeer.strategy', function ($app) { - return new CopyStrategy($app); + return new CopyDeployStrategy($app); }); $this->pretend(); diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 9b0edd700..6bbaee43d 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -1,6 +1,7 @@ swapConfig(array( - 'rocketeer::remote.strategy' => 'copy', - 'rocketeer::scm' => array( + 'rocketeer::scm' => array( 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', ) )); + $this->app['rocketeer.strategies.deploy'] = new CopyDeployStrategy($this->app); + $this->mockState(array( '10000000000000' => true, )); diff --git a/tests/Tasks/Subtasks/PhpunitTest.php b/tests/Tasks/Subtasks/PhpunitTest.php index 3ef2c72b2..a2dffd88c 100644 --- a/tests/Tasks/Subtasks/PhpunitTest.php +++ b/tests/Tasks/Subtasks/PhpunitTest.php @@ -7,7 +7,7 @@ class PhpunitTest extends RocketeerTestCase { public function testCanRunTests() { - $this->assertTaskHistory('Phpunit', array( + $this->assertTaskHistory('Test', array( array( 'cd {server}/releases/20000000000000', '{phpunit} --stop-on-failure', diff --git a/tests/Tasks/UpdateTest.php b/tests/Tasks/UpdateTest.php index 08d4fc25c..e2741a1d3 100644 --- a/tests/Tasks/UpdateTest.php +++ b/tests/Tasks/UpdateTest.php @@ -27,8 +27,12 @@ public function testCanUpdateRepository() "chown -R www-data:www-data {server}/releases/20000000000000/tests" ), array( - "cd {server}/releases/20000000000000", - "{php} artisan migrate --seed" + "cd {server}/releases/{release}", + "{php} artisan migrate" + ), + array( + "cd {server}/releases/{release}", + "{php} artisan db:seed" ), array( "cd {server}/releases/20000000000000", diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index a71c129c7..ec2e1163b 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -175,7 +175,6 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('rocketeer::default')->andReturn(array('production')); $config->shouldReceive('get')->with('rocketeer::logs')->andReturn(false); $config->shouldReceive('get')->with('rocketeer::connections')->andReturn(array()); - $config->shouldReceive('get')->with('rocketeer::remote.strategy')->andReturn('clone'); $config->shouldReceive('get')->with('rocketeer::remote.keep_releases')->andReturn(1); $config->shouldReceive('get')->with('rocketeer::remote.permissions.callback')->andReturn(function ($task, $file) { return array( @@ -215,6 +214,11 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('rocketeer::scm.scm')->andReturn('git'); $config->shouldReceive('get')->with('rocketeer::scm.shallow')->andReturn(true); $config->shouldReceive('get')->with('rocketeer::scm.submodules')->andReturn(true); + $config->shouldReceive('get')->with('rocketeer::strategies')->andReturn(array( + 'deploy' => 'Clone', + 'test' => 'Phpunit', + 'migrate' => 'Artisan', + )); // Tasks $config->shouldReceive('get')->with('rocketeer::hooks')->andReturn(array( diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index 3a61b5924..0de1acc05 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -20,7 +20,7 @@ public function testCanForgetCredentialsIfInvalid() $task = $this->pretendTask(); $task->remote = $remote; - $task->strategy->deploy($this->server.'/test'); + $task->getStrategy('Deploy')->deploy($this->server.'/test'); $this->assertNull($this->app['rocketeer.storage.local']->get('credentials')); } } From ff590856b23983e7022ed1e122f68930b5c770d1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 02:53:46 +0200 Subject: [PATCH 184/424] Work on status levels --- src/Rocketeer/Abstracts/AbstractCommand.php | 40 ++++++++++++++++++- src/Rocketeer/Abstracts/AbstractStrategy.php | 4 +- src/Rocketeer/Abstracts/AbstractTask.php | 24 +++++++++-- src/Rocketeer/Scm/Git.php | 1 - .../Strategies/CloneDeployStrategy.php | 6 +-- .../Strategies/CopyDeployStrategy.php | 2 +- src/Rocketeer/Tasks/Migrate.php | 7 ++++ src/Rocketeer/Tasks/Subtasks/Composer.php | 7 +++- .../Tasks/Subtasks/CreateRelease.php | 7 ++++ 9 files changed, 85 insertions(+), 13 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 068b56380..124e36f8f 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -21,6 +21,13 @@ */ abstract class AbstractCommand extends Command { + /** + * The level at which to display statuses + * + * @type integer + */ + public $level = 2; + /** * @param AbstractTask|null $task */ @@ -58,7 +65,6 @@ protected function getOptions() ['pretend', 'p', InputOption::VALUE_NONE, 'Shows which command would execute without actually doing anything'], ['on', 'C', InputOption::VALUE_REQUIRED, 'The connection(s) to execute the Task in'], ['stage', 'S', InputOption::VALUE_REQUIRED, 'The stage to execute the Task in'], - // Credentials ['host', null, InputOption::VALUE_REQUIRED, 'The host to use if asked'], ['username', null, InputOption::VALUE_REQUIRED, 'The username to use if asked'], @@ -96,6 +102,38 @@ public function isInsideLaravel() return $this->laravel->bound('artisan'); } + ////////////////////////////////////////////////////////////////////// + /////////////////////////////// STATUS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Execute a task in a level below + * + * @param Closure $callback + * + * @return mixed + */ + public function belowStatus(Closure $callback) + { + $this->level++; + $results = $callback(); + $this->level--; + + return $results; + } + + /** + * Display a status + * + * @param string $status + */ + public function displayStatus($status) + { + $comment = str_repeat('-', $this->level). ' '.$status; + + $this->line($comment); + } + //////////////////////////////////////////////////////////////////// ///////////////////////////// CORE METHODS ///////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php index 64fb895ff..6689b67b5 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -32,8 +32,8 @@ public function displayStatus() $name = array_get($components, 0); $strategy = array_get($components, 1); - $comment = sprintf('==> Running strategy for %s: %s', ucfirst($strategy), ucfirst($name)); + $comment = sprintf('Running strategy for %s: %s', ucfirst($strategy), ucfirst($name)); - $this->command->line($comment); + $this->command->displayStatus($comment); } } diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index e80be8800..c8ea3e3c3 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -216,7 +216,15 @@ public function getQualifiedEvent($event) public function getStrategy($strategy) { $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; - $strategy->displayStatus(); + $status = function () use ($strategy) { + $strategy->displayStatus(); + }; + + if ($this->command) { + $this->command->belowStatus($status); + } else { + $status(); + } return $strategy; } @@ -230,7 +238,15 @@ public function getStrategy($strategy) */ public function executeTask($tasks) { - return $this->queue->run($tasks); + $run = function () use ($tasks) { + return $this->queue->run($tasks); + }; + + if ($this->command) { + return $this->command->belowStatus($run); + } + + return $run(); } //////////////////////////////////////////////////////////////////// @@ -287,11 +303,11 @@ protected function displayStatus() $name = $this->getName(); $description = $this->getDescription(); - $comment = sprintf('-- Running: %s', $name); + $comment = sprintf('Running: %s', $name); if ($description) { $comment .= ' ('.$description.')'; } - $this->command->line($comment); + $this->command->displayStatus($comment); } } diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index 7c180ebc2..c03d5c3c5 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -14,7 +14,6 @@ /** * The Git implementation of the ScmInterface - * * @method string revParse(string $arguments, array $flags = array()) * @method string clone(string $arguments, array $flags = array()) * @method string pull() diff --git a/src/Rocketeer/Strategies/CloneDeployStrategy.php b/src/Rocketeer/Strategies/CloneDeployStrategy.php index 7afe088ea..e8fa2c01f 100644 --- a/src/Rocketeer/Strategies/CloneDeployStrategy.php +++ b/src/Rocketeer/Strategies/CloneDeployStrategy.php @@ -20,7 +20,7 @@ public function deploy($destination = null) } // Executing checkout - $this->command->info('Cloning repository in "'.$destination.'"'); + $this->command->comment('Cloning repository in "'.$destination.'"'); $output = $this->scm->run('checkout', $destination); // Cancel if failed and forget credentials @@ -33,8 +33,8 @@ public function deploy($destination = null) // Deploy submodules if ($this->rocketeer->getOption('scm.submodules')) { - $this->command->info('Initializing submodules if any'); - $this->bash->runForCurrentRelease($this->scm->submodules()); + $this->command->comment('Initializing submodules if any'); + $this->scm->runForCurrentRelease('submodules'); } return $success; diff --git a/src/Rocketeer/Strategies/CopyDeployStrategy.php b/src/Rocketeer/Strategies/CopyDeployStrategy.php index e0fb6e6cc..a420a5acc 100644 --- a/src/Rocketeer/Strategies/CopyDeployStrategy.php +++ b/src/Rocketeer/Strategies/CopyDeployStrategy.php @@ -33,7 +33,7 @@ public function deploy($destination = null) } // Copy old release into new one - $this->command->info('Copying previous release "'.$previous.'" in "'.$destination.'"'); + $this->command->comment('Copying previous release "'.$previous.'" in "'.$destination.'"'); $this->bash->copy($previous, $destination); // Update repository diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index 9ab9158a8..d34fd8a23 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -5,6 +5,13 @@ class Migrate extends AbstractTask { + /** + * The console command description. + * + * @var string + */ + protected $description = 'Migrates and/or seed the database'; + /** * Run the task * diff --git a/src/Rocketeer/Tasks/Subtasks/Composer.php b/src/Rocketeer/Tasks/Subtasks/Composer.php index 8ef2e5570..9c433b148 100644 --- a/src/Rocketeer/Tasks/Subtasks/Composer.php +++ b/src/Rocketeer/Tasks/Subtasks/Composer.php @@ -5,6 +5,12 @@ class Composer extends AbstractTask { + /** + * A description of what the task does + * + * @var string + */ + protected $description = 'Installs Composer dependencies'; /** * Run the task * @@ -31,7 +37,6 @@ public function execute() } // Run commands - $this->command->info('Installing Composer dependencies'); $this->runForCurrentRelease($tasks); return $this->checkStatus('Composer could not install dependencies'); diff --git a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php index 0768f1d43..b431e69fc 100644 --- a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php +++ b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php @@ -5,6 +5,13 @@ class CreateRelease extends AbstractTask { + /** + * A description of what the task does + * + * @var string + */ + protected $description = 'Creates a new release on the server'; + /** * Run the task * From cc836bea480286f94e495c56528090e6a36337b0 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 02:54:44 +0200 Subject: [PATCH 185/424] Fix tests on 5.4 (never thought I had to write that) --- tests/Services/Tasks/TasksBuilderTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php index 6eb975f18..f2441d8b3 100644 --- a/tests/Services/Tasks/TasksBuilderTest.php +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -67,7 +67,7 @@ function () { public function testThrowsExceptionOnUnbuildableTask() { - $this->setExpectedException(TaskCompositionException::class); + $this->setExpectedException('Rocketeer\Exceptions\TaskCompositionException'); $this->builder->buildTaskFromClass('Nope'); } From b49302a86563ce2394f62302312b43252fe46b42 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 03:07:07 +0200 Subject: [PATCH 186/424] Extract status displaying to a separate class --- src/Rocketeer/Abstracts/AbstractCommand.php | 39 ------------ src/Rocketeer/Abstracts/AbstractStrategy.php | 19 ++---- src/Rocketeer/Abstracts/AbstractTask.php | 32 ++-------- src/Rocketeer/QueueExplainer.php | 64 ++++++++++++++++++++ src/Rocketeer/RocketeerServiceProvider.php | 6 ++ src/Rocketeer/Traits/HasLocator.php | 42 ++++++------- tests/Traits/BashModules/BinariesTest.php | 8 +-- 7 files changed, 107 insertions(+), 103 deletions(-) create mode 100644 src/Rocketeer/QueueExplainer.php diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 124e36f8f..49cbf0391 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -21,13 +21,6 @@ */ abstract class AbstractCommand extends Command { - /** - * The level at which to display statuses - * - * @type integer - */ - public $level = 2; - /** * @param AbstractTask|null $task */ @@ -102,38 +95,6 @@ public function isInsideLaravel() return $this->laravel->bound('artisan'); } - ////////////////////////////////////////////////////////////////////// - /////////////////////////////// STATUS /////////////////////////////// - ////////////////////////////////////////////////////////////////////// - - /** - * Execute a task in a level below - * - * @param Closure $callback - * - * @return mixed - */ - public function belowStatus(Closure $callback) - { - $this->level++; - $results = $callback(); - $this->level--; - - return $results; - } - - /** - * Display a status - * - * @param string $status - */ - public function displayStatus($status) - { - $comment = str_repeat('-', $this->level). ' '.$status; - - $this->line($comment); - } - //////////////////////////////////////////////////////////////////// ///////////////////////////// CORE METHODS ///////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php index 6689b67b5..58967b406 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -1,15 +1,8 @@ command) { - return; - } - + // Recompose strategy and implementation from + // the class name $components = get_class($this); $components = class_basename($components); $components = Str::snake($components); @@ -32,8 +23,10 @@ public function displayStatus() $name = array_get($components, 0); $strategy = array_get($components, 1); - $comment = sprintf('Running strategy for %s: %s', ucfirst($strategy), ucfirst($name)); - $this->command->displayStatus($comment); + $object = 'Running strategy for '.ucfirst($strategy); + $subject = ucfirst($name); + + $this->explainer->display($object, $subject); } } diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index c8ea3e3c3..811cb518d 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -216,17 +216,11 @@ public function getQualifiedEvent($event) public function getStrategy($strategy) { $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; - $status = function () use ($strategy) { + return $this->explainer->displayBelow(function () use ($strategy) { $strategy->displayStatus(); - }; - if ($this->command) { - $this->command->belowStatus($status); - } else { - $status(); - } - - return $strategy; + return $strategy; + }); } /** @@ -238,15 +232,9 @@ public function getStrategy($strategy) */ public function executeTask($tasks) { - $run = function () use ($tasks) { + return $this->explainer->displayBelow(function () use ($tasks) { return $this->queue->run($tasks); - }; - - if ($this->command) { - return $this->command->belowStatus($run); - } - - return $run(); + }); } //////////////////////////////////////////////////////////////////// @@ -297,17 +285,9 @@ protected function displayReleases() */ protected function displayStatus() { - if (!$this->command) { - return; - } - $name = $this->getName(); $description = $this->getDescription(); - $comment = sprintf('Running: %s', $name); - if ($description) { - $comment .= ' ('.$description.')'; - } - $this->command->displayStatus($comment); + $this->explainer->display('Running', $name, $description); } } diff --git a/src/Rocketeer/QueueExplainer.php b/src/Rocketeer/QueueExplainer.php new file mode 100644 index 000000000..d36defae5 --- /dev/null +++ b/src/Rocketeer/QueueExplainer.php @@ -0,0 +1,64 @@ +command) { + return $callback(); + } + + $this->level++; + $results = $callback(); + $this->level--; + + return $results; + } + + /** + * Display a status + * + * @param string $object + * @param string $subject + * @param string|null $details + */ + public function display($object, $subject, $details = null) + { + if (!$this->command) { + return; + } + + // Build status + $tree = str_repeat('-', $this->level); + $comment = sprintf('%s %s: %s', $tree, $object, $subject); + if ($details) { + $comment .= ' ('.$details.')'; + } + + $this->command->line($comment); + } +} diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 13dd3ea0c..12d8196bd 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -15,6 +15,7 @@ use Illuminate\Http\Request; use Illuminate\Log\Writer; use Illuminate\Remote\RemoteManager; +use Illuminate\Support\Facades\Queue; use Illuminate\Support\ServiceProvider; use Monolog\Logger; use Rocketeer\Console\Commands\BaseTaskCommand; @@ -148,10 +149,15 @@ public function bindCoreClasses() $this->app->singleton('rocketeer.rocketeer', function ($app) { return new Rocketeer($app); }); + $this->app->singleton('rocketeer.connections', function ($app) { return new ConnectionsHandler($app); }); + $this->app->singleton('rocketeer.explainer', function ($app) { + return new QueueExplainer($app); + }); + $this->app->singleton('rocketeer.releases', function ($app) { return new ReleasesManager($app); }); diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 4e7d9e5b6..9ed6d0d5d 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -14,28 +14,27 @@ /** * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes - - -* -*@property \Illuminate\Config\Repository config - * @property \Illuminate\Events\Dispatcher events - * @property \Illuminate\Filesystem\Filesystem files - * @property \Illuminate\Log\Writer log - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Abstracts\AbstractCommand command - * @property \Rocketeer\Bash bash - * @property \Rocketeer\Console\Console console - * @property \Rocketeer\Interfaces\ScmInterface scm + * + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Events\Dispatcher events + * @property \Illuminate\Filesystem\Filesystem files + * @property \Illuminate\Log\Writer log + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\AbstractCommand command + * @property \Rocketeer\Bash bash + * @property \Rocketeer\QueueExplainer explainer + * @property \Rocketeer\Console\Console console + * @property \Rocketeer\Interfaces\ScmInterface scm * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Services\CredentialsGatherer credentials - * @property \Rocketeer\Services\History\History history - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\Tasks\TasksBuilder builder - * @property \Rocketeer\Services\Tasks\TasksQueue queue - * @property \Rocketeer\Services\TasksHandler tasks + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\CredentialsGatherer credentials + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage localStorage + * @property \Rocketeer\Services\Tasks\TasksBuilder builder + * @property \Rocketeer\Services\Tasks\TasksQueue queue + * @property \Rocketeer\Services\TasksHandler tasks * @author Maxime Fabre */ trait HasLocator @@ -73,6 +72,7 @@ public function __get($key) 'connections' => 'rocketeer.connections', 'console' => 'rocketeer.console', 'credentials' => 'rocketeer.credentials', + 'explainer' => 'rocketeer.explainer', 'history' => 'rocketeer.history', 'localStorage' => 'rocketeer.storage.local', 'logs' => 'rocketeer.logs', diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 7dd40abf0..77b53298e 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -54,11 +54,11 @@ public function testCanRunComposer() $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock ->shouldReceive('line') - ->shouldReceive('option')->andReturn([]) - ->shouldReceive('info')->once(); + ->shouldReceive('option')->andReturn([]); }); $this->task('Composer')->execute(); + $this->assertCount(3, $this->history->getFlattenedHistory()[0]); } public function testDoesntRunComposerIfNotNeeded() @@ -67,10 +67,10 @@ public function testDoesntRunComposerIfNotNeeded() $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock ->shouldReceive('line') - ->shouldReceive('option')->andReturn([]) - ->shouldReceive('info')->never(); + ->shouldReceive('option')->andReturn([]); }); $this->task('Composer')->execute(); + $this->assertEmpty($this->history->getFlattenedHistory()); } } From 26831d2787fc10453e0aa555b4d8a3a79bd059bd Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 03:16:39 +0200 Subject: [PATCH 187/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractBinary.php | 10 +++++----- src/Rocketeer/Abstracts/AbstractTask.php | 1 + src/Rocketeer/RocketeerServiceProvider.php | 1 - src/Rocketeer/Scm/Svn.php | 1 - src/Rocketeer/Services/TasksHandler.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 1 - src/Rocketeer/Tasks/Subtasks/Composer.php | 1 + src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- tests/Binaries/ArtisanTest.php | 2 +- tests/IgniterTest.php | 2 +- tests/Services/Tasks/TasksBuilderTest.php | 1 - tests/Services/TasksHandlerTest.php | 1 - tests/Tasks/DeployTest.php | 2 +- tests/Tasks/Subtasks/ComposerTes.php | 8 +++++--- 14 files changed, 17 insertions(+), 18 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 80101bc9a..79f2317fc 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -77,8 +77,8 @@ public function __call($name, $arguments) { // Execution aliases if (Str::startsWith($name, 'run')) { - $command = array_shift($arguments); - $command = call_user_func_array([$this, $command], $arguments); + $command = array_shift($arguments); + $command = call_user_func_array([$this, $command], $arguments); return $this->bash->$name($command); } @@ -100,9 +100,9 @@ public function __call($name, $arguments) /** * Returns a command with the SCM's binary * - * @param string|null $command - * @param string|string[] $arguments - * @param string|string[] $flags + * @param string|null $command + * @param string|string[] $arguments + * @param string|string[] $flags * * @return string */ diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 811cb518d..a32423195 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -216,6 +216,7 @@ public function getQualifiedEvent($event) public function getStrategy($strategy) { $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; + return $this->explainer->displayBelow(function () use ($strategy) { $strategy->displayStatus(); diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 12d8196bd..ddaf548a2 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -15,7 +15,6 @@ use Illuminate\Http\Request; use Illuminate\Log\Writer; use Illuminate\Remote\RemoteManager; -use Illuminate\Support\Facades\Queue; use Illuminate\Support\ServiceProvider; use Monolog\Logger; use Rocketeer\Console\Commands\BaseTaskCommand; diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index ec502d23f..b879ae2d4 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -14,7 +14,6 @@ /** * The Svn implementation of the ScmInterface - * * @method string co(array $arguments, array $flags = array()) * @method string up(array $arguments, array $flags = array()) * diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 79f9519ff..78c9802cb 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -202,7 +202,7 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) } // Prevent events on anonymous tasks - $slug = $this->builder->buildTask($task)->getSlug(); + $slug = $this->builder->buildTask($task)->getSlug(); if ($slug == 'closure') { return; } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 38bf2970b..57d1998b9 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -48,7 +48,6 @@ public function execute() // Setup the new release $release = $this->releasesManager->getNextRelease(); - // Build and execute subtasks $this->executeTask(['CreateRelease', 'Composer']); if ($this->getOption('tests')) { diff --git a/src/Rocketeer/Tasks/Subtasks/Composer.php b/src/Rocketeer/Tasks/Subtasks/Composer.php index 9c433b148..107faffdf 100644 --- a/src/Rocketeer/Tasks/Subtasks/Composer.php +++ b/src/Rocketeer/Tasks/Subtasks/Composer.php @@ -11,6 +11,7 @@ class Composer extends AbstractTask * @var string */ protected $description = 'Installs Composer dependencies'; + /** * Run the task * diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index fe7c1be0a..3b08fb35f 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -25,7 +25,7 @@ trait Binaries /** * Get an AnonymousBinary instance * - * @param string $binary + * @param string $binary * * @return \Rocketeer\Abstracts\AbstractBinary */ diff --git a/tests/Binaries/ArtisanTest.php b/tests/Binaries/ArtisanTest.php index ad3988a87..110b5731b 100644 --- a/tests/Binaries/ArtisanTest.php +++ b/tests/Binaries/ArtisanTest.php @@ -8,7 +8,7 @@ class ArtisanTest extends RocketeerTestCase { public function testCanRunMigrations() { - $php = exec('which php'); + $php = exec('which php'); $artisan = new Artisan($this->app); $commands = $artisan->migrate(); diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index e5b0a6ce0..2c3e74578 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -136,7 +136,7 @@ public function testCanGetStorageWhenBothForSomeReason() public function testCanLoadFilesOrFolder() { - $config = $this->customConfig; + $config = $this->customConfig; $this->app['path.base'] = dirname($config); $this->files->makeDirectory($config.'/events', 0755, true); diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php index f2441d8b3..06321dc45 100644 --- a/tests/Services/Tasks/TasksBuilderTest.php +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -2,7 +2,6 @@ namespace Services\Tasks; use ReflectionFunction; -use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\TestCases\RocketeerTestCase; class TasksBuilderTest extends RocketeerTestCase diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index 7d5b269d0..2b184227d 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -1,7 +1,6 @@ swapConfig(array( - 'rocketeer::scm' => array( + 'rocketeer::scm' => array( 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', diff --git a/tests/Tasks/Subtasks/ComposerTes.php b/tests/Tasks/Subtasks/ComposerTes.php index cc1618466..3b4f7710c 100644 --- a/tests/Tasks/Subtasks/ComposerTes.php +++ b/tests/Tasks/Subtasks/ComposerTes.php @@ -29,7 +29,7 @@ public function testCanConfigureComposerCommands() ), ); - $composer = $this->pretendTask('Composer'); + $composer = $this->pretendTask('Composer'); $composer->force = true; $composer->fire(); @@ -42,7 +42,7 @@ public function testCanConfigureComposerCommands() public function testCancelsIfInvalidComposerRoutine() { - $composer = $this->pretendTask('Composer'); + $composer = $this->pretendTask('Composer'); $composer->force = true; $this->swapConfig(array( @@ -53,7 +53,9 @@ public function testCancelsIfInvalidComposerRoutine() $this->assertEmpty($this->history->getFlattenedHistory()); $this->swapConfig(array( - 'rocketeer::remote.composer' => function() { return []; }, + 'rocketeer::remote.composer' => function () { + return []; + }, )); $composer->fire(); From 9c44c9fea5bdb417c3d6c972e9bff87dd79dcd95 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 03:22:16 +0200 Subject: [PATCH 188/424] Tweak Artisan binary --- src/Rocketeer/Binaries/Artisan.php | 18 ++++-------------- src/Rocketeer/Binaries/Composer.php | 3 +++ src/Rocketeer/Scm/Git.php | 2 +- .../Strategies/ArtisanMigrateStrategy.php | 2 +- src/Rocketeer/Tasks/Migrate.php | 2 ++ 5 files changed, 11 insertions(+), 16 deletions(-) diff --git a/src/Rocketeer/Binaries/Artisan.php b/src/Rocketeer/Binaries/Artisan.php index d5bfc101a..2039a729e 100644 --- a/src/Rocketeer/Binaries/Artisan.php +++ b/src/Rocketeer/Binaries/Artisan.php @@ -28,31 +28,21 @@ public function __construct(Container $app) /** * Run outstranding migrations * - * @param bool $seed - * * @return string */ - public function migrate($seed = false) + public function migrate() { - $this->command->comment('Running outstanding migrations'); - $flags = $seed ? ['--seed' => null] : []; - - return $this->getCommand('migrate', [], $flags); + return $this->getCommand('migrate'); } /** * Seed the database * - * @param string|null $class A class to seed - * * @return string */ - public function seed($class = null) + public function seed() { - $this->command->comment('Seeding database'); - $flags = $class ? ['--class' => $class] : []; - - return $this->getCommand('db:seed', [], $flags); + return $this->getCommand('db:seed'); } /** diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php index e01a1103e..1b0f9ef35 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/Composer.php @@ -4,6 +4,9 @@ use Illuminate\Container\Container; use Rocketeer\Abstracts\AbstractBinary; +/** + * @method string install(string $arguments, array $flags = array()) + */ class Composer extends AbstractBinary { /** diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index c03d5c3c5..e0e3d24c3 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -15,7 +15,7 @@ /** * The Git implementation of the ScmInterface * @method string revParse(string $arguments, array $flags = array()) - * @method string clone(string $arguments, array $flags = array()) + * @method string clone(array $arguments, array $flags = array()) * @method string pull() * @method string submodule(string $arguments, array $flags = array()) * diff --git a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php index e09366260..2787c09fa 100644 --- a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php +++ b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php @@ -23,6 +23,6 @@ public function migrate() */ public function seed() { - $this->artisan()->runForCurrentRelease('db:seed'); + $this->artisan()->runForCurrentRelease('seed'); } } diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index d34fd8a23..f626c90c6 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -22,10 +22,12 @@ public function execute() $strategy = $this->getStrategy('Migrate'); if ($this->getOption('migrate')) { + $this->command->comment('Running outstanding migrations'); $strategy->migrate(); } if ($this->getOption('seed')) { + $this->command->comment('Seeding database'); $strategy->seed(); } } From 799ff270aadd33b7b726a916d10b07baf6b82f67 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 12:47:05 +0200 Subject: [PATCH 189/424] Realign some options --- src/config/hooks.php | 2 +- src/config/scm.php | 4 ++-- src/config/stages.php | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/config/hooks.php b/src/config/hooks.php index c2bdb9bbb..9c9967ec4 100644 --- a/src/config/hooks.php +++ b/src/config/hooks.php @@ -20,7 +20,7 @@ ), // Tasks to execute after the core Rocketeer Tasks - 'after' => array( + 'after' => array( 'setup' => array(), 'deploy' => array(), 'cleanup' => array(), diff --git a/src/config/scm.php b/src/config/scm.php index 1a87d66b4..0cd2f404d 100644 --- a/src/config/scm.php +++ b/src/config/scm.php @@ -4,7 +4,7 @@ ////////////////////////////////////////////////////////////////////// // The SCM used (supported: "git", "svn") - 'scm' => 'git', + 'scm' => 'git', // The SSH/HTTPS address to your repository // Example: https://github.com/vendor/website.git @@ -24,7 +24,7 @@ // or not – this means a clone with just the latest state of your // application (no history) // If you're having problems cloning, try setting this to false - 'shallow' => true, + 'shallow' => true, // Recursively pull in submodules. Works only with GIT. 'submodules' => true, diff --git a/src/config/stages.php b/src/config/stages.php index 57c43cee2..b581e142c 100644 --- a/src/config/stages.php +++ b/src/config/stages.php @@ -8,7 +8,7 @@ // Adding entries to this array will split the remote folder in stages // Like /var/www/yourapp/staging and /var/www/yourapp/production - 'stages' => array(), + 'stages' => array(), // The default stage to execute tasks on when --stage is not provided // Falsey means all of them From 6cde13c17a7013202df2c2fd6989d80126e1d513 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 12:47:20 +0200 Subject: [PATCH 190/424] Move Composer subtask to a DependenciesStrategyInterface --- .../DependenciesStrategyInterface.php | 19 +++++++ .../ComposerDependenciesStrategy.php | 49 +++++++++++++++++++ src/Rocketeer/Tasks/Dependencies.php | 26 ++++++++++ src/config/strategies.php | 9 ++-- 4 files changed, 100 insertions(+), 3 deletions(-) create mode 100644 src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php create mode 100644 src/Rocketeer/Strategies/ComposerDependenciesStrategy.php create mode 100644 src/Rocketeer/Tasks/Dependencies.php diff --git a/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php new file mode 100644 index 000000000..2bb51634e --- /dev/null +++ b/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php @@ -0,0 +1,19 @@ +composer(); + if (!$this->force and (!$composer->getBinary() or !$this->localStorage->usesComposer())) { + return true; + } + + // Get the Composer commands to run + $tasks = $this->rocketeer->getOption('remote.composer'); + if (!is_callable($tasks)) { + return true; + } + + // Cancel if no tasks to execute + $tasks = (array) $tasks($composer, $this); + if (empty($tasks)) { + return true; + } + + // Run commands + $this->runForCurrentRelease($tasks); + + return $this->checkStatus('Composer could not install dependencies'); + } + + /** + * Update the dependencies + * + * @return boolean + */ + public function update() + { + // TODO: Implement update() method. + } +} diff --git a/src/Rocketeer/Tasks/Dependencies.php b/src/Rocketeer/Tasks/Dependencies.php new file mode 100644 index 000000000..367656dc5 --- /dev/null +++ b/src/Rocketeer/Tasks/Dependencies.php @@ -0,0 +1,26 @@ +getOption('update') ? 'update' : 'install'; + + return $this->getStrategy('Dependencies')->$method(); + } +} diff --git a/src/config/strategies.php b/src/config/strategies.php index cf17383c9..834b1461f 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -7,12 +7,15 @@ ////////////////////////////////////////////////////////////////////// // Which strategy to use to create a new release - 'deploy' => 'Clone', + 'deploy' => 'Clone', // Which strategy to use to test your application - 'test' => 'Phpunit', + 'test' => 'Phpunit', // Which strategy to use to migrate your database - 'migrate' => 'Artisan', + 'migrate' => 'Artisan', + + // Which strategy to use to install your application's dependencies + 'dependencies' => 'Polyglot', ); From 4a450a216031ff46f16cabb6571c2f5fab4792ee Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 13:17:58 +0200 Subject: [PATCH 191/424] Decouple dependencies installation from Composer --- src/Rocketeer/Abstracts/AbstractStrategy.php | 44 ++++++++++++++++++ src/Rocketeer/Abstracts/AbstractTask.php | 10 ++--- src/Rocketeer/RocketeerServiceProvider.php | 4 ++ .../Strategies/ArtisanMigrateStrategy.php | 10 +++++ .../ComposerDependenciesStrategy.php | 40 ++++++++++------- .../Strategies/PhpunitTestStrategy.php | 28 +++++------- src/Rocketeer/Tasks/Dependencies.php | 8 +++- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Tasks/Migrate.php | 3 ++ src/Rocketeer/Tasks/Subtasks/Composer.php | 45 ------------------- src/Rocketeer/Tasks/Test.php | 7 ++- src/Rocketeer/Tasks/Update.php | 2 +- src/config/remote.php | 8 ---- src/config/strategies.php | 19 +++++++- tests/Abstracts/AbstractTaskTest.php | 2 +- tests/TestCases/ContainerTestCase.php | 20 +++++---- tests/TestCases/RocketeerTestCase.php | 1 + tests/Traits/BashModules/BinariesTest.php | 6 +-- 18 files changed, 147 insertions(+), 112 deletions(-) delete mode 100644 src/Rocketeer/Tasks/Subtasks/Composer.php diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php index 58967b406..5aab9fc91 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -9,6 +9,50 @@ */ abstract class AbstractStrategy extends Bash { + /** + * Boolean to bypass certain checks + * + * @type boolean + */ + public $force = false; + + /** + * Whether this particular strategy is runnable or not + * + * @return boolean + */ + public function isExecutable() + { + return true; + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * @param string $hook + * @param array $arguments + * + * @return bool|string + */ + protected function getHookedTasks($hook, array $arguments) + { + $tasks = $this->rocketeer->getOption($hook); + if (!is_callable($tasks)) { + return; + } + + // Cancel if no tasks to execute + $tasks = (array) call_user_func_array($tasks, $arguments); + if (empty($tasks)) { + return; + } + + // Run commands + return $tasks; + } + /** * Display what the command is and does */ diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index a32423195..dcfcd257f 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -42,13 +42,6 @@ abstract class AbstractTask extends Bash */ protected $halted = false; - /** - * Boolean to bypass certain checks - * - * @type boolean - */ - public $force; - //////////////////////////////////////////////////////////////////// ////////////////////////////// REFLECTION ////////////////////////// //////////////////////////////////////////////////////////////////// @@ -216,6 +209,9 @@ public function getQualifiedEvent($event) public function getStrategy($strategy) { $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; + if (!$strategy->isExecutable()) { + return; + } return $this->explainer->displayBelow(function () use ($strategy) { $strategy->displayStatus(); diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index ddaf548a2..b704c0710 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -226,6 +226,10 @@ public function bindStrategies() // Bind strategies $strategies = $this->app['rocketeer.rocketeer']->getOption('strategies'); foreach ($strategies as $strategy => $implementation) { + if (!is_string($implementation)) { + continue; + } + $concrete = sprintf('Rocketeer\Strategies\%s%sStrategy', $implementation, ucfirst($strategy)); $this->app->bind('rocketeer.strategies.'.$strategy, function ($app) use ($strategy, $concrete) { return new $concrete($app); diff --git a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php index 2787c09fa..af21121fd 100644 --- a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php +++ b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php @@ -6,6 +6,16 @@ class ArtisanMigrateStrategy extends AbstractStrategy implements MigrateStrategyInterface { + /** + * Whether this particular strategy is runnable or not + * + * @return boolean + */ + public function isExecutable() + { + return $this->artisan()->getBinary(); + } + /** * Run outstanding migrations * diff --git a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php b/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php index 04da183d1..fdb78ded0 100644 --- a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php +++ b/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php @@ -7,31 +7,33 @@ class ComposerDependenciesStrategy extends AbstractStrategy implements DependenciesStrategyInterface { /** - * Install the dependencies + * Whether this particular strategy is runnable or not * - * @return bool + * @return boolean */ - public function install() + public function isExecutable() { - // Find Composer $composer = $this->composer(); if (!$this->force and (!$composer->getBinary() or !$this->localStorage->usesComposer())) { - return true; + return false; } - // Get the Composer commands to run - $tasks = $this->rocketeer->getOption('remote.composer'); - if (!is_callable($tasks)) { - return true; - } + return true; + } - // Cancel if no tasks to execute - $tasks = (array) $tasks($composer, $this); - if (empty($tasks)) { + /** + * Install the dependencies + * + * @return bool + */ + public function install() + { + // Get the tasks to execute + $tasks = $this->getHookedTasks('strategies.composer.install', [$this->composer(), $this]); + if (!$tasks) { return true; } - // Run commands $this->runForCurrentRelease($tasks); return $this->checkStatus('Composer could not install dependencies'); @@ -44,6 +46,14 @@ public function install() */ public function update() { - // TODO: Implement update() method. + // Get the tasks to execute + $tasks = $this->getHookedTasks('strategies.composer.update', [$this->composer(), $this]); + if (!$tasks) { + return true; + } + + $this->runForCurrentRelease($tasks); + + return $this->checkStatus('Composer could not install dependencies'); } } diff --git a/src/Rocketeer/Strategies/PhpunitTestStrategy.php b/src/Rocketeer/Strategies/PhpunitTestStrategy.php index 47c39ade2..ff7e80459 100644 --- a/src/Rocketeer/Strategies/PhpunitTestStrategy.php +++ b/src/Rocketeer/Strategies/PhpunitTestStrategy.php @@ -6,6 +6,16 @@ class PhpunitTestStrategy extends AbstractStrategy implements TestStrategyInterface { + /** + * Whether this particular strategy is runnable or not + * + * @return boolean + */ + public function isExecutable() + { + return (bool) $this->phpunit()->getBinary(); + } + /** * Run the task * @@ -13,16 +23,10 @@ class PhpunitTestStrategy extends AbstractStrategy implements TestStrategyInterf */ public function test() { - // Look for PHPUnit - $phpunit = $this->phpunit(); - if (!$phpunit->getBinary()) { - return true; - } - // Run PHPUnit $arguments = ['--stop-on-failure' => null]; $output = $this->runForCurrentRelease(array( - $phpunit->getCommand(null, [], $arguments), + $this->phpunit()->getCommand(null, [], $arguments), )); $status = $this->checkStatus('Tests failed', $output, 'Tests passed successfully'); @@ -32,14 +36,4 @@ public function test() return $status; } - - /** - * Run the task - * - * @return string - */ - public function execute() - { - // ... - } } diff --git a/src/Rocketeer/Tasks/Dependencies.php b/src/Rocketeer/Tasks/Dependencies.php index 367656dc5..964c39c95 100644 --- a/src/Rocketeer/Tasks/Dependencies.php +++ b/src/Rocketeer/Tasks/Dependencies.php @@ -19,8 +19,12 @@ class Dependencies extends AbstractTask */ public function execute() { - $method = $this->getOption('update') ? 'update' : 'install'; + $method = $this->getOption('update') ? 'update' : 'install'; + $dependencies = $this->getStrategy('Dependencies'); + if (!$dependencies) { + return true; + } - return $this->getStrategy('Dependencies')->$method(); + return $dependencies->$method(); } } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 57d1998b9..cb91f08bf 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -49,7 +49,7 @@ public function execute() $release = $this->releasesManager->getNextRelease(); // Build and execute subtasks - $this->executeTask(['CreateRelease', 'Composer']); + $this->executeTask(['CreateRelease', 'Dependencies']); if ($this->getOption('tests')) { $this->executeTask('Test'); } diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index f626c90c6..e5d4acbdb 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -20,6 +20,9 @@ class Migrate extends AbstractTask public function execute() { $strategy = $this->getStrategy('Migrate'); + if (!$strategy) { + return true; + } if ($this->getOption('migrate')) { $this->command->comment('Running outstanding migrations'); diff --git a/src/Rocketeer/Tasks/Subtasks/Composer.php b/src/Rocketeer/Tasks/Subtasks/Composer.php deleted file mode 100644 index 107faffdf..000000000 --- a/src/Rocketeer/Tasks/Subtasks/Composer.php +++ /dev/null @@ -1,45 +0,0 @@ -composer(); - if (!$this->force and (!$composer->getBinary() or !$this->localStorage->usesComposer())) { - return true; - } - - // Get the Composer commands to run - $tasks = $this->rocketeer->getOption('remote.composer'); - if (!is_callable($tasks)) { - return true; - } - - // Cancel if no tasks to execute - $tasks = (array) $tasks($composer, $this); - if (empty($tasks)) { - return true; - } - - // Run commands - $this->runForCurrentRelease($tasks); - - return $this->checkStatus('Composer could not install dependencies'); - } -} diff --git a/src/Rocketeer/Tasks/Test.php b/src/Rocketeer/Tasks/Test.php index 58ba8f644..af0445101 100644 --- a/src/Rocketeer/Tasks/Test.php +++ b/src/Rocketeer/Tasks/Test.php @@ -32,6 +32,11 @@ class Test extends AbstractTask */ public function execute() { - return $this->getStrategy('Test')->test(); + $tester = $this->getStrategy('Test'); + if (!$tester) { + return true; + } + + return $tester->test(); } } diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index e1876d340..d0d3ff587 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -37,7 +37,7 @@ public function execute() $this->syncSharedFolders(); // Recompile dependencies and stuff - $this->executeTask('Composer'); + $this->executeTask('Dependencies'); // Set permissions $this->setApplicationPermissions(); diff --git a/src/config/remote.php b/src/config/remote.php index c3336b78c..80947fbd4 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -13,14 +13,6 @@ 'line_endings' => "\n", ), - // The process that will be executed by Composer - 'composer' => function (Composer $composer, Task $task) { - return array( - // $composer->selfUpdate(), - $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]), - ); - }, - // The number of releases to keep at all times 'keep_releases' => 4, diff --git a/src/config/strategies.php b/src/config/strategies.php index 834b1461f..e1ec23692 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -1,4 +1,7 @@ - 'Artisan', // Which strategy to use to install your application's dependencies - 'dependencies' => 'Polyglot', + 'dependencies' => 'Composer', + + // Execution hooks + ////////////////////////////////////////////////////////////////////// + + 'composer' => array( + 'install' => function (Composer $composer, Task $task) { + return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); + }, + 'update' => function (Composer $composer) { + return $composer->update(); + }, + ), ); diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 5df9cad41..42994a94c 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -87,7 +87,7 @@ public function testCanListenToSubtasks() 'rocketeer::hooks' => [], )); - $this->tasks->listenTo('composer.before', ['ls']); + $this->tasks->listenTo('dependencies.before', ['ls']); $this->pretendTask('Deploy')->fire(); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index ec2e1163b..70b8cdf09 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -187,12 +187,6 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('rocketeer::remote.root_directory')->andReturn(__DIR__.'/../_server/'); $config->shouldReceive('get')->with('rocketeer::remote.app_directory')->andReturn(null); $config->shouldReceive('get')->with('rocketeer::remote.shared')->andReturn(array('tests/Elements')); - $config->shouldReceive('get')->with('rocketeer::remote.composer')->andReturn(function ($composer) { - return array( - $composer->selfUpdate(), - $composer->install(null, '--no-interaction --no-dev --prefer-dist'), - ); - }); $config->shouldReceive('get')->with('rocketeer::stages.default')->andReturn(null); $config->shouldReceive('get')->with('rocketeer::stages.stages')->andReturn(array()); @@ -215,11 +209,19 @@ protected function getConfig($expectations = array()) $config->shouldReceive('get')->with('rocketeer::scm.shallow')->andReturn(true); $config->shouldReceive('get')->with('rocketeer::scm.submodules')->andReturn(true); $config->shouldReceive('get')->with('rocketeer::strategies')->andReturn(array( - 'deploy' => 'Clone', - 'test' => 'Phpunit', - 'migrate' => 'Artisan', + 'deploy' => 'Clone', + 'test' => 'Phpunit', + 'migrate' => 'Artisan', + 'dependencies' => 'Composer', )); + $config->shouldReceive('get')->with('rocketeer::strategies.composer.install')->andReturn(function ($composer) { + return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); + }); + $config->shouldReceive('get')->with('rocketeer::strategies.composer.update')->andReturn(function ($composer) { + return $composer->update(); + }); + // Tasks $config->shouldReceive('get')->with('rocketeer::hooks')->andReturn(array( 'before' => array( diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index eb7071f21..cbf0ff4c7 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -155,6 +155,7 @@ protected function mockCommand($options = array(), $expectations = array()) 'seed' => false, 'stage' => false, 'parallel' => false, + 'update' => false, ), $options); $this->app['rocketeer.command'] = $this->getCommand($expectations, $options); diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 77b53298e..1709d5e87 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -57,8 +57,8 @@ public function testCanRunComposer() ->shouldReceive('option')->andReturn([]); }); - $this->task('Composer')->execute(); - $this->assertCount(3, $this->history->getFlattenedHistory()[0]); + $this->task('Dependencies')->execute(); + $this->assertCount(2, $this->history->getFlattenedHistory()[0]); } public function testDoesntRunComposerIfNotNeeded() @@ -70,7 +70,7 @@ public function testDoesntRunComposerIfNotNeeded() ->shouldReceive('option')->andReturn([]); }); - $this->task('Composer')->execute(); + $this->task('Dependencies')->execute(); $this->assertEmpty($this->history->getFlattenedHistory()); } } From 28f2349e7f50801b2de2618c7333be7a6e523b04 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 13:24:38 +0200 Subject: [PATCH 192/424] Update tests --- src/Rocketeer/Abstracts/AbstractStrategy.php | 7 ------- src/Rocketeer/Abstracts/AbstractTask.php | 5 +++-- src/Rocketeer/RocketeerServiceProvider.php | 2 +- .../Strategies/ComposerDependenciesStrategy.php | 2 +- tests/Tasks/Subtasks/ComposerTes.php | 13 ++++++------- 5 files changed, 11 insertions(+), 18 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php index 5aab9fc91..8c98de50a 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -9,13 +9,6 @@ */ abstract class AbstractStrategy extends Bash { - /** - * Boolean to bypass certain checks - * - * @type boolean - */ - public $force = false; - /** * Whether this particular strategy is runnable or not * diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index dcfcd257f..3335e7975 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -203,13 +203,14 @@ public function getQualifiedEvent($event) * Get the implementation behind a strategy * * @param string $strategy + * @param bool $force * * @return \Rocketeer\Abstracts\AbstractStrategy */ - public function getStrategy($strategy) + public function getStrategy($strategy, $force = false) { $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; - if (!$strategy->isExecutable()) { + if (!$strategy->isExecutable() and !$force) { return; } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b704c0710..22be460b8 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -229,7 +229,7 @@ public function bindStrategies() if (!is_string($implementation)) { continue; } - + $concrete = sprintf('Rocketeer\Strategies\%s%sStrategy', $implementation, ucfirst($strategy)); $this->app->bind('rocketeer.strategies.'.$strategy, function ($app) use ($strategy, $concrete) { return new $concrete($app); diff --git a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php b/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php index fdb78ded0..692e6bd15 100644 --- a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php +++ b/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php @@ -14,7 +14,7 @@ class ComposerDependenciesStrategy extends AbstractStrategy implements Dependenc public function isExecutable() { $composer = $this->composer(); - if (!$this->force and (!$composer->getBinary() or !$this->localStorage->usesComposer())) { + if (!$composer->getBinary() or !$this->localStorage->usesComposer()) { return false; } diff --git a/tests/Tasks/Subtasks/ComposerTes.php b/tests/Tasks/Subtasks/ComposerTes.php index 3b4f7710c..881ebfa97 100644 --- a/tests/Tasks/Subtasks/ComposerTes.php +++ b/tests/Tasks/Subtasks/ComposerTes.php @@ -13,7 +13,7 @@ public function testCanConfigureComposerCommands() 'username' => '', 'password' => '', ), - 'rocketeer::remote.composer' => function ($composer, $task) { + 'rocketeer::strategies.composer.install' => function ($composer, $task) { return array( $composer->selfUpdate(), $composer->install([], '--prefer-source'), @@ -29,9 +29,8 @@ public function testCanConfigureComposerCommands() ), ); - $composer = $this->pretendTask('Composer'); - $composer->force = true; - $composer->fire(); + $composer = $this->pretendTask('Dependencies')->getStrategy('Dependencies', true); + $composer->install(); $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( 'tests' => false, @@ -42,18 +41,18 @@ public function testCanConfigureComposerCommands() public function testCancelsIfInvalidComposerRoutine() { - $composer = $this->pretendTask('Composer'); + $composer = $this->pretendTask('Dependencies'); $composer->force = true; $this->swapConfig(array( - 'rocketeer::remote.composer' => 'lol', + 'rocketeer::strategies.composer.install' => 'lol', )); $composer->fire(); $this->assertEmpty($this->history->getFlattenedHistory()); $this->swapConfig(array( - 'rocketeer::remote.composer' => function () { + 'rocketeer::strategies.composer.install' => function () { return []; }, )); From d622506d53fde20bb33c71aeec1e9e2570587e95 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 17:50:46 +0200 Subject: [PATCH 193/424] Missing use --- src/config/strategies.php | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/config/strategies.php b/src/config/strategies.php index e1ec23692..21621b03a 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -1,4 +1,5 @@ array( - 'install' => function (Composer $composer, Task $task) { + 'install' => function (Composer $composer, AbstractTask $task) { return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); }, 'update' => function (Composer $composer) { From 11f1ccd5549424fcc8e3f350ea91fa2c2521af86 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 17:52:42 +0200 Subject: [PATCH 194/424] Use ServerStorage in clean-all --- src/Rocketeer/Tasks/Cleanup.php | 4 +++- tests/Tasks/Subtasks/ComposerTes.php | 4 ++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index 8855dda57..864e14f2d 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -11,6 +11,7 @@ use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractTask; +use Rocketeer\Services\Storages\ServerStorage; /** * Clean up old releases from the server @@ -47,7 +48,8 @@ public function execute() // Delete state file if ($this->getOption('clean-all')) { - $this->removeFolder('state.json'); + $state = new ServerStorage($this->app, 'state'); + $state->destroy(); $this->releasesManager->markReleaseAsValid(); } diff --git a/tests/Tasks/Subtasks/ComposerTes.php b/tests/Tasks/Subtasks/ComposerTes.php index 881ebfa97..e4ed1a768 100644 --- a/tests/Tasks/Subtasks/ComposerTes.php +++ b/tests/Tasks/Subtasks/ComposerTes.php @@ -8,7 +8,7 @@ class ComposerTest extends RocketeerTestCase public function testCanConfigureComposerCommands() { $this->swapConfig(array( - 'rocketeer::scm' => array( + 'rocketeer::scm' => array( 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', @@ -29,7 +29,7 @@ public function testCanConfigureComposerCommands() ), ); - $composer = $this->pretendTask('Dependencies')->getStrategy('Dependencies', true); + $composer = $this->pretendTask('Dependencies')->getStrategy('Dependencies', true); $composer->install(); $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( From 0c7ab3a4252aadd0dd5fe47d48ce0f6b2bf845e5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 18:11:31 +0200 Subject: [PATCH 195/424] Close #272 - Remove server handle when setting default connection in config --- src/Rocketeer/Tasks/Ignite.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index 2940e05f7..a29f8be56 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -84,7 +84,7 @@ protected function getConfigurationInformations() return array_merge( $this->connections->getServerCredentials(), array( - 'connection' => $this->connections->getConnection(), + 'connection' => preg_replace('/#[0-9]/', null, $this->connections->getConnection()), 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], From 3e20c8f8228b552b4795ad190a9017b8001b2d31 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 18:16:34 +0200 Subject: [PATCH 196/424] Code duplication --- .../ComposerDependenciesStrategy.php | 23 ++++++++++--------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php b/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php index 692e6bd15..2df10d2b3 100644 --- a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php +++ b/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php @@ -28,15 +28,7 @@ public function isExecutable() */ public function install() { - // Get the tasks to execute - $tasks = $this->getHookedTasks('strategies.composer.install', [$this->composer(), $this]); - if (!$tasks) { - return true; - } - - $this->runForCurrentRelease($tasks); - - return $this->checkStatus('Composer could not install dependencies'); + return $this->executeHook('install'); } /** @@ -46,8 +38,17 @@ public function install() */ public function update() { - // Get the tasks to execute - $tasks = $this->getHookedTasks('strategies.composer.update', [$this->composer(), $this]); + return $this->executeHook('update'); + } + + /** + * @param string $hook + * + * @return bool + */ + protected function executeHook($hook) + { + $tasks = $this->getHookedTasks('strategies.composer.'.$hook, [$this->composer(), $this]); if (!$tasks) { return true; } From e8c98eded4a5768758f155ac40620b104e5c509e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 19:02:05 +0200 Subject: [PATCH 197/424] Fuck this. --- src/Rocketeer/Binaries/Composer.php | 3 --- src/Rocketeer/Scm/Git.php | 4 ---- src/Rocketeer/Scm/Svn.php | 2 -- 3 files changed, 9 deletions(-) diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php index 1b0f9ef35..e01a1103e 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/Composer.php @@ -4,9 +4,6 @@ use Illuminate\Container\Container; use Rocketeer\Abstracts\AbstractBinary; -/** - * @method string install(string $arguments, array $flags = array()) - */ class Composer extends AbstractBinary { /** diff --git a/src/Rocketeer/Scm/Git.php b/src/Rocketeer/Scm/Git.php index e0e3d24c3..255d0095c 100644 --- a/src/Rocketeer/Scm/Git.php +++ b/src/Rocketeer/Scm/Git.php @@ -14,10 +14,6 @@ /** * The Git implementation of the ScmInterface - * @method string revParse(string $arguments, array $flags = array()) - * @method string clone(array $arguments, array $flags = array()) - * @method string pull() - * @method string submodule(string $arguments, array $flags = array()) * * @author Maxime Fabre */ diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index b879ae2d4..1657d01c3 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -14,8 +14,6 @@ /** * The Svn implementation of the ScmInterface - * @method string co(array $arguments, array $flags = array()) - * @method string up(array $arguments, array $flags = array()) * * @author Maxime Fabre * @author Gasillo From 39a7b11418563157ec770a8e45acb71aea9832a1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 19:03:15 +0200 Subject: [PATCH 198/424] Dead code --- src/Rocketeer/Traits/BashModules/Binaries.php | 22 ------------------- 1 file changed, 22 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 3b08fb35f..143a31a2f 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -80,28 +80,6 @@ public function artisan() return $this->binary('artisan'); } - /** - * Run an artisan command - * - * @param string|null $command - * @param array $flags - * - * @return string - */ - public function runArtisan($command = null, $flags = array()) - { - // Check if the seeds/migration need to be forced - $forced = array('migrate', 'db:seed'); - if (in_array($command, $forced) && $this->versionCheck('4.2.0')) { - $flags['force'] = ''; - } - - // Create full command - $command = $this->artisan($command, $flags); - - return $this->runForCurrentRelease($command); - } - //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// From 85c3eab47faaa49d013ca72b1982dcc820ab7a36 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 19:10:40 +0200 Subject: [PATCH 199/424] Code tweaks --- src/Rocketeer/Services/CredentialsGatherer.php | 2 +- src/Rocketeer/Strategies/ArtisanMigrateStrategy.php | 4 ++-- src/Rocketeer/Tasks/Migrate.php | 2 +- src/Rocketeer/Tasks/Rollback.php | 2 +- src/config/remote.php | 1 - 5 files changed, 5 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 19c103a79..670177915 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -161,7 +161,7 @@ protected function gatherCredential($handle, $credential, $question = null) /** * Check if a credential needs to be filled * - * @param array $credentials + * @param string[] $credentials * @param string $credential * * @return string diff --git a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php index af21121fd..b6ea3810e 100644 --- a/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php +++ b/src/Rocketeer/Strategies/ArtisanMigrateStrategy.php @@ -19,7 +19,7 @@ public function isExecutable() /** * Run outstanding migrations * - * @return boolean + * @return boolean|null */ public function migrate() { @@ -29,7 +29,7 @@ public function migrate() /** * Seed the database * - * @return boolean + * @return boolean|null */ public function seed() { diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index e5d4acbdb..f9aa68e2f 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -15,7 +15,7 @@ class Migrate extends AbstractTask /** * Run the task * - * @return string + * @return boolean|null */ public function execute() { diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 75133daa9..d5dd2f27a 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -60,7 +60,7 @@ public function execute() /** * Get the release to rollback to * - * @return string|null + * @return integer|null */ protected function getRollbackRelease() { diff --git a/src/config/remote.php b/src/config/remote.php index 80947fbd4..471a2b57b 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -1,5 +1,4 @@ Date: Wed, 13 Aug 2014 19:22:05 +0200 Subject: [PATCH 200/424] Always cast stages to array --- src/Rocketeer/Services/ConnectionsHandler.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/ConnectionsHandler.php index e28bbf562..cdf8f2bf3 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/ConnectionsHandler.php @@ -99,7 +99,7 @@ public function getStage() */ public function getStages() { - return $this->rocketeer->getOption('stages.stages'); + return (array) $this->rocketeer->getOption('stages.stages'); } //////////////////////////////////////////////////////////////////// From 8f9eab8a865711210e1a42f66f3336903a206795 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 22:04:01 +0200 Subject: [PATCH 201/424] Make Rocketeer use the default config as base for mocks --- src/config/strategies.php | 3 +- tests/TestCases/ContainerTestCase.php | 163 +++++++++++++------------- 2 files changed, 82 insertions(+), 84 deletions(-) diff --git a/src/config/strategies.php b/src/config/strategies.php index 21621b03a..724d52871 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -1,5 +1,4 @@ array( - 'install' => function (Composer $composer, AbstractTask $task) { + 'install' => function (Composer $composer, $task) { return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); }, 'update' => function (Composer $composer) { diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 70b8cdf09..b7949fe22 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -13,6 +13,11 @@ abstract class ContainerTestCase extends PHPUnit_Framework_TestCase { use HasLocator; + /** + * @type arra + */ + protected $defaults; + /** * Override the trait constructor */ @@ -45,7 +50,6 @@ public function setUp() $this->app->instance('path.storage', '/src/app/storage'); $this->app['files'] = new Filesystem; - $this->app['config'] = $this->getConfig(); $this->app['remote'] = $this->getRemote(); $this->app['artisan'] = $this->getArtisan(); $this->app['rocketeer.command'] = $this->getCommand(); @@ -54,6 +58,10 @@ public function setUp() $serviceProvider = new RocketeerServiceProvider($this->app); $serviceProvider->boot(); + + // Swap some instances with Mockeries -------------------------- / + + $this->app['config'] = $this->getConfig(); } /** @@ -156,91 +164,12 @@ protected function getConfig($expectations = array()) $config = Mockery::mock('Illuminate\Config\Repository'); $config->shouldIgnoreMissing(); + $defaults = $this->getFactoryConfiguration(); + $expectations = array_merge($defaults, $expectations); foreach ($expectations as $key => $value) { $config->shouldReceive('get')->with($key)->andReturn($value); } - // Drivers - $config->shouldReceive('get')->with('cache.driver')->andReturn('file'); - $config->shouldReceive('get')->with('database.default')->andReturn('mysql'); - $config->shouldReceive('get')->with('remote.default')->andReturn('production'); - $config->shouldReceive('get')->with('remote.connections')->andReturn(array( - 'production' => array(), - 'staging' => array() - )); - $config->shouldReceive('get')->with('session.driver')->andReturn('file'); - - // Rocketeer - $config->shouldReceive('get')->with('rocketeer::application_name')->andReturn('foobar'); - $config->shouldReceive('get')->with('rocketeer::default')->andReturn(array('production')); - $config->shouldReceive('get')->with('rocketeer::logs')->andReturn(false); - $config->shouldReceive('get')->with('rocketeer::connections')->andReturn(array()); - $config->shouldReceive('get')->with('rocketeer::remote.keep_releases')->andReturn(1); - $config->shouldReceive('get')->with('rocketeer::remote.permissions.callback')->andReturn(function ($task, $file) { - return array( - sprintf('chmod -R 755 %s', $file), - sprintf('chmod -R g+s %s', $file), - sprintf('chown -R www-data:www-data %s', $file), - ); - }); - $config->shouldReceive('get')->with('rocketeer::remote.permissions.files')->andReturn(array('tests')); - $config->shouldReceive('get')->with('rocketeer::remote.root_directory')->andReturn(__DIR__.'/../_server/'); - $config->shouldReceive('get')->with('rocketeer::remote.app_directory')->andReturn(null); - $config->shouldReceive('get')->with('rocketeer::remote.shared')->andReturn(array('tests/Elements')); - $config->shouldReceive('get')->with('rocketeer::stages.default')->andReturn(null); - $config->shouldReceive('get')->with('rocketeer::stages.stages')->andReturn(array()); - - // Paths - $config->shouldReceive('get')->with('rocketeer::paths.php')->andReturn(''); - $config->shouldReceive('get')->with('rocketeer::paths.composer')->andReturn(''); - $config->shouldReceive('get')->with('rocketeer::paths.artisan')->andReturn(''); - - // SCM - $config->shouldReceive('get')->with('rocketeer::scm')->andReturn(array( - 'branch' => 'master', - 'repository' => 'https://github.com/'.$this->repository, - 'scm' => 'git', - 'shallow' => true, - 'submodules' => true, - )); - $config->shouldReceive('get')->with('rocketeer::scm.branch')->andReturn('master'); - $config->shouldReceive('get')->with('rocketeer::scm.repository')->andReturn('https://github.com/'.$this->repository); - $config->shouldReceive('get')->with('rocketeer::scm.scm')->andReturn('git'); - $config->shouldReceive('get')->with('rocketeer::scm.shallow')->andReturn(true); - $config->shouldReceive('get')->with('rocketeer::scm.submodules')->andReturn(true); - $config->shouldReceive('get')->with('rocketeer::strategies')->andReturn(array( - 'deploy' => 'Clone', - 'test' => 'Phpunit', - 'migrate' => 'Artisan', - 'dependencies' => 'Composer', - )); - - $config->shouldReceive('get')->with('rocketeer::strategies.composer.install')->andReturn(function ($composer) { - return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); - }); - $config->shouldReceive('get')->with('rocketeer::strategies.composer.update')->andReturn(function ($composer) { - return $composer->update(); - }); - - // Tasks - $config->shouldReceive('get')->with('rocketeer::hooks')->andReturn(array( - 'before' => array( - 'deploy' => array( - 'before', - 'foobar' - ), - ), - 'after' => array( - 'check' => array( - 'Rocketeer\Dummies\MyCustomTask', - ), - 'deploy' => array( - 'after', - 'foobar' - ), - ), - )); - return $config; } @@ -307,4 +236,74 @@ protected function getArtisan() return $artisan; } + + /** + * @return array + */ + protected function getFactoryConfiguration() + { + if ($this->defaults) { + return $this->defaults; + } + + // Base the mocked configuration off the factory values + $defaults = []; + $files = ['config', 'hooks', 'paths', 'remote', 'scm', 'stages', 'strategies']; + foreach ($files as $file) { + $defaults[$file] = $this->config->get('rocketeer::'.$file); + } + + // Build correct keys + $defaults = array_dot($defaults); + $keys = array_keys($defaults); + $keys = array_map(function ($key) { + return 'rocketeer::'.str_replace('config.', null, $key); + }, $keys); + $defaults = array_combine($keys, array_values($defaults)); + + $overrides = array( + 'cache.driver' => 'file', + 'database.default' => 'mysql', + 'remote.default' => 'production', + 'session.driver' => 'file', + 'remote.connections' => array( + 'production' => [], + 'staging' => [] + ), + 'rocketeer::application_name' => 'foobar', + 'rocketeer::remote.permissions.files' => ['tests'], + 'rocketeer::remote.shared' => ['tests/Elements'], + 'rocketeer::remote.keep_releases' => 1, + 'rocketeer::remote.root_directory' => __DIR__.'/../_server/', + 'rocketeer::scm' => array( + 'branch' => 'master', + 'repository' => 'https://github.com/'.$this->repository, + 'scm' => 'git', + 'shallow' => true, + 'submodules' => true, + ), + 'rocketeer::hooks' => array( + 'before' => array( + 'deploy' => array( + 'before', + 'foobar' + ), + ), + 'after' => array( + 'check' => array( + 'Rocketeer\Dummies\MyCustomTask', + ), + 'deploy' => array( + 'after', + 'foobar' + ), + ), + ) + ); + + // Assign options to expectations + $this->defaults = array_merge($defaults, $overrides); + + return $this->defaults; + } } From 09ad3862832ac8cf1c9ae9af782f236e72638f53 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 13 Aug 2014 22:19:25 +0200 Subject: [PATCH 202/424] Add TasksBuilder::buildStrategy --- src/Rocketeer/Abstracts/AbstractStrategy.php | 4 +++ src/Rocketeer/Abstracts/AbstractTask.php | 13 +++++---- src/Rocketeer/RocketeerServiceProvider.php | 7 +++-- src/Rocketeer/Services/Tasks/TasksBuilder.php | 27 +++++++++++++++++++ .../{ComposerTes.php => ComposerTest.php} | 2 +- 5 files changed, 41 insertions(+), 12 deletions(-) rename tests/Tasks/Subtasks/{ComposerTes.php => ComposerTest.php} (97%) diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/AbstractStrategy.php index 8c98de50a..d55253d95 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/AbstractStrategy.php @@ -48,6 +48,8 @@ protected function getHookedTasks($hook, array $arguments) /** * Display what the command is and does + * + * @return $this */ public function displayStatus() { @@ -65,5 +67,7 @@ public function displayStatus() $subject = ucfirst($name); $this->explainer->display($object, $subject); + + return $this; } } diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 3335e7975..25d71df6a 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -202,22 +202,21 @@ public function getQualifiedEvent($event) /** * Get the implementation behind a strategy * - * @param string $strategy - * @param bool $force + * @param string $strategy + * @param string|null $concrete + * @param bool $force * * @return \Rocketeer\Abstracts\AbstractStrategy */ - public function getStrategy($strategy, $force = false) + public function getStrategy($strategy, $concrete = null, $force = false) { - $strategy = $this->app['rocketeer.strategies.'.strtolower($strategy)]; + $strategy = $this->builder->buildStrategy($strategy, $concrete); if (!$strategy->isExecutable() and !$force) { return; } return $this->explainer->displayBelow(function () use ($strategy) { - $strategy->displayStatus(); - - return $strategy; + return $strategy->displayStatus(); }); } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 22be460b8..bdda837f2 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -225,14 +225,13 @@ public function bindStrategies() // Bind strategies $strategies = $this->app['rocketeer.rocketeer']->getOption('strategies'); - foreach ($strategies as $strategy => $implementation) { - if (!is_string($implementation)) { + foreach ($strategies as $strategy => $concrete) { + if (!is_string($concrete)) { continue; } - $concrete = sprintf('Rocketeer\Strategies\%s%sStrategy', $implementation, ucfirst($strategy)); $this->app->bind('rocketeer.strategies.'.$strategy, function ($app) use ($strategy, $concrete) { - return new $concrete($app); + return $app['rocketeer.builder']->buildStrategy($strategy, $concrete); }); } } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 836ea7d28..f3314eb67 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -24,6 +24,33 @@ class TasksBuilder { use HasLocator; + ////////////////////////////////////////////////////////////////////// + ///////////////////////////// STRATEGIES ///////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Build a strategy + * + * @param string $strategy + * @param string|null $concrete + * + * @return \Rocketeer\Abstracts\AbstractStrategy + */ + public function buildStrategy($strategy, $concrete = null) + { + // If we passed a concrete implementation + // build it, otherwise get the bound one + $handle = strtolower($strategy); + if ($concrete) { + $core = sprintf('Rocketeer\Strategies\%s%sStrategy', $concrete, ucfirst($strategy)); + $concrete = class_exists($core) ? $core : $concrete; + + return new $concrete($this->app); + } + + return $this->app['rocketeer.strategies.'.$handle]; + } + //////////////////////////////////////////////////////////////////// /////////////////////////////// BUILDING /////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/tests/Tasks/Subtasks/ComposerTes.php b/tests/Tasks/Subtasks/ComposerTest.php similarity index 97% rename from tests/Tasks/Subtasks/ComposerTes.php rename to tests/Tasks/Subtasks/ComposerTest.php index e4ed1a768..32962b001 100644 --- a/tests/Tasks/Subtasks/ComposerTes.php +++ b/tests/Tasks/Subtasks/ComposerTest.php @@ -29,7 +29,7 @@ public function testCanConfigureComposerCommands() ), ); - $composer = $this->pretendTask('Dependencies')->getStrategy('Dependencies', true); + $composer = $this->pretendTask('Dependencies')->getStrategy('Dependencies', 'Composer', true); $composer->install(); $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( From a15eccff71289f4449c2b1a03493ebb01d5dc75f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 01:11:39 +0200 Subject: [PATCH 203/424] Work on PolyglotStrategy --- src/Rocketeer/Abstracts/AbstractTask.php | 39 ------------- src/Rocketeer/Bash.php | 39 +++++++++++++ .../PolyglotDependenciesStrategy.php | 58 +++++++++++++++++++ 3 files changed, 97 insertions(+), 39 deletions(-) create mode 100644 src/Rocketeer/Strategies/PolyglotDependenciesStrategy.php diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 25d71df6a..fe0b01d1a 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -195,45 +195,6 @@ public function getQualifiedEvent($event) return 'rocketeer.'.$this->getSlug().'.'.$event; } - ////////////////////////////////////////////////////////////////////// - ////////////////////////////// RUNNERS /////////////////////////////// - ////////////////////////////////////////////////////////////////////// - - /** - * Get the implementation behind a strategy - * - * @param string $strategy - * @param string|null $concrete - * @param bool $force - * - * @return \Rocketeer\Abstracts\AbstractStrategy - */ - public function getStrategy($strategy, $concrete = null, $force = false) - { - $strategy = $this->builder->buildStrategy($strategy, $concrete); - if (!$strategy->isExecutable() and !$force) { - return; - } - - return $this->explainer->displayBelow(function () use ($strategy) { - return $strategy->displayStatus(); - }); - } - - /** - * Execute another AbstractTask by name - * - * @param string|string[] $tasks - * - * @return string|false - */ - public function executeTask($tasks) - { - return $this->explainer->displayBelow(function () use ($tasks) { - return $this->queue->run($tasks); - }); - } - //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index 45877edc4..efbe3b5a6 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -25,4 +25,43 @@ class Bash use Binaries; use Filesystem; use Flow; + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// RUNNERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the implementation behind a strategy + * + * @param string $strategy + * @param string|null $concrete + * @param bool $force + * + * @return \Rocketeer\Abstracts\AbstractStrategy + */ + public function getStrategy($strategy, $concrete = null, $force = false) + { + $strategy = $this->builder->buildStrategy($strategy, $concrete); + if (!$strategy->isExecutable() and !$force) { + return; + } + + return $this->explainer->displayBelow(function () use ($strategy) { + return $strategy->displayStatus(); + }); + } + + /** + * Execute another AbstractTask by name + * + * @param string|string[] $tasks + * + * @return string|false + */ + public function executeTask($tasks) + { + return $this->explainer->displayBelow(function () use ($tasks) { + return $this->queue->run($tasks); + }); + } } diff --git a/src/Rocketeer/Strategies/PolyglotDependenciesStrategy.php b/src/Rocketeer/Strategies/PolyglotDependenciesStrategy.php new file mode 100644 index 000000000..f69b8c7bd --- /dev/null +++ b/src/Rocketeer/Strategies/PolyglotDependenciesStrategy.php @@ -0,0 +1,58 @@ +onManagers(function ($manager) { + return $manager->install(); + }); + } + + /** + * Update the dependencies + * + * @return boolean + */ + public function update() + { + return $this->onManagers(function ($manager) { + return $manager->update(); + }); + } + + /** + * @param Closure $closure + * + * @return array + */ + protected function onManagers(Closure $closure) + { + $results = []; + foreach ($this->managers as $manager) { + $strategy = $this->getStrategy($manager); + if ($strategy) { + $results[$manager] = $closure($strategy); + } + } + + return $results; + } +} From e441d864949488beb2d46b19eea6d7ae9f36c26c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 01:14:30 +0200 Subject: [PATCH 204/424] Use namespaces for strategies --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- .../ComposerStrategy.php} | 4 ++-- .../PolyglotStrategy.php} | 4 ++-- .../{CloneDeployStrategy.php => Deploy/CloneStrategy.php} | 4 ++-- .../{CopyDeployStrategy.php => Deploy/CopyStrategy.php} | 4 ++-- .../ArtisanStrategy.php} | 4 ++-- .../{PhpunitTestStrategy.php => Test/PhpunitStrategy.php} | 4 ++-- tests/Strategies/CopyStrategyTest.php | 4 ++-- tests/Tasks/DeployTest.php | 4 ++-- 9 files changed, 17 insertions(+), 17 deletions(-) rename src/Rocketeer/Strategies/{ComposerDependenciesStrategy.php => Dependencies/ComposerStrategy.php} (88%) rename src/Rocketeer/Strategies/{PolyglotDependenciesStrategy.php => Dependencies/PolyglotStrategy.php} (87%) rename src/Rocketeer/Strategies/{CloneDeployStrategy.php => Deploy/CloneStrategy.php} (91%) rename src/Rocketeer/Strategies/{CopyDeployStrategy.php => Deploy/CopyStrategy.php} (89%) rename src/Rocketeer/Strategies/{ArtisanMigrateStrategy.php => Migrate/ArtisanStrategy.php} (82%) rename src/Rocketeer/Strategies/{PhpunitTestStrategy.php => Test/PhpunitStrategy.php} (85%) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index f3314eb67..c81e1f73d 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -42,7 +42,7 @@ public function buildStrategy($strategy, $concrete = null) // build it, otherwise get the bound one $handle = strtolower($strategy); if ($concrete) { - $core = sprintf('Rocketeer\Strategies\%s%sStrategy', $concrete, ucfirst($strategy)); + $core = sprintf('Rocketeer\Strategies\%s\%sStrategy', ucfirst($strategy), $concrete); $concrete = class_exists($core) ? $core : $concrete; return new $concrete($this->app); diff --git a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php similarity index 88% rename from src/Rocketeer/Strategies/ComposerDependenciesStrategy.php rename to src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 2df10d2b3..9d22812c4 100644 --- a/src/Rocketeer/Strategies/ComposerDependenciesStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -1,10 +1,10 @@ app->bind('rocketeer.strategy', function ($app) { - return new CopyDeployStrategy($app); + return new CopyStrategy($app); }); $this->pretend(); diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 5f0e1c612..4f2caf5f8 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -1,7 +1,7 @@ app['rocketeer.strategies.deploy'] = new CopyDeployStrategy($this->app); + $this->app['rocketeer.strategies.deploy'] = new CopyStrategy($this->app); $this->mockState(array( '10000000000000' => true, From 4becc7ab63a88c0a704ccbe17887486c911c6f14 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 01:18:19 +0200 Subject: [PATCH 205/424] Add BundlerStrategy --- .../Dependencies/BundlerStrategy.php | 43 +++++++++++++++++++ .../Dependencies/ComposerStrategy.php | 2 +- .../Dependencies/PolyglotStrategy.php | 2 +- .../{ => Deploy}/CloneStrategyTest.php | 2 +- .../{ => Deploy}/CopyStrategyTest.php | 2 +- 5 files changed, 47 insertions(+), 4 deletions(-) create mode 100644 src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php rename tests/Strategies/{ => Deploy}/CloneStrategyTest.php (96%) rename tests/Strategies/{ => Deploy}/CopyStrategyTest.php (98%) diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php new file mode 100644 index 000000000..04da0f2a8 --- /dev/null +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -0,0 +1,43 @@ +binary('bundle'); + if (!$bundler->getBinary() or !$this->bash->fileExists($this->rocketeer->getFolder('Gemfile'))) { + return false; + } + + return true; + } + + /** + * Install the dependencies + * + * @return bool + */ + public function install() + { + return $this->binary('bundle')->install(); + } + + /** + * Update the dependencies + * + * @return boolean + */ + public function update() + { + return $this->binary('bundle')->update(); + } +} diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 9d22812c4..ecf988157 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -14,7 +14,7 @@ class ComposerStrategy extends AbstractStrategy implements DependenciesStrategyI public function isExecutable() { $composer = $this->composer(); - if (!$composer->getBinary() or !$this->localStorage->usesComposer()) { + if (!$composer->getBinary() or !$this->bash->fileExists($this->rocketeer->getFolder('composer.json'))) { return false; } diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index e82876ee2..a5a74e3ba 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -12,7 +12,7 @@ class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyI * * @type array */ - protected $managers = ['bundler', 'composer', 'npm', 'bower']; + protected $managers = ['Bundler', 'Composer', 'Npm', 'Bower']; /** * Install the dependencies diff --git a/tests/Strategies/CloneStrategyTest.php b/tests/Strategies/Deploy/CloneStrategyTest.php similarity index 96% rename from tests/Strategies/CloneStrategyTest.php rename to tests/Strategies/Deploy/CloneStrategyTest.php index 85e545fd8..48ac62e5c 100644 --- a/tests/Strategies/CloneStrategyTest.php +++ b/tests/Strategies/Deploy/CloneStrategyTest.php @@ -1,5 +1,5 @@ Date: Thu, 14 Aug 2014 01:29:10 +0200 Subject: [PATCH 206/424] Work on dependencies strategies --- .../AbstractDependenciesStrategy.php | 50 +++++++++++++++++++ .../{ => Strategies}/AbstractStrategy.php | 2 +- src/Rocketeer/Bash.php | 12 +++-- .../Services/Storages/LocalStorage.php | 12 ----- src/Rocketeer/Services/Tasks/TasksBuilder.php | 12 +++-- .../Dependencies/BundlerStrategy.php | 25 +++++----- .../Dependencies/ComposerStrategy.php | 26 +++++----- .../Dependencies/PolyglotStrategy.php | 2 +- .../Strategies/Deploy/CloneStrategy.php | 2 +- .../Strategies/Migrate/ArtisanStrategy.php | 2 +- .../Strategies/Test/PhpunitStrategy.php | 2 +- src/Rocketeer/Tasks/Check.php | 3 +- tests/Services/Storages/LocalStorageTest.php | 9 ---- tests/TestCases/RocketeerTestCase.php | 10 ++-- 14 files changed, 104 insertions(+), 65 deletions(-) create mode 100644 src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php rename src/Rocketeer/Abstracts/{ => Strategies}/AbstractStrategy.php (97%) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php new file mode 100644 index 000000000..8d8acd974 --- /dev/null +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -0,0 +1,50 @@ +getManager(); + $manifest = $this->rocketeer->getFolder('current/'.$this->manifest); + if (!$manager->getBinary() or !$this->bash->fileExists($manifest)) { + return false; + } + + return true; + } + + /** + * Get an instance of the Binary + * + * @return \Rocketeer\Abstracts\AbstractBinary + */ + public function getManager() + { + $binary = $this->binary; + if (method_exists($this, $binary)) { + return $this->$binary(); + } + + return $this->binary($this->binary); + } +} diff --git a/src/Rocketeer/Abstracts/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php similarity index 97% rename from src/Rocketeer/Abstracts/AbstractStrategy.php rename to src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index d55253d95..25ad068eb 100644 --- a/src/Rocketeer/Abstracts/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -1,5 +1,5 @@ app['path.base'].DIRECTORY_SEPARATOR.'composer.json'; - - return $this->files->exists($path); - } - /** * Change the folder in use * diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index c81e1f73d..c2cfc30ce 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -30,11 +30,15 @@ class TasksBuilder /** * Build a strategy - * - * @param string $strategy + + +* +*@param string $strategy * @param string|null $concrete - * - * @return \Rocketeer\Abstracts\AbstractStrategy + + +* +*@return \Rocketeer\Abstracts\Strategies\AbstractStrategy */ public function buildStrategy($strategy, $concrete = null) { diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 04da0f2a8..00d78bd81 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -1,25 +1,24 @@ binary('bundle'); - if (!$bundler->getBinary() or !$this->bash->fileExists($this->rocketeer->getFolder('Gemfile'))) { - return false; - } + protected $manifest = 'Gemfile'; - return true; - } + /** + * The name of the binary + * + * @type string + */ + protected $binary = 'bundle'; /** * Install the dependencies @@ -28,7 +27,7 @@ public function isExecutable() */ public function install() { - return $this->binary('bundle')->install(); + return $this->getManager()->install(); } /** @@ -38,6 +37,6 @@ public function install() */ public function update() { - return $this->binary('bundle')->update(); + return $this->getManager()->update(); } } diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index ecf988157..8b4607fb1 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -1,25 +1,25 @@ composer(); - if (!$composer->getBinary() or !$this->bash->fileExists($this->rocketeer->getFolder('composer.json'))) { - return false; - } + protected $manifest = 'composer.json'; - return true; - } + /** + * The name of the binary + * + * @type string + */ + protected $binary = 'composer'; /** * Install the dependencies @@ -48,7 +48,7 @@ public function update() */ protected function executeHook($hook) { - $tasks = $this->getHookedTasks('strategies.composer.'.$hook, [$this->composer(), $this]); + $tasks = $this->getHookedTasks('strategies.composer.'.$hook, [$this->getManager(), $this]); if (!$tasks) { return true; } diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index a5a74e3ba..168386568 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -2,7 +2,7 @@ namespace Rocketeer\Strategies\Dependencies; use Closure; -use Rocketeer\Abstracts\AbstractStrategy; +use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyInterface diff --git a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php index d7909f896..6d402eb32 100644 --- a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php @@ -1,7 +1,7 @@ localStorage->usesComposer()) { + $composer = $this->app['path.base'].DIRECTORY_SEPARATOR.'composer.json'; + if (!file_exists($composer)) { return true; } diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 3b12e2993..9f0a216a1 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -61,15 +61,6 @@ public function testCanComputeHashAccordingToContentsOfFiles() $this->assertEquals(md5('["foo"]["bar"]'), $hash); } - public function testCanCheckIfComposerIsNeeded() - { - $this->usesComposer(true); - $this->assertTrue($this->localStorage->usesComposer()); - - $this->usesComposer(false); - $this->assertFalse($this->localStorage->usesComposer()); - } - public function testCanSwitchFolder() { $storage = new LocalStorage($this->app, 'foo', '/foo'); diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index cbf0ff4c7..9fa9343bb 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -182,10 +182,12 @@ protected function mockState(array $state) */ protected function usesComposer($uses = true) { - $composer = $this->app['path.base'].DIRECTORY_SEPARATOR.'composer.json'; - $this->mock('files', 'Illuminate\Filesystem\Filesystem', function ($mock) use ($composer, $uses) { - return $mock->makePartial()->shouldReceive('exists')->with($composer)->andReturn($uses); - }); + $composer = $this->server.'/current/composer.json'; + if ($uses) { + $this->files->put($composer, '{}'); + } else { + $this->files->delete($composer); + } } /** From 459add94a9c9fb2787ebf2ed0ee810952f5f7ffc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 01:35:38 +0200 Subject: [PATCH 207/424] Add Bundler tests --- .../AbstractDependenciesStrategy.php | 5 --- .../Dependencies/BundlerStrategy.php | 7 ++-- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- .../Dependencies/BundlerStrategyTest.php | 33 +++++++++++++++++++ .../Dependencies/ComposerStrategyTest.php} | 7 ++-- 5 files changed, 41 insertions(+), 13 deletions(-) create mode 100644 tests/Strategies/Dependencies/BundlerStrategyTest.php rename tests/{Tasks/Subtasks/ComposerTest.php => Strategies/Dependencies/ComposerStrategyTest.php} (89%) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 8d8acd974..9480854bb 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -40,11 +40,6 @@ public function isExecutable() */ public function getManager() { - $binary = $this->binary; - if (method_exists($this, $binary)) { - return $this->$binary(); - } - return $this->binary($this->binary); } } diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 00d78bd81..79d647439 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -1,10 +1,11 @@ getManager()->install(); + return $this->getManager()->runForCurrentRelease('install'); } /** @@ -37,6 +38,6 @@ public function install() */ public function update() { - return $this->getManager()->update(); + return $this->getManager()->runForCurrentRelease('update'); } } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 143a31a2f..4a55208c7 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -41,7 +41,7 @@ public function binary($binary) $anonymous = new AnonymousBinary($this->app); $anonymous->setBinary($binary); - return $binary; + return $anonymous; } /** diff --git a/tests/Strategies/Dependencies/BundlerStrategyTest.php b/tests/Strategies/Dependencies/BundlerStrategyTest.php new file mode 100644 index 000000000..f2fbe752a --- /dev/null +++ b/tests/Strategies/Dependencies/BundlerStrategyTest.php @@ -0,0 +1,33 @@ +pretendTask()->getStrategy('Dependencies', 'Bundler', true); + $bundler->install(); + + $this->assertHistory(array( + array( + 'cd {server}/releases/{release}', + 'bundle install', + ), + )); + } + + public function testCanUpdateDependencies() + { + $bundler = $this->pretendTask()->getStrategy('Dependencies', 'Bundler', true); + $bundler->update(); + + $this->assertHistory(array( + array( + 'cd {server}/releases/{release}', + 'bundle update', + ), + )); + } +} diff --git a/tests/Tasks/Subtasks/ComposerTest.php b/tests/Strategies/Dependencies/ComposerStrategyTest.php similarity index 89% rename from tests/Tasks/Subtasks/ComposerTest.php rename to tests/Strategies/Dependencies/ComposerStrategyTest.php index 32962b001..1cc1367b0 100644 --- a/tests/Tasks/Subtasks/ComposerTest.php +++ b/tests/Strategies/Dependencies/ComposerStrategyTest.php @@ -1,9 +1,9 @@ pretendTask('Dependencies'); - $composer->force = true; + $composer = $this->pretendTask('Dependencies'); $this->swapConfig(array( 'rocketeer::strategies.composer.install' => 'lol', From a1ad3027dc459853fe1a67c21fd764b4dc26db57 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 01:39:12 +0200 Subject: [PATCH 208/424] Tweak strategies tests --- .../Strategies/Dependencies/BundlerStrategyTest.php | 4 ++-- .../Strategies/Dependencies/ComposerStrategyTest.php | 12 ++++++------ .../Test/PhpunitStrategyTest.php} | 8 +++++--- 3 files changed, 13 insertions(+), 11 deletions(-) rename tests/{Tasks/Subtasks/PhpunitTest.php => Strategies/Test/PhpunitStrategyTest.php} (52%) diff --git a/tests/Strategies/Dependencies/BundlerStrategyTest.php b/tests/Strategies/Dependencies/BundlerStrategyTest.php index f2fbe752a..fab478b34 100644 --- a/tests/Strategies/Dependencies/BundlerStrategyTest.php +++ b/tests/Strategies/Dependencies/BundlerStrategyTest.php @@ -7,7 +7,7 @@ class BundlerStrategyTest extends RocketeerTestCase { public function testCanInstallDependencies() { - $bundler = $this->pretendTask()->getStrategy('Dependencies', 'Bundler', true); + $bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); $bundler->install(); $this->assertHistory(array( @@ -20,7 +20,7 @@ public function testCanInstallDependencies() public function testCanUpdateDependencies() { - $bundler = $this->pretendTask()->getStrategy('Dependencies', 'Bundler', true); + $bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); $bundler->update(); $this->assertHistory(array( diff --git a/tests/Strategies/Dependencies/ComposerStrategyTest.php b/tests/Strategies/Dependencies/ComposerStrategyTest.php index 1cc1367b0..7d150c4c6 100644 --- a/tests/Strategies/Dependencies/ComposerStrategyTest.php +++ b/tests/Strategies/Dependencies/ComposerStrategyTest.php @@ -29,7 +29,7 @@ public function testCanConfigureComposerCommands() ), ); - $composer = $this->pretendTask('Dependencies')->getStrategy('Dependencies', 'Composer', true); + $composer = $this->builder->buildStrategy('Dependencies', 'Composer'); $composer->install(); $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( @@ -41,14 +41,14 @@ public function testCanConfigureComposerCommands() public function testCancelsIfInvalidComposerRoutine() { - $composer = $this->pretendTask('Dependencies'); + $composer = $this->builder->buildStrategy('Dependencies', 'Composer'); $this->swapConfig(array( 'rocketeer::strategies.composer.install' => 'lol', )); - $composer->fire(); - $this->assertEmpty($this->history->getFlattenedHistory()); + $composer->install(); + $this->assertHistory([]); $this->swapConfig(array( 'rocketeer::strategies.composer.install' => function () { @@ -56,7 +56,7 @@ public function testCancelsIfInvalidComposerRoutine() }, )); - $composer->fire(); - $this->assertEmpty($this->history->getFlattenedHistory()); + $composer->install(); + $this->assertHistory([]); } } diff --git a/tests/Tasks/Subtasks/PhpunitTest.php b/tests/Strategies/Test/PhpunitStrategyTest.php similarity index 52% rename from tests/Tasks/Subtasks/PhpunitTest.php rename to tests/Strategies/Test/PhpunitStrategyTest.php index a2dffd88c..06be0419d 100644 --- a/tests/Tasks/Subtasks/PhpunitTest.php +++ b/tests/Strategies/Test/PhpunitStrategyTest.php @@ -1,13 +1,15 @@ assertTaskHistory('Test', array( + $this->builder->buildStrategy('Test', 'Phpunit')->test(); + + $this->assertHistory(array( array( 'cd {server}/releases/20000000000000', '{phpunit} --stop-on-failure', From c7b5f5aba48c81295433f5bc2f61a1f0d61b5843 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 01:50:42 +0200 Subject: [PATCH 209/424] Add Polyglot strategy test --- src/Rocketeer/Bash.php | 17 +++---- src/Rocketeer/Services/Tasks/TasksBuilder.php | 51 ++++++++++++------- .../Dependencies/PolyglotStrategy.php | 2 +- .../Dependencies/PolyglotStrategyTest.php | 27 ++++++++++ tests/Strategies/Deploy/CloneStrategyTest.php | 4 +- tests/Strategies/Deploy/CopyStrategyTest.php | 6 +-- 6 files changed, 73 insertions(+), 34 deletions(-) create mode 100644 tests/Strategies/Dependencies/PolyglotStrategyTest.php diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index 4f484cc09..b7dcdc83d 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -32,21 +32,16 @@ class Bash /** * Get the implementation behind a strategy - - -* -*@param string $strategy + * + * @param string $strategy * @param string|null $concrete - * @param bool $force - - -* -*@return \Rocketeer\Abstracts\Strategies\AbstractStrategy + * + * @return \Rocketeer\Abstracts\Strategies\AbstractStrategy */ - public function getStrategy($strategy, $concrete = null, $force = false) + public function getStrategy($strategy, $concrete = null) { $strategy = $this->builder->buildStrategy($strategy, $concrete); - if (!$strategy->isExecutable() and !$force) { + if (!$strategy or !$strategy->isExecutable()) { return; } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index c2cfc30ce..fa11f07b8 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -30,15 +30,11 @@ class TasksBuilder /** * Build a strategy - - -* -*@param string $strategy + * + * @param string $strategy * @param string|null $concrete - - -* -*@return \Rocketeer\Abstracts\Strategies\AbstractStrategy + * + * @return \Rocketeer\Abstracts\Strategies\AbstractStrategy */ public function buildStrategy($strategy, $concrete = null) { @@ -46,8 +42,12 @@ public function buildStrategy($strategy, $concrete = null) // build it, otherwise get the bound one $handle = strtolower($strategy); if ($concrete) { - $core = sprintf('Rocketeer\Strategies\%s\%sStrategy', ucfirst($strategy), $concrete); - $concrete = class_exists($core) ? $core : $concrete; + $concrete = $this->findQualifiedName($concrete, array( + 'Rocketeer\Strategies\\' .ucfirst($strategy). '\%sStrategy', + )); + if (!$concrete) { + return false; + } return new $concrete($this->app); } @@ -195,13 +195,30 @@ protected function isStringCommand($string) */ protected function taskClassExists($task) { - $class = ucfirst($task); - if (class_exists('Rocketeer\Tasks\\'.$class)) { - return 'Rocketeer\Tasks\\'.$class; - } elseif (class_exists('Rocketeer\Tasks\Subtasks\\'.$class)) { - return 'Rocketeer\Tasks\Subtasks\\'.$class; - } elseif (class_exists($task)) { - return $task; + return $this->findQualifiedName($task, array( + 'Rocketeer\Tasks\%s', + 'Rocketeer\Tasks\Subtasks\%s', + )); + } + + /** + * Find a class in various predefined namespaces + * + * @param string $class + * @param array $paths + * + * @return string|false + */ + protected function findQualifiedName($class, $paths = array()) + { + $paths[] = '%s'; + + $class = ucfirst($class); + foreach ($paths as $path) { + $path = sprintf($path, $class); + if (class_exists($path)) { + return $path; + } } return false; diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index 168386568..87fdb0ba4 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -47,7 +47,7 @@ protected function onManagers(Closure $closure) { $results = []; foreach ($this->managers as $manager) { - $strategy = $this->getStrategy($manager); + $strategy = $this->getStrategy('Dependencies', $manager); if ($strategy) { $results[$manager] = $closure($strategy); } diff --git a/tests/Strategies/Dependencies/PolyglotStrategyTest.php b/tests/Strategies/Dependencies/PolyglotStrategyTest.php new file mode 100644 index 000000000..45303c402 --- /dev/null +++ b/tests/Strategies/Dependencies/PolyglotStrategyTest.php @@ -0,0 +1,27 @@ +usesComposer(true); + $this->files->put($this->server.'/current/Gemfile', ''); + + $polyglot = $this->builder->buildStrategy('Dependencies', 'Polyglot'); + $polyglot->install(); + + $this->assertHistory(array( + array( + 'cd {server}/releases/{release}', + 'bundle install', + ), + array( + 'cd {server}/releases/{release}', + '{composer} install --no-interaction --no-dev --prefer-dist', + ), + )); + } +} diff --git a/tests/Strategies/Deploy/CloneStrategyTest.php b/tests/Strategies/Deploy/CloneStrategyTest.php index 48ac62e5c..d5cbfa272 100644 --- a/tests/Strategies/Deploy/CloneStrategyTest.php +++ b/tests/Strategies/Deploy/CloneStrategyTest.php @@ -18,7 +18,7 @@ public function testCanDeployRepository() ), ); - $this->assertHistory($matcher, $task->history->getFlattenedHistory()); + $this->assertHistory($matcher); } public function testCanUpdateRepository() @@ -34,6 +34,6 @@ public function testCanUpdateRepository() ) ); - $this->assertHistory($matcher, $task->history->getFlattenedHistory()); + $this->assertHistory($matcher); } } diff --git a/tests/Strategies/Deploy/CopyStrategyTest.php b/tests/Strategies/Deploy/CopyStrategyTest.php index 67d923a8e..49a4c3bd3 100644 --- a/tests/Strategies/Deploy/CopyStrategyTest.php +++ b/tests/Strategies/Deploy/CopyStrategyTest.php @@ -31,7 +31,7 @@ public function testCanCopyPreviousRelease() ), ); - $this->assertHistory($matcher, $this->history->getFlattenedHistory()); + $this->assertHistory($matcher); } public function testClonesIfNoPreviousRelease() @@ -51,7 +51,7 @@ public function testClonesIfNoPreviousRelease() ), ); - $this->assertHistory($matcher, $this->history->getFlattenedHistory()); + $this->assertHistory($matcher); } public function testCanCloneIfPreviousReleaseIsInvalid() @@ -73,6 +73,6 @@ public function testCanCloneIfPreviousReleaseIsInvalid() ), ); - $this->assertHistory($matcher, $this->history->getFlattenedHistory()); + $this->assertHistory($matcher); } } From 20fba32c106e5c62bde9667c2e4f460515ecc4fb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:06:22 +0200 Subject: [PATCH 210/424] Fix strategies statuses --- .../Abstracts/Strategies/AbstractStrategy.php | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index 25ad068eb..e0f0825bb 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -56,15 +56,13 @@ public function displayStatus() // Recompose strategy and implementation from // the class name $components = get_class($this); - $components = class_basename($components); - $components = Str::snake($components); - $components = explode('_', $components); + $components = explode('\\', $components); - $name = array_get($components, 0); - $strategy = array_get($components, 1); + $name = array_get($components, sizeof($components) - 1); + $strategy = array_get($components, sizeof($components) - 2); $object = 'Running strategy for '.ucfirst($strategy); - $subject = ucfirst($name); + $subject = str_replace('Strategy', null, $name); $this->explainer->display($object, $subject); From fadc2b48e9a22e25a5ebde003be56f101c4cea4c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:06:36 +0200 Subject: [PATCH 211/424] Loose command options --- src/Rocketeer/Tasks/Dependencies.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 13 +++++++++---- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Tasks/Dependencies.php b/src/Rocketeer/Tasks/Dependencies.php index 964c39c95..4281ca282 100644 --- a/src/Rocketeer/Tasks/Dependencies.php +++ b/src/Rocketeer/Tasks/Dependencies.php @@ -19,7 +19,7 @@ class Dependencies extends AbstractTask */ public function execute() { - $method = $this->getOption('update') ? 'update' : 'install'; + $method = $this->getOption('update', true) ? 'update' : 'install'; $dependencies = $this->getStrategy('Dependencies'); if (!$dependencies) { return true; diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 9ed6d0d5d..34ee801f6 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -59,7 +59,7 @@ public function __construct(Container $app) /** * Get an instance from the Container * - * @param string $key + * @param string $key * * @return object */ @@ -116,12 +116,17 @@ protected function hasCommand() /** * Get an option from the Command * - * @param string $option + * @param string $option + * @param bool $loose * * @return string */ - protected function getOption($option) + protected function getOption($option, $loose = false) { - return $this->hasCommand() ? $this->command->option($option) : null; + if (!$this->hasCommand()) { + return null; + } + + return $loose ? array_get($this->command->option(), $option) : $this->command->option($option); } } From 272dbf1460ac635d74baada995b9810d04d3db98 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:06:44 +0200 Subject: [PATCH 212/424] Better verbose output --- src/Rocketeer/Traits/BashModules/Core.php | 5 +++-- src/Rocketeer/Traits/HasHistory.php | 1 + 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index c9329bb56..4372c3783 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -47,9 +47,10 @@ public function run($commands, $silent = false, $array = false) } // Display for pretend mode - if ($this->getOption('pretend') and !$silent) { + if ($verbose or ($this->getOption('pretend') and !$silent)) { $this->toOutput($commands); - $this->command->line(implode(PHP_EOL, $commands)); + $flattened = implode(PHP_EOL.'$ ', $commands); + $this->command->line('$ '.$flattened.''); return count($commands) == 1 ? $commands[0] : $commands; } diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index 49a848fdb..a99705de1 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -83,6 +83,7 @@ protected function appendTo($type, $command) { // Flatten one-liners $command = (array) $command; + $command = array_values($command); $command = count($command) == 1 ? $command[0] : $command; // Get the various handles From 7eecdb8712f814f0cced092ae779fc6700660799 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:15:47 +0200 Subject: [PATCH 213/424] Fix tests with verbose flag --- src/Rocketeer/Traits/BashModules/Core.php | 7 +++++-- tests/TestCases/ContainerTestCase.php | 2 +- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 4372c3783..3ca75487b 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -40,6 +40,7 @@ public function run($commands, $silent = false, $array = false) { $commands = $this->processCommands($commands); $verbose = $this->getOption('verbose') && !$silent; + $pretend = $this->getOption('pretend'); // Log the commands if (!$silent) { @@ -47,12 +48,14 @@ public function run($commands, $silent = false, $array = false) } // Display for pretend mode - if ($verbose or ($this->getOption('pretend') and !$silent)) { + if ($verbose or ($pretend and !$silent)) { $this->toOutput($commands); $flattened = implode(PHP_EOL.'$ ', $commands); $this->command->line('$ '.$flattened.''); - return count($commands) == 1 ? $commands[0] : $commands; + if ($pretend) { + return count($commands) == 1 ? $commands[0] : $commands; + } } // Run commands diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index b7949fe22..764375f5e 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -111,7 +111,7 @@ protected function getCommand(array $expectations = array(), array $options = ar return $message; }; - $command = Mockery::mock('Command'); + $command = Mockery::mock('Command')->shouldIgnoreMissing(); $command->shouldReceive('getOutput')->andReturn(null); // Bind the output expectations From ccc93ab237a8637bc5230bd6fc3c2234d58d8156 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:25:57 +0200 Subject: [PATCH 214/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractStorage.php | 2 +- .../AbstractDependenciesStrategy.php | 7 ++--- .../Abstracts/Strategies/AbstractStrategy.php | 3 +-- src/Rocketeer/Igniter.php | 2 +- src/Rocketeer/Interfaces/ScmInterface.php | 2 +- src/Rocketeer/Rocketeer.php | 12 ++++----- src/Rocketeer/Scm/Git.php | 2 +- src/Rocketeer/Scm/Svn.php | 2 +- src/Rocketeer/Services/ConnectionsHandler.php | 2 +- .../Services/CredentialsGatherer.php | 4 +-- src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- src/Rocketeer/Services/TasksHandler.php | 18 ++++++------- .../Dependencies/BundlerStrategy.php | 1 - .../Dependencies/ComposerStrategy.php | 1 - src/Rocketeer/Tasks/Check.php | 6 ++--- src/Rocketeer/Tasks/Closure.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 4 +-- src/Rocketeer/Traits/BashModules/Core.php | 26 +++++++++---------- .../Traits/BashModules/Filesystem.php | 18 ++++++------- src/Rocketeer/Traits/BashModules/Flow.php | 4 +-- src/Rocketeer/Traits/HasHistory.php | 8 +++--- src/Rocketeer/Traits/HasLocator.php | 2 +- tests/Services/ConnectionsHandlerTest.php | 6 ++--- tests/TestCases/ContainerTestCase.php | 2 +- 24 files changed, 66 insertions(+), 72 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index c47d8832c..0ed3369c3 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -80,7 +80,7 @@ public function set($key, $value = null) /** * Forget a value from the repository file * - * @param string $key + * @param string $key */ public function forget($key) { diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 9480854bb..551976637 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -24,13 +24,10 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy */ public function isExecutable() { - $manager = $this->getManager(); + $manager = $this->getManager(); $manifest = $this->rocketeer->getFolder('current/'.$this->manifest); - if (!$manager->getBinary() or !$this->bash->fileExists($manifest)) { - return false; - } - return true; + return $manager->getBinary() and $this->bash->fileExists($manifest); } /** diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index e0f0825bb..d81d075b8 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -1,7 +1,6 @@ findQualifiedName($concrete, array( - 'Rocketeer\Strategies\\' .ucfirst($strategy). '\%sStrategy', + 'Rocketeer\Strategies\\'.ucfirst($strategy).'\%sStrategy', )); if (!$concrete) { return false; diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 78c9802cb..9f0073378 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -109,9 +109,9 @@ public function task($name, $task, $description = null) /** * Execute a task before another one * - * @param string $task - * @param Closure $listeners - * @param integer $priority + * @param string $task + * @param Closure $listeners + * @param integer $priority * * @return void */ @@ -123,9 +123,9 @@ public function before($task, $listeners, $priority = 0) /** * Execute a task after another one * - * @param string $task - * @param Closure $listeners - * @param integer $priority + * @param string $task + * @param Closure $listeners + * @param integer $priority * * @return void */ @@ -217,9 +217,9 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) /** * Get all of a task's listeners * - * @param string|AbstractTask $task - * @param string $event - * @param boolean $flatten + * @param string|AbstractTask $task + * @param string $event + * @param boolean $flatten * * @return array */ diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 79d647439..4675da7b8 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -2,7 +2,6 @@ namespace Rocketeer\Strategies\Dependencies; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; -use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; class BundlerStrategy extends AbstractDependenciesStrategy implements DependenciesStrategyInterface diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 8b4607fb1..af60b6bbf 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -2,7 +2,6 @@ namespace Rocketeer\Strategies\Dependencies; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; -use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; class ComposerStrategy extends AbstractDependenciesStrategy implements DependenciesStrategyInterface diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index d31b990ab..0ec7ae6a6 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -169,7 +169,7 @@ public function checkPhpVersion() /** * Check the presence of the correct database PHP extension * - * @param string $database + * @param string $database * * @return boolean */ @@ -190,7 +190,7 @@ public function checkDatabaseDriver($database) /** * Check the presence of the correct cache PHP extension * - * @param string $cache + * @param string $cache * * @return boolean|string */ @@ -212,7 +212,7 @@ public function checkCacheDriver($cache) /** * Check the presence of a PHP extension * - * @param string $extension The extension + * @param string $extension The extension * * @return boolean */ diff --git a/src/Rocketeer/Tasks/Closure.php b/src/Rocketeer/Tasks/Closure.php index 899adc172..8c56c69ee 100644 --- a/src/Rocketeer/Tasks/Closure.php +++ b/src/Rocketeer/Tasks/Closure.php @@ -59,7 +59,7 @@ public function getDescription() /** * Create a task from a Closure * - * @param AnonymousFunction $closure + * @param AnonymousFunction $closure */ public function setClosure(AnonymousFunction $closure) { diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 4a55208c7..25ed6ea2a 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -131,8 +131,8 @@ public function which($binary, $fallback = null, $default = false) /** * Check the Laravel version * - * @param string $version The version to check against - * @param string $operator The operator (default: '>=') + * @param string $version The version to check against + * @param string $operator The operator (default: '>=') * * @return bool */ diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 3ca75487b..523f98ede 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -30,9 +30,9 @@ trait Core /** * Run actions on the remote server and gather the ouput * - * @param string|array $commands One or more commands - * @param boolean $silent Whether the command should stay silent no matter what - * @param boolean $array Whether the output should be returned as an array + * @param string|array $commands One or more commands + * @param boolean $silent Whether the command should stay silent no matter what + * @param boolean $array Whether the output should be returned as an array * * @return string|null */ @@ -40,7 +40,7 @@ public function run($commands, $silent = false, $array = false) { $commands = $this->processCommands($commands); $verbose = $this->getOption('verbose') && !$silent; - $pretend = $this->getOption('pretend'); + $pretend = $this->getOption('pretend'); // Log the commands if (!$silent) { @@ -95,9 +95,9 @@ public function runLast($commands) * Run a raw command, without any processing, and * get its output as a string or array * - * @param string $commands - * @param boolean $array Whether the output should be returned as an array - * @param boolean $trim Whether the output should be trimmed + * @param string $commands + * @param boolean $array Whether the output should be returned as an array + * @param boolean $trim Whether the output should be trimmed * * @return string|string[] */ @@ -131,8 +131,8 @@ public function runSilently($commands, $array = false) /** * Run commands in a folder * - * @param string|null $folder - * @param string|array $tasks + * @param string|null $folder + * @param string|array $tasks * * @return string */ @@ -152,9 +152,9 @@ public function runInFolder($folder = null, $tasks = array()) /** * Check the status of the last run command, return an error if any * - * @param string $error The message to display on error - * @param string|null $output The command's output - * @param string|null $success The message to display on success + * @param string $error The message to display on error + * @param string|null $output The command's output + * @param string|null $success The message to display on success * * @return boolean */ @@ -201,7 +201,7 @@ public function getTimestamp() /** * Process an array of commands * - * @param string|array $commands + * @param string|array $commands * * @return array */ diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index 6a5ed28b8..d9faa5d57 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -23,8 +23,8 @@ trait Filesystem /** * Symlinks two folders * - * @param string $folder The folder in shared/ - * @param string $symlink The folder that will symlink to it + * @param string $folder The folder in shared/ + * @param string $symlink The folder that will symlink to it * * @return string */ @@ -47,8 +47,8 @@ public function symlink($folder, $symlink) /** * Move a file * - * @param string $origin - * @param string $destination + * @param string $origin + * @param string $destination * * @return string */ @@ -73,7 +73,7 @@ public function copy($origin, $destination) /** * Get the contents of a directory * - * @param string $directory + * @param string $directory * * @return array */ @@ -85,7 +85,7 @@ public function listContents($directory) /** * Check if a file exists * - * @param string $file Path to the file + * @param string $file Path to the file * * @return boolean */ @@ -176,8 +176,8 @@ public function upload($file, $destination = null) /** * Create a folder in the application's folder * - * @param string|null $folder The folder to create - * @param boolean $recursive + * @param string|null $folder The folder to create + * @param boolean $recursive * * @return string The task */ @@ -191,7 +191,7 @@ public function createFolder($folder = null, $recursive = false) /** * Remove a folder in the application's folder * - * @param string|null $folder The folder to remove + * @param string|null $folder The folder to remove * * @return string The task */ diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 4ce362216..551317b1c 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -48,7 +48,7 @@ public function usesStages() /** * Run actions in the current release's folder * - * @param string|array $tasks One or more tasks + * @param string|array $tasks One or more tasks * * @return string */ @@ -98,7 +98,7 @@ public function updateSymlink($release = null) /** * Share a file or folder between releases * - * @param string $file Path to the file in a release folder + * @param string $file Path to the file in a release folder * * @return string */ diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index a99705de1..aa6a15a36 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -36,7 +36,7 @@ public function getHistory($type = null) /** * Append an entry to the history * - * @param array|string $command + * @param array|string|boolean $command */ public function toHistory($command) { @@ -46,7 +46,7 @@ public function toHistory($command) /** * Append an entry to the output * - * @param array|string $output + * @param array|string|boolean $output */ public function toOutput($output) { @@ -76,8 +76,8 @@ protected function getHistoryHandle() /** * Append something to the history * - * @param string $type - * @param string|array $command + * @param string $type + * @param string|array|boolean $command */ protected function appendTo($type, $command) { diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 34ee801f6..a9f3a31de 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -117,7 +117,7 @@ protected function hasCommand() * Get an option from the Command * * @param string $option - * @param bool $loose + * @param bool $loose * * @return string */ diff --git a/tests/Services/ConnectionsHandlerTest.php b/tests/Services/ConnectionsHandlerTest.php index 0b1ef8fe5..d628d7edf 100644 --- a/tests/Services/ConnectionsHandlerTest.php +++ b/tests/Services/ConnectionsHandlerTest.php @@ -122,9 +122,9 @@ public function testFillsConnectionCredentialsHoles() /** * Make the config return specific SCM config * - * @param string $repository - * @param string $username - * @param string $password + * @param string $repository + * @param string $username + * @param string $password * * @return void */ diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 764375f5e..40c8ec198 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -176,7 +176,7 @@ protected function getConfig($expectations = array()) /** * Swap the current config * - * @param array $config + * @param array $config * * @return void */ From f334a3d93e5c8fd4885b507b5b790eb055eb99f7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:35:02 +0200 Subject: [PATCH 215/424] Fix strategies not executing on first deploy --- .../AbstractDependenciesStrategy.php | 49 +++++++++++++++++-- .../Dependencies/BundlerStrategy.php | 20 -------- 2 files changed, 45 insertions(+), 24 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 551976637..1da149304 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -24,10 +24,51 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy */ public function isExecutable() { - $manager = $this->getManager(); - $manifest = $this->rocketeer->getFolder('current/'.$this->manifest); + return $this->getManager()->getBinary() and $this->hasManifest(); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// COMMANDS ////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Install the dependencies + * + * @return bool + */ + public function install() + { + return $this->getManager()->runForCurrentRelease('install'); + } + + /** + * Update the dependencies + * + * @return boolean + */ + public function update() + { + return $this->getManager()->runForCurrentRelease('update'); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check if the manifest file exists, locally or on server + * + * @return bool + */ + protected function hasManifest() + { + $server = $this->rocketeer->getFolder('current/'.$this->manifest); + $server = $this->bash->fileExists($server); + + $local = $this->app['path.base'].DS.$this->manifest; + $local = $this->files->exists($local); - return $manager->getBinary() and $this->bash->fileExists($manifest); + return $local || $server; } /** @@ -35,7 +76,7 @@ public function isExecutable() * * @return \Rocketeer\Abstracts\AbstractBinary */ - public function getManager() + protected function getManager() { return $this->binary($this->binary); } diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 4675da7b8..79ccda2fd 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -19,24 +19,4 @@ class BundlerStrategy extends AbstractDependenciesStrategy implements Dependenci * @type string */ protected $binary = 'bundle'; - - /** - * Install the dependencies - * - * @return bool - */ - public function install() - { - return $this->getManager()->runForCurrentRelease('install'); - } - - /** - * Update the dependencies - * - * @return boolean - */ - public function update() - { - return $this->getManager()->runForCurrentRelease('update'); - } } From 781c5a24d35b02d712f5c1423c25c1ad29c5d8d3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:35:07 +0200 Subject: [PATCH 216/424] Add Bower and NPM --- .../Strategies/Dependencies/BowerStrategy.php | 22 +++++++++++++++++++ .../Strategies/Dependencies/NpmStrategy.php | 22 +++++++++++++++++++ 2 files changed, 44 insertions(+) create mode 100644 src/Rocketeer/Strategies/Dependencies/BowerStrategy.php create mode 100644 src/Rocketeer/Strategies/Dependencies/NpmStrategy.php diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php new file mode 100644 index 000000000..ceeb8508b --- /dev/null +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -0,0 +1,22 @@ + Date: Thu, 14 Aug 2014 02:39:11 +0200 Subject: [PATCH 217/424] Add test for first time deploy dependencies --- .../Strategies/AbstractStrategyTest.php | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 tests/Abstracts/Strategies/AbstractStrategyTest.php diff --git a/tests/Abstracts/Strategies/AbstractStrategyTest.php b/tests/Abstracts/Strategies/AbstractStrategyTest.php new file mode 100644 index 000000000..ec4403bd8 --- /dev/null +++ b/tests/Abstracts/Strategies/AbstractStrategyTest.php @@ -0,0 +1,16 @@ +app['path.base'] = realpath(__DIR__.'/../../..'); + + $this->usesComposer(false); + $strategy = $this->builder->buildStrategy('Dependencies', 'Composer'); + $this->assertTrue($strategy->isExecutable()); + } +} From d85eee4d2dac0c56f7f6bda7484de1c45fa7a3d9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:40:35 +0200 Subject: [PATCH 218/424] Unify name of closure arguments --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 6 +++--- src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 878eae5fb..1f92b0dd8 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -128,16 +128,16 @@ public function buildTaskFromString($task) /** * Build a task from a Closure or a string command * - * @param Closure $closure + * @param Closure $callback * @param string|null $stringTask * * @return AbstractTask */ - public function buildTaskFromClosure(Closure $closure, $stringTask = null) + public function buildTaskFromClosure(Closure $callback, $stringTask = null) { /** @type \Rocketeer\Tasks\Closure $task */ $task = $this->buildTaskFromClass('Rocketeer\Tasks\Closure'); - $task->setClosure($closure); + $task->setClosure($callback); // If we had an original string used, store it on // the task for easier reflection diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index 87fdb0ba4..9f7bc7479 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -39,17 +39,17 @@ public function update() } /** - * @param Closure $closure + * @param Closure $callback * * @return array */ - protected function onManagers(Closure $closure) + protected function onManagers(Closure $callback) { $results = []; foreach ($this->managers as $manager) { $strategy = $this->getStrategy('Dependencies', $manager); if ($strategy) { - $results[$manager] = $closure($strategy); + $results[$manager] = $callback($strategy); } } From b5c4d8bfff51a87be1f329bdfac5c53ccd887172 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:42:10 +0200 Subject: [PATCH 219/424] Fix extra output during tests --- tests/Strategies/Test/PhpunitStrategyTest.php | 1 + 1 file changed, 1 insertion(+) diff --git a/tests/Strategies/Test/PhpunitStrategyTest.php b/tests/Strategies/Test/PhpunitStrategyTest.php index 06be0419d..0c3b7f351 100644 --- a/tests/Strategies/Test/PhpunitStrategyTest.php +++ b/tests/Strategies/Test/PhpunitStrategyTest.php @@ -7,6 +7,7 @@ class PhpunitStrategyTest extends RocketeerTestCase { public function testCanRunTests() { + $this->pretendTask(); $this->builder->buildStrategy('Test', 'Phpunit')->test(); $this->assertHistory(array( From 22d9ec21e70ee0bf25af5732f0ab02d66bb61bfc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:45:03 +0200 Subject: [PATCH 220/424] Update some inconsistence namespaces in the tests --- tests/Abstracts/AbstractStorageTest.php | 2 +- tests/Abstracts/Strategies/AbstractStrategyTest.php | 2 +- tests/Binaries/AnonymousBinaryTest.php | 2 +- tests/Binaries/ArtisanTest.php | 2 +- tests/Binaries/ComposerTest.php | 2 +- tests/Binaries/PhpTest.php | 2 +- tests/Services/CredentialsGathererTest.php | 2 +- tests/Services/History/HistoryTest.php | 2 +- tests/Services/Storages/ServerStorageTest.php | 2 +- tests/Services/Tasks/JobTest.php | 2 +- tests/Services/Tasks/TasksBuilderTest.php | 2 +- tests/Strategies/Dependencies/BundlerStrategyTest.php | 2 +- tests/Strategies/Dependencies/ComposerStrategyTest.php | 2 +- tests/Strategies/Dependencies/PolyglotStrategyTest.php | 2 +- tests/Strategies/Deploy/CloneStrategyTest.php | 2 +- tests/Strategies/Deploy/CopyStrategyTest.php | 2 +- tests/Tasks/ClosureTest.php | 2 +- 17 files changed, 17 insertions(+), 17 deletions(-) diff --git a/tests/Abstracts/AbstractStorageTest.php b/tests/Abstracts/AbstractStorageTest.php index 4fb94860f..ed3e58c2f 100644 --- a/tests/Abstracts/AbstractStorageTest.php +++ b/tests/Abstracts/AbstractStorageTest.php @@ -1,5 +1,5 @@ Date: Thu, 14 Aug 2014 02:47:32 +0200 Subject: [PATCH 221/424] Fix slow test --- .../Dependencies/ComposerStrategyTest.php | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/tests/Strategies/Dependencies/ComposerStrategyTest.php b/tests/Strategies/Dependencies/ComposerStrategyTest.php index a8f054b22..0c8bb9949 100644 --- a/tests/Strategies/Dependencies/ComposerStrategyTest.php +++ b/tests/Strategies/Dependencies/ComposerStrategyTest.php @@ -21,21 +21,16 @@ public function testCanConfigureComposerCommands() }, )); - $matcher = array( + $this->pretendTask(); + $composer = $this->builder->buildStrategy('Dependencies', 'Composer'); + $composer->install(); + + $this->assertHistory(array( array( "cd {server}/releases/{release}", "{composer} self-update", "{composer} install --prefer-source", ), - ); - - $composer = $this->builder->buildStrategy('Dependencies', 'Composer'); - $composer->install(); - - $this->assertTaskHistory($this->history->getFlattenedHistory(), $matcher, array( - 'tests' => false, - 'seed' => false, - 'migrate' => false )); } From 80b45252b5ef95a0b969e5a9604227450e3e5aee Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 02:56:37 +0200 Subject: [PATCH 222/424] Nicer badges --- README.md | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index 52658d1e8..7d8e1490c 100644 --- a/README.md +++ b/README.md @@ -1,12 +1,11 @@ # Rocketeer -[![Build Status](https://travis-ci.org/Anahkiasen/rocketeer.png?branch=master)](https://travis-ci.org/Anahkiasen/rocketeer) -[![Latest Stable Version](https://poser.pugx.org/anahkiasen/rocketeer/v/stable.png)](https://packagist.org/packages/anahkiasen/rocketeer) -[![Total Downloads](https://poser.pugx.org/anahkiasen/rocketeer/downloads.png)](https://packagist.org/packages/anahkiasen/rocketeer) -[![Scrutinizer Quality Score](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/badges/quality-score.png?s=20d9a4be6695b7677c427eab73151c1a9d803044)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) -[![Code Coverage](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/badges/coverage.png?s=f6e022cbcf1a51f82b5d9e6fb30bd1643fc70e76)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) -[![HHVM Status](http://hhvm.h4cc.de/badge/anahkiasen/rocketeer.png)](http://hhvm.h4cc.de/package/anahkiasen/rocketeer) -[![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg)](https://www.gittip.com/Anahkiasen/) +[![Build Status](http://img.shields.io/travis/Anahkiasen/rocketeer.svg?style=flat)](https://travis-ci.org/Anahkiasen/rocketeer) +[![Latest Stable Version](http://img.shields.io/packagist/v/Anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) +[![Total Downloads](http://img.shields.io/packagist/dt/Anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) +[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/Anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) +[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/Anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) +[![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg?style=flat)](https://www.gittip.com/Anahkiasen/) **Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. From 2970fed0f716fa2d99ccbcfa2c92021dd949ab23 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 09:30:34 +0200 Subject: [PATCH 223/424] Less strict server cleanup --- src/Rocketeer/Tasks/Ignite.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index a29f8be56..229d3bd7e 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -84,7 +84,7 @@ protected function getConfigurationInformations() return array_merge( $this->connections->getServerCredentials(), array( - 'connection' => preg_replace('/#[0-9]/', null, $this->connections->getConnection()), + 'connection' => preg_replace('/#[0-9]+/', null, $this->connections->getConnection()), 'scm_repository' => $repositoryCredentials['repository'], 'scm_username' => $repositoryCredentials['username'], 'scm_password' => $repositoryCredentials['password'], From 8e0ef9c3fc86962aa438653f4cf8e20436df191c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 17:44:12 +0200 Subject: [PATCH 224/424] Add some class docblocks --- src/Rocketeer/Abstracts/AbstractStorage.php | 14 +++++++++++++- .../Strategies/AbstractDependenciesStrategy.php | 13 +++++++++++++ .../Abstracts/Strategies/AbstractStrategy.php | 10 ++++++++++ src/Rocketeer/Binaries/AnonymousBinary.php | 8 ++++++++ src/Rocketeer/Binaries/Artisan.php | 8 ++++++++ src/Rocketeer/Binaries/Composer.php | 8 ++++++++ src/Rocketeer/Binaries/Php.php | 8 ++++++++ src/Rocketeer/Binaries/Phpunit.php | 8 ++++++++ .../Exceptions/TaskCompositionException.php | 8 ++++++++ src/Rocketeer/Interfaces/StorageInterface.php | 8 ++++++++ .../Strategies/DependenciesStrategyInterface.php | 8 ++++++++ .../Strategies/MigrateStrategyInterface.php | 8 ++++++++ .../Strategies/TestStrategyInterface.php | 8 ++++++++ src/Rocketeer/QueueExplainer.php | 8 ++++++++ src/Rocketeer/Services/CredentialsGatherer.php | 8 ++++++++ src/Rocketeer/Services/History/History.php | 8 ++++++++ .../Strategies/Dependencies/BowerStrategy.php | 8 ++++++++ .../Strategies/Dependencies/BundlerStrategy.php | 8 ++++++++ .../Strategies/Dependencies/ComposerStrategy.php | 8 ++++++++ .../Strategies/Dependencies/NpmStrategy.php | 8 ++++++++ .../Strategies/Dependencies/PolyglotStrategy.php | 8 ++++++++ src/Rocketeer/Strategies/Deploy/CloneStrategy.php | 8 ++++++++ src/Rocketeer/Strategies/Deploy/CopyStrategy.php | 8 ++++++++ .../Strategies/Migrate/ArtisanStrategy.php | 8 ++++++++ src/Rocketeer/Strategies/Test/PhpunitStrategy.php | 8 ++++++++ src/Rocketeer/Tasks/Dependencies.php | 8 ++++++++ src/Rocketeer/Tasks/Migrate.php | 8 ++++++++ src/Rocketeer/Tasks/Subtasks/CreateRelease.php | 8 ++++++++ 28 files changed, 236 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 0ed3369c3..b3ad87d33 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -1,11 +1,23 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Abstracts; use Closure; use Illuminate\Container\Container; use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; - +/** + * Abstract class for storage implementations + * + * @author Maxime Fabre + */ abstract class AbstractStorage { use HasLocator; diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 1da149304..8b06207e5 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -1,6 +1,19 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Abstracts\Strategies; +/** + * Abstract class for Dependencies strategies + * + * @author Maxime Fabre + */ abstract class AbstractDependenciesStrategy extends AbstractStrategy { /** diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index d81d075b8..a4c9361c7 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -1,10 +1,20 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Abstracts\Strategies; use Rocketeer\Bash; /** * Core class for strategies + * + * @author Maxime Fabre */ abstract class AbstractStrategy extends Bash { diff --git a/src/Rocketeer/Binaries/AnonymousBinary.php b/src/Rocketeer/Binaries/AnonymousBinary.php index ed608d746..d601e039d 100644 --- a/src/Rocketeer/Binaries/AnonymousBinary.php +++ b/src/Rocketeer/Binaries/AnonymousBinary.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Binaries; use Rocketeer\Abstracts\AbstractBinary; diff --git a/src/Rocketeer/Binaries/Artisan.php b/src/Rocketeer/Binaries/Artisan.php index 2039a729e..85c486835 100644 --- a/src/Rocketeer/Binaries/Artisan.php +++ b/src/Rocketeer/Binaries/Artisan.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Binaries; use Illuminate\Container\Container; diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php index e01a1103e..e8c393161 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/Composer.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Binaries; use Illuminate\Container\Container; diff --git a/src/Rocketeer/Binaries/Php.php b/src/Rocketeer/Binaries/Php.php index 948909c46..de0b41f69 100644 --- a/src/Rocketeer/Binaries/Php.php +++ b/src/Rocketeer/Binaries/Php.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Binaries; use Illuminate\Container\Container; diff --git a/src/Rocketeer/Binaries/Phpunit.php b/src/Rocketeer/Binaries/Phpunit.php index 40006a940..5afbfc1d9 100644 --- a/src/Rocketeer/Binaries/Phpunit.php +++ b/src/Rocketeer/Binaries/Phpunit.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Binaries; use Illuminate\Container\Container; diff --git a/src/Rocketeer/Exceptions/TaskCompositionException.php b/src/Rocketeer/Exceptions/TaskCompositionException.php index a9e2fb813..6729f2d22 100644 --- a/src/Rocketeer/Exceptions/TaskCompositionException.php +++ b/src/Rocketeer/Exceptions/TaskCompositionException.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Exceptions; use Exception; diff --git a/src/Rocketeer/Interfaces/StorageInterface.php b/src/Rocketeer/Interfaces/StorageInterface.php index db0eba9ae..f926a30a7 100644 --- a/src/Rocketeer/Interfaces/StorageInterface.php +++ b/src/Rocketeer/Interfaces/StorageInterface.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Interfaces; interface StorageInterface diff --git a/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php index 2bb51634e..449d6f448 100644 --- a/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php +++ b/src/Rocketeer/Interfaces/Strategies/DependenciesStrategyInterface.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Interfaces\Strategies; interface DependenciesStrategyInterface diff --git a/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php index 1e342b637..dfef20b24 100644 --- a/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php +++ b/src/Rocketeer/Interfaces/Strategies/MigrateStrategyInterface.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Interfaces\Strategies; /** diff --git a/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php index c869d4efc..2d46a5b39 100644 --- a/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php +++ b/src/Rocketeer/Interfaces/Strategies/TestStrategyInterface.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Interfaces\Strategies; interface TestStrategyInterface diff --git a/src/Rocketeer/QueueExplainer.php b/src/Rocketeer/QueueExplainer.php index d36defae5..6d4d82663 100644 --- a/src/Rocketeer/QueueExplainer.php +++ b/src/Rocketeer/QueueExplainer.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer; use Closure; diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 8a5fc5df0..37577924e 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Services; use Rocketeer\Traits\HasLocator; diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 375c75c6f..4bb2a75f0 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Services\History; use Illuminate\Support\Collection; diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php index ceeb8508b..a2fa88ca4 100644 --- a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Dependencies; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 79ccda2fd..50f1e3f01 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Dependencies; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index af60b6bbf..29797620e 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Dependencies; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; diff --git a/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php b/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php index 94be8b693..5f735c4d3 100644 --- a/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Dependencies; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index 9f7bc7479..bc70be1b4 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Dependencies; use Closure; diff --git a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php index 6d402eb32..c47879774 100644 --- a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Deploy; use Rocketeer\Abstracts\Strategies\AbstractStrategy; diff --git a/src/Rocketeer/Strategies/Deploy/CopyStrategy.php b/src/Rocketeer/Strategies/Deploy/CopyStrategy.php index a921d2c63..51d176766 100644 --- a/src/Rocketeer/Strategies/Deploy/CopyStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CopyStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Deploy; use Rocketeer\Interfaces\Strategies\DeployStrategyInterface; diff --git a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php index b3db97352..ecbf8892d 100644 --- a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php +++ b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Migrate; use Rocketeer\Abstracts\Strategies\AbstractStrategy; diff --git a/src/Rocketeer/Strategies/Test/PhpunitStrategy.php b/src/Rocketeer/Strategies/Test/PhpunitStrategy.php index e895f1f5a..83648735d 100644 --- a/src/Rocketeer/Strategies/Test/PhpunitStrategy.php +++ b/src/Rocketeer/Strategies/Test/PhpunitStrategy.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Strategies\Test; use Rocketeer\Abstracts\Strategies\AbstractStrategy; diff --git a/src/Rocketeer/Tasks/Dependencies.php b/src/Rocketeer/Tasks/Dependencies.php index 4281ca282..5d3f69189 100644 --- a/src/Rocketeer/Tasks/Dependencies.php +++ b/src/Rocketeer/Tasks/Dependencies.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Tasks; use Rocketeer\Abstracts\AbstractTask; diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index f9aa68e2f..31f5d4f54 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Tasks; use Rocketeer\Abstracts\AbstractTask; diff --git a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php index b431e69fc..9c1e7cdb1 100644 --- a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php +++ b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Tasks\Subtasks; use Rocketeer\Abstracts\AbstractTask; From e406e3f161f0fcc101a6ed681ed1d908719d029f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 14 Aug 2014 23:00:29 +0200 Subject: [PATCH 225/424] Fix task instance problem --- src/Rocketeer/RocketeerServiceProvider.php | 2 +- src/Rocketeer/Services/Tasks/TasksBuilder.php | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index bdda837f2..792f544ec 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -269,7 +269,7 @@ public function bindCommands() $fakeCommand = !class_exists($commandClass); try { - $taskInstance = $this->app['rocketeer.builder']->buildTaskFromClass($task); + $taskInstance = $this->app['rocketeer.builder']->buildTask($task); } catch (TaskCompositionException $exception) { $taskInstance = null; } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 1f92b0dd8..0daabc1f2 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -101,6 +101,11 @@ public function buildTask($task, $name = null, $description = null) $task = $this->buildTaskFromClass($task); } + // If the built class is invalid, cancel + if (!$task instanceof AbstractTask) { + throw new TaskCompositionException('Class '.get_class($task). ' is not a valid task'); + } + // Set task properties $task->setName($name); $task->setDescription($description); From 2efc12e7fe8d2bdac3e9ef084b87f78a88a48cd7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 00:58:16 +0200 Subject: [PATCH 226/424] Fix call to command --- src/Rocketeer/QueueExplainer.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/QueueExplainer.php b/src/Rocketeer/QueueExplainer.php index 6d4d82663..de86f1637 100644 --- a/src/Rocketeer/QueueExplainer.php +++ b/src/Rocketeer/QueueExplainer.php @@ -36,7 +36,7 @@ class QueueExplainer */ public function displayBelow(Closure $callback) { - if (!$this->command) { + if (!$this->hasCommand()) { return $callback(); } @@ -56,7 +56,7 @@ public function displayBelow(Closure $callback) */ public function display($object, $subject, $details = null) { - if (!$this->command) { + if (!$this->hasCommand()) { return; } From 723956cba3555d0ea3ef83c1b9296b6edb5c556d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 01:21:32 +0200 Subject: [PATCH 227/424] Simpler path definitions for binaries --- src/Rocketeer/Abstracts/AbstractBinary.php | 25 ++++++++++++++++++++++ src/Rocketeer/Binaries/Artisan.php | 19 ++++++++++------ src/Rocketeer/Binaries/Composer.php | 13 +++++------ src/Rocketeer/Binaries/Php.php | 10 ++++----- src/Rocketeer/Binaries/Phpunit.php | 11 +++++----- 5 files changed, 53 insertions(+), 25 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 79f2317fc..bff0db17e 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Abstracts; +use Illuminate\Container\Container; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; @@ -35,6 +36,30 @@ class AbstractBinary */ protected $parent; + /** + * @param Container $app + */ + public function __construct(Container $app) + { + $this->app = $app; + + // Assign default paths + if ($paths = $this->getKnownPaths()) { + $binary = call_user_func_array([$this->bash, 'which'], $paths); + $this->setBinary($binary); + } + } + + /** + * Get an array of default paths to look for + * + * @return array + */ + protected function getKnownPaths() + { + return []; + } + ////////////////////////////////////////////////////////////////////// ///////////////////////////// PROPERTIES ///////////////////////////// ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Binaries/Artisan.php b/src/Rocketeer/Binaries/Artisan.php index 85c486835..324bdb5ce 100644 --- a/src/Rocketeer/Binaries/Artisan.php +++ b/src/Rocketeer/Binaries/Artisan.php @@ -21,16 +21,23 @@ public function __construct(Container $app) { parent::__construct($app); - // Set binary path - $this->binary = $this->bash->which( + // Set PHP as parent + $php = new Php($this->app); + $this->setParent($php); + } + + /** + * Get an array of default paths to look for + * + * @return array + */ + protected function getKnownPaths() + { + return array( 'artisan', $this->releasesManager->getCurrentReleasePath().'/artisan', 'artisan' ); - - // Set PHP as parent - $php = new Php($this->app); - $this->setParent($php); } /** diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php index e8c393161..fd67f9234 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/Composer.php @@ -15,19 +15,16 @@ class Composer extends AbstractBinary { /** - * @param Container $app + * Get an array of default paths to look for + * + * @return array */ - public function __construct(Container $app) + protected function getKnownPaths() { - parent::__construct($app); - - $binary = $this->bash->which( + return array( 'composer', $this->releasesManager->getCurrentReleasePath().'/composer.phar' ); - - // Set binary path - $this->setBinary($binary); } /** diff --git a/src/Rocketeer/Binaries/Php.php b/src/Rocketeer/Binaries/Php.php index de0b41f69..d9eafb42c 100644 --- a/src/Rocketeer/Binaries/Php.php +++ b/src/Rocketeer/Binaries/Php.php @@ -15,13 +15,13 @@ class Php extends AbstractBinary { /** - * @param Container $app + * Get an array of default paths to look for + * + * @return array */ - public function __construct(Container $app) + protected function getKnownPaths() { - parent::__construct($app); - - $this->binary = $this->bash->which('php'); + return ['php']; } /** diff --git a/src/Rocketeer/Binaries/Phpunit.php b/src/Rocketeer/Binaries/Phpunit.php index 5afbfc1d9..934d579ec 100644 --- a/src/Rocketeer/Binaries/Phpunit.php +++ b/src/Rocketeer/Binaries/Phpunit.php @@ -15,14 +15,13 @@ class Phpunit extends AbstractBinary { /** - * @param Container $app + * Get an array of default paths to look for + * + * @return array */ - public function __construct(Container $app) + protected function getKnownPaths() { - parent::__construct($app); - - // Set binary path - $this->binary = $this->bash->which( + return array( 'phpunit', $this->releasesManager->getCurrentReleasePath().'/vendor/bin/phpunit' ); From 6c1df7e63993462a6392c2907282ed85bb3dc427 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 01:21:45 +0200 Subject: [PATCH 228/424] Make execute return the output --- src/Rocketeer/Services/Tasks/TasksQueue.php | 8 ++++++-- src/Rocketeer/Traits/BashModules/Binaries.php | 6 +++--- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index b3b2c6328..9ba5632a6 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -60,7 +60,8 @@ public function setParallel($parallel) //////////////////////////////////////////////////////////////////// /** - * Execute Tasks on the default connection + * Execute Tasks on the default connection and + * return their output * * @param string|array|Closure $queue * @param string|string[]|null $connections @@ -73,7 +74,10 @@ public function execute($queue, $connections = null) $this->connections->setConnections($connections); } - return $this->run($queue); + // Run tasks + $this->run($queue); + + return $this->history->getFlattenedOutput(); } /** diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 25ed6ea2a..2b4edabb1 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -97,9 +97,9 @@ public function which($binary, $fallback = null, $default = false) { $location = false; $locations = array( - array($this->localStorage, 'get', 'paths.'.$binary), - array($this->rocketeer, 'getPath', $binary), - array($this, 'runSilently', 'which '.$binary), + [$this->localStorage, 'get', 'paths.'.$binary], + [$this->rocketeer, 'getPath', $binary], + [$this, 'runSilently', 'which '.$binary], ); // Add fallback if provided From 16abd63aeffccedff93c53f5c8e38f6f805cdd86 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 01:21:49 +0200 Subject: [PATCH 229/424] Add Bower --- src/Rocketeer/Binaries/Bower.php | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 src/Rocketeer/Binaries/Bower.php diff --git a/src/Rocketeer/Binaries/Bower.php b/src/Rocketeer/Binaries/Bower.php new file mode 100644 index 000000000..c819c0603 --- /dev/null +++ b/src/Rocketeer/Binaries/Bower.php @@ -0,0 +1,21 @@ +releasesManager->getCurrentReleasePath().'/node_modules/.bin/bower' + ); + } +} From 57e2f379482180b07308ac807a308b52f011d7d6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 01:32:03 +0200 Subject: [PATCH 230/424] Fix logic flaw in which() method --- src/Rocketeer/Traits/BashModules/Binaries.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 2b4edabb1..6dce3c391 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -119,6 +119,7 @@ public function which($binary, $fallback = null, $default = false) list($object, $method, $argument) = $locations[$tryout]; $location = $object->$method($argument); + $location = strpos($location, 'not found') !== false ? null : $location; $tryout++; } From a6370bf43db11fab04b3c6f3f62f137764f604dd Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 01:35:21 +0200 Subject: [PATCH 231/424] Break vendor search on first --- bin/rocketeer | 1 + 1 file changed, 1 insertion(+) diff --git a/bin/rocketeer b/bin/rocketeer index e3377d588..624f1e04c 100755 --- a/bin/rocketeer +++ b/bin/rocketeer @@ -11,6 +11,7 @@ $vendors = array( foreach ($vendors as $vendor) { if (file_exists($vendor)) { require_once $vendor; + break; } } From c323612f4d2a06c43aee421ca4b9b9894aa5e6cc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 01:45:04 +0200 Subject: [PATCH 232/424] Update tests --- tests/Services/Tasks/TasksQueueTest.php | 5 ++--- tests/Strategies/Dependencies/BundlerStrategyTest.php | 2 ++ 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 5d2567c7c..454be7f36 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -73,17 +73,16 @@ public function testCanRunOnMultipleConnectionsViaOn() 'rocketeer::stages.stages' => array('first', 'second'), )); - $status = $this->queue->on(array('staging', 'production'), function ($task) { + $results = $this->queue->on(array('staging', 'production'), function ($task) { return $task->connections->getConnection().' - '.$task->connections->getStage(); }); - $this->assertTrue($status); $this->assertEquals(array( 'staging - first', 'staging - second', 'production - first', 'production - second', - ), $this->history->getFlattenedOutput()); + ), $results); } public function testCanRunTasksInParallel() diff --git a/tests/Strategies/Dependencies/BundlerStrategyTest.php b/tests/Strategies/Dependencies/BundlerStrategyTest.php index fdcd707f8..e1da7deca 100644 --- a/tests/Strategies/Dependencies/BundlerStrategyTest.php +++ b/tests/Strategies/Dependencies/BundlerStrategyTest.php @@ -7,6 +7,7 @@ class BundlerStrategyTest extends RocketeerTestCase { public function testCanInstallDependencies() { + $this->pretend(); $bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); $bundler->install(); @@ -20,6 +21,7 @@ public function testCanInstallDependencies() public function testCanUpdateDependencies() { + $this->pretend(); $bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); $bundler->update(); From e3b7cb1242c2592530f71d4670993088d2fb9383 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 02:15:52 +0200 Subject: [PATCH 233/424] Add tasks timer --- src/Rocketeer/Abstracts/AbstractTask.php | 13 ++- src/Rocketeer/RocketeerServiceProvider.php | 6 + .../{ => Services/Display}/QueueExplainer.php | 16 ++- src/Rocketeer/Services/Display/QueueTimer.php | 106 ++++++++++++++++++ src/Rocketeer/Traits/HasLocator.php | 42 +++---- tests/Plugins/AbstractNotifierTest.php | 1 + 6 files changed, 157 insertions(+), 27 deletions(-) rename src/Rocketeer/{ => Services/Display}/QueueExplainer.php (78%) create mode 100644 src/Rocketeer/Services/Display/QueueTimer.php diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index fe0b01d1a..412041ddb 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -12,6 +12,7 @@ use DateTime; use Illuminate\Support\Str; use Rocketeer\Bash; +use Rocketeer\Traits\HasTimer; use Symfony\Component\Console\Helper\Table; /** @@ -116,17 +117,18 @@ abstract public function execute(); public function fire() { // Print status + $results = false; $this->displayStatus(); // Fire the task if the before event passes if ($this->fireEvent('before')) { - $results = $this->execute(); + $this->timer->time($this, function () use (&$results) { + $results = $this->execute(); + }); $this->fireEvent('after'); - - return $results; } - return false; + return $results; } /** @@ -245,7 +247,8 @@ protected function displayStatus() { $name = $this->getName(); $description = $this->getDescription(); + $time = $this->timer->getTaskTime($this); - $this->explainer->display('Running', $name, $description); + $this->explainer->display('Running', $name, $description, $time); } } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 792f544ec..afef951db 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -21,6 +21,8 @@ use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\Services\ConnectionsHandler; use Rocketeer\Services\CredentialsGatherer; +use Rocketeer\Services\Display\QueueExplainer; +use Rocketeer\Services\Display\QueueTimer; use Rocketeer\Services\History\History; use Rocketeer\Services\History\LogsHandler; use Rocketeer\Services\ReleasesManager; @@ -157,6 +159,10 @@ public function bindCoreClasses() return new QueueExplainer($app); }); + $this->app->bind('rocketeer.timer', function ($app) { + return new QueueTimer($app); + }); + $this->app->singleton('rocketeer.releases', function ($app) { return new ReleasesManager($app); }); diff --git a/src/Rocketeer/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php similarity index 78% rename from src/Rocketeer/QueueExplainer.php rename to src/Rocketeer/Services/Display/QueueExplainer.php index de86f1637..f8e29ff64 100644 --- a/src/Rocketeer/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -7,11 +7,17 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer; +namespace Rocketeer\Services\Display; use Closure; use Rocketeer\Traits\HasLocator; +/** + * Gives some insight into what task is executing, + * what it's doing, what its parent is, etc. + * + * @author Maxime Fabre + */ class QueueExplainer { use HasLocator; @@ -53,8 +59,9 @@ public function displayBelow(Closure $callback) * @param string $object * @param string $subject * @param string|null $details + * @param float|null $time */ - public function display($object, $subject, $details = null) + public function display($object, $subject, $details = null, $time = null) { if (!$this->hasCommand()) { return; @@ -63,9 +70,14 @@ public function display($object, $subject, $details = null) // Build status $tree = str_repeat('-', $this->level); $comment = sprintf('%s %s: %s', $tree, $object, $subject); + + // Add details if ($details) { $comment .= ' ('.$details.')'; } + if ($time) { + $comment .= ' [~' .$time. 's]'; + } $this->command->line($comment); } diff --git a/src/Rocketeer/Services/Display/QueueTimer.php b/src/Rocketeer/Services/Display/QueueTimer.php new file mode 100644 index 000000000..97f2dd647 --- /dev/null +++ b/src/Rocketeer/Services/Display/QueueTimer.php @@ -0,0 +1,106 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Display; + +use Closure; +use Rocketeer\Abstracts\AbstractTask; +use Rocketeer\Traits\HasLocator; + +/** + * Saves the execution time of tasks and + * predicts their future ones + * + * @author Maxime Fabre + */ +class QueueTimer +{ + use HasLocator; + + /** + * Time a task operation + * + * @param AbstractTask $task + * @param Closure $callback + * + * @return boolean + */ + public function time(AbstractTask $task, Closure $callback) + { + // Start timer, execute callback, close timer + $timerStart = microtime(true); + $callback(); + $time = round(microtime(true) - $timerStart, 4); + + $this->saveTaskTime($task, $time); + } + + /** + * Save the execution time of a task for future reference + * + * @param AbstractTask $task + * @param float $time + */ + public function saveTaskTime(AbstractTask $task, $time) + { + // Append the new time to past ones + $past = $this->getTaskTimes($task); + $past[] = $time; + + $this->saveTaskTimes($task, $past); + } + + /** + * Compute the predicted execution time of a task + * + * @param AbstractTask $task + * + * @return float + */ + public function getTaskTime(AbstractTask $task) + { + $past = $this->getTaskTimes($task); + if (!$past) { + return; + } + + // Compute average time + $average = array_sum($past) / count($past); + $average = round($average, 2); + + return $average; + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////// SETTERS/GETTERS /////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * @param AbstractTask $task + * + * @return array + */ + protected function getTaskTimes(AbstractTask $task) + { + $handle = sprintf('times.%s', $task->getSlug()); + $past = $this->localStorage->get($handle, []); + + return $past; + } + + /** + * @param AbstractTask $task + * @param array $past + */ + protected function saveTaskTimes(AbstractTask $task, array $past) + { + $handle = sprintf('times.%s', $task->getSlug()); + $this->localStorage->set($handle, $past); + } +} diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index a9f3a31de..411720452 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -15,26 +15,27 @@ * A trait for Service Locator-based classes wich adds * a few shortcuts to Rocketeer classes * - * @property \Illuminate\Config\Repository config - * @property \Illuminate\Events\Dispatcher events - * @property \Illuminate\Filesystem\Filesystem files - * @property \Illuminate\Log\Writer log - * @property \Illuminate\Remote\Connection remote - * @property \Rocketeer\Abstracts\AbstractCommand command - * @property \Rocketeer\Bash bash - * @property \Rocketeer\QueueExplainer explainer - * @property \Rocketeer\Console\Console console - * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy - * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections - * @property \Rocketeer\Services\CredentialsGatherer credentials - * @property \Rocketeer\Services\History\History history - * @property \Rocketeer\Services\ReleasesManager releasesManager - * @property \Rocketeer\Services\Storages\LocalStorage localStorage - * @property \Rocketeer\Services\Tasks\TasksBuilder builder - * @property \Rocketeer\Services\Tasks\TasksQueue queue - * @property \Rocketeer\Services\TasksHandler tasks + * @property \Illuminate\Config\Repository config + * @property \Illuminate\Events\Dispatcher events + * @property \Illuminate\Filesystem\Filesystem files + * @property \Illuminate\Log\Writer log + * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Abstracts\AbstractCommand command + * @property \Rocketeer\Bash bash + * @property \Rocketeer\Services\Display\QueueExplainer explainer + * @property \Rocketeer\Services\Display\QueueTimer timer + * @property \Rocketeer\Console\Console console + * @property \Rocketeer\Interfaces\ScmInterface scm + * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy + * @property \Rocketeer\Rocketeer rocketeer + * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\CredentialsGatherer credentials + * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\ReleasesManager releasesManager + * @property \Rocketeer\Services\Storages\LocalStorage localStorage + * @property \Rocketeer\Services\Tasks\TasksBuilder builder + * @property \Rocketeer\Services\Tasks\TasksQueue queue + * @property \Rocketeer\Services\TasksHandler tasks * @author Maxime Fabre */ trait HasLocator @@ -73,6 +74,7 @@ public function __get($key) 'console' => 'rocketeer.console', 'credentials' => 'rocketeer.credentials', 'explainer' => 'rocketeer.explainer', + 'timer' => 'rocketeer.timer', 'history' => 'rocketeer.history', 'localStorage' => 'rocketeer.storage.local', 'logs' => 'rocketeer.logs', diff --git a/tests/Plugins/AbstractNotifierTest.php b/tests/Plugins/AbstractNotifierTest.php index d7b07fcea..5ff8e5b2c 100644 --- a/tests/Plugins/AbstractNotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -32,6 +32,7 @@ public function testCanAskForNameIfNoneProvided() $this->mockCommand([], ['ask' => 'foobar']); $this->mock('rocketeer.storage.local', 'LocalStorage', function ($mock) { return $mock + ->shouldIgnoreMissing() ->shouldReceive('get')->with('connections') ->shouldReceive('get')->with('notifier.name')->andReturn(null) ->shouldReceive('set')->once()->with('notifier.name', 'foobar'); From e8750bc12411d5f41d21feb640da6443babd7a60 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 02:19:39 +0200 Subject: [PATCH 234/424] Don't save times in pretend mode --- src/Rocketeer/Services/Display/QueueTimer.php | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/Rocketeer/Services/Display/QueueTimer.php b/src/Rocketeer/Services/Display/QueueTimer.php index 97f2dd647..fd4bd413c 100644 --- a/src/Rocketeer/Services/Display/QueueTimer.php +++ b/src/Rocketeer/Services/Display/QueueTimer.php @@ -49,6 +49,11 @@ public function time(AbstractTask $task, Closure $callback) */ public function saveTaskTime(AbstractTask $task, $time) { + // Don't save times in pretend mode + if ($this->getOption('pretend')) { + return; + } + // Append the new time to past ones $past = $this->getTaskTimes($task); $past[] = $time; From 54eb0825a7300e578ba0bba58f6b5e2c55b6401d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 02:41:57 +0200 Subject: [PATCH 235/424] Only return last line in execute --- src/Rocketeer/Services/Tasks/TasksQueue.php | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 9ba5632a6..bf37574a6 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -76,8 +76,9 @@ public function execute($queue, $connections = null) // Run tasks $this->run($queue); + $history = $this->history->getFlattenedOutput(); - return $this->history->getFlattenedOutput(); + return end($history); } /** From 7af3e4baf51613a3e84a5085f8483c1155e8cf39 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 03:05:57 +0200 Subject: [PATCH 236/424] Add shell workaround option for now --- src/Rocketeer/Traits/BashModules/Core.php | 7 +++++++ src/config/remote.php | 4 ++++ 2 files changed, 11 insertions(+) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 523f98ede..4c8102b68 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -209,6 +209,8 @@ public function processCommands($commands) { $stage = $this->connections->getStage(); $separator = $this->localStorage->getSeparator(); + $shell = $this->rocketeer->getOption('remote.login'); + $shelled = ['npm ', 'bundle ', 'grunt']; // Cast commands to array if (!is_array($commands)) { @@ -227,6 +229,11 @@ public function processCommands($commands) if (Str::contains($command, 'artisan') and $stage) { $command .= ' --env="'.$stage.'"'; } + + // Create shell if asked + if ($shell && Str::contains($command, $shelled)) { + $command = "bash --login -c '".$command."'"; + } } return $commands; diff --git a/src/config/remote.php b/src/config/remote.php index 471a2b57b..2db1a5ce9 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -36,6 +36,10 @@ // Permissions //////////////////////////////////////////////////////////////////// + // If enabled will force a shell to be created on some commands + // which is requried for some tools like RVM or NVM + 'login' => false, + 'permissions' => array( // The folders and files to set as web writable From d967d145a367f008ad36fc138ce6f5b8c930c512 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 03:06:48 +0200 Subject: [PATCH 237/424] Fix tests --- tests/Services/Tasks/TasksQueueTest.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 454be7f36..6f184e253 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -73,7 +73,7 @@ public function testCanRunOnMultipleConnectionsViaOn() 'rocketeer::stages.stages' => array('first', 'second'), )); - $results = $this->queue->on(array('staging', 'production'), function ($task) { + $this->queue->on(array('staging', 'production'), function ($task) { return $task->connections->getConnection().' - '.$task->connections->getStage(); }); @@ -82,7 +82,7 @@ public function testCanRunOnMultipleConnectionsViaOn() 'staging - second', 'production - first', 'production - second', - ), $results); + ), $this->history->getFlattenedOutput()); } public function testCanRunTasksInParallel() From b7119f28a72d1ad931474ea593cf9d8a055bfdeb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 03:25:38 +0200 Subject: [PATCH 238/424] Fix BowerStrategy when under root --- .../Strategies/Dependencies/BowerStrategy.php | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php index a2fa88ca4..44c478352 100644 --- a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -27,4 +27,47 @@ class BowerStrategy extends AbstractDependenciesStrategy implements Dependencies * @type string */ protected $binary = 'bower'; + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// COMMANDS ////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Install the dependencies + * + * @return bool + */ + public function install() + { + return $this->getManager()->runForCurrentRelease('install', [], $this->getInstallationOptions()); + } + + /** + * Update the dependencies + * + * @return boolean + */ + public function update() + { + return $this->getManager()->runForCurrentRelease('update', [], $this->getInstallationOptions()); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the options to run Bower with + * + * @return array + */ + protected function getInstallationOptions() + { + $credentials = $this->connections->getServerCredentials(); + if (array_get($credentials, 'username') == 'root') { + return ['--allow-root' => null]; + } + + return []; + } } From 3bc9dce7e19915f475e80fd81588b0d9b21852ad Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 03:25:43 +0200 Subject: [PATCH 239/424] Tweak shell options --- src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- src/config/remote.php | 28 ++++++++++++++--------- 2 files changed, 19 insertions(+), 13 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 4c8102b68..77bae58b4 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -209,8 +209,8 @@ public function processCommands($commands) { $stage = $this->connections->getStage(); $separator = $this->localStorage->getSeparator(); - $shell = $this->rocketeer->getOption('remote.login'); - $shelled = ['npm ', 'bundle ', 'grunt']; + $shell = $this->rocketeer->getOption('remote.shell'); + $shelled = $this->rocketeer->getOption('remote.shelled'); // Cast commands to array if (!is_array($commands)) { diff --git a/src/config/remote.php b/src/config/remote.php index 2db1a5ce9..f81bdc322 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -7,45 +7,51 @@ // Variables about the servers. Those can be guessed but in // case of problem it's best to input those manually - 'variables' => array( + 'variables' => array( 'directory_separator' => '/', 'line_endings' => "\n", ), // The number of releases to keep at all times - 'keep_releases' => 4, + 'keep_releases' => 4, // Folders //////////////////////////////////////////////////////////////////// // The root directory where your applications will be deployed - 'root_directory' => '/home/www/', + 'root_directory' => '/home/www/', // The folder the application will be cloned in // Leave empty to use `application_name` as your folder name - 'app_directory' => '', + 'app_directory' => '', // A list of folders/file to be shared between releases // Use this to list folders that need to keep their state, like // user uploaded data, file-based databases, etc. - 'shared' => array( + 'shared' => array( '{path.storage}/logs', '{path.storage}/sessions', ), - // Permissions - //////////////////////////////////////////////////////////////////// + // Execution + ////////////////////////////////////////////////////////////////////// - // If enabled will force a shell to be created on some commands + // If enabled will force a shell to be created // which is requried for some tools like RVM or NVM - 'login' => false, + 'shell' => false, + + // An array of commands to run under shell + 'shelled' => ['npm ', 'bundle ', 'grunt'], + + // Permissions + //////////////////////////////////////////////////////////////////// - 'permissions' => array( + 'permissions' => array( // The folders and files to set as web writable // You can pass paths in brackets, so {path.public} will return // the correct path to the public folder - 'files' => array( + 'files' => array( 'app/database/production.sqlite', '{path.storage}', '{path.public}', From d5e4daf4f7d080f519e1192755a6dd8a8eef06a9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 18:37:06 +0200 Subject: [PATCH 240/424] Simpler upload method --- src/Rocketeer/Traits/BashModules/Filesystem.php | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index d9faa5d57..81a26be48 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -164,9 +164,8 @@ public function upload($file, $destination = null) // Get contents and destination $destination = $destination ?: basename($file); - $contents = file_get_contents($file); - $this->putFile($destination, $contents); + $this->remote->put($file, $destination); } //////////////////////////////////////////////////////////////////// From 1030ffea3c5fc2cb7c4450fe1d7ab08733b61cc8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 20:56:37 +0200 Subject: [PATCH 241/424] Add Pipeline task --- src/Rocketeer/Services/Tasks/Pipeline.php | 70 +++++++++++++++++++++ src/Rocketeer/Services/Tasks/TasksQueue.php | 47 ++++++++------ tests/Services/Tasks/TasksQueueTest.php | 25 +++++--- 3 files changed, 114 insertions(+), 28 deletions(-) create mode 100644 src/Rocketeer/Services/Tasks/Pipeline.php diff --git a/src/Rocketeer/Services/Tasks/Pipeline.php b/src/Rocketeer/Services/Tasks/Pipeline.php new file mode 100644 index 000000000..0176a9d89 --- /dev/null +++ b/src/Rocketeer/Services/Tasks/Pipeline.php @@ -0,0 +1,70 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Tasks; + +use Illuminate\Support\Collection; + +/** + * A class representing a pipeline of jobs + * to be executed + * + * @author Maxime Fabre + */ +class Pipeline extends Collection +{ + /** + * The stored results of each task + * + * @type array + */ + protected $results = []; + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// RESULTS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check if the pipeline failed + * + * @return boolean + */ + public function failed() + { + $succeeded = count(array_filter($this->results)); + + return $succeeded != $this->count(); + } + + /** + * Check if the pipeline ran its course + * + * @return boolean + */ + public function succeeded() + { + return !$this->failed(); + } + + /** + * @return array + */ + public function getResults() + { + return $this->results; + } + + /** + * @param array $results + */ + public function setResults($results) + { + $this->results = $results; + } +} diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index bf37574a6..a0d028efa 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -11,7 +11,6 @@ use Closure; use Exception; -use Illuminate\Support\Collection; use KzykHys\Parallel\Parallel; use Rocketeer\Connection; use Rocketeer\Traits\HasHistory; @@ -106,7 +105,7 @@ public function on($connections, $queue) * @param string|array $tasks An array of tasks * * @throws Exception - * @return boolean + * @return Pipeline */ public function run($tasks) { @@ -121,13 +120,14 @@ public function run($tasks) }; } + // Run the tasks and store the results if ($this->getOption('parallel')) { - $results = $this->runAsynchronously($pipeline); + $pipeline = $this->runAsynchronously($pipeline); } else { - $results = $this->runSynchronously($pipeline); + $pipeline = $this->runSynchronously($pipeline); } - return $results; + return $pipeline; } /** @@ -135,12 +135,12 @@ public function run($tasks) * * @param array $queue * - * @return Collection + * @return Pipeline */ public function buildPipeline(array $queue) { // First we'll build the queue - $pipeline = new Collection(); + $pipeline = new Pipeline(); // Get the connections to execute the tasks on $connections = (array) $this->connections->getConnections(); @@ -206,38 +206,47 @@ protected function executeJob(Job $job) * Run the pipeline in order. * As long as the previous entry didn't fail, continue * - * @param Collection $pipeline + * @param Pipeline $pipeline * - * @return boolean + * @return Pipeline */ - protected function runSynchronously(Collection $pipeline) + protected function runSynchronously(Pipeline $pipeline) { + $results = []; + /** @type Closure $task */ - foreach ($pipeline as $task) { - if (!$task()) { - return false; + foreach ($pipeline as $key => $task) { + $results[$key] = $task(); + if (!$results[$key]) { + break; } } - return true; + // Update Pipeline results + $pipeline->setResults($results); + + return $pipeline; } /** - * @param Collection $pipeline + * Run the pipeline in parallel order * - * @return boolean + * @param Pipeline $pipeline + * + * @return Pipeline * @throws \Exception */ - protected function runAsynchronously(Collection $pipeline) + protected function runAsynchronously(Pipeline $pipeline) { if (!extension_loaded('pcntl')) { throw new Exception('Parallel jobs require the PCNTL extension'); } $this->parallel = $this->parallel ?: new Parallel(); - $this->parallel->run($pipeline->all()); + $results = $this->parallel->values($pipeline->all()); + $pipeline->setResults($results); - return true; + return $pipeline; } //////////////////////////////////////////////////////////////////// diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 6f184e253..54122f414 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -35,9 +35,9 @@ function ($task) use (&$output) { } ); - $status = $this->queue->run($queue); + $pipeline = $this->queue->run($queue); - $this->assertTrue($status); + $this->assertTrue($pipeline->succeeded()); $this->assertEquals(array( 'staging - first', 'staging - second', @@ -52,7 +52,7 @@ public function testCanRunQueueViaExecute() 'rocketeer::default' => 'production', )); - $status = $this->queue->run(array( + $pipeline = $this->queue->run(array( 'ls -a', function () { return 'JOEY DOESNT SHARE FOOD'; @@ -60,7 +60,7 @@ function () { )); $output = array_slice($this->history->getFlattenedOutput(), 2, 3); - $this->assertTrue($status); + $this->assertTrue($pipeline->succeeded()); $this->assertEquals(array( '.'.PHP_EOL.'..'.PHP_EOL.'.gitkeep', 'JOEY DOESNT SHARE FOOD', @@ -88,13 +88,20 @@ public function testCanRunOnMultipleConnectionsViaOn() public function testCanRunTasksInParallel() { $parallel = Mockery::mock('Parallel') - ->shouldReceive('run')->once()->with(Mockery::type('array')) + ->shouldReceive('values')->once()->with(Mockery::type('array')) ->mock(); $this->mockCommand(['parallel' => true]); - $this->tasksQueue()->setParallel($parallel); + $this->queue->setParallel($parallel); - $this->tasksQueue()->execute(['ls', 'ls']); + $task = function() { + sleep(1); + return time(); + }; + + $this->queue->execute(array( + $task, $task + )); } public function testCanCancelQueueIfTaskFails() @@ -107,12 +114,12 @@ public function testCanCancelQueueIfTaskFails() }, )); - $status = $this->queue->run(array( + $pipeline = $this->queue->run(array( 'Rocketeer\Dummies\MyCustomHaltingTask', 'Rocketeer\Dummies\MyCustomTask', )); - $this->assertFalse($status); + $this->assertTrue($pipeline->failed()); $this->assertEquals([false], $this->history->getFlattenedOutput()); } } From af762798eaa907ba9f9c4d2809940bcadb4f9b88 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 21:15:17 +0200 Subject: [PATCH 242/424] Work on local tasks --- src/Rocketeer/Igniter.php | 14 +-- src/Rocketeer/LocalConnection.php | 124 ++++++++++++++++++++++ src/Rocketeer/Traits/BashModules/Core.php | 33 +++++- tests/Traits/BashModules/CoreTest.php | 12 +++ 4 files changed, 173 insertions(+), 10 deletions(-) create mode 100644 src/Rocketeer/LocalConnection.php diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index a06076fdc..116ba6275 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -1,12 +1,12 @@ - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ +* This file is part of Rocketeer +* +* (c) Maxime Fabre +* +* For the full copyright and license information, please view the LICENSE +* file that was distributed with this source code. +*/ namespace Rocketeer; use Rocketeer\Traits\HasLocator; diff --git a/src/Rocketeer/LocalConnection.php b/src/Rocketeer/LocalConnection.php new file mode 100644 index 000000000..4e053221e --- /dev/null +++ b/src/Rocketeer/LocalConnection.php @@ -0,0 +1,124 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer; + +use Closure; +use Illuminate\Remote\ConnectionInterface; +use Rocketeer\Traits\HasLocator; + +/** + * Stub of local connections to make Rocketeer work + * locally when necessary + * + * @author Maxime Fabre + */ +class LocalConnection implements ConnectionInterface +{ + use HasLocator; + + /** + * Define a set of commands as a task. + * + * @param string $task + * @param string|array $commands + * + * @return void + */ + public function define($task, $commands) + { + // ... + } + + /** + * Run a task against the connection. + * + * @param string $task + * @param \Closure $callback + * + * @return void + */ + public function task($task, Closure $callback = null) + { + // ... + } + + /** + * Run a set of commands against the connection. + * + * @param string|array $commands + * @param \Closure $callback + * + * @return void + */ + public function run($commands, Closure $callback = null) + { + $commands = (array) $commands; + foreach ($commands as $command) { + exec($command, $output); + + if ($callback) { + $output = implode(PHP_EOL, $output); + $callback($output); + } + } + } + + /** + * Upload a local file to the server. + * + * @param string $local + * @param string $remote + * + * @return void + */ + public function put($local, $remote) + { + $local = $this->files->get($local); + + return $this->putString($local, $remote); + } + + /** + * Get the contents of a remote file. + * + * @param string $remote + * @return string + */ + public function getString($remote) + { + return $this->files->get($remote); + } + + /** + * Display the given line using the default output. + * + * @param string $line + * @return void + */ + public function display($line) + { + $lead = '[local]'; + + $this->command->line($lead.' '.$line); + } + + /** + * Upload a string to to the given file on the server. + * + * @param string $remote + * @param string $contents + * + * @return void + */ + public function putString($remote, $contents) + { + return $this->files->put($remote, $contents); + } +} diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 77bae58b4..2b33690a5 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -10,6 +10,7 @@ namespace Rocketeer\Traits\BashModules; use Illuminate\Support\Str; +use Rocketeer\LocalConnection; use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; @@ -23,6 +24,32 @@ trait Core use HasLocator; use HasHistory; + /** + * Whether to run the commands locally + * or on the server + * + * @type boolean + */ + protected $local = false; + + /** + * @param boolean $local + */ + public function setLocal($local) + { + $this->local = $local; + } + + /** + * Get which Connection to call commands with + * + * @return \Illuminate\Remote\ConnectionInterface + */ + public function getConnection() + { + return $this->local ? new LocalConnection($this->app) : $this->remote; + } + //////////////////////////////////////////////////////////////////// ///////////////////////////// CORE METHODS ///////////////////////// //////////////////////////////////////////////////////////////////// @@ -60,11 +87,11 @@ public function run($commands, $silent = false, $array = false) // Run commands $output = null; - $this->remote->run($commands, function ($results) use (&$output, $verbose) { + $this->getConnection()->run($commands, function ($results) use (&$output, $verbose) { $output .= $results; if ($verbose) { - $this->remote->display(trim($results)); + $this->getConnection()->display(trim($results)); } }); @@ -105,7 +132,7 @@ public function runRaw($commands, $array = false, $trim = false) { // Run commands $output = null; - $this->remote->run($commands, function ($results) use (&$output) { + $this->getConnection()->run($commands, function ($results) use (&$output) { $output .= $results; }); diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index e8bb61ad4..c3d542b44 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -64,4 +64,16 @@ public function testCanRemoveCommonPollutingOutput() $this->assertEquals('something', $result); } + + public function testCanRunCommandsLocally() + { + $this->mock('remote', 'Remote', function ($mock) { + return $mock->shouldReceive('run')->never(); + }); + + $this->task->setLocal(true); + $contents = $this->task->runRaw('ls', true, true); + + $this->assertCount(12, $contents); + } } From 0098c7571486aca4c723ab5c72fd487ec403a5d2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 22:25:42 +0200 Subject: [PATCH 243/424] Work on Primer task --- .../Abstracts/Strategies/AbstractStrategy.php | 23 ------------ src/Rocketeer/Bash.php | 27 +++++++++++++- src/Rocketeer/LocalConnection.php | 25 +++++++++++-- src/Rocketeer/RocketeerServiceProvider.php | 4 ++ src/Rocketeer/Services/Tasks/TasksBuilder.php | 3 +- .../Dependencies/ComposerStrategy.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 7 +++- src/Rocketeer/Tasks/Subtasks/Primer.php | 37 +++++++++++++++++++ src/Rocketeer/Traits/BashModules/Binaries.php | 4 +- src/Rocketeer/Traits/BashModules/Core.php | 12 +++++- src/config/strategies.php | 7 ++++ tests/Abstracts/AbstractTaskTest.php | 2 +- 12 files changed, 120 insertions(+), 33 deletions(-) create mode 100644 src/Rocketeer/Tasks/Subtasks/Primer.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index a4c9361c7..230d42693 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -32,29 +32,6 @@ public function isExecutable() ////////////////////////////// HELPERS /////////////////////////////// ////////////////////////////////////////////////////////////////////// - /** - * @param string $hook - * @param array $arguments - * - * @return string|array|null - */ - protected function getHookedTasks($hook, array $arguments) - { - $tasks = $this->rocketeer->getOption($hook); - if (!is_callable($tasks)) { - return; - } - - // Cancel if no tasks to execute - $tasks = (array) call_user_func_array($tasks, $arguments); - if (empty($tasks)) { - return; - } - - // Run commands - return $tasks; - } - /** * Display what the command is and does * diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index b7dcdc83d..27d400dec 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -26,6 +26,29 @@ class Bash use Filesystem; use Flow; + /** + * @param string $hook + * @param array $arguments + * + * @return string|array|null + */ + protected function getHookedTasks($hook, array $arguments) + { + $tasks = $this->rocketeer->getOption('strategies.'.$hook); + if (!is_callable($tasks)) { + return; + } + + // Cancel if no tasks to execute + $tasks = (array) call_user_func_array($tasks, $arguments); + if (empty($tasks)) { + return; + } + + // Run commands + return $tasks; + } + ////////////////////////////////////////////////////////////////////// ////////////////////////////// RUNNERS /////////////////////////////// ////////////////////////////////////////////////////////////////////// @@ -59,8 +82,10 @@ public function getStrategy($strategy, $concrete = null) */ public function executeTask($tasks) { - return $this->explainer->displayBelow(function () use ($tasks) { + $pipeline = $this->explainer->displayBelow(function () use ($tasks) { return $this->queue->run($tasks); }); + + return $pipeline->succeeded(); } } diff --git a/src/Rocketeer/LocalConnection.php b/src/Rocketeer/LocalConnection.php index 4e053221e..71a441466 100644 --- a/src/Rocketeer/LocalConnection.php +++ b/src/Rocketeer/LocalConnection.php @@ -23,6 +23,13 @@ class LocalConnection implements ConnectionInterface { use HasLocator; + /** + * Return status of the last command + * + * @type integer + */ + protected $previousStatus; + /** * Define a set of commands as a task. * @@ -61,15 +68,27 @@ public function run($commands, Closure $callback = null) { $commands = (array) $commands; foreach ($commands as $command) { - exec($command, $output); + exec($command, $output, $status); + $this->previousStatus = $status; if ($callback) { - $output = implode(PHP_EOL, $output); - $callback($output); + foreach ($output as $line) { + $callback($line.PHP_EOL); + } } } } + /** + * Get the exit status of the last command. + * + * @return int|bool + */ + public function status() + { + return $this->previousStatus; + } + /** * Upload a local file to the server. * diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index afef951db..22b00d143 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -130,6 +130,10 @@ public function bindThirdPartyServices() return new RemoteManager($app); }, true); + $this->app->singleton('remote.local', function ($app) { + return new LocalConnection($app); + }); + $this->app->bindIf('events', function ($app) { return new Dispatcher($app); }, true); diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 0daabc1f2..88df1dd61 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -78,6 +78,7 @@ public function buildTasks(array $tasks) * @param string|null $name * @param string|null $description * + * @throws \Rocketeer\Exceptions\TaskCompositionException * @return AbstractTask */ public function buildTask($task, $name = null, $description = null) @@ -103,7 +104,7 @@ public function buildTask($task, $name = null, $description = null) // If the built class is invalid, cancel if (!$task instanceof AbstractTask) { - throw new TaskCompositionException('Class '.get_class($task). ' is not a valid task'); + throw new TaskCompositionException('Class '.get_class($task).' is not a valid task'); } // Set task properties diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 29797620e..4c3dacd62 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -55,7 +55,7 @@ public function update() */ protected function executeHook($hook) { - $tasks = $this->getHookedTasks('strategies.composer.'.$hook, [$this->getManager(), $this]); + $tasks = $this->getHookedTasks('composer.'.$hook, [$this->getManager(), $this]); if (!$tasks) { return true; } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index cb91f08bf..46491099b 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -39,12 +39,17 @@ class Deploy extends AbstractTask */ public function execute() { - // Setup if necessary + // Check if server is ready for deployment if (!$this->isSetup()) { $this->command->error('Server is not ready, running Setup task'); $this->executeTask('Setup'); } + // Check if local is ready for deployment + if (!$this->executeTask('Primer')) { + return $this->halt('Project is not ready for deploy. You were almost fired.'); + } + // Setup the new release $release = $this->releasesManager->getNextRelease(); diff --git a/src/Rocketeer/Tasks/Subtasks/Primer.php b/src/Rocketeer/Tasks/Subtasks/Primer.php new file mode 100644 index 000000000..cfe66283c --- /dev/null +++ b/src/Rocketeer/Tasks/Subtasks/Primer.php @@ -0,0 +1,37 @@ + + */ +class Primer extends AbstractTask +{ + /** + * Whether to run the commands locally + * or on the server + * + * @type boolean + */ + protected $local = true; + + /** + * Run the task + * + * @return string + */ + public function execute() + { + $tasks = $this->getHookedTasks('primer', [$this]); + if (!$tasks) { + return true; + } + + $this->run($tasks); + + return $this->status(); + } +} diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 6dce3c391..44be38ec6 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -124,7 +124,9 @@ public function which($binary, $fallback = null, $default = false) } // Store found location - $this->localStorage->set('paths.'.$binary, $location); + if (!$this->local) { + $this->localStorage->set('paths.'.$binary, $location); + } return $location ?: $default; } diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 2b33690a5..cdb55ba51 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -47,7 +47,7 @@ public function setLocal($local) */ public function getConnection() { - return $this->local ? new LocalConnection($this->app) : $this->remote; + return $this->local ? $this->app['remote.local'] : $this->remote; } //////////////////////////////////////////////////////////////////// @@ -176,6 +176,16 @@ public function runInFolder($folder = null, $tasks = array()) return $this->run($tasks); } + /** + * Check the status of the last command + * + * @return bool + */ + public function status() + { + return $this->getConnection()->status() == 0; + } + /** * Check the status of the last run command, return an error if any * diff --git a/src/config/strategies.php b/src/config/strategies.php index 724d52871..a33d156af 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -1,5 +1,6 @@ function (Primer $task) { + return array( + // $task->getStrategy('Test')->test(), + ); + } + ); diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 42994a94c..ca192c2f8 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -95,6 +95,6 @@ public function testCanListenToSubtasks() $this->assertHistory(array( 'cd {server}/releases/{release}', 'ls', - ), $history[4]); + ), $history[5]); } } From 70619aea7618efd7b053053f8757373489674892 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 23:30:09 +0200 Subject: [PATCH 244/424] Fix configuration hash not being stored --- src/Rocketeer/RocketeerServiceProvider.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 2 +- tests/Abstracts/AbstractTaskTest.php | 2 +- tests/MetaTest.php | 2 +- tests/Services/TasksHandlerTest.php | 4 ++-- tests/TestCases/RocketeerTestCase.php | 10 ---------- 6 files changed, 6 insertions(+), 16 deletions(-) diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 22b00d143..b9ce9283b 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -171,7 +171,7 @@ public function bindCoreClasses() return new ReleasesManager($app); }); - $this->app->bind('rocketeer.storage.local', function ($app) { + $this->app->singleton('rocketeer.storage.local', function ($app) { $filename = $app['rocketeer.rocketeer']->getApplicationName(); $filename = $filename === '{application_name}' ? 'deployments' : $filename; diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 411720452..cded2cdab 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -87,7 +87,7 @@ public function __get($key) ); // Replace shortcuts - if (array_key_exists($key, $shortcuts)) { + if (isset($shortcuts[$key])) { $key = $shortcuts[$key]; } diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index ca192c2f8..e719ebee6 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -42,7 +42,7 @@ public function testCanFireEventsDuringTasks() echo 'foobar'; }); - $this->tasksQueue()->execute(function ($task) { + $this->queue->execute(function ($task) { $task->fireEvent('test.foobar'); }, 'staging'); } diff --git a/tests/MetaTest.php b/tests/MetaTest.php index 23f670418..95c3336ad 100644 --- a/tests/MetaTest.php +++ b/tests/MetaTest.php @@ -12,7 +12,7 @@ public function testCanOverwriteTasksViaContainer() return new MyCustomTask($app); }); - $this->tasks->on('production', ['cleanup'], $this->getCommand()); + $this->queue->on('production', ['cleanup'], $this->getCommand()); $this->assertEquals(['foobar'], $this->history->getFlattenedOutput()); } } diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index 2b184227d..a1d659c69 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -56,7 +56,7 @@ public function testCanRegisterCustomTask() $this->assertInstanceOf('Rocketeer\Tasks\Closure', $this->builder->buildTask('foobar')); - $this->tasks->run('foobar'); + $this->queue->run('foobar'); $this->assertHistory([['cd {server}/releases/{release}', 'ls']]); } @@ -69,7 +69,7 @@ public function testCanRegisterCustomTaskViaArray() $this->tasks->task('foobar', ['ls', 'ls']); $this->assertInstanceOf('Rocketeer\Tasks\Closure', $this->builder->buildTask('foobar')); - $this->tasks->run('foobar'); + $this->queue->run('foobar'); $this->assertHistory([['cd {server}/releases/{release}', 'ls', 'ls']]); } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 9fa9343bb..08ea9ee65 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -239,14 +239,4 @@ protected function task($task = null, $options = array()) return $this->builder->buildTaskFromClass($task); } - - /** - * Get TasksQueue instance - * - * @return \Rocketeer\Services\TasksHandler - */ - protected function tasksQueue() - { - return $this->app['rocketeer.tasks']; - } } From f43e17cbb26418835dfb4fad3e5d99ca1252c74b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 15 Aug 2014 23:34:02 +0200 Subject: [PATCH 245/424] Run Primer before Update too --- src/Rocketeer/Tasks/Subtasks/Primer.php | 7 +++++++ src/Rocketeer/Tasks/Update.php | 5 +++++ 2 files changed, 12 insertions(+) diff --git a/src/Rocketeer/Tasks/Subtasks/Primer.php b/src/Rocketeer/Tasks/Subtasks/Primer.php index cfe66283c..b985aceb2 100644 --- a/src/Rocketeer/Tasks/Subtasks/Primer.php +++ b/src/Rocketeer/Tasks/Subtasks/Primer.php @@ -10,6 +10,13 @@ */ class Primer extends AbstractTask { + /** + * A description of what the task does + * + * @var string + */ + protected $description = 'Run local checks to ensure deploy can proceed'; + /** * Whether to run the commands locally * or on the server diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index d0d3ff587..234e41cb2 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -30,6 +30,11 @@ class Update extends Deploy */ public function execute() { + // Check if local is ready for deployment + if (!$this->executeTask('Primer')) { + return $this->halt('Project is not ready for deploy. You were almost fired.'); + } + // Update repository $this->getStrategy('Deploy')->update(); From 678e8a11d5777cd10d7ad9ec68a9419fa1c5457f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 00:01:14 +0200 Subject: [PATCH 246/424] Stop using Illuminate's RemoteManager for connections handling Half of what it does is already handled by internal Rocketeer classes (ConnectionsHandler, TasksQueue), having to make the credentials go back and forth between Rocketeer's internal configuration and Remote's is slow and awkward. Doing this yields much better performances and reduces a lot the low-level logic redundancy. --- src/Rocketeer/RocketeerServiceProvider.php | 9 +- .../{ => Connections}/ConnectionsHandler.php | 2 +- .../Connections}/LocalConnection.php | 2 +- .../Services/Connections/RemoteHandler.php | 115 ++++++++++++++++++ src/Rocketeer/Traits/BashModules/Core.php | 1 - src/Rocketeer/Traits/HasLocator.php | 5 +- 6 files changed, 125 insertions(+), 9 deletions(-) rename src/Rocketeer/Services/{ => Connections}/ConnectionsHandler.php (99%) rename src/Rocketeer/{ => Services/Connections}/LocalConnection.php (98%) create mode 100644 src/Rocketeer/Services/Connections/RemoteHandler.php diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b9ce9283b..f61f4ceaf 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -14,12 +14,13 @@ use Illuminate\Events\Dispatcher; use Illuminate\Http\Request; use Illuminate\Log\Writer; -use Illuminate\Remote\RemoteManager; use Illuminate\Support\ServiceProvider; use Monolog\Logger; use Rocketeer\Console\Commands\BaseTaskCommand; use Rocketeer\Exceptions\TaskCompositionException; -use Rocketeer\Services\ConnectionsHandler; +use Rocketeer\Services\Connections\ConnectionsHandler; +use Rocketeer\Services\Connections\LocalConnection; +use Rocketeer\Services\Connections\RemoteHandler; use Rocketeer\Services\CredentialsGatherer; use Rocketeer\Services\Display\QueueExplainer; use Rocketeer\Services\Display\QueueTimer; @@ -126,8 +127,8 @@ public function bindThirdPartyServices() return new Repository($fileloader, 'config'); }, true); - $this->app->bindIf('remote', function ($app) { - return new RemoteManager($app); + $this->app->bindIf('rocketeer.remote', function ($app) { + return new RemoteHandler($app); }, true); $this->app->singleton('remote.local', function ($app) { diff --git a/src/Rocketeer/Services/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php similarity index 99% rename from src/Rocketeer/Services/ConnectionsHandler.php rename to src/Rocketeer/Services/Connections/ConnectionsHandler.php index 2ed0ebb0f..0d218376c 100644 --- a/src/Rocketeer/Services/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Services; +namespace Rocketeer\Services\Connections; use Illuminate\Support\Arr; use Illuminate\Support\Str; diff --git a/src/Rocketeer/LocalConnection.php b/src/Rocketeer/Services/Connections/LocalConnection.php similarity index 98% rename from src/Rocketeer/LocalConnection.php rename to src/Rocketeer/Services/Connections/LocalConnection.php index 71a441466..ed8565661 100644 --- a/src/Rocketeer/LocalConnection.php +++ b/src/Rocketeer/Services/Connections/LocalConnection.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer; +namespace Rocketeer\Services\Connections; use Closure; use Illuminate\Remote\ConnectionInterface; diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php new file mode 100644 index 000000000..c32d844f9 --- /dev/null +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -0,0 +1,115 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Connections; + +use Illuminate\Remote\Connection; +use InvalidArgumentException; +use Rocketeer\Traits\HasLocator; +use Symfony\Component\Console\Output\NullOutput; + +/** + * Handle creationg and caching of connections + * + * @author Maxime Fabre + * @author Taylor Otwell + */ +class RemoteHandler +{ + use HasLocator; + + /** + * A storage of active connections + * + * @type Connection[] + */ + protected $active = []; + + /** + * Get the current Connection + */ + public function connection() + { + $name = $this->connections->getConnection(); + $server = $this->connections->getServer(); + $handle = $name.'#'.$server; + + // Check the cache + if (isset($this->active[$handle])) { + return $this->active[$handle]; + } + + // Create connection + $credentials = $this->connections->getServerCredentials(); + $connection = $this->makeConnection($name, $credentials); + + // Save to cache + $this->active[$handle] = $connection; + + return $connection; + } + + /** + * @param string $name + * @param array $credentials + * + * @return Connection + */ + protected function makeConnection($name, array $credentials) + { + $connection = new Connection( + $name, + $credentials['host'], + $credentials['username'], + $this->getAuth($credentials) + ); + + // Set output on connection + $output = $this->hasCommand() ? $this->command->getOutput() : new NullOutput(); + $connection->setOutput($output); + + return $connection; + } + + /** + * Format the appropriate authentication array payload. + * + * @param array $config + * + * @return array + * @throws InvalidArgumentException + */ + protected function getAuth(array $config) + { + if (isset($config['agent']) && $config['agent'] === true) { + return array('agent' => true); + } elseif (isset($config['key']) && trim($config['key']) != '') { + return array('key' => $config['key'], 'keyphrase' => $config['keyphrase']); + } elseif (isset($config['keytext']) && trim($config['keytext']) != '') { + return array('keytext' => $config['keytext']); + } elseif (isset($config['password'])) { + return array('password' => $config['password']); + } + + throw new InvalidArgumentException('Password / key is required.'); + } + + /** + * Dynamically pass methods to the default connection. + * + * @param string $method + * @param array $parameters + * + * @return mixed + */ + public function __call($method, $parameters) + { + return call_user_func_array([$this->connection(), $method], $parameters); + } +} diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index cdb55ba51..4b73aafb4 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -10,7 +10,6 @@ namespace Rocketeer\Traits\BashModules; use Illuminate\Support\Str; -use Rocketeer\LocalConnection; use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index cded2cdab..263a46cf7 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -19,7 +19,7 @@ * @property \Illuminate\Events\Dispatcher events * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Log\Writer log - * @property \Illuminate\Remote\Connection remote + * @property \Rocketeer\Services\Connections\RemoteHandler remote * @property \Rocketeer\Abstracts\AbstractCommand command * @property \Rocketeer\Bash bash * @property \Rocketeer\Services\Display\QueueExplainer explainer @@ -28,7 +28,7 @@ * @property \Rocketeer\Interfaces\ScmInterface scm * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy * @property \Rocketeer\Rocketeer rocketeer - * @property \Rocketeer\Services\ConnectionsHandler connections + * @property \Rocketeer\Services\Connections\ConnectionsHandler connections * @property \Rocketeer\Services\CredentialsGatherer credentials * @property \Rocketeer\Services\History\History history * @property \Rocketeer\Services\ReleasesManager releasesManager @@ -79,6 +79,7 @@ public function __get($key) 'localStorage' => 'rocketeer.storage.local', 'logs' => 'rocketeer.logs', 'queue' => 'rocketeer.queue', + 'remote' => 'rocketeer.remote', 'releasesManager' => 'rocketeer.releases', 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', From 67183c5ad5072b45e05b09834a40c5ebad05a1e2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 00:19:58 +0200 Subject: [PATCH 247/424] Remove some leftover references to RemoteManager --- .../Services/Connections/ConnectionsHandler.php | 8 -------- src/Rocketeer/Services/Connections/RemoteHandler.php | 4 ++++ tests/Tasks/CheckTest.php | 2 +- tests/TestCases/ContainerTestCase.php | 2 +- tests/Traits/BashModules/CoreTest.php | 12 ++++++------ tests/Traits/BashModules/ScmTest.php | 4 ++-- 6 files changed, 14 insertions(+), 18 deletions(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 0d218376c..23078b9f7 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -286,18 +286,10 @@ public function setConnection($connection, $server = 0) return; } - // Fetch the credentials - $credentials = $this->getServerCredentials($connection, $server); - // Set the connection $this->connection = $connection; $this->localStorage = $server; - // Register it with SSH component - $name = $connection.'#'.$server; - $this->config->set('remote.default', $name); - $this->config->set('remote.connections.'.$name, $credentials); - // Update events $this->tasks->registerConfiguredEvents(); } diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index c32d844f9..52dca533e 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -63,6 +63,10 @@ public function connection() */ protected function makeConnection($name, array $credentials) { + if (!isset($credentials['host']) || !isset($credentials['username'])) { + throw new InvalidArgumentException('Host and/or username is required for '.$name); + } + $connection = new Connection( $name, $credentials['host'], diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index 8a540e2f8..39eaeebc4 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -53,7 +53,7 @@ public function testCanCheckPhpExtensions() public function testCanCheckForHhvmExtensions() { - $this->app['remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); + $this->app['rocketeer.remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); $exists = $this->task('Check')->checkPhpExtension('_hhvm'); $this->assertTrue($exists); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 40c8ec198..ad8bcdcb8 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -50,8 +50,8 @@ public function setUp() $this->app->instance('path.storage', '/src/app/storage'); $this->app['files'] = new Filesystem; - $this->app['remote'] = $this->getRemote(); $this->app['artisan'] = $this->getArtisan(); + $this->app['rocketeer.remote'] = $this->getRemote(); $this->app['rocketeer.command'] = $this->getCommand(); // Rocketeer classes ------------------------------------------- / diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index c3d542b44..cc1519647 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -16,7 +16,7 @@ public function testCanCheckStatusOfACommand() { $this->expectOutputString('An error occured: "Oh noes", while running:'.PHP_EOL.'git clone'); - $this->task->remote = clone $this->getRemote()->shouldReceive('status')->andReturn(1)->mock(); + $this->app['rocketeer.remote'] = clone $this->getRemote()->shouldReceive('status')->andReturn(1)->mock(); $this->mockCommand([], array( 'error' => function ($error) { echo $error; @@ -37,8 +37,8 @@ public function testCanGetTimestampOffServer() public function testCanGetLocalTimestampIfError() { - $this->app['remote'] = $this->getRemote('NOPE'); - $timestamp = $this->task->getTimestamp(); + $this->app['rocketeer.remote'] = $this->getRemote('NOPE'); + $timestamp = $this->task->getTimestamp(); $this->assertEquals(date('YmdHis'), $timestamp); } @@ -59,15 +59,15 @@ public function testDoesntAppendEnvironmentToStandardTasks() public function testCanRemoveCommonPollutingOutput() { - $this->app['remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); - $result = $this->bash->run('ls'); + $this->app['rocketeer.remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); + $result = $this->bash->run('ls'); $this->assertEquals('something', $result); } public function testCanRunCommandsLocally() { - $this->mock('remote', 'Remote', function ($mock) { + $this->mock('rocketeer.remote', 'Remote', function ($mock) { return $mock->shouldReceive('run')->never(); }); diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index 0de1acc05..d20587b97 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -16,9 +16,9 @@ public function testCanForgetCredentialsIfInvalid() // Create fake remote $remote = $this->getRemote(); $remote->shouldReceive('status')->andReturn(1); + $this->app['rocketeer.remote'] = $remote; - $task = $this->pretendTask(); - $task->remote = $remote; + $task = $this->pretendTask(); $task->getStrategy('Deploy')->deploy($this->server.'/test'); $this->assertNull($this->app['rocketeer.storage.local']->get('credentials')); From 038eaabbd2845577484002b31f16a9919614294c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 00:30:36 +0200 Subject: [PATCH 248/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractStorage.php | 1 + .../Abstracts/Strategies/AbstractDependenciesStrategy.php | 2 +- src/Rocketeer/Binaries/Bower.php | 1 - src/Rocketeer/Binaries/Composer.php | 1 - src/Rocketeer/Binaries/Php.php | 1 - src/Rocketeer/Binaries/Phpunit.php | 1 - src/Rocketeer/Services/Connections/LocalConnection.php | 6 ++++-- src/Rocketeer/Services/Display/QueueExplainer.php | 8 ++++---- src/Rocketeer/Services/Tasks/TasksQueue.php | 2 +- tests/Binaries/AnonymousBinaryTest.php | 1 - tests/Binaries/ArtisanTest.php | 1 - tests/Binaries/ComposerTest.php | 1 - tests/Binaries/PhpTest.php | 1 - tests/Services/Storages/ServerStorageTest.php | 1 - tests/Services/Tasks/TasksQueueTest.php | 6 ++++-- tests/Strategies/Deploy/CopyStrategyTest.php | 1 - tests/Tasks/CheckTest.php | 2 +- tests/Traits/BashModules/CoreTest.php | 4 ++-- 18 files changed, 18 insertions(+), 23 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index b3ad87d33..91d6bbb90 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -13,6 +13,7 @@ use Illuminate\Container\Container; use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; + /** * Abstract class for storage implementations * diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 8b06207e5..9d3b124e2 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -78,7 +78,7 @@ protected function hasManifest() $server = $this->rocketeer->getFolder('current/'.$this->manifest); $server = $this->bash->fileExists($server); - $local = $this->app['path.base'].DS.$this->manifest; + $local = $this->app['path.base'].DS.$this->manifest; $local = $this->files->exists($local); return $local || $server; diff --git a/src/Rocketeer/Binaries/Bower.php b/src/Rocketeer/Binaries/Bower.php index c819c0603..39bd7c19c 100644 --- a/src/Rocketeer/Binaries/Bower.php +++ b/src/Rocketeer/Binaries/Bower.php @@ -1,7 +1,6 @@ level); + $tree = '|'.str_repeat('--', $this->level); $comment = sprintf('%s %s: %s', $tree, $object, $subject); // Add details @@ -76,7 +76,7 @@ public function display($object, $subject, $details = null, $time = null) $comment .= ' ('.$details.')'; } if ($time) { - $comment .= ' [~' .$time. 's]'; + $comment .= ' [~'.$time.'s]'; } $this->command->line($comment); diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index a0d028efa..1bd8f3044 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -243,7 +243,7 @@ protected function runAsynchronously(Pipeline $pipeline) } $this->parallel = $this->parallel ?: new Parallel(); - $results = $this->parallel->values($pipeline->all()); + $results = $this->parallel->values($pipeline->all()); $pipeline->setResults($results); return $pipeline; diff --git a/tests/Binaries/AnonymousBinaryTest.php b/tests/Binaries/AnonymousBinaryTest.php index 17cb878f9..de432180e 100644 --- a/tests/Binaries/AnonymousBinaryTest.php +++ b/tests/Binaries/AnonymousBinaryTest.php @@ -1,7 +1,6 @@ mockCommand(['parallel' => true]); $this->queue->setParallel($parallel); - $task = function() { + $task = function () { sleep(1); + return time(); }; $this->queue->execute(array( - $task, $task + $task, + $task )); } diff --git a/tests/Strategies/Deploy/CopyStrategyTest.php b/tests/Strategies/Deploy/CopyStrategyTest.php index 8f9783749..1aead9242 100644 --- a/tests/Strategies/Deploy/CopyStrategyTest.php +++ b/tests/Strategies/Deploy/CopyStrategyTest.php @@ -2,7 +2,6 @@ namespace Rocketeer\Strategies\Deploy; use Mockery\MockInterface; -use Rocketeer\Strategies\Deploy\CopyStrategy; use Rocketeer\TestCases\RocketeerTestCase; class CopyStrategyTest extends RocketeerTestCase diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index 39eaeebc4..a0e1a0f27 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -54,7 +54,7 @@ public function testCanCheckPhpExtensions() public function testCanCheckForHhvmExtensions() { $this->app['rocketeer.remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); - $exists = $this->task('Check')->checkPhpExtension('_hhvm'); + $exists = $this->task('Check')->checkPhpExtension('_hhvm'); $this->assertTrue($exists); } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index cc1519647..23896e445 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -38,7 +38,7 @@ public function testCanGetTimestampOffServer() public function testCanGetLocalTimestampIfError() { $this->app['rocketeer.remote'] = $this->getRemote('NOPE'); - $timestamp = $this->task->getTimestamp(); + $timestamp = $this->task->getTimestamp(); $this->assertEquals(date('YmdHis'), $timestamp); } @@ -60,7 +60,7 @@ public function testDoesntAppendEnvironmentToStandardTasks() public function testCanRemoveCommonPollutingOutput() { $this->app['rocketeer.remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); - $result = $this->bash->run('ls'); + $result = $this->bash->run('ls'); $this->assertEquals('something', $result); } From 095e6962ad47ff7bdaf7f53ab28f9dcb83cb3a08 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 01:33:26 +0200 Subject: [PATCH 249/424] Work on steps running --- src/Rocketeer/Abstracts/AbstractTask.php | 39 +++++++++++++++++++++++ src/Rocketeer/Services/StepsBuilder.php | 33 +++++++++++++++++++ src/Rocketeer/Tasks/Deploy.php | 31 +++++++++++------- src/Rocketeer/Tasks/Update.php | 17 +++++++--- src/Rocketeer/Traits/BashModules/Flow.php | 4 ++- 5 files changed, 106 insertions(+), 18 deletions(-) create mode 100644 src/Rocketeer/Services/StepsBuilder.php diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 412041ddb..746dc077b 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -10,8 +10,10 @@ namespace Rocketeer\Abstracts; use DateTime; +use Illuminate\Container\Container; use Illuminate\Support\Str; use Rocketeer\Bash; +use Rocketeer\Services\StepsBuilder; use Rocketeer\Traits\HasTimer; use Symfony\Component\Console\Helper\Table; @@ -43,6 +45,20 @@ abstract class AbstractTask extends Bash */ protected $halted = false; + /** + * @type StepsBuilder + */ + protected $steps; + + /** + * @param Container $app + */ + public function __construct(Container $app) + { + $this->app = $app; + $this->steps = new StepsBuilder; + } + //////////////////////////////////////////////////////////////////// ////////////////////////////// REFLECTION ////////////////////////// //////////////////////////////////////////////////////////////////// @@ -160,6 +176,29 @@ public function wasHalted() return $this->halted === true; } + //////////////////////////////////////////////////////////////////// + /////////////////////////////// STEPS ////////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Execute an array of calls until one halts + * + * @return boolean + */ + protected function runSteps() + { + foreach ($this->steps->getSteps() as $step) { + list($method, $arguments) = $step; + $arguments = (array) $arguments; + + if (!call_user_func_array([$this, $method], $arguments)) { + return false; + } + } + + return true; + } + //////////////////////////////////////////////////////////////////// /////////////////////////////// EVENTS ///////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/StepsBuilder.php b/src/Rocketeer/Services/StepsBuilder.php new file mode 100644 index 000000000..d961e2af6 --- /dev/null +++ b/src/Rocketeer/Services/StepsBuilder.php @@ -0,0 +1,33 @@ +steps[] = [$name, $arguments]; + } + + /** + * Get the steps to execute + * + * @return array + */ + public function getSteps() + { + return $this->steps; + } +} diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 46491099b..784d58b1e 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -53,28 +53,33 @@ public function execute() // Setup the new release $release = $this->releasesManager->getNextRelease(); - // Build and execute subtasks - $this->executeTask(['CreateRelease', 'Dependencies']); + // Build subtasks + $tasks = ['CreateRelease', 'Dependencies']; if ($this->getOption('tests')) { - $this->executeTask('Test'); + $tasks[] = 'Test'; } - // Set permissions - $this->setApplicationPermissions(); + // Create release and set permissions + $this->steps->executeTask($tasks); + $this->steps->setApplicationPermissions(); // Run migrations - $this->executeTask('Migrate'); + $this->steps->executeTask('Migrate'); // Synchronize shared folders and files - $this->syncSharedFolders(); + $this->steps->syncSharedFolders(); // Run before-symlink events - if (!$this->fireEvent('before-symlink')) { + $this->steps->fireEvent('before-symlink'); + + // Update symlink + $this->steps->updateSymlink(); + + // Run the steps until one fails + if (!$this->runSteps()) { return $this->halt(); } - // Update symlink and mark release as valid - $this->updateSymlink(); $this->releasesManager->markReleaseAsValid($release); $this->command->info('Successfully deployed release '.$release); @@ -87,13 +92,15 @@ public function execute() /** * Set permissions for the folders used by the application * - * @return void + * @return true */ protected function setApplicationPermissions() { $files = (array) $this->rocketeer->getOption('remote.permissions.files'); - foreach ($files as $file) { + foreach ($files as &$file) { $this->setPermissions($file); } + + return $files; } } diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 234e41cb2..818a662b2 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -36,19 +36,26 @@ public function execute() } // Update repository - $this->getStrategy('Deploy')->update(); + if (!$this->getStrategy('Deploy')->update()) { + return $this->halt(); + } // Recreate symlinks if necessary - $this->syncSharedFolders(); + $this->steps->syncSharedFolders(); // Recompile dependencies and stuff - $this->executeTask('Dependencies'); + $this->steps->executeTask('Dependencies'); // Set permissions - $this->setApplicationPermissions(); + $this->steps->setApplicationPermissions(); // Run migrations - $this->executeTask('Migrate'); + $this->steps->executeTask('Migrate'); + + // Run the steps + if (!$this->runSteps()) { + return $this->halt(); + } // Clear cache $this->artisan()->runForCurrentRelease('clearCache'); diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 551317b1c..2323b1b7e 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -69,9 +69,11 @@ public function runForCurrentRelease($tasks) protected function syncSharedFolders() { $shared = (array) $this->rocketeer->getOption('remote.shared'); - foreach ($shared as $file) { + foreach ($shared as &$file) { $this->share($file); } + + return $shared; } /** From 1ac41e149f371233cd0b9495f216d216d39c5952 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 01:49:41 +0200 Subject: [PATCH 250/424] Docblocks --- src/Rocketeer/Abstracts/AbstractTask.php | 3 +-- src/Rocketeer/Bash.php | 4 ++-- src/Rocketeer/Binaries/Artisan.php | 2 +- src/Rocketeer/Binaries/Bower.php | 2 +- src/Rocketeer/Binaries/Composer.php | 2 +- src/Rocketeer/Binaries/Php.php | 2 +- src/Rocketeer/Binaries/Phpunit.php | 2 +- src/Rocketeer/Services/Connections/LocalConnection.php | 6 +++--- src/Rocketeer/Services/Display/QueueTimer.php | 4 ++-- src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 7 ------- src/Rocketeer/Tasks/Subtasks/Primer.php | 2 +- src/Rocketeer/Tasks/Update.php | 2 +- 14 files changed, 17 insertions(+), 25 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 746dc077b..bc23f9ec3 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -14,7 +14,6 @@ use Illuminate\Support\Str; use Rocketeer\Bash; use Rocketeer\Services\StepsBuilder; -use Rocketeer\Traits\HasTimer; use Symfony\Component\Console\Helper\Table; /** @@ -128,7 +127,7 @@ abstract public function execute(); /** * Fire the command * - * @return string|false + * @return boolean */ public function fire() { diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index 27d400dec..a0aec38cc 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -74,9 +74,9 @@ public function getStrategy($strategy, $concrete = null) } /** - * Execute another AbstractTask by name + * Execute another task by name * - * @param string|string[] $tasks + * @param string|array $tasks * * @return string|false */ diff --git a/src/Rocketeer/Binaries/Artisan.php b/src/Rocketeer/Binaries/Artisan.php index 324bdb5ce..5fa22ff44 100644 --- a/src/Rocketeer/Binaries/Artisan.php +++ b/src/Rocketeer/Binaries/Artisan.php @@ -29,7 +29,7 @@ public function __construct(Container $app) /** * Get an array of default paths to look for * - * @return array + * @return string[] */ protected function getKnownPaths() { diff --git a/src/Rocketeer/Binaries/Bower.php b/src/Rocketeer/Binaries/Bower.php index 39bd7c19c..e322f054c 100644 --- a/src/Rocketeer/Binaries/Bower.php +++ b/src/Rocketeer/Binaries/Bower.php @@ -8,7 +8,7 @@ class Bower extends AbstractBinary /** * Get an array of default paths to look for * - * @return array + * @return string[] */ protected function getKnownPaths() { diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/Composer.php index 1ac255be8..203eb4a21 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/Composer.php @@ -16,7 +16,7 @@ class Composer extends AbstractBinary /** * Get an array of default paths to look for * - * @return array + * @return string[] */ protected function getKnownPaths() { diff --git a/src/Rocketeer/Binaries/Php.php b/src/Rocketeer/Binaries/Php.php index 710f4a43e..cfa40f6f6 100644 --- a/src/Rocketeer/Binaries/Php.php +++ b/src/Rocketeer/Binaries/Php.php @@ -16,7 +16,7 @@ class Php extends AbstractBinary /** * Get an array of default paths to look for * - * @return array + * @return string[] */ protected function getKnownPaths() { diff --git a/src/Rocketeer/Binaries/Phpunit.php b/src/Rocketeer/Binaries/Phpunit.php index 52a137532..b855cbbc0 100644 --- a/src/Rocketeer/Binaries/Phpunit.php +++ b/src/Rocketeer/Binaries/Phpunit.php @@ -16,7 +16,7 @@ class Phpunit extends AbstractBinary /** * Get an array of default paths to look for * - * @return array + * @return string[] */ protected function getKnownPaths() { diff --git a/src/Rocketeer/Services/Connections/LocalConnection.php b/src/Rocketeer/Services/Connections/LocalConnection.php index fd0e8b41e..369d35f41 100644 --- a/src/Rocketeer/Services/Connections/LocalConnection.php +++ b/src/Rocketeer/Services/Connections/LocalConnection.php @@ -82,7 +82,7 @@ public function run($commands, Closure $callback = null) /** * Get the exit status of the last command. * - * @return int|bool + * @return integer|null */ public function status() { @@ -95,7 +95,7 @@ public function status() * @param string $local * @param string $remote * - * @return void + * @return integer */ public function put($local, $remote) { @@ -136,7 +136,7 @@ public function display($line) * @param string $remote * @param string $contents * - * @return void + * @return integer */ public function putString($remote, $contents) { diff --git a/src/Rocketeer/Services/Display/QueueTimer.php b/src/Rocketeer/Services/Display/QueueTimer.php index fd4bd413c..48d274f3c 100644 --- a/src/Rocketeer/Services/Display/QueueTimer.php +++ b/src/Rocketeer/Services/Display/QueueTimer.php @@ -29,7 +29,7 @@ class QueueTimer * @param AbstractTask $task * @param Closure $callback * - * @return boolean + * @return boolean|null */ public function time(AbstractTask $task, Closure $callback) { @@ -101,7 +101,7 @@ protected function getTaskTimes(AbstractTask $task) /** * @param AbstractTask $task - * @param array $past + * @param double[] $past */ protected function saveTaskTimes(AbstractTask $task, array $past) { diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 88df1dd61..e2b16ea0c 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -211,7 +211,7 @@ protected function taskClassExists($task) * Find a class in various predefined namespaces * * @param string $class - * @param array $paths + * @param string[] $paths * * @return string|false */ diff --git a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php index ecbf8892d..f68807ea6 100644 --- a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php +++ b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php @@ -21,7 +21,7 @@ class ArtisanStrategy extends AbstractStrategy implements MigrateStrategyInterfa */ public function isExecutable() { - return $this->artisan()->getBinary(); + return (bool) $this->artisan()->getBinary(); } /** diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 784d58b1e..ab673fd8b 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -18,13 +18,6 @@ */ class Deploy extends AbstractTask { - /** - * Methods that can halt deployment - * - * @var array - */ - protected $halting = array(); - /** * The console command description. * diff --git a/src/Rocketeer/Tasks/Subtasks/Primer.php b/src/Rocketeer/Tasks/Subtasks/Primer.php index b985aceb2..01c038797 100644 --- a/src/Rocketeer/Tasks/Subtasks/Primer.php +++ b/src/Rocketeer/Tasks/Subtasks/Primer.php @@ -28,7 +28,7 @@ class Primer extends AbstractTask /** * Run the task * - * @return string + * @return boolean */ public function execute() { diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 818a662b2..8377b4e1c 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -26,7 +26,7 @@ class Update extends Deploy /** * Run the task * - * @return void + * @return boolean|null */ public function execute() { From a95dd0256cd3c6604f39d1bd227da91ffe9eb4ea Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 02:02:55 +0200 Subject: [PATCH 251/424] Docmoar --- src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php | 4 ++-- src/Rocketeer/Services/Connections/LocalConnection.php | 6 +++--- src/Rocketeer/Services/Connections/RemoteHandler.php | 2 ++ src/Rocketeer/Services/Display/QueueTimer.php | 6 +++--- 4 files changed, 10 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index 230d42693..94bd6a83d 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -44,8 +44,8 @@ public function displayStatus() $components = get_class($this); $components = explode('\\', $components); - $name = array_get($components, sizeof($components) - 1); - $strategy = array_get($components, sizeof($components) - 2); + $name = array_get($components, count($components) - 1); + $strategy = array_get($components, count($components) - 2); $object = 'Running strategy for '.ucfirst($strategy); $subject = str_replace('Strategy', null, $name); diff --git a/src/Rocketeer/Services/Connections/LocalConnection.php b/src/Rocketeer/Services/Connections/LocalConnection.php index 369d35f41..57ea91406 100644 --- a/src/Rocketeer/Services/Connections/LocalConnection.php +++ b/src/Rocketeer/Services/Connections/LocalConnection.php @@ -46,8 +46,8 @@ public function define($task, $commands) /** * Run a task against the connection. * - * @param string $task - * @param \Closure $callback + * @param string $task + * @param Closure|null $callback * * @return void */ @@ -60,7 +60,7 @@ public function task($task, Closure $callback = null) * Run a set of commands against the connection. * * @param string|array $commands - * @param \Closure $callback + * @param Closure|null $callback * * @return void */ diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index 52dca533e..a8ca865c8 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -33,6 +33,8 @@ class RemoteHandler /** * Get the current Connection + * + * @return Connection */ public function connection() { diff --git a/src/Rocketeer/Services/Display/QueueTimer.php b/src/Rocketeer/Services/Display/QueueTimer.php index 48d274f3c..f3f2f82b3 100644 --- a/src/Rocketeer/Services/Display/QueueTimer.php +++ b/src/Rocketeer/Services/Display/QueueTimer.php @@ -45,7 +45,7 @@ public function time(AbstractTask $task, Closure $callback) * Save the execution time of a task for future reference * * @param AbstractTask $task - * @param float $time + * @param double $time */ public function saveTaskTime(AbstractTask $task, $time) { @@ -66,7 +66,7 @@ public function saveTaskTime(AbstractTask $task, $time) * * @param AbstractTask $task * - * @return float + * @return double|null */ public function getTaskTime(AbstractTask $task) { @@ -101,7 +101,7 @@ protected function getTaskTimes(AbstractTask $task) /** * @param AbstractTask $task - * @param double[] $past + * @param double[] $past */ protected function saveTaskTimes(AbstractTask $task, array $past) { From 47ef35d341aa1998083105c1bd2c9bc04656cb40 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 13:17:26 +0200 Subject: [PATCH 252/424] Fix empty permission/shared canceling steps --- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Traits/BashModules/Flow.php | 2 +- tests/Tasks/DeployTest.php | 37 +++++++++++++++++++++++ 3 files changed, 39 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index ab673fd8b..3d4f18c67 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -94,6 +94,6 @@ protected function setApplicationPermissions() $this->setPermissions($file); } - return $files; + return true; } } diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 2323b1b7e..cbdaf8f39 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -73,7 +73,7 @@ protected function syncSharedFolders() $this->share($file); } - return $shared; + return true; } /** diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 4f2caf5f8..64a893657 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -52,6 +52,43 @@ public function testCanDeployToServer() )); } + public function testStepsRunnerDoesntCancelWithPermissionsAndShared() + { + $this->swapConfig(array( + 'rocketeer::remote.shared' => [], + 'rocketeer::remote.permissions.files' => [], + )); + + $matcher = array( + 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', + array( + "cd {server}/releases/{release}", + "git submodule update --init --recursive" + ), + array( + "cd {server}/releases/{release}", + exec('which phpunit')." --stop-on-failure" + ), + array( + "cd {server}/releases/{release}", + "{php} artisan migrate" + ), + array( + "cd {server}/releases/{release}", + "{php} artisan db:seed" + ), + "mv {server}/current {server}/releases/{release}", + "rm -rf {server}/current", + "ln -s {server}/releases/{release} {server}/current", + ); + + $this->assertTaskHistory('Deploy', $matcher, array( + 'tests' => true, + 'seed' => true, + 'migrate' => true + )); + } + public function testCanDisableGitOptions() { $this->swapConfig(array( From 81d3f3be131e301c88f6d73b41c21c6416b09fec Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 13:25:31 +0200 Subject: [PATCH 253/424] Tweak default Primer tasks --- src/config/strategies.php | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/config/strategies.php b/src/config/strategies.php index a33d156af..190ea9084 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -36,7 +36,8 @@ 'primer' => function (Primer $task) { return array( - // $task->getStrategy('Test')->test(), + // $task->executeTask('Test'), + // $task->binary('grunt')->execute('lint'), ); } From b02a27a82191c56b2666ad1ab9ab86afd15f907d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 15:18:12 +0200 Subject: [PATCH 254/424] Move Steps capacities to a trait --- src/Rocketeer/Abstracts/AbstractTask.php | 40 ++-------------- src/Rocketeer/Tasks/Deploy.php | 12 ++--- src/Rocketeer/Tasks/Update.php | 8 ++-- src/Rocketeer/Traits/StepsRunner.php | 59 ++++++++++++++++++++++++ 4 files changed, 72 insertions(+), 47 deletions(-) create mode 100644 src/Rocketeer/Traits/StepsRunner.php diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index bc23f9ec3..68868c715 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -14,6 +14,7 @@ use Illuminate\Support\Str; use Rocketeer\Bash; use Rocketeer\Services\StepsBuilder; +use Rocketeer\Traits\StepsRunner; use Symfony\Component\Console\Helper\Table; /** @@ -23,6 +24,8 @@ */ abstract class AbstractTask extends Bash { + use StepsRunner; + /** * The name of the task * @@ -44,20 +47,6 @@ abstract class AbstractTask extends Bash */ protected $halted = false; - /** - * @type StepsBuilder - */ - protected $steps; - - /** - * @param Container $app - */ - public function __construct(Container $app) - { - $this->app = $app; - $this->steps = new StepsBuilder; - } - //////////////////////////////////////////////////////////////////// ////////////////////////////// REFLECTION ////////////////////////// //////////////////////////////////////////////////////////////////// @@ -175,29 +164,6 @@ public function wasHalted() return $this->halted === true; } - //////////////////////////////////////////////////////////////////// - /////////////////////////////// STEPS ////////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Execute an array of calls until one halts - * - * @return boolean - */ - protected function runSteps() - { - foreach ($this->steps->getSteps() as $step) { - list($method, $arguments) = $step; - $arguments = (array) $arguments; - - if (!call_user_func_array([$this, $method], $arguments)) { - return false; - } - } - - return true; - } - //////////////////////////////////////////////////////////////////// /////////////////////////////// EVENTS ///////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 3d4f18c67..9534ea1ad 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -53,20 +53,20 @@ public function execute() } // Create release and set permissions - $this->steps->executeTask($tasks); - $this->steps->setApplicationPermissions(); + $this->steps()->executeTask($tasks); + $this->steps()->setApplicationPermissions(); // Run migrations - $this->steps->executeTask('Migrate'); + $this->steps()->executeTask('Migrate'); // Synchronize shared folders and files - $this->steps->syncSharedFolders(); + $this->steps()->syncSharedFolders(); // Run before-symlink events - $this->steps->fireEvent('before-symlink'); + $this->steps()->fireEvent('before-symlink'); // Update symlink - $this->steps->updateSymlink(); + $this->steps()->updateSymlink(); // Run the steps until one fails if (!$this->runSteps()) { diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 8377b4e1c..8080af759 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -41,16 +41,16 @@ public function execute() } // Recreate symlinks if necessary - $this->steps->syncSharedFolders(); + $this->steps()->syncSharedFolders(); // Recompile dependencies and stuff - $this->steps->executeTask('Dependencies'); + $this->steps()->executeTask('Dependencies'); // Set permissions - $this->steps->setApplicationPermissions(); + $this->steps()->setApplicationPermissions(); // Run migrations - $this->steps->executeTask('Migrate'); + $this->steps()->executeTask('Migrate'); // Run the steps if (!$this->runSteps()) { diff --git a/src/Rocketeer/Traits/StepsRunner.php b/src/Rocketeer/Traits/StepsRunner.php new file mode 100644 index 000000000..0e6cbf726 --- /dev/null +++ b/src/Rocketeer/Traits/StepsRunner.php @@ -0,0 +1,59 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Traits; + +use Rocketeer\Services\StepsBuilder; + +/** + * Gives a class the ability to prepare steps to run and + * loop over them + * + * @author Maxime Fabre + */ +trait StepsRunner +{ + /** + * @type StepsBuilder + */ + protected $steps; + + /** + * @return StepsBuilder + */ + public function steps() + { + if (!$this->steps) { + $this->steps = new StepsBuilder; + } + + return $this->steps; + } + + /** + * Execute an array of calls until one halts + * + * @return boolean + */ + public function runSteps() + { + foreach ($this->steps()->getSteps() as $step) { + list($method, $arguments) = $step; + $arguments = (array) $arguments; + + $results = call_user_func_array([$this, $method], $arguments); + $results = $results ?: $this->status(); + if (!$results) { + return false; + } + } + + return true; + } +} From 6a1db9df3011f0b3bddc3d933d3e27a894dcc082 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 15:18:22 +0200 Subject: [PATCH 255/424] Add test for silent commands --- tests/Traits/StepsRunnerTest.php | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 tests/Traits/StepsRunnerTest.php diff --git a/tests/Traits/StepsRunnerTest.php b/tests/Traits/StepsRunnerTest.php new file mode 100644 index 000000000..988594cf9 --- /dev/null +++ b/tests/Traits/StepsRunnerTest.php @@ -0,0 +1,17 @@ +task; + $task->steps()->copy($this->server.'/state.json', $this->server.'/state2.json'); + + $results = $task->runSteps(); + + $this->assertTrue($results); + } +} From 5bff7593a2c5e1fbd463f69710c64521c62dfd3e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 15:21:44 +0200 Subject: [PATCH 256/424] Tweak tests --- tests/TestCases/RocketeerTestCase.php | 16 ++++++++-------- tests/Traits/StepsRunnerTest.php | 4 +++- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 08ea9ee65..6126c174a 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -81,7 +81,7 @@ protected function recreateVirtualServer() $this->home = $_SERVER['HOME']; // Recreate deployments file - $this->app['files']->put($this->deploymentsFile, json_encode(array( + $this->files->put($this->deploymentsFile, json_encode(array( 'foo' => 'bar', 'directory_separator' => '/', 'is_setup' => true, @@ -92,8 +92,8 @@ protected function recreateVirtualServer() $rootPath = $this->server.'/../../..'; // Recreate altered local server - $this->app['files']->deleteDirectory($rootPath.'/storage'); - $this->app['files']->deleteDirectory($this->server.'/logs'); + $this->files->deleteDirectory($rootPath.'/storage'); + $this->files->deleteDirectory($this->server.'/logs'); $folders = array( 'current', 'shared', @@ -105,9 +105,9 @@ protected function recreateVirtualServer() foreach ($folders as $folder) { $folder = $this->server.'/'.$folder; - $this->app['files']->deleteDirectory($folder); - $this->app['files']->delete($folder); - $this->app['files']->makeDirectory($folder, 0777, true); + $this->files->deleteDirectory($folder); + $this->files->delete($folder); + $this->files->makeDirectory($folder, 0777, true); file_put_contents($folder.'/.gitkeep', ''); } file_put_contents($this->server.'/state.json', json_encode(array( @@ -118,8 +118,8 @@ protected function recreateVirtualServer() // Delete rocketeer config $binary = $rootPath.'/.rocketeer'; - $this->app['files']->deleteDirectory($binary); - $this->app['files']->deleteDirectory($this->customConfig); + $this->files->deleteDirectory($binary); + $this->files->deleteDirectory($this->customConfig); } //////////////////////////////////////////////////////////////////// diff --git a/tests/Traits/StepsRunnerTest.php b/tests/Traits/StepsRunnerTest.php index 988594cf9..e16dcfdee 100644 --- a/tests/Traits/StepsRunnerTest.php +++ b/tests/Traits/StepsRunnerTest.php @@ -8,10 +8,12 @@ class StepsRunnerTest extends RocketeerTestCase public function testCanRunStepsOnSilentCommands() { $task = $this->task; - $task->steps()->copy($this->server.'/state.json', $this->server.'/state2.json'); + $copy = $this->server.'/state2.json'; + $task->steps()->copy($this->server.'/state.json', $copy); $results = $task->runSteps(); + $this->files->delete($copy); $this->assertTrue($results); } } From 074e9d08b191488a257b0407e40eb059929f3b28 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 17:48:54 +0200 Subject: [PATCH 257/424] Always merge core configuration with stored one --- .../Services/Connections/ConnectionsHandler.php | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 23078b9f7..4beb7d621 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -314,19 +314,15 @@ public function disconnect() */ public function getRepositoryCredentials() { - $credentials = $this->localStorage->get('credentials'); - if (!$credentials) { - $credentials = $this->rocketeer->getOption('scm'); - } - - // Cast to array - $credentials = (array) $credentials; - - return array_merge(array( + $config = (array) $this->rocketeer->getOption('scm'); + $credentials = (array) $this->localStorage->get('credentials'); + $defaults = array( 'repository' => '', 'username' => '', 'password' => '', - ), $credentials); + ); + + return array_merge($defaults, $config, $credentials); } /** From 0e32fb3200c298e4a01ef9db254493ede90680d5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 18:04:43 +0200 Subject: [PATCH 258/424] Change the way Rocketeer handles credentials, '' will prompt, null will not --- .../Services/Connections/ConnectionsHandler.php | 7 +------ src/Rocketeer/Services/CredentialsGatherer.php | 17 +++++++++++------ tests/Services/CredentialsGathererTest.php | 11 ++++++++++- 3 files changed, 22 insertions(+), 13 deletions(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 4beb7d621..d000cfbeb 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -316,13 +316,8 @@ public function getRepositoryCredentials() { $config = (array) $this->rocketeer->getOption('scm'); $credentials = (array) $this->localStorage->get('credentials'); - $defaults = array( - 'repository' => '', - 'username' => '', - 'password' => '', - ); - return array_merge($defaults, $config, $credentials); + return array_merge($config, $credentials); } /** diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 37577924e..9979ea6c2 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -22,14 +22,19 @@ public function getRepositoryCredentials() { // Check for repository credentials $repositoryCredentials = $this->connections->getRepositoryCredentials(); - $credentials = ['repository' => true]; + + // Build credentials array + // null values are considered non required + $credentials = array( + 'repository' => true, + 'username' => !is_null(array_get($repositoryCredentials, 'username', '')), + 'password' => !is_null(array_get($repositoryCredentials, 'password', '')), + ); // If we didn't specify a login/password ask for both the first time - if (!$this->getCredential($repositoryCredentials, 'repository')) { - $credentials += ['username' => true, 'password' => true]; - } elseif ($this->connections->needsCredentials()) { + if ($this->connections->needsCredentials()) { // Else assume the repository is passwordless and only ask again for username - $credentials += ['username' => true, 'password' => false]; + $credentials += ['username' => true, 'password' => true]; } // Gather credentials @@ -87,7 +92,7 @@ protected function getConnectionCredentials($connectionName, $server = null) // Get the credentials for the asked connection $connection = $connectionName.'.servers'; $connection = !is_null($server) ? $connection.'.'.$server : $connection; - $connection = array_get($connections, $connection, array()); + $connection = array_get($connections, $connection, []); // Update connection name $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index eab6bfc5c..c19cbc7b9 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -60,9 +60,17 @@ public function testCanGetRepositoryCredentials() public function testDoesntAskForRepositoryCredentialsIfUneeded() { $this->mockAnswers(); - $this->givenConfiguredRepositoryCredentials(['repository' => $this->repository], false); + $this->command->shouldReceive('option')->andReturn(null); + + $this->givenConfiguredRepositoryCredentials([ + 'repository' => $this->repository, + 'username' => null, + 'password' => null + ], false); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, + 'username' => null, + 'password' => null, )); $this->credentials->getRepositoryCredentials(); @@ -72,6 +80,7 @@ public function testCanFillRepositoryCredentialsIfNeeded() { $this->mockAnswers(array( 'No username is set for [repository]' => $this->username, + 'No password is set for [repository]' => null, )); $this->command->shouldReceive('option')->andReturn(null); From 21b1a4e3be28c689788a5ffd9942ba8d2887d61a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 18:07:10 +0200 Subject: [PATCH 259/424] Update Ignite task --- src/Rocketeer/Tasks/Ignite.php | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index 229d3bd7e..e51a51d61 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -85,9 +85,9 @@ protected function getConfigurationInformations() $this->connections->getServerCredentials(), array( 'connection' => preg_replace('/#[0-9]+/', null, $this->connections->getConnection()), - 'scm_repository' => $repositoryCredentials['repository'], - 'scm_username' => $repositoryCredentials['username'], - 'scm_password' => $repositoryCredentials['password'], + 'scm_repository' => array_get($repositoryCredentials, 'repository'), + 'scm_username' => array_get($repositoryCredentials, 'username'), + 'scm_password' => array_get($repositoryCredentials, 'password'), 'application_name' => $this->command->ask('What is your application\'s name ? ('.$name.')', $name), ) ); From 8dafef444c5ea5732afa3e7581ef6ebe895839ea Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 18:13:03 +0200 Subject: [PATCH 260/424] Use directly Arr::get instead of alias --- src/Rocketeer/Abstracts/AbstractBinary.php | 3 ++- src/Rocketeer/Abstracts/AbstractTask.php | 2 -- .../Abstracts/Strategies/AbstractStrategy.php | 5 +++-- src/Rocketeer/Igniter.php | 3 ++- src/Rocketeer/Plugins/AbstractNotifier.php | 3 ++- src/Rocketeer/Scm/Svn.php | 5 +++-- .../Services/Connections/ConnectionsHandler.php | 16 ++++++++-------- src/Rocketeer/Services/CredentialsGatherer.php | 11 ++++++----- src/Rocketeer/Services/ReleasesManager.php | 7 ++++--- src/Rocketeer/Services/Tasks/TasksBuilder.php | 4 ++-- .../Strategies/Dependencies/BowerStrategy.php | 3 ++- src/Rocketeer/Tasks/Check.php | 3 ++- src/Rocketeer/Tasks/Ignite.php | 7 ++++--- src/Rocketeer/Traits/HasHistory.php | 4 +++- src/Rocketeer/Traits/HasLocator.php | 3 ++- tests/Services/CredentialsGathererTest.php | 8 ++++---- tests/TestCases/RocketeerAssertions.php | 6 ++++-- 17 files changed, 53 insertions(+), 40 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index bff0db17e..1e7603af2 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -10,6 +10,7 @@ namespace Rocketeer\Abstracts; use Illuminate\Container\Container; +use Illuminate\Support\Arr; use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; @@ -169,7 +170,7 @@ protected function buildOptions($flags) $flags = (array) $flags; // Flip array if necessary - $firstKey = array_get(array_keys($flags), 0); + $firstKey = Arr::get(array_keys($flags), 0); if (!is_null($firstKey) and is_int($firstKey)) { $flags = array_combine( array_values($flags), diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 68868c715..4801631ad 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -10,10 +10,8 @@ namespace Rocketeer\Abstracts; use DateTime; -use Illuminate\Container\Container; use Illuminate\Support\Str; use Rocketeer\Bash; -use Rocketeer\Services\StepsBuilder; use Rocketeer\Traits\StepsRunner; use Symfony\Component\Console\Helper\Table; diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index 94bd6a83d..9b0a85075 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Abstracts\Strategies; +use Illuminate\Support\Arr; use Rocketeer\Bash; /** @@ -44,8 +45,8 @@ public function displayStatus() $components = get_class($this); $components = explode('\\', $components); - $name = array_get($components, count($components) - 1); - $strategy = array_get($components, count($components) - 2); + $name = Arr::get($components, count($components) - 1); + $strategy = Arr::get($components, count($components) - 2); $object = 'Running strategy for '.ucfirst($strategy); $subject = str_replace('Strategy', null, $name); diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 116ba6275..372f5fb52 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -9,6 +9,7 @@ */ namespace Rocketeer; +use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; use Symfony\Component\Finder\Finder; use Symfony\Component\Finder\SplFileInfo; @@ -137,7 +138,7 @@ public function updateConfiguration($folder, array $values = array()) } // Change repository in use - $application = array_get($values, 'application_name'); + $application = Arr::get($values, 'application_name'); $this->localStorage->setFile($application); } diff --git a/src/Rocketeer/Plugins/AbstractNotifier.php b/src/Rocketeer/Plugins/AbstractNotifier.php index 77e209f67..19edb0974 100644 --- a/src/Rocketeer/Plugins/AbstractNotifier.php +++ b/src/Rocketeer/Plugins/AbstractNotifier.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Plugins; +use Illuminate\Support\Arr; use Rocketeer\Abstracts\AbstractPlugin; use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Services\TasksHandler; @@ -71,7 +72,7 @@ protected function getComponents() // Get hostname $credentials = $this->connections->getServerCredentials($connection, $server); - $host = array_get($credentials, 'host'); + $host = Arr::get($credentials, 'host'); if ($stage) { $connection = $stage.'@'.$connection; } diff --git a/src/Rocketeer/Scm/Svn.php b/src/Rocketeer/Scm/Svn.php index 9cb7722ad..ed9b621f7 100644 --- a/src/Rocketeer/Scm/Svn.php +++ b/src/Rocketeer/Scm/Svn.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Scm; +use Illuminate\Support\Arr; use Rocketeer\Abstracts\AbstractBinary; use Rocketeer\Interfaces\ScmInterface; @@ -114,10 +115,10 @@ protected function getCredentials() $credentials = $this->connections->getRepositoryCredentials(); // Build command - if ($user = array_get($credentials, 'username')) { + if ($user = Arr::get($credentials, 'username')) { $options['--username'] = $user; } - if ($pass = array_get($credentials, 'password')) { + if ($pass = Arr::get($credentials, 'password')) { $options['--password'] = $pass; } diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index d000cfbeb..151e7c149 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -137,7 +137,7 @@ public function getAvailableConnections() // Unify multiservers foreach ($connections as $key => $servers) { - $servers = array_get($servers, 'servers', [$servers]); + $servers = Arr::get($servers, 'servers', [$servers]); $connections[$key] = ['servers' => array_values($servers)]; } @@ -155,7 +155,7 @@ public function isValidConnection($connection) { $available = (array) $this->getAvailableConnections(); - return (bool) array_get($available, $connection.'.servers'); + return (bool) Arr::get($available, $connection.'.servers'); } /** @@ -203,7 +203,7 @@ public function getConnection() return $this->connection; } - $connection = array_get($this->getConnections(), 0); + $connection = Arr::get($this->getConnections(), 0); $this->connection = $connection; return $this->connection; @@ -221,7 +221,7 @@ public function getConnectionCredentials($connection = null) $connection = $connection ?: $this->getConnection(); $available = $this->getAvailableConnections(); - return array_get($available, $connection.'.servers'); + return Arr::get($available, $connection.'.servers'); } /** @@ -236,7 +236,7 @@ public function getServerCredentials($connection = null, $server = 0) { $connection = $this->getConnectionCredentials($connection); - return array_get($connection, $server); + return Arr::get($connection, $server); } /** @@ -329,9 +329,9 @@ public function getRepositoryEndpoint() { // Get credentials $repository = $this->getRepositoryCredentials(); - $username = array_get($repository, 'username'); - $password = array_get($repository, 'password'); - $repository = array_get($repository, 'repository'); + $username = Arr::get($repository, 'username'); + $password = Arr::get($repository, 'password'); + $repository = Arr::get($repository, 'repository'); // Add credentials if possible if ($username or $password) { diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 9979ea6c2..2c4186a96 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Services; +use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; class CredentialsGatherer @@ -27,8 +28,8 @@ public function getRepositoryCredentials() // null values are considered non required $credentials = array( 'repository' => true, - 'username' => !is_null(array_get($repositoryCredentials, 'username', '')), - 'password' => !is_null(array_get($repositoryCredentials, 'password', '')), + 'username' => !is_null(Arr::get($repositoryCredentials, 'username', '')), + 'password' => !is_null(Arr::get($repositoryCredentials, 'password', '')), ); // If we didn't specify a login/password ask for both the first time @@ -70,7 +71,7 @@ public function getServerCredentials() // Else loop through the connections and fill in credentials foreach ($activeConnections as $connectionName) { - $servers = array_get($availableConnections, $connectionName.'.servers'); + $servers = Arr::get($availableConnections, $connectionName.'.servers'); $servers = array_keys($servers); foreach ($servers as $server) { $this->getConnectionCredentials($connectionName, $server); @@ -92,7 +93,7 @@ protected function getConnectionCredentials($connectionName, $server = null) // Get the credentials for the asked connection $connection = $connectionName.'.servers'; $connection = !is_null($server) ? $connection.'.'.$server : $connection; - $connection = array_get($connections, $connection, []); + $connection = Arr::get($connections, $connection, []); // Update connection name $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; @@ -181,7 +182,7 @@ protected function gatherCredential($handle, $credential, $question = null) */ protected function getCredential($credentials, $credential) { - $value = array_get($credentials, $credential); + $value = Arr::get($credentials, $credential); if (substr($value, 0, 1) === '{') { return; } diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 7a2dca52d..854cfd94c 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -10,6 +10,7 @@ namespace Rocketeer\Services; use Illuminate\Container\Container; +use Illuminate\Support\Arr; use Rocketeer\Services\Storages\ServerStorage; use Rocketeer\Traits\HasLocator; @@ -225,7 +226,7 @@ public function markReleaseAsValid($release = null) */ public function checkReleaseState($release) { - return array_get($this->state, $release, true); + return Arr::get($this->state, $release, true); } //////////////////////////////////////////////////////////////////// @@ -239,7 +240,7 @@ public function checkReleaseState($release) */ public function getCurrentRelease() { - $current = array_get($this->getReleases(), 0); + $current = Arr::get($this->getReleases(), 0); $current = $this->sanitizeRelease($current); return $this->nextRelease ?: $current; @@ -263,7 +264,7 @@ public function getPreviousRelease($release = null) $key = !is_int($key) ? -1 : $key; $next = 1; do { - $release = array_get($releases, $key + $next); + $release = Arr::get($releases, $key + $next); $next++; } while (!$this->checkReleaseState($release)); diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index e2b16ea0c..ddd954199 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -210,8 +210,8 @@ protected function taskClassExists($task) /** * Find a class in various predefined namespaces * - * @param string $class - * @param string[] $paths + * @param string $class + * @param string[] $paths * * @return string|false */ diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php index 44c478352..cbd497d45 100644 --- a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Strategies\Dependencies; +use Illuminate\Support\Arr; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; @@ -64,7 +65,7 @@ public function update() protected function getInstallationOptions() { $credentials = $this->connections->getServerCredentials(); - if (array_get($credentials, 'username') == 'root') { + if (Arr::get($credentials, 'username') == 'root') { return ['--allow-root' => null]; } diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 0ec7ae6a6..1e3d4b821 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Tasks; +use Illuminate\Support\Arr; use Rocketeer\Abstracts\AbstractTask; /** @@ -147,7 +148,7 @@ public function checkPhpVersion() $composer = json_decode($composer, true); // Strip versions of constraints - $required = (string) array_get($composer, 'require.php'); + $required = (string) Arr::get($composer, 'require.php'); $required = preg_replace('/>=/', '', $required); } diff --git a/src/Rocketeer/Tasks/Ignite.php b/src/Rocketeer/Tasks/Ignite.php index e51a51d61..0371473d8 100644 --- a/src/Rocketeer/Tasks/Ignite.php +++ b/src/Rocketeer/Tasks/Ignite.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Tasks; +use Illuminate\Support\Arr; use Rocketeer\Abstracts\AbstractTask; /** @@ -85,9 +86,9 @@ protected function getConfigurationInformations() $this->connections->getServerCredentials(), array( 'connection' => preg_replace('/#[0-9]+/', null, $this->connections->getConnection()), - 'scm_repository' => array_get($repositoryCredentials, 'repository'), - 'scm_username' => array_get($repositoryCredentials, 'username'), - 'scm_password' => array_get($repositoryCredentials, 'password'), + 'scm_repository' => Arr::get($repositoryCredentials, 'repository'), + 'scm_username' => Arr::get($repositoryCredentials, 'username'), + 'scm_password' => Arr::get($repositoryCredentials, 'password'), 'application_name' => $this->command->ask('What is your application\'s name ? ('.$name.')', $name), ) ); diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index aa6a15a36..3cac9d46b 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -9,6 +9,8 @@ */ namespace Rocketeer\Traits; +use Illuminate\Support\Arr; + /** * A class that maintains an history of results/commands * @@ -28,7 +30,7 @@ public function getHistory($type = null) { $handle = $this->getHistoryHandle(); $history = $this->history[$handle]; - $history = array_get($history, $type); + $history = Arr::get($history, $type); return $history; } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 263a46cf7..cfbf63497 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -10,6 +10,7 @@ namespace Rocketeer\Traits; use Illuminate\Container\Container; +use Illuminate\Support\Arr; /** * A trait for Service Locator-based classes wich adds @@ -130,6 +131,6 @@ protected function getOption($option, $loose = false) return null; } - return $loose ? array_get($this->command->option(), $option) : $this->command->option($option); + return $loose ? Arr::get($this->command->option(), $option) : $this->command->option($option); } } diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index c19cbc7b9..b048886f1 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -63,10 +63,10 @@ public function testDoesntAskForRepositoryCredentialsIfUneeded() $this->command->shouldReceive('option')->andReturn(null); $this->givenConfiguredRepositoryCredentials([ - 'repository' => $this->repository, - 'username' => null, - 'password' => null - ], false); + 'repository' => $this->repository, + 'username' => null, + 'password' => null + ], false); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, 'username' => null, diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index b12aa474f..a4f4240e8 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -1,6 +1,8 @@ Date: Sat, 16 Aug 2014 19:08:19 +0200 Subject: [PATCH 261/424] Update handles --- README.md | 41 +++++++++++------------------------------ composer.json | 6 +++--- 2 files changed, 14 insertions(+), 33 deletions(-) diff --git a/README.md b/README.md index 7d8e1490c..d31e5fe2f 100644 --- a/README.md +++ b/README.md @@ -1,10 +1,10 @@ # Rocketeer -[![Build Status](http://img.shields.io/travis/Anahkiasen/rocketeer.svg?style=flat)](https://travis-ci.org/Anahkiasen/rocketeer) -[![Latest Stable Version](http://img.shields.io/packagist/v/Anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) -[![Total Downloads](http://img.shields.io/packagist/dt/Anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) -[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/Anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) -[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/Anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/Anahkiasen/rocketeer/) +[![Build Status](http://img.shields.io/travis/rocketeers/rocketeer.svg?style=flat)](https://travis-ci.org/rocketeers/rocketeer) +[![Latest Stable Version](http://img.shields.io/packagist/v/rocketeers/rocketeer.svg?style=flat)](https://packagist.org/packages/rocketeers/rocketeer) +[![Total Downloads](http://img.shields.io/packagist/dt/rocketeers/rocketeer.svg?style=flat)](https://packagist.org/packages/rocketeers/rocketeer) +[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) +[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) [![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg?style=flat)](https://www.gittip.com/Anahkiasen/) **Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. @@ -13,7 +13,7 @@ The easiest way is to get the latest compiled version [from the website](http://rocketeer.autopergamene.eu/versions/rocketeer.phar), put it at the root of the project you want to deploy, and hit `php rocketeer.phar ignite`. You'll get asked a series of questions that should get you up and running in no time. -Rocketeer also integrates nicely with the Laravel framework, for that refer to the [Getting Started](https://github.com/Anahkiasen/rocketeer/wiki/Getting-started) pages of the documentation. +Rocketeer also integrates nicely with the Laravel framework, for that refer to the [Getting Started](https://github.com/rocketeers/rocketeer/wiki/Getting-started) pages of the documentation. ## Usage @@ -44,23 +44,23 @@ $ phpunit ## Contributing -Please see [CONTRIBUTING](https://github.com/anahkiasen/rocketeer/blob/master/CONTRIBUTING.md) for details. +Please see [CONTRIBUTING](https://github.com/rocketeers/rocketeer/blob/master/CONTRIBUTING.md) for details. ## Credits - [Anahkiasen](https://github.com/Anahkiasen) -- [All Contributors](https://github.com/anahkiasen/rocketeer/contributors) +- [All Contributors](https://github.com/rocketeers/rocketeer/contributors) ## License -The MIT License (MIT). Please see [License File](https://github.com/anahkiasen/rocketeer/blob/master/LICENSE) for more information. +The MIT License (MIT). Please see [License File](https://github.com/rocketeers/rocketeer/blob/master/LICENSE) for more information. ----- ## Available plugins and integrations -- [Campfire](https://github.com/Anahkiasen/rocketeer-campfire) -- [Slack](https://github.com/Anahkiasen/rocketeer-slack) +- [Campfire](https://github.com/rocketeers/rocketeer-campfire) +- [Slack](https://github.com/rocketeers/rocketeer-slack) - [HipChat](https://github.com/hannesvdvreken/rocketeer-hipchat) - [Wordpress](https://github.com/mykebates/wp-rocketeer) @@ -72,22 +72,3 @@ But, it remains a Ruby package and one that's tightly coupled to Rails in some w It's also meant to be a lot easier to comprehend, for first-time users or novices, Capistrano is a lot to take at once – Rocketeer aims to be as simple as possible by providing smart defaults and speeding up the time between installing it and first hitting `deploy`. It's also more thought out for the PHP world – although you can configure Capistrano to run Composer and PHPUnit, that's not something it expects from the get go, while those tasks that are a part of every PHP developer are integrated in Rocketeer's core deploy process. - -## Table of contents - -### Getting started - -- **[What's Rocketeer](https://github.com/Anahkiasen/rocketeer/wiki/Whats-Rocketeer)** -- **[Getting Started](https://github.com/Anahkiasen/rocketeer/wiki/Getting-started)** - -### Core concepts - -- **[Tasks](https://github.com/Anahkiasen/rocketeer/wiki/Tasks)** -- **[Events](https://github.com/Anahkiasen/rocketeer/wiki/Events)** -- **[Connections and stages](https://github.com/Anahkiasen/rocketeer/wiki/Connections-Stages)** -- **[Plugins](https://github.com/Anahkiasen/rocketeer/wiki/Plugins)** - -### Going further - -- **[Architecture](https://github.com/Anahkiasen/rocketeer/wiki/Architecture)** -- **[Troubleshooting](https://github.com/Anahkiasen/rocketeer/wiki/Troubleshooting)** diff --git a/composer.json b/composer.json index 975beb17f..77f1939a3 100644 --- a/composer.json +++ b/composer.json @@ -1,5 +1,5 @@ { - "name": "anahkiasen/rocketeer", + "name": "rocketeers/rocketeer", "description": "Rocketeer is a fast and simple deployer for the PHP world", "license": "MIT", "keywords": [ @@ -37,8 +37,8 @@ "johnkary/phpunit-speedtrap": "dev-master" }, "suggest": { - "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", - "anahkiasen/rocketeer-slack": "Slack plugin to create deployments notifications", + "rocketeers/rocketeer-campfire": "Campfire plugin to create deployments notifications", + "rocketeers/rocketeer-slack": "Slack plugin to create deployments notifications", "ext-pcntl": "Allow parallel deployments" }, "bin": [ From 173aa70f49de4d5af3899e95e949e8164b878573 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 20:35:17 +0200 Subject: [PATCH 262/424] Welp that failed miserably --- README.md | 10 +++++----- composer.json | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index d31e5fe2f..2b2f12c65 100644 --- a/README.md +++ b/README.md @@ -1,10 +1,10 @@ # Rocketeer -[![Build Status](http://img.shields.io/travis/rocketeers/rocketeer.svg?style=flat)](https://travis-ci.org/rocketeers/rocketeer) -[![Latest Stable Version](http://img.shields.io/packagist/v/rocketeers/rocketeer.svg?style=flat)](https://packagist.org/packages/rocketeers/rocketeer) -[![Total Downloads](http://img.shields.io/packagist/dt/rocketeers/rocketeer.svg?style=flat)](https://packagist.org/packages/rocketeers/rocketeer) -[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) -[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) +[![Build Status](http://img.shields.io/travis/anahkiasen/rocketeer.svg?style=flat)](https://travis-ci.org/anahkiasen/rocketeer) +[![Latest Stable Version](http://img.shields.io/packagist/v/anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) +[![Total Downloads](http://img.shields.io/packagist/dt/anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) +[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/anahkiasen/rocketeer/) +[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/anahkiasen/rocketeer/) [![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg?style=flat)](https://www.gittip.com/Anahkiasen/) **Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. diff --git a/composer.json b/composer.json index 77f1939a3..1076dc535 100644 --- a/composer.json +++ b/composer.json @@ -37,8 +37,8 @@ "johnkary/phpunit-speedtrap": "dev-master" }, "suggest": { - "rocketeers/rocketeer-campfire": "Campfire plugin to create deployments notifications", - "rocketeers/rocketeer-slack": "Slack plugin to create deployments notifications", + "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", + "anahkiasen/rocketeer-slack": "Slack plugin to create deployments notifications", "ext-pcntl": "Allow parallel deployments" }, "bin": [ From df2d710e2cbceeb78af72b142e4ffc53ab152446 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 20:56:25 +0200 Subject: [PATCH 263/424] Update README.md --- README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 2b2f12c65..5b9f375d6 100644 --- a/README.md +++ b/README.md @@ -1,10 +1,10 @@ # Rocketeer -[![Build Status](http://img.shields.io/travis/anahkiasen/rocketeer.svg?style=flat)](https://travis-ci.org/anahkiasen/rocketeer) +[![Build Status](http://img.shields.io/travis/rocketeers/rocketeer.svg?style=flat)](https://travis-ci.org/rocketeers/rocketeer) [![Latest Stable Version](http://img.shields.io/packagist/v/anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) [![Total Downloads](http://img.shields.io/packagist/dt/anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) -[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/anahkiasen/rocketeer/) -[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/anahkiasen/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/anahkiasen/rocketeer/) +[![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) +[![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) [![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg?style=flat)](https://www.gittip.com/Anahkiasen/) **Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. From ab4873b96b861b95bf442cc23389db54eb1b5801 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 16 Aug 2014 21:24:52 +0200 Subject: [PATCH 264/424] Remove polluting output when display too --- src/Rocketeer/Traits/BashModules/Core.php | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 4b73aafb4..3aed90346 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -90,7 +90,8 @@ public function run($commands, $silent = false, $array = false) $output .= $results; if ($verbose) { - $this->getConnection()->display(trim($results)); + $display = $this->cleanOutput($results); + $this->getConnection()->display(trim($display)); } }); @@ -275,6 +276,20 @@ public function processCommands($commands) return $commands; } + /** + * Clean the output of various intruding bits + * + * @param string $output + * + * @return string + */ + protected function cleanOutput($output) + { + return strtr($output, array( + 'stdin: is not a tty' => null, + )); + } + /** * Process the output of a command * @@ -287,7 +302,7 @@ public function processCommands($commands) protected function processOutput($output, $array = false, $trim = true) { // Remove polluting strings - $output = str_replace('stdin: is not a tty', null, $output); + $output = $this->cleanOutput($output); // Explode output if necessary if ($array) { From 94567417f2aa253c29fe5ef20de45c44107a1dc7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 13:47:46 +0200 Subject: [PATCH 265/424] Simplify some commands and docblock fixes --- src/Rocketeer/Abstracts/AbstractCommand.php | 7 ++++ src/Rocketeer/Abstracts/AbstractStorage.php | 4 +- .../Console/Commands/BaseTaskCommand.php | 7 ---- .../Console/Commands/CleanupCommand.php | 19 +-------- .../Console/Commands/DeployCommand.php | 9 +---- .../Console/Commands/RollbackCommand.php | 19 +-------- .../Console/Commands/TestCommand.php | 39 ------------------- .../Console/Commands/UpdateCommand.php | 19 +-------- src/Rocketeer/Igniter.php | 2 +- .../Services/Connections/LocalConnection.php | 1 + src/Rocketeer/Tasks/Check.php | 2 +- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 2 +- .../Traits/BashModules/Filesystem.php | 6 +-- 14 files changed, 21 insertions(+), 117 deletions(-) delete mode 100644 src/Rocketeer/Console/Commands/TestCommand.php diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 49cbf0391..2825fc17a 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -21,6 +21,13 @@ */ abstract class AbstractCommand extends Command { + /** + * the task to execute on fire + * + * @var AbstractTask + */ + protected $task; + /** * @param AbstractTask|null $task */ diff --git a/src/Rocketeer/Abstracts/AbstractStorage.php b/src/Rocketeer/Abstracts/AbstractStorage.php index 91d6bbb90..1d510920e 100644 --- a/src/Rocketeer/Abstracts/AbstractStorage.php +++ b/src/Rocketeer/Abstracts/AbstractStorage.php @@ -59,8 +59,8 @@ public function setFile($file) /** * Get a value on the server * - * @param string|null $key - * @param Closure|null $fallback + * @param string|null $key + * @param array|string|Closure|null $fallback * * @return string|integer|array */ diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index db1e66a6d..a4b748afe 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -27,13 +27,6 @@ class BaseTaskCommand extends AbstractCommand */ protected $name = 'deploy:custom'; - /** - * the task to execute on fire - * - * @var AbstractTask - */ - protected $task; - /** * Build a new custom command * diff --git a/src/Rocketeer/Console/Commands/CleanupCommand.php b/src/Rocketeer/Console/Commands/CleanupCommand.php index aeaa6282b..b4ebdf429 100644 --- a/src/Rocketeer/Console/Commands/CleanupCommand.php +++ b/src/Rocketeer/Console/Commands/CleanupCommand.php @@ -17,25 +17,8 @@ * * @author Maxime Fabre */ -class CleanupCommand extends AbstractCommand +class CleanupCommand extends BaseTaskCommand { - /** - * The console command name. - * - * @var string - */ - protected $name = 'deploy:cleanup'; - - /** - * Execute the tasks - * - * @return integer - */ - public function fire() - { - return $this->fireTasksQueue('cleanup'); - } - /** * Get the console command options. * diff --git a/src/Rocketeer/Console/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php index e473d4b40..c975f0452 100644 --- a/src/Rocketeer/Console/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -17,15 +17,8 @@ * * @author Maxime Fabre */ -class DeployCommand extends AbstractCommand +class DeployCommand extends BaseTaskCommand { - /** - * The console command name. - * - * @var string - */ - protected $name = 'deploy:deploy'; - /** * Execute the tasks * diff --git a/src/Rocketeer/Console/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php index f1b2ba368..2690efd05 100644 --- a/src/Rocketeer/Console/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -18,25 +18,8 @@ * * @author Maxime Fabre */ -class RollbackCommand extends AbstractCommand +class RollbackCommand extends BaseTaskCommand { - /** - * The console command name. - * - * @var string - */ - protected $name = 'deploy:rollback'; - - /** - * The tasks to execute - * - * @return integer - */ - public function fire() - { - return $this->fireTasksQueue('rollback'); - } - /** * Get the console command arguments. * diff --git a/src/Rocketeer/Console/Commands/TestCommand.php b/src/Rocketeer/Console/Commands/TestCommand.php deleted file mode 100644 index a5a0fdcde..000000000 --- a/src/Rocketeer/Console/Commands/TestCommand.php +++ /dev/null @@ -1,39 +0,0 @@ - - * - * For the full copyright and license information, please view the LICENSE - * file that was distributed with this source code. - */ -namespace Rocketeer\Console\Commands; - -use Rocketeer\Abstracts\AbstractCommand; - -/** - * Run the tests on the server and displays the output - * - * @author Maxime Fabre - */ -class TestCommand extends AbstractCommand -{ - /** - * The console command name. - * - * @var string - */ - protected $name = 'deploy:test'; - - /** - * The tasks to execute - * - * @return integer - */ - public function fire() - { - $this->input->setOption('verbose', true); - - return $this->fireTasksQueue('test'); - } -} diff --git a/src/Rocketeer/Console/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php index 434fa11e8..8d963d839 100644 --- a/src/Rocketeer/Console/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -17,25 +17,8 @@ * * @author Maxime Fabre */ -class UpdateCommand extends AbstractCommand +class UpdateCommand extends BaseTaskCommand { - /** - * The console command name. - * - * @var string - */ - protected $name = 'deploy:update'; - - /** - * Execute the tasks - * - * @return integer - */ - public function fire() - { - return $this->fireTasksQueue('update'); - } - /** * Get the console command options. * diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 372f5fb52..c15e43c18 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -50,7 +50,7 @@ public function loadUserConfiguration() }; // Defer loading of tasks and events or not - if (method_exists($this->app, 'booted')) { + if (is_a($this->app, 'Illuminate\Foundation\Application')) { $this->app->booted($fileLoaders); } else { $fileLoaders(); diff --git a/src/Rocketeer/Services/Connections/LocalConnection.php b/src/Rocketeer/Services/Connections/LocalConnection.php index 57ea91406..4f870bb5d 100644 --- a/src/Rocketeer/Services/Connections/LocalConnection.php +++ b/src/Rocketeer/Services/Connections/LocalConnection.php @@ -72,6 +72,7 @@ public function run($commands, Closure $callback = null) $this->previousStatus = $status; if ($callback) { + $output = (array) $output; foreach ($output as $line) { $callback($line.PHP_EOL); } diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 1e3d4b821..a279c1313 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -112,7 +112,7 @@ public function checkScm() $results = $this->scm->run('check'); $this->toOutput($results); - return $this->remote->status() == 0; + return $this->getConnection()->status() == 0; } /** diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 9534ea1ad..66b8389e4 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -85,7 +85,7 @@ public function execute() /** * Set permissions for the folders used by the application * - * @return true + * @return boolean */ protected function setApplicationPermissions() { diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 3aed90346..444fb2f24 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -198,7 +198,7 @@ public function status() public function checkStatus($error, $output = null, $success = null) { // If all went well - if ($this->remote->status() == 0) { + if ($this->getConnection()->status() == 0) { if ($success) { $this->command->comment($success); } diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index 81a26be48..8fcc404fb 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -134,7 +134,7 @@ public function setPermissions($folder) */ public function getFile($file) { - return $this->remote->getString($file); + return $this->getConnection()->getString($file); } /** @@ -147,7 +147,7 @@ public function getFile($file) */ public function putFile($file, $contents) { - $this->remote->putString($file, $contents); + $this->getConnection()->putString($file, $contents); } /** @@ -165,7 +165,7 @@ public function upload($file, $destination = null) // Get contents and destination $destination = $destination ?: basename($file); - $this->remote->put($file, $destination); + $this->getConnection()->put($file, $destination); } //////////////////////////////////////////////////////////////////// From 6dc6759e56903717b2250463ea1cbced82fb917a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 14:02:34 +0200 Subject: [PATCH 266/424] Add some RemoteHandler tests --- .../MissingCredentialsException.php | 7 ++ .../Services/Connections/Connection.php | 50 +++++++++ .../Services/Connections/RemoteHandler.php | 18 ++-- .../ConnectionsHandlerTest.php | 2 +- .../Connections/RemoteHandlerTest.php | 100 ++++++++++++++++++ 5 files changed, 169 insertions(+), 8 deletions(-) create mode 100644 src/Rocketeer/Exceptions/MissingCredentialsException.php create mode 100644 src/Rocketeer/Services/Connections/Connection.php rename tests/Services/{ => Connections}/ConnectionsHandlerTest.php (99%) create mode 100644 tests/Services/Connections/RemoteHandlerTest.php diff --git a/src/Rocketeer/Exceptions/MissingCredentialsException.php b/src/Rocketeer/Exceptions/MissingCredentialsException.php new file mode 100644 index 000000000..3756a800e --- /dev/null +++ b/src/Rocketeer/Exceptions/MissingCredentialsException.php @@ -0,0 +1,7 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services\Connections; + +/** + * Base connection class with additional setters + * + * @author Maxime Fabre + */ +class Connection extends \Illuminate\Remote\Connection +{ + /** + * @return array + */ + public function getAuth() + { + return $this->auth; + } + + /** + * @return string + */ + public function getHost() + { + return $this->host; + } + + /** + * @return string + */ + public function getName() + { + return $this->name; + } + + /** + * @return string + */ + public function getUsername() + { + return $this->username; + } +} diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index a8ca865c8..8ef3afd60 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -9,8 +9,8 @@ */ namespace Rocketeer\Services\Connections; -use Illuminate\Remote\Connection; use InvalidArgumentException; +use Rocketeer\Exceptions\MissingCredentialsException; use Rocketeer\Traits\HasLocator; use Symfony\Component\Console\Output\NullOutput; @@ -32,14 +32,17 @@ class RemoteHandler protected $active = []; /** - * Get the current Connection + * Create a specific connection or the default one + * + * @param string|null $connection + * @param integer $server * * @return Connection */ - public function connection() + public function connection($connection = null, $server = 0) { - $name = $this->connections->getConnection(); - $server = $this->connections->getServer(); + $name = $connection ?: $this->connections->getConnection(); + $server = $server ?: $this->connections->getServer(); $handle = $name.'#'.$server; // Check the cache @@ -61,12 +64,13 @@ public function connection() * @param string $name * @param array $credentials * + * @throws MissingCredentialsException * @return Connection */ protected function makeConnection($name, array $credentials) { if (!isset($credentials['host']) || !isset($credentials['username'])) { - throw new InvalidArgumentException('Host and/or username is required for '.$name); + throw new MissingCredentialsException('Host and/or username is required for '.$name); } $connection = new Connection( @@ -103,7 +107,7 @@ protected function getAuth(array $config) return array('password' => $config['password']); } - throw new InvalidArgumentException('Password / key is required.'); + throw new MissingCredentialsException('Password / key is required.'); } /** diff --git a/tests/Services/ConnectionsHandlerTest.php b/tests/Services/Connections/ConnectionsHandlerTest.php similarity index 99% rename from tests/Services/ConnectionsHandlerTest.php rename to tests/Services/Connections/ConnectionsHandlerTest.php index d628d7edf..1340fe489 100644 --- a/tests/Services/ConnectionsHandlerTest.php +++ b/tests/Services/Connections/ConnectionsHandlerTest.php @@ -1,5 +1,5 @@ handler = new RemoteHandler($this->app); + unset($this->app['rocketeer.command']); + } + + public function testCanCreateConnection() + { + $this->swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + 'host' => 'foobar.com', + 'username' => 'foobar', + 'password' => 'foobar', + ), + ), + )); + + $connection = $this->handler->connection(); + + $this->assertInstanceOf('Rocketeer\Services\Connections\Connection', $connection); + $this->assertEquals('production', $connection->getName()); + $this->assertEquals('foobar', $connection->getUsername()); + } + + public function testThrowsExceptionIfMissingCredentials() + { + $this->setExpectedException('Rocketeer\Exceptions\MissingCredentialsException'); + + $this->swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + 'host' => 'foobar.com', + 'username' => 'foobar', + ), + ), + )); + + $this->handler->connection(); + } + + public function testThrowsExceptionIfMissingInformations() + { + $this->setExpectedException('Rocketeer\Exceptions\MissingCredentialsException'); + + $this->swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + 'username' => 'foobar', + 'password' => 'foobar', + ), + ), + )); + + $this->handler->connection(); + } + + public function testCachesConnections() + { + $this->swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + 'host' => 'foobar.com', + 'username' => 'foobar', + 'password' => 'foobar', + ), + ), + )); + + $connection = $this->handler->connection(); + $this->assertInstanceOf('Rocketeer\Services\Connections\Connection', $connection); + $this->assertEquals('production', $connection->getName()); + + $this->swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + ), + ), + )); + + $connection = $this->handler->connection(); + $this->assertInstanceOf('Rocketeer\Services\Connections\Connection', $connection); + $this->assertEquals('production', $connection->getName()); + } +} From e37089a1566c0cb689d44902a28491d0c357084b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 14:15:48 +0200 Subject: [PATCH 267/424] Code tweaks --- src/Rocketeer/Console/Commands/CleanupCommand.php | 1 - src/Rocketeer/Console/Commands/DeployCommand.php | 1 - src/Rocketeer/Console/Commands/RollbackCommand.php | 1 - src/Rocketeer/Console/Commands/UpdateCommand.php | 1 - src/Rocketeer/Traits/BashModules/Flow.php | 2 +- 5 files changed, 1 insertion(+), 5 deletions(-) diff --git a/src/Rocketeer/Console/Commands/CleanupCommand.php b/src/Rocketeer/Console/Commands/CleanupCommand.php index b4ebdf429..03d8a064a 100644 --- a/src/Rocketeer/Console/Commands/CleanupCommand.php +++ b/src/Rocketeer/Console/Commands/CleanupCommand.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Console\Commands; -use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputOption; /** diff --git a/src/Rocketeer/Console/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php index c975f0452..a375e7ad0 100644 --- a/src/Rocketeer/Console/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Console\Commands; -use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputOption; /** diff --git a/src/Rocketeer/Console/Commands/RollbackCommand.php b/src/Rocketeer/Console/Commands/RollbackCommand.php index 2690efd05..145e42568 100644 --- a/src/Rocketeer/Console/Commands/RollbackCommand.php +++ b/src/Rocketeer/Console/Commands/RollbackCommand.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Console\Commands; -use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputOption; diff --git a/src/Rocketeer/Console/Commands/UpdateCommand.php b/src/Rocketeer/Console/Commands/UpdateCommand.php index 8d963d839..e29bb1993 100644 --- a/src/Rocketeer/Console/Commands/UpdateCommand.php +++ b/src/Rocketeer/Console/Commands/UpdateCommand.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Console\Commands; -use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Input\InputOption; /** diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index cbdaf8f39..3780ccf17 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -64,7 +64,7 @@ public function runForCurrentRelease($tasks) /** * Sync the requested folders and files * - * @return void + * @return boolean */ protected function syncSharedFolders() { From 9bfdf942786315316f874f3e52516b1a11bd2518 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 14:25:06 +0200 Subject: [PATCH 268/424] Split complexity of buildTask --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 76 ++++++++++++++----- 1 file changed, 58 insertions(+), 18 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index ddd954199..faa7883b6 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -83,24 +83,8 @@ public function buildTasks(array $tasks) */ public function buildTask($task, $name = null, $description = null) { - // Check the handle if possible - if (is_string($task)) { - $handle = 'rocketeer.tasks.'.Str::snake($task, '-'); - } - - if ($task instanceof Closure) { - // If we provided a Closure, build a ClosureTask - $task = $this->buildTaskFromClosure($task); - } elseif (isset($handle) and $this->app->bound($handle)) { - // If we passed a task handle, return it - $task = $this->app[$handle]; - } elseif (is_array($task) or $this->isStringCommand($task)) { - // If we passed a command, build a ClosureTask - $task = $this->buildTaskFromString($task); - } elseif (!$task instanceof AbstractTask) { - // Else it's a class name, get the appropriated task - $task = $this->buildTaskFromClass($task); - } + // Compose the task from their various types + $task = $this->composeTask($task); // If the built class is invalid, cancel if (!$task instanceof AbstractTask) { @@ -114,6 +98,41 @@ public function buildTask($task, $name = null, $description = null) return $task; } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// COMPOSING ///////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Compose a Task from its various types + * + * @param string|Closure|AbstractTask $task + * + * @return mixed|AbstractTask + * @throws \Rocketeer\Exceptions\TaskCompositionException + */ + protected function composeTask($task) + { + // If we provided a Closure, build a ClosureTask + if ($task instanceof Closure) { + return $this->buildTaskFromClosure($task); + } + + // If we passed a task handle, return it + if ($handle = $this->getTaskHandle($task)) { + return $this->app[$handle]; + } + + // If we passed a command, build a ClosureTask + if (is_array($task) or $this->isStringCommand($task)) { + return $this->buildTaskFromString($task); + } + + // Else it's a class name, get the appropriated task + if (!$task instanceof AbstractTask) { + return $this->buildTaskFromClass($task); + } + } + /** * Build a task from a string * @@ -180,6 +199,27 @@ public function buildTaskFromClass($task) /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// + /** + * Get the handle of a task from its name + * + * @param string $task + * + * @return string|null + */ + protected function getTaskHandle($task) + { + // Check the handle if possible + if (!is_string($task)) { + return; + } + + // Compute the handle and check it's bound + $handle = 'rocketeer.tasks.'.Str::snake($task, '-'); + $task = $this->app->bound($handle) ? $handle : null; + + return $task; + } + /** * Check if a string is a command or a task * From c33575f229bc52ebd32506882bd7e89ada59119f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 14:56:31 +0200 Subject: [PATCH 269/424] Fix deploy command --- src/Rocketeer/Console/Commands/BaseTaskCommand.php | 6 ++++-- src/Rocketeer/Console/Commands/DeployCommand.php | 7 +++++++ 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index a4b748afe..af818bfc2 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -38,8 +38,10 @@ public function __construct(AbstractTask $task, $name = null) parent::__construct($task); // Set name - $this->name = $name ?: $task->getSlug(); - $this->name = 'deploy:'.$this->name; + if ($this->name == 'deploy:custom') { + $this->name = $name ?: $task->getSlug(); + $this->name = 'deploy:'.$this->name; + } } /** diff --git a/src/Rocketeer/Console/Commands/DeployCommand.php b/src/Rocketeer/Console/Commands/DeployCommand.php index a375e7ad0..76575d5fb 100644 --- a/src/Rocketeer/Console/Commands/DeployCommand.php +++ b/src/Rocketeer/Console/Commands/DeployCommand.php @@ -18,6 +18,13 @@ */ class DeployCommand extends BaseTaskCommand { + /** + * The default name + * + * @var string + */ + protected $name = 'deploy:deploy'; + /** * Execute the tasks * From 97e481d8c6b646d710b0efb5ff82cfc09f23c612 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 16:05:43 +0200 Subject: [PATCH 270/424] Close #271 - Add sync strategy --- .../Strategies/Deploy/SyncStrategy.php | 81 +++++++++++++++++++ src/Rocketeer/Traits/BashModules/Core.php | 17 ++++ 2 files changed, 98 insertions(+) create mode 100644 src/Rocketeer/Strategies/Deploy/SyncStrategy.php diff --git a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php new file mode 100644 index 000000000..32398753c --- /dev/null +++ b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php @@ -0,0 +1,81 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Strategies\Deploy; + +use Rocketeer\Abstracts\Strategies\AbstractStrategy; +use Rocketeer\Interfaces\Strategies\DeployStrategyInterface; + +class SyncStrategy extends AbstractStrategy implements DeployStrategyInterface +{ + /** + * Deploy a new clean copy of the application + * + * @param string|null $destination + * + * @return boolean + */ + public function deploy($destination = null) + { + if (!$destination) { + $destination = $this->releasesManager->getCurrentReleasePath(); + } + + // Create receiveing folder + $this->createFolder($destination); + + return $this->rsyncTo($destination); + } + + /** + * Update the latest version of the application + * + * @param boolean $reset + * + * @return boolean + */ + public function update($reset = true) + { + $release = $this->releasesManager->getCurrentReleasePath(); + + return $this->rsyncTo($release); + } + + /** + * Rsyncs the local folder to a remote one + * + * @param string $destination + * + * @return boolean + */ + protected function rsyncTo($destination) + { + // Build host handle + $credentials = $this->connections->getServerCredentials(); + $handle = $credentials['host']; + if ($user = array_get($credentials, 'username')) { + $handle = $user.'@'.$handle; + } + + // Create options + $options = '--verbose --recursive --rsh="ssh"'; + $excludes = ['.git', 'vendor']; + foreach ($excludes as $exclude) { + $options .= ' --exclude="'.$exclude.'"'; + } + + // Create binary and command + $rsync = $this->binary('rsync'); + $rsync = $rsync->getCommand(null, ['./', $handle.':'.$destination], $options); + + return $this->bash->onLocal(function ($bash) use ($rsync) { + return $bash->run($rsync); + }); + } +} diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 444fb2f24..9c8f02a27 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Traits\BashModules; +use Closure; use Illuminate\Support\Str; use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; @@ -49,6 +50,22 @@ public function getConnection() return $this->local ? $this->app['remote.local'] : $this->remote; } + /** + * Run a series of commands in local + * + * @param Closure $callback + * + * @return boolean + */ + public function onLocal(Closure $callback) + { + $this->local = true; + $results = $callback($this); + $this->local = false; + + return $results; + } + //////////////////////////////////////////////////////////////////// ///////////////////////////// CORE METHODS ///////////////////////// //////////////////////////////////////////////////////////////////// From bbdd4d4f394ed558dec200004875e1b7fb600151 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 16:15:06 +0200 Subject: [PATCH 271/424] Add strategies command to list available implementation of strategies --- .../Abstracts/Strategies/AbstractStrategy.php | 13 +++++ .../Console/Commands/StrategiesCommand.php | 48 +++++++++++++++++++ src/Rocketeer/RocketeerServiceProvider.php | 25 +++++----- .../Strategies/Dependencies/BowerStrategy.php | 5 ++ .../Dependencies/BundlerStrategy.php | 5 ++ .../Dependencies/ComposerStrategy.php | 5 ++ .../Strategies/Dependencies/NpmStrategy.php | 5 ++ .../Dependencies/PolyglotStrategy.php | 5 ++ .../Strategies/Deploy/CloneStrategy.php | 5 ++ .../Strategies/Deploy/CopyStrategy.php | 5 ++ .../Strategies/Deploy/SyncStrategy.php | 5 ++ .../Strategies/Migrate/ArtisanStrategy.php | 5 ++ .../Strategies/Test/PhpunitStrategy.php | 5 ++ tests/TestCases/ContainerTestCase.php | 2 +- 14 files changed, 125 insertions(+), 13 deletions(-) create mode 100644 src/Rocketeer/Console/Commands/StrategiesCommand.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index 9b0a85075..3996000e1 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -19,6 +19,19 @@ */ abstract class AbstractStrategy extends Bash { + /** + * @type string + */ + protected $description; + + /** + * @return string + */ + public function getDescription() + { + return $this->description; + } + /** * Whether this particular strategy is runnable or not * diff --git a/src/Rocketeer/Console/Commands/StrategiesCommand.php b/src/Rocketeer/Console/Commands/StrategiesCommand.php new file mode 100644 index 000000000..eff021074 --- /dev/null +++ b/src/Rocketeer/Console/Commands/StrategiesCommand.php @@ -0,0 +1,48 @@ + ['Clone', 'Copy', 'Sync'], + 'test' => ['Phpunit'], + 'migrate' => ['Artisan'], + 'dependencies' => ['Composer', 'Bundler', 'Npm', 'Bower', 'Polyglot'], + ); + + $table = new Table($this->getOutput()); + $table->setHeaders(['Strategy', 'Implementation', 'Description']); + foreach ($strategies as $strategy => $implementations) { + foreach ($implementations as $implementation) { + $instance = $this->laravel['rocketeer.builder']->buildStrategy($strategy, $implementation); + $table->addRow([$strategy, $implementation, $instance->getDescription()]); + } + } + + $table->render(); + } +} diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index f61f4ceaf..670384530 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -254,18 +254,19 @@ public function bindCommands() { // Base commands $tasks = array( - '' => 'Rocketeer', - 'check' => 'Check', - 'cleanup' => 'Cleanup', - 'current' => 'CurrentRelease', - 'deploy' => 'Deploy', - 'flush' => 'Flush', - 'ignite' => 'Ignite', - 'rollback' => 'Rollback', - 'setup' => 'Setup', - 'teardown' => 'Teardown', - 'test' => 'Test', - 'update' => 'Update', + '' => 'Rocketeer', + 'check' => 'Check', + 'cleanup' => 'Cleanup', + 'current' => 'CurrentRelease', + 'deploy' => 'Deploy', + 'flush' => 'Flush', + 'ignite' => 'Ignite', + 'rollback' => 'Rollback', + 'setup' => 'Setup', + 'strategies' => 'Strategies', + 'teardown' => 'Teardown', + 'test' => 'Test', + 'update' => 'Update', ); // Add User commands diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php index cbd497d45..bae442923 100644 --- a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -15,6 +15,11 @@ class BowerStrategy extends AbstractDependenciesStrategy implements DependenciesStrategyInterface { + /** + * @type string + */ + protected $description = 'Installs dependencies with Bower'; + /** * The name of the manifest file to look for * diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 50f1e3f01..789441402 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -14,6 +14,11 @@ class BundlerStrategy extends AbstractDependenciesStrategy implements DependenciesStrategyInterface { + /** + * @type string + */ + protected $description = 'Installs dependencies with Bundler'; + /** * The name of the manifest file to look for * diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 4c3dacd62..129a769a2 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -14,6 +14,11 @@ class ComposerStrategy extends AbstractDependenciesStrategy implements DependenciesStrategyInterface { + /** + * @type string + */ + protected $description = 'Installs dependencies with Composer'; + /** * The name of the manifest file to look for * diff --git a/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php b/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php index 5f735c4d3..8cabaf841 100644 --- a/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php @@ -14,6 +14,11 @@ class NpmStrategy extends AbstractDependenciesStrategy implements DependenciesStrategyInterface { + /** + * @type string + */ + protected $description = 'Installs dependencies with NPM'; + /** * The name of the manifest file to look for * diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index bc70be1b4..d56719467 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -15,6 +15,11 @@ class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyInterface { + /** + * @type string + */ + protected $description = 'Runs all of the above package managers if necessary'; + /** * The various dependencies managers * diff --git a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php index c47879774..9d576b0d4 100644 --- a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php @@ -14,6 +14,11 @@ class CloneStrategy extends AbstractStrategy implements DeployStrategyInterface { + /** + * @type string + */ + protected $description = 'Clones a fresh instance of the repository by SCM'; + /** * Deploy a new clean copy of the application * diff --git a/src/Rocketeer/Strategies/Deploy/CopyStrategy.php b/src/Rocketeer/Strategies/Deploy/CopyStrategy.php index 51d176766..a15f70846 100644 --- a/src/Rocketeer/Strategies/Deploy/CopyStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CopyStrategy.php @@ -13,6 +13,11 @@ class CopyStrategy extends CloneStrategy implements DeployStrategyInterface { + /** + * @type string + */ + protected $description = 'Copies the previously cloned instance of the repository and update it'; + /** * Deploy a new clean copy of the application * diff --git a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php index 32398753c..6e3e19d60 100644 --- a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php @@ -14,6 +14,11 @@ class SyncStrategy extends AbstractStrategy implements DeployStrategyInterface { + /** + * @type string + */ + protected $description = 'Uses rsync to create or update a release from the local files'; + /** * Deploy a new clean copy of the application * diff --git a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php index f68807ea6..e1a14da60 100644 --- a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php +++ b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php @@ -14,6 +14,11 @@ class ArtisanStrategy extends AbstractStrategy implements MigrateStrategyInterface { + /** + * @type string + */ + protected $description = 'Migrates your database with Laravel\'s Artisan CLI'; + /** * Whether this particular strategy is runnable or not * diff --git a/src/Rocketeer/Strategies/Test/PhpunitStrategy.php b/src/Rocketeer/Strategies/Test/PhpunitStrategy.php index 83648735d..45863be4c 100644 --- a/src/Rocketeer/Strategies/Test/PhpunitStrategy.php +++ b/src/Rocketeer/Strategies/Test/PhpunitStrategy.php @@ -14,6 +14,11 @@ class PhpunitStrategy extends AbstractStrategy implements TestStrategyInterface { + /** + * @type string + */ + protected $description = 'Run the tests with PHPUnit'; + /** * Whether this particular strategy is runnable or not * diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index ad8bcdcb8..4de9c4bf3 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -298,7 +298,7 @@ protected function getFactoryConfiguration() 'foobar' ), ), - ) + ), ); // Assign options to expectations From d8a771b8be345093f03b4999f5c8252f67babdac Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 16:16:14 +0200 Subject: [PATCH 272/424] Make Polyglot the default dependencies strategy --- src/config/strategies.php | 2 +- tests/TestCases/ContainerTestCase.php | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/config/strategies.php b/src/config/strategies.php index 190ea9084..e8a18c268 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -20,7 +20,7 @@ 'migrate' => 'Artisan', // Which strategy to use to install your application's dependencies - 'dependencies' => 'Composer', + 'dependencies' => 'Polyglot', // Execution hooks ////////////////////////////////////////////////////////////////////// diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 4de9c4bf3..3a42d4b0e 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -282,6 +282,7 @@ protected function getFactoryConfiguration() 'shallow' => true, 'submodules' => true, ), + 'rocketeer::strategies.dependencies' => 'Composer', 'rocketeer::hooks' => array( 'before' => array( 'deploy' => array( From 253f59bfdcda7caa1d662c3af05534b6dd6d7b83 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 17:08:59 +0200 Subject: [PATCH 273/424] Custom binary classes --- src/Rocketeer/Traits/BashModules/Binaries.php | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 44be38ec6..ce6e2072d 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -32,9 +32,11 @@ trait Binaries public function binary($binary) { // Check for an existing Binary - $existing = sprintf('Rocketeer\Binaries\%s', ucfirst($binary)); - if (class_exists($existing)) { - return new $existing($this->app); + $core = sprintf('Rocketeer\Binaries\%s', ucfirst($binary)); + if (class_exists($core)) { + return new $core($this->app); + } elseif (class_exists($binary)) { + return new $binary($this->app); } // Else wrap the command in an AnonymousBinary From 9fd524805d8c30255788f7000bcd3fc72a10d67b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 19:58:24 +0200 Subject: [PATCH 274/424] Remove docs --- docs | 1 - 1 file changed, 1 deletion(-) delete mode 160000 docs diff --git a/docs b/docs deleted file mode 160000 index cf947b11c..000000000 --- a/docs +++ /dev/null @@ -1 +0,0 @@ -Subproject commit cf947b11c636abca7956b350f3fee9f09837cc34 From a33a54a09e32f8e6627806e582309f4c89b7e14b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 20:02:03 +0200 Subject: [PATCH 275/424] Exclude dev dependencies from PHAR --- src/Rocketeer/Console/Compiler.php | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Console/Compiler.php b/src/Rocketeer/Console/Compiler.php index 087cd6b70..6dfa5c124 100644 --- a/src/Rocketeer/Console/Compiler.php +++ b/src/Rocketeer/Console/Compiler.php @@ -97,11 +97,14 @@ public function compile() // Add core files and dependencies $this->addFolder($src); $this->addFolder($vendor, array( - 'mockery', - 'patchwork', + 'd11wtq', 'herrera-io', + 'johnkary', + 'mockery', 'nesbot', + 'patchwork', 'phine', + 'raveren', )); // Add binary From d603ebfb0ecc0658fdbf67623192e5a0f0a73ccb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 20:09:20 +0200 Subject: [PATCH 276/424] Fix tests --- tests/Traits/BashModules/BinariesTest.php | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 1709d5e87..9e3e98599 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -53,6 +53,7 @@ public function testCanRunComposer() $this->usesComposer(true); $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock + ->shouldIgnoreMissing() ->shouldReceive('line') ->shouldReceive('option')->andReturn([]); }); @@ -66,6 +67,7 @@ public function testDoesntRunComposerIfNotNeeded() $this->usesComposer(false); $this->mock('rocketeer.command', 'Illuminate\Console\Command', function ($mock) { return $mock + ->shouldIgnoreMissing() ->shouldReceive('line') ->shouldReceive('option')->andReturn([]); }); From 16e7f0fc7973101e6d19a2da003d2821efbc62df Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 20:11:05 +0200 Subject: [PATCH 277/424] Tweak gitignore --- .gitignore | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/.gitignore b/.gitignore index a2cda783d..9922bc96f 100644 --- a/.gitignore +++ b/.gitignore @@ -1,16 +1,11 @@ -# Cache and compiled +# Development .idea + +# Cache and compiled .rocketeer bin/phar bin/rocketeer.phar composer.lock -storage - -# Plugins -rocketeer-campfire - -# Tests -tests/_meta/coverage # Dependencies vendor From 25399a513abf875c816177f712213c90e2834596 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 20:34:26 +0200 Subject: [PATCH 278/424] Debug --- tests/BashTest.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/tests/BashTest.php b/tests/BashTest.php index 9f2bb9082..10cc7528e 100644 --- a/tests/BashTest.php +++ b/tests/BashTest.php @@ -8,6 +8,9 @@ class BashTest extends RocketeerTestCase public function testBashIsCorrectlyComposed() { $contents = $this->task->runRaw('ls', true, true); + if (count($contents) !== 12) { + var_dump($contents); + } $this->assertCount(12, $contents); } From 83179a8055d98f283539d5b900b1c910427934ef Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 20:40:23 +0200 Subject: [PATCH 279/424] Fix tests --- tests/BashTest.php | 4 ++-- tests/Traits/BashModules/CoreTest.php | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/tests/BashTest.php b/tests/BashTest.php index 10cc7528e..1a4031ed7 100644 --- a/tests/BashTest.php +++ b/tests/BashTest.php @@ -8,10 +8,10 @@ class BashTest extends RocketeerTestCase public function testBashIsCorrectlyComposed() { $contents = $this->task->runRaw('ls', true, true); - if (count($contents) !== 12) { + if (count($contents) !== 11) { var_dump($contents); } - $this->assertCount(12, $contents); + $this->assertCount(11, $contents); } } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 23896e445..c4ae76d2c 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -9,7 +9,7 @@ public function testCanGetArraysFromRawCommands() { $contents = $this->task->runRaw('ls', true, true); - $this->assertCount(12, $contents); + $this->assertCount(11, $contents); } public function testCanCheckStatusOfACommand() @@ -74,6 +74,6 @@ public function testCanRunCommandsLocally() $this->task->setLocal(true); $contents = $this->task->runRaw('ls', true, true); - $this->assertCount(12, $contents); + $this->assertCount(11, $contents); } } From 33a50aec3c7f695959ac6b44487239b2fa504dec Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 20:48:03 +0200 Subject: [PATCH 280/424] Fix pretend flag --- src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 9c8f02a27..ebc6e5f8d 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -200,7 +200,7 @@ public function runInFolder($folder = null, $tasks = array()) */ public function status() { - return $this->getConnection()->status() == 0; + return $this->getOption('pretend') ? 0 : $this->getConnection()->status() == 0; } /** @@ -215,7 +215,7 @@ public function status() public function checkStatus($error, $output = null, $success = null) { // If all went well - if ($this->getConnection()->status() == 0) { + if ($this->status() == 0) { if ($success) { $this->command->comment($success); } From c3082a29a4746c58f4278d62422d60100b239d7c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 22:17:14 +0200 Subject: [PATCH 281/424] Fix Core::status --- src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- tests/Traits/BashModules/CoreTest.php | 2 +- tests/Traits/BashModules/ScmTest.php | 11 ++++++----- 3 files changed, 9 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index ebc6e5f8d..df97a049a 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -200,7 +200,7 @@ public function runInFolder($folder = null, $tasks = array()) */ public function status() { - return $this->getOption('pretend') ? 0 : $this->getConnection()->status() == 0; + return $this->getOption('pretend') ? true : $this->getConnection()->status() == 0; } /** @@ -215,7 +215,7 @@ public function status() public function checkStatus($error, $output = null, $success = null) { // If all went well - if ($this->status() == 0) { + if ($this->status()) { if ($success) { $this->command->comment($success); } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index c4ae76d2c..26fd5d66e 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -23,7 +23,7 @@ public function testCanCheckStatusOfACommand() } )); - $status = $this->task->checkStatus('Oh noes', 'git clone'); + $status = $this->task('Deploy')->checkStatus('Oh noes', 'git clone'); $this->assertFalse($status); } diff --git a/tests/Traits/BashModules/ScmTest.php b/tests/Traits/BashModules/ScmTest.php index d20587b97..b7b7b8798 100644 --- a/tests/Traits/BashModules/ScmTest.php +++ b/tests/Traits/BashModules/ScmTest.php @@ -8,15 +8,16 @@ class ScmTest extends RocketeerTestCase public function testCanForgetCredentialsIfInvalid() { $this->app['rocketeer.storage.local']->set('credentials', array( - 'repository' => 'https://Anahkiasen@bitbucket.org/Anahkiasen/registry.git', + 'repository' => 'https://bitbucket.org/Anahkiasen/registry.git', 'username' => 'Anahkiasen', 'password' => 'baz', )); - // Create fake remote - $remote = $this->getRemote(); - $remote->shouldReceive('status')->andReturn(1); - $this->app['rocketeer.remote'] = $remote; + $this->mock('rocketeer.bash', 'Bash', function ($mock) { + return $mock + ->shouldIgnoreMissing() + ->shouldReceive('checkStatus')->andReturn(false); + }); $task = $this->pretendTask(); From dabd501318c8cdce08a36618a2534ce31b2b80d2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 22:38:12 +0200 Subject: [PATCH 282/424] Work on output --- .../Connections/ConnectionsHandler.php | 23 +++++ .../Services/Display/QueueExplainer.php | 89 +++++++++++++++++-- .../Strategies/Deploy/CloneStrategy.php | 4 +- src/Rocketeer/Tasks/Cleanup.php | 4 +- src/Rocketeer/Tasks/Deploy.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 6 +- 6 files changed, 115 insertions(+), 13 deletions(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 151e7c149..88aad2031 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -51,6 +51,29 @@ class ConnectionsHandler */ protected $connection; + /** + * Build the current connection's handle + * + * @param string|null $connection + * @param integer|null $server + * @param string|null $stage + * + * @return string + */ + public function getHandle($connection = null, $server = null, $stage = null) + { + // Get identifiers + $connection = $connection ?: $this->getConnection(); + $server = $server ?: $this->getServer(); + $stage = $stage ?: $this->getStage(); + + // Concatenate + $handle = [$connection, $server, $stage]; + $handle = implode('/', $handle); + + return $handle; + } + ////////////////////////////////////////////////////////////////////// ////////////////////////////// SERVERS /////////////////////////////// ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index 551fdb98a..18ecde196 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -27,7 +27,14 @@ class QueueExplainer * * @type integer */ - public $level = 1; + public $level = 0; + + /** + * Length of the longest handle to display + * + * @type integer + */ + protected $longest; ////////////////////////////////////////////////////////////////////// /////////////////////////////// STATUS /////////////////////////////// @@ -61,17 +68,19 @@ public function displayBelow(Closure $callback) * @param string|null $details * @param float|null $time */ - public function display($object, $subject, $details = null, $time = null) + public function display($object, $subject = null, $details = null, $time = null) { if (!$this->hasCommand()) { return; } - // Build status - $tree = '|'.str_repeat('--', $this->level); - $comment = sprintf('%s %s: %s', $tree, $object, $subject); + // Build handle + $comment = $this->getTree().' '.$object; // Add details + if ($subject) { + $comment .= ': '.$subject.''; + } if ($details) { $comment .= ' ('.$details.')'; } @@ -81,4 +90,74 @@ public function display($object, $subject, $details = null, $time = null) $this->command->line($comment); } + + /** + * Display the results of something + * + * @param string $comment + */ + public function results($comment) + { + if (!$this->hasCommand()) { + return; + } + + // Build results and display them + $comment = $this->getTree('==').'=> '.$comment; + $this->command->line($comment); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the longest size an handle can have + * + * @return integer + */ + protected function getLongestSize() + { + if ($this->longest) { + return $this->longest; + } + + // Build possible handles + $strings = []; + $connections = $this->connections->getAvailableConnections(); + $stages = $this->connections->getStages(); + foreach ($connections as $connection => $servers) { + foreach ($stages as $stage) { + $strings[] = $connection.'/' .sizeof($servers). '/'.$stage; + } + } + + // Get longest string + $strings = array_map('strlen', $strings); + $strings = max($strings); + + // Cache value + $this->longest = $strings + 1; + + return $this->longest; + } + + /** + * @param string $dashes + * + * @return string + */ + protected function getTree($dashes = '--') + { + // Build handle + $handle = $this->connections->getHandle(); + $spacing = $this->getLongestSize() - strlen($handle) ?: 0; + $spacing = str_repeat(' ', $spacing); + + // Build tree and command + $dashes = $this->level ? str_repeat($dashes, $this->level) : null; + $tree = sprintf('%s%s|%s', $handle, $spacing, $dashes); + + return $tree; + } } diff --git a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php index 9d576b0d4..29a55ef25 100644 --- a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php @@ -33,7 +33,7 @@ public function deploy($destination = null) } // Executing checkout - $this->command->comment('Cloning repository in "'.$destination.'"'); + $this->explainer->results('Cloning repository in "'.$destination.'"'); $output = $this->scm->run('checkout', $destination); // Cancel if failed and forget credentials @@ -46,7 +46,7 @@ public function deploy($destination = null) // Deploy submodules if ($this->rocketeer->getOption('scm.submodules')) { - $this->command->comment('Initializing submodules if any'); + $this->explainer->results('Initializing submodules if any'); $this->scm->runForCurrentRelease('submodules'); } diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index 864e14f2d..c681dacdb 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -34,7 +34,7 @@ public function execute() { // If no releases to prune if (!$trash = $this->getReleasesToCleanup()) { - return $this->command->comment('No releases to prune from the server'); + return $this->explainer->results('No releases to prune from the server'); } // Prune releases @@ -53,7 +53,7 @@ public function execute() $this->releasesManager->markReleaseAsValid(); } - return $this->command->line($message); + return $this->explainer->results($message); } /** diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index 66b8389e4..b7b769e93 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -75,7 +75,7 @@ public function execute() $this->releasesManager->markReleaseAsValid($release); - $this->command->info('Successfully deployed release '.$release); + $this->explainer->results('Successfully deployed release '.$release); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index cfbf63497..33d260300 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -20,17 +20,17 @@ * @property \Illuminate\Events\Dispatcher events * @property \Illuminate\Filesystem\Filesystem files * @property \Illuminate\Log\Writer log - * @property \Rocketeer\Services\Connections\RemoteHandler remote * @property \Rocketeer\Abstracts\AbstractCommand command * @property \Rocketeer\Bash bash - * @property \Rocketeer\Services\Display\QueueExplainer explainer - * @property \Rocketeer\Services\Display\QueueTimer timer * @property \Rocketeer\Console\Console console * @property \Rocketeer\Interfaces\ScmInterface scm * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Services\Connections\ConnectionsHandler connections + * @property \Rocketeer\Services\Connections\RemoteHandler remote * @property \Rocketeer\Services\CredentialsGatherer credentials + * @property \Rocketeer\Services\Display\QueueExplainer explainer + * @property \Rocketeer\Services\Display\QueueTimer timer * @property \Rocketeer\Services\History\History history * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Services\Storages\LocalStorage localStorage From bc842d3297d467eea2343085b00cdbd7d6b52679 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 23:13:27 +0200 Subject: [PATCH 283/424] Use built-in check for Parallel --- src/Rocketeer/Services/Tasks/TasksQueue.php | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 1bd8f3044..88be9da72 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -238,7 +238,10 @@ protected function runSynchronously(Pipeline $pipeline) */ protected function runAsynchronously(Pipeline $pipeline) { - if (!extension_loaded('pcntl')) { + $this->parallel = $this->parallel ?: new Parallel(); + + // Check if supported + if (!$this->parallel->isSupported()) { throw new Exception('Parallel jobs require the PCNTL extension'); } From a9701cd812d5e30c34eaf7b40798019578d40cf2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 17 Aug 2014 23:13:34 +0200 Subject: [PATCH 284/424] Disable stages for Primer --- src/Rocketeer/Tasks/Subtasks/Primer.php | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/Rocketeer/Tasks/Subtasks/Primer.php b/src/Rocketeer/Tasks/Subtasks/Primer.php index 01c038797..658c3d7d0 100644 --- a/src/Rocketeer/Tasks/Subtasks/Primer.php +++ b/src/Rocketeer/Tasks/Subtasks/Primer.php @@ -25,6 +25,13 @@ class Primer extends AbstractTask */ protected $local = true; + /** + * Whether the task needs to be run on each stage or globally + * + * @var boolean + */ + public $usesStages = false; + /** * Run the task * From 660fd3cbdf70f9360ac6d269920931b4a13effac Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 00:30:59 +0200 Subject: [PATCH 285/424] Fix multistage/server causing duplicated queues --- src/Rocketeer/Bash.php | 6 +++--- src/Rocketeer/Tasks/Deploy.php | 9 +++++---- 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index a0aec38cc..99ffe832e 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -82,10 +82,10 @@ public function getStrategy($strategy, $concrete = null) */ public function executeTask($tasks) { - $pipeline = $this->explainer->displayBelow(function () use ($tasks) { - return $this->queue->run($tasks); + $results = $this->explainer->displayBelow(function () use ($tasks) { + return $this->builder->buildTask($tasks)->fire(); }); - return $pipeline->succeeded(); + return $results; } } diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index b7b769e93..d512afcdb 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -46,14 +46,15 @@ public function execute() // Setup the new release $release = $this->releasesManager->getNextRelease(); - // Build subtasks - $tasks = ['CreateRelease', 'Dependencies']; + // Create release and set it up + $this->steps()->executeTask('CreateRelease'); + $this->steps()->executeTask('Dependencies'); + if ($this->getOption('tests')) { - $tasks[] = 'Test'; + $this->steps()->executeTask('Test'); } // Create release and set permissions - $this->steps()->executeTask($tasks); $this->steps()->setApplicationPermissions(); // Run migrations From 8224075919409a1ebe3a0c288f188b60a4baa62c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 00:31:22 +0200 Subject: [PATCH 286/424] Fix steps not being cleared once run --- src/Rocketeer/Services/StepsBuilder.php | 14 ++++++++++++++ src/Rocketeer/Traits/StepsRunner.php | 2 +- tests/Traits/StepsRunnerTest.php | 15 +++++++++++++++ 3 files changed, 30 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/StepsBuilder.php b/src/Rocketeer/Services/StepsBuilder.php index d961e2af6..4b2d125f6 100644 --- a/src/Rocketeer/Services/StepsBuilder.php +++ b/src/Rocketeer/Services/StepsBuilder.php @@ -21,6 +21,20 @@ public function __call($name, $arguments) $this->steps[] = [$name, $arguments]; } + /** + * Get and clear the steps + * + * @return array + */ + public function pullSteps() + { + $steps = $this->steps; + + $this->steps = []; + + return $steps; + } + /** * Get the steps to execute * diff --git a/src/Rocketeer/Traits/StepsRunner.php b/src/Rocketeer/Traits/StepsRunner.php index 0e6cbf726..75c829ff5 100644 --- a/src/Rocketeer/Traits/StepsRunner.php +++ b/src/Rocketeer/Traits/StepsRunner.php @@ -43,7 +43,7 @@ public function steps() */ public function runSteps() { - foreach ($this->steps()->getSteps() as $step) { + foreach ($this->steps()->pullSteps() as $step) { list($method, $arguments) = $step; $arguments = (array) $arguments; diff --git a/tests/Traits/StepsRunnerTest.php b/tests/Traits/StepsRunnerTest.php index e16dcfdee..779037a5d 100644 --- a/tests/Traits/StepsRunnerTest.php +++ b/tests/Traits/StepsRunnerTest.php @@ -16,4 +16,19 @@ public function testCanRunStepsOnSilentCommands() $this->files->delete($copy); $this->assertTrue($results); } + + public function testStepsAreClearedOnceRun() + { + $task = $this->task; + $task->steps()->run('ls'); + + $this->assertEquals(array( + ['run', ['ls']] + ), $task->steps()->getSteps()); + $task->runSteps(); + $task->steps()->run('php --version'); + $this->assertEquals(array( + ['run', ['php --version']] + ), $task->steps()->getSteps()); + } } From 46591601bb54a4aa8e0bb6a84e110880adcdbf30 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 00:39:40 +0200 Subject: [PATCH 287/424] Add test for duplicated queues --- src/Rocketeer/Services/Display/QueueExplainer.php | 5 +++-- tests/Abstracts/AbstractTaskTest.php | 12 ++++++++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index 18ecde196..5d2b10d7e 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -134,7 +134,7 @@ protected function getLongestSize() // Get longest string $strings = array_map('strlen', $strings); - $strings = max($strings); + $strings = $strings ? max($strings) : 0; // Cache value $this->longest = $strings + 1; @@ -151,7 +151,8 @@ protected function getTree($dashes = '--') { // Build handle $handle = $this->connections->getHandle(); - $spacing = $this->getLongestSize() - strlen($handle) ?: 0; + $spacing = $this->getLongestSize() - strlen($handle); + $spacing = $spacing < 1 ? 1 : $spacing; $spacing = str_repeat(' ', $spacing); // Build tree and command diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index e719ebee6..51c4e34b2 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -97,4 +97,16 @@ public function testCanListenToSubtasks() 'ls', ), $history[5]); } + + public function testDoesntDuplicateQueuesOnSubtasks() + { + $this->swapConfig(array( + 'rocketeer::default' => ['staging', 'production'], + )); + + $this->pretend(); + $this->queue->run('Deploy'); + + $this->assertCount(24, $this->history->getFlattenedHistory()); + } } From 56f48bf6043e309bbc6142a879d4fd0829a5edcc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 00:48:55 +0200 Subject: [PATCH 288/424] Update tests --- src/Rocketeer/Services/Display/QueueExplainer.php | 8 ++++++-- tests/Abstracts/AbstractTaskTest.php | 2 +- tests/Services/Tasks/TasksQueueTest.php | 1 + tests/TestCases/ContainerTestCase.php | 2 +- tests/Traits/BashModules/FilesystemTest.php | 5 ++++- 5 files changed, 13 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index 5d2b10d7e..30c2f3d43 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -95,6 +95,8 @@ public function display($object, $subject = null, $details = null, $time = null) * Display the results of something * * @param string $comment + * + * @return string */ public function results($comment) { @@ -105,6 +107,8 @@ public function results($comment) // Build results and display them $comment = $this->getTree('==').'=> '.$comment; $this->command->line($comment); + + return $comment; } ////////////////////////////////////////////////////////////////////// @@ -124,8 +128,8 @@ protected function getLongestSize() // Build possible handles $strings = []; - $connections = $this->connections->getAvailableConnections(); - $stages = $this->connections->getStages(); + $connections = (array) $this->connections->getAvailableConnections(); + $stages = (array) $this->connections->getStages(); foreach ($connections as $connection => $servers) { foreach ($stages as $stage) { $strings[] = $connection.'/' .sizeof($servers). '/'.$stage; diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 51c4e34b2..3adce181a 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -95,7 +95,7 @@ public function testCanListenToSubtasks() $this->assertHistory(array( 'cd {server}/releases/{release}', 'ls', - ), $history[5]); + ), $history[3]); } public function testDoesntDuplicateQueuesOnSubtasks() diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 7307b5634..2ec2a51c8 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -88,6 +88,7 @@ public function testCanRunOnMultipleConnectionsViaOn() public function testCanRunTasksInParallel() { $parallel = Mockery::mock('Parallel') + ->shouldReceive('isSupported')->andReturn(true) ->shouldReceive('values')->once()->with(Mockery::type('array')) ->mock(); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 3a42d4b0e..6ec10ca20 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -89,7 +89,7 @@ public function tearDown() */ protected function mock($handle, $class, Closure $expectations) { - $mockery = Mockery::mock($class); + $mockery = Mockery::mock($class)->shouldIgnoreMissing(); $mockery = $expectations($mockery)->mock(); $this->app[$handle] = $mockery; diff --git a/tests/Traits/BashModules/FilesystemTest.php b/tests/Traits/BashModules/FilesystemTest.php index c8000fccd..b8e77e919 100644 --- a/tests/Traits/BashModules/FilesystemTest.php +++ b/tests/Traits/BashModules/FilesystemTest.php @@ -33,7 +33,10 @@ public function testCanListContentsOfAFolder() { $contents = $this->task->listContents($this->server); - $this->assertEquals(['current', 'releases', 'shared', 'state.json'], $contents); + $this->assertContains('current', $contents); + $this->assertContains('releases', $contents); + $this->assertContains('shared', $contents); + $this->assertContains('state.json', $contents); } public function testCanCheckIfFileExists() From 95b2c5c835a2fd6bef09a2e607d33b2fd2cba343 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 00:53:33 +0200 Subject: [PATCH 289/424] Reduce output a little --- src/Rocketeer/Abstracts/AbstractTask.php | 2 +- .../Abstracts/Strategies/AbstractStrategy.php | 7 ++++--- src/Rocketeer/Services/Display/QueueExplainer.php | 13 ++++++------- 3 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 4801631ad..d3495de1d 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -251,6 +251,6 @@ protected function displayStatus() $description = $this->getDescription(); $time = $this->timer->getTaskTime($this); - $this->explainer->display('Running', $name, $description, $time); + $this->explainer->display($name, $description, $time); } } diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php index 3996000e1..996f81a49 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractStrategy.php @@ -61,10 +61,11 @@ public function displayStatus() $name = Arr::get($components, count($components) - 1); $strategy = Arr::get($components, count($components) - 2); - $object = 'Running strategy for '.ucfirst($strategy); - $subject = str_replace('Strategy', null, $name); + $parent = ucfirst($strategy); + $concrete = str_replace('Strategy', null, $name); + $details = $this->getDescription(); - $this->explainer->display($object, $subject); + $this->explainer->display($parent.'/'.$concrete, $details); return $this; } diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index 30c2f3d43..b16eadca8 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -63,23 +63,22 @@ public function displayBelow(Closure $callback) /** * Display a status * - * @param string $object - * @param string $subject + * @param string $info * @param string|null $details * @param float|null $time */ - public function display($object, $subject = null, $details = null, $time = null) + public function display($info = null, $details = null, $time = null) { if (!$this->hasCommand()) { return; } // Build handle - $comment = $this->getTree().' '.$object; + $comment = $this->getTree(); // Add details - if ($subject) { - $comment .= ': '.$subject.''; + if ($info) { + $comment .= ' '.$info.''; } if ($details) { $comment .= ' ('.$details.')'; @@ -132,7 +131,7 @@ protected function getLongestSize() $stages = (array) $this->connections->getStages(); foreach ($connections as $connection => $servers) { foreach ($stages as $stage) { - $strings[] = $connection.'/' .sizeof($servers). '/'.$stage; + $strings[] = $connection.'/'.sizeof($servers).'/'.$stage; } } From 07dec20b3687882dd66194e5bbf48b68e72cead0 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 00:58:16 +0200 Subject: [PATCH 290/424] Don't show handle if only one connection/stage --- .../Services/Display/QueueExplainer.php | 21 +++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index b16eadca8..6edaa0109 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -153,14 +153,23 @@ protected function getLongestSize() protected function getTree($dashes = '--') { // Build handle - $handle = $this->connections->getHandle(); - $spacing = $this->getLongestSize() - strlen($handle); - $spacing = $spacing < 1 ? 1 : $spacing; - $spacing = str_repeat(' ', $spacing); + $numberConnections = count($this->connections->getAvailableConnections()); + $numberStages = count($this->connections->getStages()); + + $tree = null; + if ($numberConnections > 1 || $numberStages > 1) { + $handle = $this->connections->getHandle(); + $spacing = $this->getLongestSize() - strlen($handle); + $spacing = $spacing < 1 ? 1 : $spacing; + $spacing = str_repeat(' ', $spacing); + + // Build tree and command + $tree .= sprintf('%s%s', $handle, $spacing); + } - // Build tree and command + // Add tree $dashes = $this->level ? str_repeat($dashes, $this->level) : null; - $tree = sprintf('%s%s|%s', $handle, $spacing, $dashes); + $tree .= '|'.$dashes; return $tree; } From 87e79c7024d3fe9d8ae6b520a3a63aec9d193523 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 01:10:30 +0200 Subject: [PATCH 291/424] More work on output --- .../Services/Display/QueueExplainer.php | 40 +++++++++++++++---- src/Rocketeer/Services/ReleasesManager.php | 2 +- .../Strategies/Deploy/CloneStrategy.php | 4 +- .../Strategies/Test/PhpunitStrategy.php | 2 +- src/Rocketeer/Tasks/Check.php | 8 ++-- src/Rocketeer/Tasks/Cleanup.php | 4 +- src/Rocketeer/Tasks/CurrentRelease.php | 4 +- src/Rocketeer/Tasks/Deploy.php | 4 +- src/Rocketeer/Tasks/Rollback.php | 4 +- src/Rocketeer/Tasks/Setup.php | 4 +- src/Rocketeer/Traits/BashModules/Core.php | 2 +- 11 files changed, 52 insertions(+), 26 deletions(-) diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index 6edaa0109..31ce163ef 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -90,24 +90,50 @@ public function display($info = null, $details = null, $time = null) $this->command->line($comment); } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// PROGRESS ////////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** - * Display the results of something + * Format and send a message by the command * - * @param string $comment + * @param string $message + * @param string|null $color * * @return string */ - public function results($comment) + public function line($message, $color = null) { if (!$this->hasCommand()) { return; } - // Build results and display them - $comment = $this->getTree('==').'=> '.$comment; - $this->command->line($comment); + // Format and pass to Command + $message = $color ? sprintf('%s', $color, $message, $color) : $message; + $message = $this->getTree('==').'=> '.$message; + $this->command->line($message); + + return $message; + } + + /** + * @param $message + * + * @return string + */ + public function success($message) + { + return $this->line($message, 'green'); + } - return $comment; + /** + * @param $message + * + * @return string + */ + public function error($message) + { + return $this->line($message, 'red'); } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 854cfd94c..44838930d 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -266,7 +266,7 @@ public function getPreviousRelease($release = null) do { $release = Arr::get($releases, $key + $next); $next++; - } while (!$this->checkReleaseState($release)); + } while (!$this->checkReleaseState($release) and isset($this->state[$release])); return $release ?: $current; } diff --git a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php index 29a55ef25..650d2e183 100644 --- a/src/Rocketeer/Strategies/Deploy/CloneStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CloneStrategy.php @@ -33,7 +33,7 @@ public function deploy($destination = null) } // Executing checkout - $this->explainer->results('Cloning repository in "'.$destination.'"'); + $this->explainer->line('Cloning repository in "'.$destination.'"'); $output = $this->scm->run('checkout', $destination); // Cancel if failed and forget credentials @@ -46,7 +46,7 @@ public function deploy($destination = null) // Deploy submodules if ($this->rocketeer->getOption('scm.submodules')) { - $this->explainer->results('Initializing submodules if any'); + $this->explainer->line('Initializing submodules if any'); $this->scm->runForCurrentRelease('submodules'); } diff --git a/src/Rocketeer/Strategies/Test/PhpunitStrategy.php b/src/Rocketeer/Strategies/Test/PhpunitStrategy.php index 45863be4c..e7218d2b9 100644 --- a/src/Rocketeer/Strategies/Test/PhpunitStrategy.php +++ b/src/Rocketeer/Strategies/Test/PhpunitStrategy.php @@ -44,7 +44,7 @@ public function test() $status = $this->checkStatus('Tests failed', $output, 'Tests passed successfully'); if (!$status) { - $this->command->error('Tests failed'); + $this->explainer->error('Tests failed'); } return $status; diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index a279c1313..e4a978131 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -71,7 +71,7 @@ public function execute() } // Display confirmation message - $this->command->info('Your server is ready to deploy'); + $this->explainer->line('Your server is ready to deploy'); } /** @@ -108,7 +108,7 @@ protected function getChecks() */ public function checkScm() { - $this->command->info('Checking presence of '.$this->scm->getBinary()); + $this->explainer->line('Checking presence of '.$this->scm->getBinary()); $results = $this->scm->run('check'); $this->toOutput($results); @@ -127,7 +127,7 @@ public function checkComposer() return true; } - $this->command->info('Checking presence of Composer'); + $this->explainer->line('Checking presence of Composer'); return $this->composer()->getBinary(); } @@ -219,7 +219,7 @@ public function checkCacheDriver($cache) */ public function checkPhpExtension($extension) { - $this->command->info('Checking presence of '.$extension.' extension'); + $this->explainer->line('Checking presence of '.$extension.' extension'); // Check for HHVM and built-in extensions if ($this->php()->isHhvm()) { diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index c681dacdb..abaf11cd4 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -34,7 +34,7 @@ public function execute() { // If no releases to prune if (!$trash = $this->getReleasesToCleanup()) { - return $this->explainer->results('No releases to prune from the server'); + return $this->explainer->line('No releases to prune from the server'); } // Prune releases @@ -53,7 +53,7 @@ public function execute() $this->releasesManager->markReleaseAsValid(); } - return $this->explainer->results($message); + return $this->explainer->line($message); } /** diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index 4e4e7ec05..1737e7934 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -47,7 +47,7 @@ public function execute() // Check if a release has been deployed already $currentRelease = $this->releasesManager->getCurrentRelease(); if (!$currentRelease) { - return $this->command->error('No release has yet been deployed'.$stage); + return $this->explainer->error('No release has yet been deployed'.$stage); } // Create state message @@ -59,7 +59,7 @@ public function execute() ); // Display current and past releases - $this->command->line($message); + $this->explainer->line($message); $this->displayReleases(); return $message; diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index d512afcdb..f7e96ce44 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -34,7 +34,7 @@ public function execute() { // Check if server is ready for deployment if (!$this->isSetup()) { - $this->command->error('Server is not ready, running Setup task'); + $this->explainer->error('Server is not ready, running Setup task'); $this->executeTask('Setup'); } @@ -76,7 +76,7 @@ public function execute() $this->releasesManager->markReleaseAsValid($release); - $this->explainer->results('Successfully deployed release '.$release); + $this->explainer->line('Successfully deployed release '.$release); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index d5dd2f27a..933277e27 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -35,7 +35,7 @@ public function execute() // Get previous release $rollbackRelease = $this->getRollbackRelease(); if (!$rollbackRelease) { - return $this->command->error('Rocketeer could not rollback as no releases have yet been deployed'); + return $this->explainer->error('Rocketeer could not rollback as no releases have yet been deployed'); } // If no release specified, display the available ones @@ -49,7 +49,7 @@ public function execute() } // Rollback release - $this->command->info('Rolling back to release '.$rollbackRelease); + $this->explainer->info('Rolling back to release '.$rollbackRelease); $this->updateSymlink($rollbackRelease); } diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 10f3f8220..38ede7bc3 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -52,7 +52,7 @@ public function execute() $this->localStorage->set('is_setup', true); // Get server informations - $this->command->comment('Getting some informations about the server'); + $this->explainer->line('Getting some informations about the server'); $this->localStorage->getSeparator(); $this->localStorage->getLineEndings(); @@ -61,7 +61,7 @@ public function execute() $homeFolder = $this->rocketeer->getHomeFolder(); $message = sprintf('Successfully setup "%s" at "%s"', $application, $homeFolder); - return $this->command->info($message); + return $this->explainer->success($message); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index df97a049a..bf5821647 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -225,7 +225,7 @@ public function checkStatus($error, $output = null, $success = null) // Else display the error $error = sprintf('An error occured: "%s", while running:'.PHP_EOL.'%s', $error, $output); - $this->command->error($error); + $this->explainer->error($error); return false; } From 64f45e079cba09277a5e75743fc81123c69b9717 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 01:16:17 +0200 Subject: [PATCH 292/424] Squash a few bugs --- src/Rocketeer/Abstracts/AbstractCommand.php | 4 +++- src/Rocketeer/Tasks/CurrentRelease.php | 2 +- src/Rocketeer/Tasks/Rollback.php | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 2825fc17a..7fea0cc46 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -41,7 +41,9 @@ public function __construct(AbstractTask $task = null) $this->task = $task; $this->task->command = $this; - $this->setDescription($task->getDescription()); + if (!$this->description and $description = $task->getDescription()) { + $this->setDescription($description); + } } } diff --git a/src/Rocketeer/Tasks/CurrentRelease.php b/src/Rocketeer/Tasks/CurrentRelease.php index 1737e7934..e7fb21055 100644 --- a/src/Rocketeer/Tasks/CurrentRelease.php +++ b/src/Rocketeer/Tasks/CurrentRelease.php @@ -24,7 +24,7 @@ class CurrentRelease extends AbstractTask * * @var string */ - protected $name = 'current'; + protected $name = 'Current'; /** * A description of what the task does diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 933277e27..02430c1cf 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -49,7 +49,7 @@ public function execute() } // Rollback release - $this->explainer->info('Rolling back to release '.$rollbackRelease); + $this->explainer->success('Rolling back to release '.$rollbackRelease); $this->updateSymlink($rollbackRelease); } From 47ff133c7d99510abaff2858b77fef03722525a8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 01:18:00 +0200 Subject: [PATCH 293/424] Add test for rollback loop --- tests/Services/ReleasesManagerTest.php | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/tests/Services/ReleasesManagerTest.php b/tests/Services/ReleasesManagerTest.php index e9329d105..7840f3a32 100644 --- a/tests/Services/ReleasesManagerTest.php +++ b/tests/Services/ReleasesManagerTest.php @@ -133,9 +133,24 @@ public function testReturnsCorrectPreviousReleaseIfUpdatedBeforehand() '20000000000000' => true, )); - $currentRelease = $this->releasesManager->getPreviousRelease(); + $previous = $this->releasesManager->getPreviousRelease(); - $this->assertEquals(20000000000000, $currentRelease); + $this->assertEquals(20000000000000, $previous); + } + + public function testCanReturnPreviousReleaseIfNoReleases() + { + $this->mock('rocketeer.bash', 'Rocketeer\Bash', function ($mock) { + return $mock + ->shouldReceive('getFile')->times(1) + ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([]); + }); + + $this->mockState(array( + )); + + $previous = $this->releasesManager->getPreviousRelease(); + $this->assertNull($previous); } public function testCanGetFolderInRelease() From 504cf5f794a6424100495be52376665675cc13ee Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 10:08:11 +0200 Subject: [PATCH 294/424] Fix tests --- tests/Tasks/RollbackTest.php | 2 +- tests/Traits/BashModules/CoreTest.php | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/tests/Tasks/RollbackTest.php b/tests/Tasks/RollbackTest.php index b86c8d805..36b82ee4d 100644 --- a/tests/Tasks/RollbackTest.php +++ b/tests/Tasks/RollbackTest.php @@ -40,6 +40,6 @@ public function testCantRollbackIfNoPreviousRelease() }); $status = $this->task('Rollback')->execute(); - $this->assertEquals('Rocketeer could not rollback as no releases have yet been deployed', $status); + $this->assertContains('Rocketeer could not rollback as no releases have yet been deployed', $status); } } diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 26fd5d66e..1c586cba7 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -14,11 +14,11 @@ public function testCanGetArraysFromRawCommands() public function testCanCheckStatusOfACommand() { - $this->expectOutputString('An error occured: "Oh noes", while running:'.PHP_EOL.'git clone'); + $this->expectOutputRegex('/.+An error occured: "Oh noes", while running:\ngit clone.+/'); $this->app['rocketeer.remote'] = clone $this->getRemote()->shouldReceive('status')->andReturn(1)->mock(); $this->mockCommand([], array( - 'error' => function ($error) { + 'line' => function ($error) { echo $error; } )); From bb70752893e5dd8576ac49f2b7f664661fb5bfa8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 11:26:10 +0200 Subject: [PATCH 295/424] Update README.md --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index 5b9f375d6..876fb9841 100644 --- a/README.md +++ b/README.md @@ -5,6 +5,7 @@ [![Total Downloads](http://img.shields.io/packagist/dt/anahkiasen/rocketeer.svg?style=flat)](https://packagist.org/packages/anahkiasen/rocketeer) [![Scrutinizer Quality Score](http://img.shields.io/scrutinizer/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) [![Code Coverage](http://img.shields.io/scrutinizer/coverage/g/rocketeers/rocketeer.svg?style=flat)](https://scrutinizer-ci.com/g/rocketeers/rocketeer/) +[![Dependency Status](https://www.versioneye.com/user/projects/53f1c65f13bb0677b1000744/badge.svg?style=flat)](https://www.versioneye.com/user/projects/53f1c65f13bb0677b1000744) [![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg?style=flat)](https://www.gittip.com/Anahkiasen/) **Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. From b01d444fa5f4d1aacb6ec5a8ec7f12048503b26c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 19:31:20 +0200 Subject: [PATCH 296/424] Move creation of commands to TasksBuilder --- src/Rocketeer/RocketeerServiceProvider.php | 25 +++++----------- src/Rocketeer/Services/Tasks/TasksBuilder.php | 30 +++++++++++++++++++ 2 files changed, 37 insertions(+), 18 deletions(-) diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 670384530..e07baeb17 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -16,8 +16,6 @@ use Illuminate\Log\Writer; use Illuminate\Support\ServiceProvider; use Monolog\Logger; -use Rocketeer\Console\Commands\BaseTaskCommand; -use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\Services\Connections\ConnectionsHandler; use Rocketeer\Services\Connections\LocalConnection; use Rocketeer\Services\Connections\RemoteHandler; @@ -275,30 +273,21 @@ public function bindCommands() // Bind the commands foreach ($tasks as $slug => $task) { - - // Check if we have an actual command to use - $commandClass = 'Rocketeer\Console\Commands\\'.$task.'Command'; - $fakeCommand = !class_exists($commandClass); - - try { - $taskInstance = $this->app['rocketeer.builder']->buildTask($task); - } catch (TaskCompositionException $exception) { - $taskInstance = null; - } + $command = $this->app['rocketeer.builder']->buildCommand($task, $slug); // Bind Task to container $handle = 'rocketeer.tasks.'.$slug; - $this->app->bind($handle, function () use ($taskInstance) { - return $taskInstance; + $this->app->bind($handle, function () use ($command) { + return $command->getTask(); }); // Add command to array - $command = trim('deploy.'.$slug, '.'); - $this->commands[] = $command; + $commandHandle = trim('deploy.'.$slug, '.'); + $this->commands[] = $commandHandle; // Register command with the container - $this->app->singleton($command, function () use ($fakeCommand, $commandClass, $taskInstance, $slug) { - return !$fakeCommand ? new $commandClass($taskInstance) : new BaseTaskCommand($taskInstance, $slug); + $this->app->singleton($commandHandle, function () use ($command) { + return $command; }); } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index faa7883b6..2e29048a0 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -24,6 +24,36 @@ class TasksBuilder { use HasLocator; + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// COMMANDS ////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Build the command bound to a task + * + * @param string $task + * @param string|null $slug + * + * @return \Rocketeer\Abstracts\AbstractCommand + */ + public function buildCommand($task, $slug = null) + { + // Build the task instance + try { + $instance = $this->buildTaskFromClass($task); + } catch (TaskCompositionException $exception) { + $instance = null; + } + + // Get the command name + $command = $this->findQualifiedName($task, array( + 'Rocketeer\Console\Commands\%sCommand', + 'Rocketeer\Console\Commands\BaseTaskCommand', + )); + + return new $command($instance, $slug); + } + ////////////////////////////////////////////////////////////////////// ///////////////////////////// STRATEGIES ///////////////////////////// ////////////////////////////////////////////////////////////////////// From a793d87ac613a88b48a18013f2a8c47946950d88 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 19:31:30 +0200 Subject: [PATCH 297/424] Fix Rocketeer command --- src/Rocketeer/Abstracts/AbstractCommand.php | 44 ++++++++++++------- .../Console/Commands/BaseTaskCommand.php | 14 +----- src/Rocketeer/Services/TasksHandler.php | 3 +- 3 files changed, 33 insertions(+), 28 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 7fea0cc46..f13db22a3 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -47,6 +47,35 @@ public function __construct(AbstractTask $task = null) } } + /** + * Get the task this command executes + * + * @return AbstractTask + */ + public function getTask() + { + return $this->task; + } + + /** + * Returns the command name. + * + * @return string The command name + */ + public function getName() + { + // Return commands without namespace if standalone + if (!$this->isInsideLaravel()) { + return str_replace('deploy:', null, $this->name); + } + + return $this->name; + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// EXECUTION ///////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** * Run the tasks * @@ -78,21 +107,6 @@ protected function getOptions() ); } - /** - * Returns the command name. - * - * @return string The command name - */ - public function getName() - { - // Return commands without namespace if standalone - if (!$this->isInsideLaravel()) { - return str_replace('deploy:', null, $this->name); - } - - return $this->name; - } - /** * Check if the current command is run in the scope of * Laravel or standalone diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index af818bfc2..cba25593d 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -33,12 +33,12 @@ class BaseTaskCommand extends AbstractCommand * @param AbstractTask $task * @param string|null $name A name for the command */ - public function __construct(AbstractTask $task, $name = null) + public function __construct(AbstractTask $task = null, $name = null) { parent::__construct($task); // Set name - if ($this->name == 'deploy:custom') { + if ($this->name == 'deploy:custom' and $task) { $this->name = $name ?: $task->getSlug(); $this->name = 'deploy:'.$this->name; } @@ -53,14 +53,4 @@ public function fire() { return $this->fireTasksQueue($this->task->getSlug()); } - - /** - * Get the task this command executes - * - * @return AbstractTask - */ - public function getTask() - { - return $this->task; - } } diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 9f0073378..2aa504cc5 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -82,7 +82,8 @@ public function add($task, $name = null, $description = null) // Bind to Artisan too if ($this->app->bound('artisan')) { - $this->app['artisan']->add(new BaseTaskCommand($task)); + $command = new BaseTaskCommand($task); + $this->app['artisan']->add($command); } return $bound; From 6980e79a722fae066f5daac6eec9ee298f05236d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 19:36:46 +0200 Subject: [PATCH 298/424] Work on command building --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 11 ++++++++--- src/Rocketeer/Services/TasksHandler.php | 2 +- tests/Services/Tasks/TasksBuilderTest.php | 15 +++++++++++++++ 3 files changed, 24 insertions(+), 4 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 2e29048a0..f031589f8 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -40,18 +40,23 @@ public function buildCommand($task, $slug = null) { // Build the task instance try { - $instance = $this->buildTaskFromClass($task); + $instance = $this->buildTask($task); } catch (TaskCompositionException $exception) { $instance = null; } // Get the command name - $command = $this->findQualifiedName($task, array( + $name = $instance ? $instance->getName() : null; + $name = is_string($task) ? $task : $name; + $command = $this->findQualifiedName($name, array( 'Rocketeer\Console\Commands\%sCommand', 'Rocketeer\Console\Commands\BaseTaskCommand', )); - return new $command($instance, $slug); + $command = new $command($instance, $slug); + $command->setLaravel($this->app); + + return $command; } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 2aa504cc5..a8dc55dd7 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -82,7 +82,7 @@ public function add($task, $name = null, $description = null) // Bind to Artisan too if ($this->app->bound('artisan')) { - $command = new BaseTaskCommand($task); + $command = $this->builder->buildCommand($task); $this->app['artisan']->add($command); } diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php index a17c15cfd..3fbb75e94 100644 --- a/tests/Services/Tasks/TasksBuilderTest.php +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -70,4 +70,19 @@ public function testThrowsExceptionOnUnbuildableTask() $this->builder->buildTaskFromClass('Nope'); } + + public function testCanCreateCommandOfTask() + { + $command = $this->builder->buildCommand('Rocketeer', ''); + $this->assertInstanceOf('Rocketeer\Console\Commands\RocketeerCommand', $command); + $this->assertEquals('deploy', $command->getName()); + + $command = $this->builder->buildCommand('Deploy', 'lol'); + $this->assertInstanceOf('Rocketeer\Console\Commands\DeployCommand', $command); + $this->assertEquals('deploy:deploy', $command->getName()); + + $command = $this->builder->buildCommand('ls', 'ls'); + $this->assertInstanceOf('Rocketeer\Console\Commands\BaseTaskCommand', $command); + $this->assertEquals('deploy:ls', $command->getName()); + } } From acfeb2db37a6500f326f139923776bb64294236b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 19:41:25 +0200 Subject: [PATCH 299/424] Fix handle --- src/Rocketeer/Services/Connections/ConnectionsHandler.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 88aad2031..8801a731a 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -69,6 +69,9 @@ public function getHandle($connection = null, $server = null, $stage = null) // Concatenate $handle = [$connection, $server, $stage]; + $handle = array_filter($handle, function ($value) { + return !is_null($value); + }); $handle = implode('/', $handle); return $handle; From 935d93a738c73e94a137994d7c7272122add6b8b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 19:44:02 +0200 Subject: [PATCH 300/424] Fix error messages when no output --- src/Rocketeer/Traits/BashModules/Core.php | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index bf5821647..34cf7c509 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -60,7 +60,7 @@ public function getConnection() public function onLocal(Closure $callback) { $this->local = true; - $results = $callback($this); + $results = $callback($this); $this->local = false; return $results; @@ -224,7 +224,11 @@ public function checkStatus($error, $output = null, $success = null) } // Else display the error - $error = sprintf('An error occured: "%s", while running:'.PHP_EOL.'%s', $error, $output); + $error = sprintf('An error occured: "%s"', $error); + if ($output) { + $error .= 'while running:'.PHP_EOL.$output; + } + $this->explainer->error($error); return false; From aeb58b64c6912243f7147488452fab21a306e875 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 23:51:08 +0200 Subject: [PATCH 301/424] Fix #279 - Rocketeer preventing Artisan boot --- src/Rocketeer/Services/TasksHandler.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index a8dc55dd7..df32b5fc9 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -81,7 +81,7 @@ public function add($task, $name = null, $description = null) $bound = $this->console->add(new BaseTaskCommand($this->app[$slug])); // Bind to Artisan too - if ($this->app->bound('artisan')) { + if ($this->app->bound('artisan') and $this->app->resolved('artisan')) { $command = $this->builder->buildCommand($task); $this->app['artisan']->add($command); } From b18b12333edd6e3eb83ecbca21bbfcf3df7a1319 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 18 Aug 2014 23:52:51 +0200 Subject: [PATCH 302/424] Update tests --- src/Rocketeer/Traits/BashModules/Core.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 34cf7c509..c7eb44fcb 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -226,7 +226,7 @@ public function checkStatus($error, $output = null, $success = null) // Else display the error $error = sprintf('An error occured: "%s"', $error); if ($output) { - $error .= 'while running:'.PHP_EOL.$output; + $error .= ', while running:'.PHP_EOL.$output; } $this->explainer->error($error); From 5098b7b2a4309da40ada5d0c897322d063dca751 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 00:02:59 +0200 Subject: [PATCH 303/424] Add Bower tests --- .../Dependencies/BowerStrategyTest.php | 53 +++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 tests/Strategies/Dependencies/BowerStrategyTest.php diff --git a/tests/Strategies/Dependencies/BowerStrategyTest.php b/tests/Strategies/Dependencies/BowerStrategyTest.php new file mode 100644 index 000000000..04109c103 --- /dev/null +++ b/tests/Strategies/Dependencies/BowerStrategyTest.php @@ -0,0 +1,53 @@ +pretend(); + $bower = $this->builder->buildStrategy('Dependencies', 'Bower'); + $bower->install(); + + $this->assertHistory(array( + array( + 'cd {server}/releases/{release}', + exec('which bower').' install', + ), + )); + } + + public function testCanUpdateDependencies() + { + $this->pretend(); + $bower = $this->builder->buildStrategy('Dependencies', 'Bower'); + $bower->update(); + + $this->assertHistory(array( + array( + 'cd {server}/releases/{release}', + exec('which bower').' update', + ), + )); + } + + public function testUsesAllowRootIfRoot() + { + $this->mock('rocketeer.connections', 'Connections', function ($mock) { + return $mock->shouldReceive('getServerCredentials')->andReturn(['username' => 'root']); + }); + + $this->pretend(); + $bower = $this->builder->buildStrategy('Dependencies', 'Bower'); + $bower->install(); + + $this->assertHistory(array( + array( + 'cd {server}/releases/{release}', + exec('which bower').' install --allow-root', + ), + )); + } +} From ab04624faf34b058c4b2d6fa8a785449451f05b3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 00:12:53 +0200 Subject: [PATCH 304/424] Unify logical operators --- src/Rocketeer/Abstracts/AbstractBinary.php | 2 +- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- .../Abstracts/Strategies/AbstractDependenciesStrategy.php | 2 +- src/Rocketeer/Bash.php | 2 +- src/Rocketeer/Console/Commands/BaseTaskCommand.php | 2 +- src/Rocketeer/Console/WhitespaceCompactor.php | 2 +- src/Rocketeer/Igniter.php | 8 ++++---- src/Rocketeer/Rocketeer.php | 4 ++-- src/Rocketeer/Services/Connections/ConnectionsHandler.php | 4 ++-- src/Rocketeer/Services/CredentialsGatherer.php | 6 +++--- src/Rocketeer/Services/ReleasesManager.php | 2 +- src/Rocketeer/Services/Storages/LocalStorage.php | 2 +- src/Rocketeer/Services/Tasks/TasksBuilder.php | 4 ++-- src/Rocketeer/Services/Tasks/TasksQueue.php | 4 ++-- src/Rocketeer/Services/TasksHandler.php | 4 ++-- src/Rocketeer/Tasks/Check.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 4 ++-- src/Rocketeer/Traits/BashModules/Flow.php | 2 +- tests/TestCases/RocketeerAssertions.php | 2 +- 21 files changed, 32 insertions(+), 32 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 1e7603af2..513f14844 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -171,7 +171,7 @@ protected function buildOptions($flags) // Flip array if necessary $firstKey = Arr::get(array_keys($flags), 0); - if (!is_null($firstKey) and is_int($firstKey)) { + if (!is_null($firstKey) && is_int($firstKey)) { $flags = array_combine( array_values($flags), array_fill(0, count($flags), null) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index f13db22a3..c22351881 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -41,7 +41,7 @@ public function __construct(AbstractTask $task = null) $this->task = $task; $this->task->command = $this; - if (!$this->description and $description = $task->getDescription()) { + if (!$this->description && $description = $task->getDescription()) { $this->setDescription($description); } } diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 9d3b124e2..b4c639166 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -37,7 +37,7 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy */ public function isExecutable() { - return $this->getManager()->getBinary() and $this->hasManifest(); + return $this->getManager()->getBinary() && $this->hasManifest(); } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index 99ffe832e..aea536de4 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -64,7 +64,7 @@ protected function getHookedTasks($hook, array $arguments) public function getStrategy($strategy, $concrete = null) { $strategy = $this->builder->buildStrategy($strategy, $concrete); - if (!$strategy or !$strategy->isExecutable()) { + if (!$strategy || !$strategy->isExecutable()) { return; } diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index cba25593d..9d167d760 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -38,7 +38,7 @@ public function __construct(AbstractTask $task = null, $name = null) parent::__construct($task); // Set name - if ($this->name == 'deploy:custom' and $task) { + if ($this->name == 'deploy:custom' && $task) { $this->name = $name ?: $task->getSlug(); $this->name = 'deploy:'.$this->name; } diff --git a/src/Rocketeer/Console/WhitespaceCompactor.php b/src/Rocketeer/Console/WhitespaceCompactor.php index 418c054cb..b264c11df 100644 --- a/src/Rocketeer/Console/WhitespaceCompactor.php +++ b/src/Rocketeer/Console/WhitespaceCompactor.php @@ -29,6 +29,6 @@ class WhitespaceCompactor extends Php */ public function supports($file) { - return dirname($file) !== 'src/config' and parent::supports($file); + return dirname($file) !== 'src/config' && parent::supports($file); } } diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index c15e43c18..059d594c7 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -67,7 +67,7 @@ public function mergeContextualConfigurations() { // Cancel if not ignited yet $storage = $this->app['path.rocketeer.config']; - if (!is_dir($storage) or (!is_dir($storage.'/stages') and !is_dir($storage.'/connections'))) { + if (!is_dir($storage) || (!is_dir($storage.'/stages') && !is_dir($storage.'/connections'))) { return; } @@ -216,13 +216,13 @@ protected function bindConfiguration() foreach ($paths as $key => $file) { // Check whether we provided a file or folder - if (!is_dir($file) and file_exists($file.'.php')) { + if (!is_dir($file) && file_exists($file.'.php')) { $file .= '.php'; } // Use configuration in current folder if none found $realpath = realpath('.').'/'.basename($file); - if (!file_exists($file) and file_exists($realpath)) { + if (!file_exists($file) && file_exists($realpath)) { $file = $realpath; } @@ -266,7 +266,7 @@ protected function loadFileOrFolder($handle) // If we have one unified tasks file, include it $file = $this->app['path.rocketeer.'.$handle]; - if (!is_dir($file) and file_exists($file)) { + if (!is_dir($file) && file_exists($file)) { include $file; } // Else include its contents elseif (is_dir($file)) { diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index abf883492..f718410f8 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -110,7 +110,7 @@ protected function getContextualOption($option, $type, $original = null) // Merge with defaults $value = $this->config->get($contextual); - if (is_array($value) and $original) { + if (is_array($value) && $original) { $value = array_replace($original, $value); } @@ -169,7 +169,7 @@ public function getFolder($folder = null) $base = $this->getHomeFolder().'/'; $stage = $this->connections->getStage(); - if ($folder and $stage) { + if ($folder && $stage) { $base .= $stage.'/'; } $folder = str_replace($base, null, $folder); diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 8801a731a..5ef38b55d 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -207,7 +207,7 @@ public function getConnections() }); // Return default if no active connection(s) set - if (empty($connections) and $default) { + if (empty($connections) && $default) { return array($default); } @@ -360,7 +360,7 @@ public function getRepositoryEndpoint() $repository = Arr::get($repository, 'repository'); // Add credentials if possible - if ($username or $password) { + if ($username || $password) { // Build credentials chain $credentials = $password ? $username.':'.$password : $username; diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 2c4186a96..7d7390665 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -62,7 +62,7 @@ public function getServerCredentials() $activeConnections = $this->connections->getConnections(); // If we didn't set any connection, ask for them - if (!$activeConnections or empty($availableConnections)) { + if (!$activeConnections || empty($availableConnections)) { $connectionName = $this->command->askWith('No connections have been set, please create one:', 'production'); $this->getConnectionCredentials($connectionName); @@ -109,7 +109,7 @@ protected function getConnectionCredentials($connectionName, $server = null) ), $connection, $handle); // Get password or key - if (!$credentials['password'] and !$credentials['key']) { + if (!$credentials['password'] && !$credentials['key']) { $types = ['key', 'password']; $type = $this->command->askWith('No password or SSH key is set for ['.$handle.'], which would you use?', 'key', $types); if ($type == 'key') { @@ -144,7 +144,7 @@ protected function gatherCredentials($credentials, $current, $handle) // Loop throguh credentials and ask missing ones foreach ($credentials as $credential => $required) { $$credential = $this->getCredential($current, $credential); - if ($required and !$$credential) { + if ($required && !$$credential) { $$credential = $this->gatherCredential($handle, $credential); } } diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 44838930d..658b7f968 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -266,7 +266,7 @@ public function getPreviousRelease($release = null) do { $release = Arr::get($releases, $key + $next); $next++; - } while (!$this->checkReleaseState($release) and isset($this->state[$release])); + } while (!$this->checkReleaseState($release) && isset($this->state[$release])); return $release ?: $current; } diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index 59d1fb7c2..bf10714ff 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -115,7 +115,7 @@ public function shouldFlush() { $currentHash = $this->get('hash'); - return $currentHash and $currentHash !== $this->getHash(); + return $currentHash && $currentHash !== $this->getHash(); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index f031589f8..a81be9bd0 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -158,7 +158,7 @@ protected function composeTask($task) } // If we passed a command, build a ClosureTask - if (is_array($task) or $this->isStringCommand($task)) { + if (is_array($task) || $this->isStringCommand($task)) { return $this->buildTaskFromString($task); } @@ -218,7 +218,7 @@ public function buildTaskFromClosure(Closure $callback, $stringTask = null) */ public function buildTaskFromClass($task) { - if (is_object($task) and $task instanceof AbstractTask) { + if (is_object($task) && $task instanceof AbstractTask) { return $task; } diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 88be9da72..959bff105 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -188,7 +188,7 @@ protected function executeJob(Job $job) $this->toOutput($state); // If the task didn't finish, display what the error was - if ($task->wasHalted() or $state === false) { + if ($task->wasHalted() || $state === false) { $this->command->error('The tasks queue was canceled by task "'.$task->getName().'"'); return false; @@ -273,7 +273,7 @@ public function getStages($connection) } // Return all stages if "all" - if ($stage == 'all' or !$stage) { + if ($stage == 'all' || !$stage) { $stage = $this->connections->getStages(); } diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index df32b5fc9..95b152ea0 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -81,7 +81,7 @@ public function add($task, $name = null, $description = null) $bound = $this->console->add(new BaseTaskCommand($this->app[$slug])); // Bind to Artisan too - if ($this->app->bound('artisan') and $this->app->resolved('artisan')) { + if ($this->app->bound('artisan') && $this->app->resolved('artisan')) { $command = $this->builder->buildCommand($task); $this->app['artisan']->add($command); } @@ -233,7 +233,7 @@ public function getTasksListeners($task, $event, $flatten = false) // Flatten the queue if requested foreach ($events as $key => $event) { $task = $event[0]; - if ($flatten and $task instanceof Tasks\Closure and $stringTask = $task->getStringTask()) { + if ($flatten && $task instanceof Tasks\Closure && $stringTask = $task->getStringTask()) { $events[$key] = $stringTask; } } diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index e4a978131..ee231288b 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -181,7 +181,7 @@ public function checkDatabaseDriver($database) return $this->checkPhpExtension('pdo_sqlite'); case 'mysql': - return $this->checkPhpExtension('mysql') and $this->checkPhpExtension('pdo_mysql'); + return $this->checkPhpExtension('mysql') && $this->checkPhpExtension('pdo_mysql'); default: return true; diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 38ede7bc3..ce19766ce 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -40,7 +40,7 @@ class Setup extends AbstractTask public function execute() { // Check if requirements are met - if ($this->executeTask('Check') === false and !$this->getOption('pretend')) { + if ($this->executeTask('Check') === false && !$this->getOption('pretend')) { return false; } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index ce6e2072d..fa5f436bc 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -117,7 +117,7 @@ public function which($binary, $fallback = null, $default = false) // Look in all the locations $tryout = 0; - while (!$location and array_key_exists($tryout, $locations)) { + while (!$location && array_key_exists($tryout, $locations)) { list($object, $method, $argument) = $locations[$tryout]; $location = $object->$method($argument); diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index c7eb44fcb..f3e32eb32 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -91,7 +91,7 @@ public function run($commands, $silent = false, $array = false) } // Display for pretend mode - if ($verbose or ($pretend and !$silent)) { + if ($verbose || ($pretend && !$silent)) { $this->toOutput($commands); $flattened = implode(PHP_EOL.'$ ', $commands); $this->command->line('$ '.$flattened.''); @@ -284,7 +284,7 @@ public function processCommands($commands) } // Add stage flag to Artisan commands - if (Str::contains($command, 'artisan') and $stage) { + if (Str::contains($command, 'artisan') && $stage) { $command .= ' --env="'.$stage.'"'; } diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 3780ccf17..7a3c07f3e 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -42,7 +42,7 @@ public function usesStages() { $stages = $this->connections->getStages(); - return $this->usesStages and !empty($stages); + return $this->usesStages && !empty($stages); } /** diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/RocketeerAssertions.php index a4f4240e8..902b6cc64 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/RocketeerAssertions.php @@ -130,7 +130,7 @@ protected function replaceHistoryPlaceholders($history, $release = null) $replaced = []; foreach ($history as $key => $entries) { - if ($hhvm and $entries == '{php} -m') { + if ($hhvm && $entries == '{php} -m') { continue; } From 988efb431a49e1cf3e75dc1bd0690028d7c45755 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 00:33:35 +0200 Subject: [PATCH 305/424] Fix Bower tests --- composer.json | 3 ++- .../Dependencies/BowerStrategyTest.php | 14 +++++++++++--- tests/TestCases/ContainerTestCase.php | 18 ++++++++++++++++-- 3 files changed, 29 insertions(+), 6 deletions(-) diff --git a/composer.json b/composer.json index 1076dc535..c3bb84a11 100644 --- a/composer.json +++ b/composer.json @@ -34,7 +34,8 @@ "phpseclib/phpseclib": "~0.3.5", "d11wtq/boris": "~1.0.8", "raveren/kint": "~0.9.1", - "johnkary/phpunit-speedtrap": "dev-master" + "johnkary/phpunit-speedtrap": "dev-master", + "codeception/aspect-mock": "~0.4.2" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", diff --git a/tests/Strategies/Dependencies/BowerStrategyTest.php b/tests/Strategies/Dependencies/BowerStrategyTest.php index 04109c103..15298a67c 100644 --- a/tests/Strategies/Dependencies/BowerStrategyTest.php +++ b/tests/Strategies/Dependencies/BowerStrategyTest.php @@ -1,10 +1,18 @@ app['rocketeer.bash'] = Test::double($this->app['rocketeer.bash'], ['which' => 'bower']); + } + public function testCanInstallDependencies() { $this->pretend(); @@ -14,7 +22,7 @@ public function testCanInstallDependencies() $this->assertHistory(array( array( 'cd {server}/releases/{release}', - exec('which bower').' install', + 'bower install', ), )); } @@ -28,7 +36,7 @@ public function testCanUpdateDependencies() $this->assertHistory(array( array( 'cd {server}/releases/{release}', - exec('which bower').' update', + 'bower update', ), )); } @@ -46,7 +54,7 @@ public function testUsesAllowRootIfRoot() $this->assertHistory(array( array( 'cd {server}/releases/{release}', - exec('which bower').' install --allow-root', + 'bower install --allow-root', ), )); } diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 6ec10ca20..9294a2499 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -1,6 +1,8 @@ init(array( + 'debug' => true, + 'includePaths' => [__DIR__.'/../../src'], +)); + abstract class ContainerTestCase extends PHPUnit_Framework_TestCase { use HasLocator; @@ -72,6 +80,7 @@ public function setUp() public function tearDown() { Mockery::close(); + Test::clean(); } //////////////////////////////////////////////////////////////////// @@ -84,12 +93,17 @@ public function tearDown() * @param string $handle * @param string $class * @param Closure $expectations + * @param boolean $partial * * @return Mockery */ - protected function mock($handle, $class, Closure $expectations) + protected function mock($handle, $class, Closure $expectations, $partial = true) { - $mockery = Mockery::mock($class)->shouldIgnoreMissing(); + $mockery = Mockery::mock($class); + if ($partial) { + $mockery = $mockery->shouldIgnoreMissing(); + } + $mockery = $expectations($mockery)->mock(); $this->app[$handle] = $mockery; From 6862757b6a5f8a7c5ae8722a26ce2ab158371768 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 00:49:54 +0200 Subject: [PATCH 306/424] Fuck this shit --- composer.json | 3 +- .../AbstractDependenciesStrategy.php | 32 +++++++++++++++++-- .../Strategies/Dependencies/BowerStrategy.php | 4 +-- .../Dependencies/ComposerStrategy.php | 2 +- .../Dependencies/BowerStrategyTest.php | 22 ++++++++----- tests/TestCases/ContainerTestCase.php | 9 ------ 6 files changed, 47 insertions(+), 25 deletions(-) diff --git a/composer.json b/composer.json index c3bb84a11..1076dc535 100644 --- a/composer.json +++ b/composer.json @@ -34,8 +34,7 @@ "phpseclib/phpseclib": "~0.3.5", "d11wtq/boris": "~1.0.8", "raveren/kint": "~0.9.1", - "johnkary/phpunit-speedtrap": "dev-master", - "codeception/aspect-mock": "~0.4.2" + "johnkary/phpunit-speedtrap": "dev-master" }, "suggest": { "anahkiasen/rocketeer-campfire": "Campfire plugin to create deployments notifications", diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index b4c639166..4a6dbeb1c 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -9,6 +9,8 @@ */ namespace Rocketeer\Abstracts\Strategies; +use Illuminate\Container\Container; + /** * Abstract class for Dependencies strategies * @@ -30,6 +32,30 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy */ protected $binary; + /** + * The package manager instance + * + * @type \Rocketeer\Abstracts\AbstractBinary + */ + protected $manager; + + /** + * @param Container $app + */ + public function __construct(Container $app) + { + $this->app = $app; + $this->manager = $this->binary($this->binary); + } + + /** + * @param \Rocketeer\Abstracts\AbstractBinary $manager + */ + public function setManager($manager) + { + $this->manager = $manager; + } + /** * Whether this particular strategy is runnable or not * @@ -37,7 +63,7 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy */ public function isExecutable() { - return $this->getManager()->getBinary() && $this->hasManifest(); + return $this->manager->getBinary() && $this->hasManifest(); } ////////////////////////////////////////////////////////////////////// @@ -51,7 +77,7 @@ public function isExecutable() */ public function install() { - return $this->getManager()->runForCurrentRelease('install'); + return $this->manager->runForCurrentRelease('install'); } /** @@ -61,7 +87,7 @@ public function install() */ public function update() { - return $this->getManager()->runForCurrentRelease('update'); + return $this->manager->runForCurrentRelease('update'); } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php index bae442923..cc3aa703a 100644 --- a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -45,7 +45,7 @@ class BowerStrategy extends AbstractDependenciesStrategy implements Dependencies */ public function install() { - return $this->getManager()->runForCurrentRelease('install', [], $this->getInstallationOptions()); + return $this->manager->runForCurrentRelease('install', [], $this->getInstallationOptions()); } /** @@ -55,7 +55,7 @@ public function install() */ public function update() { - return $this->getManager()->runForCurrentRelease('update', [], $this->getInstallationOptions()); + return $this->manager->runForCurrentRelease('update', [], $this->getInstallationOptions()); } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 129a769a2..5dbc02420 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -60,7 +60,7 @@ public function update() */ protected function executeHook($hook) { - $tasks = $this->getHookedTasks('composer.'.$hook, [$this->getManager(), $this]); + $tasks = $this->getHookedTasks('composer.'.$hook, [$this->manager, $this]); if (!$tasks) { return true; } diff --git a/tests/Strategies/Dependencies/BowerStrategyTest.php b/tests/Strategies/Dependencies/BowerStrategyTest.php index 15298a67c..bed089da1 100644 --- a/tests/Strategies/Dependencies/BowerStrategyTest.php +++ b/tests/Strategies/Dependencies/BowerStrategyTest.php @@ -1,23 +1,31 @@ app['rocketeer.bash'] = Test::double($this->app['rocketeer.bash'], ['which' => 'bower']); + $bower = new Bower($this->app); + $bower->setBinary('bower'); + + $this->bower = $this->builder->buildStrategy('Dependencies', 'Bower'); + $this->bower->setManager($bower); } public function testCanInstallDependencies() { $this->pretend(); - $bower = $this->builder->buildStrategy('Dependencies', 'Bower'); - $bower->install(); + $this->bower->install(); $this->assertHistory(array( array( @@ -30,8 +38,7 @@ public function testCanInstallDependencies() public function testCanUpdateDependencies() { $this->pretend(); - $bower = $this->builder->buildStrategy('Dependencies', 'Bower'); - $bower->update(); + $this->bower->update(); $this->assertHistory(array( array( @@ -48,8 +55,7 @@ public function testUsesAllowRootIfRoot() }); $this->pretend(); - $bower = $this->builder->buildStrategy('Dependencies', 'Bower'); - $bower->install(); + $this->bower->install(); $this->assertHistory(array( array( diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 9294a2499..4468671b6 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -1,8 +1,6 @@ init(array( - 'debug' => true, - 'includePaths' => [__DIR__.'/../../src'], -)); - abstract class ContainerTestCase extends PHPUnit_Framework_TestCase { use HasLocator; @@ -80,7 +72,6 @@ public function setUp() public function tearDown() { Mockery::close(); - Test::clean(); } //////////////////////////////////////////////////////////////////// From 6d82cb7f7b226521b316cce1d3a3e2c56131b854 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 01:14:38 +0200 Subject: [PATCH 307/424] Docblock fixes --- src/Rocketeer/Bash.php | 2 +- src/Rocketeer/Console/Commands/BaseTaskCommand.php | 4 ++-- src/Rocketeer/Services/Display/QueueExplainer.php | 14 +++++++------- src/Rocketeer/Services/Tasks/TasksBuilder.php | 12 ++++++------ src/Rocketeer/Tasks/Rollback.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 8 ++++---- 7 files changed, 22 insertions(+), 22 deletions(-) diff --git a/src/Rocketeer/Bash.php b/src/Rocketeer/Bash.php index aea536de4..5d660bdc4 100644 --- a/src/Rocketeer/Bash.php +++ b/src/Rocketeer/Bash.php @@ -76,7 +76,7 @@ public function getStrategy($strategy, $concrete = null) /** * Execute another task by name * - * @param string|array $tasks + * @param string $tasks * * @return string|false */ diff --git a/src/Rocketeer/Console/Commands/BaseTaskCommand.php b/src/Rocketeer/Console/Commands/BaseTaskCommand.php index 9d167d760..1013711b6 100644 --- a/src/Rocketeer/Console/Commands/BaseTaskCommand.php +++ b/src/Rocketeer/Console/Commands/BaseTaskCommand.php @@ -30,8 +30,8 @@ class BaseTaskCommand extends AbstractCommand /** * Build a new custom command * - * @param AbstractTask $task - * @param string|null $name A name for the command + * @param AbstractTask|null $task + * @param string|null $name A name for the command */ public function __construct(AbstractTask $task = null, $name = null) { diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index 31ce163ef..a0f1c5d9d 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -63,7 +63,7 @@ public function displayBelow(Closure $callback) /** * Display a status * - * @param string $info + * @param string|null $info * @param string|null $details * @param float|null $time */ @@ -100,7 +100,7 @@ public function display($info = null, $details = null, $time = null) * @param string $message * @param string|null $color * - * @return string + * @return string|null */ public function line($message, $color = null) { @@ -117,9 +117,9 @@ public function line($message, $color = null) } /** - * @param $message + * @param string $message * - * @return string + * @return string|null */ public function success($message) { @@ -127,9 +127,9 @@ public function success($message) } /** - * @param $message + * @param string $message * - * @return string + * @return string|null */ public function error($message) { @@ -157,7 +157,7 @@ protected function getLongestSize() $stages = (array) $this->connections->getStages(); foreach ($connections as $connection => $servers) { foreach ($stages as $stage) { - $strings[] = $connection.'/'.sizeof($servers).'/'.$stage; + $strings[] = $connection.'/'.count($servers).'/'.$stage; } } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index a81be9bd0..511b46da1 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -31,8 +31,8 @@ class TasksBuilder /** * Build the command bound to a task * - * @param string $task - * @param string|null $slug + * @param string|AbstractTask $task + * @param string|null $slug * * @return \Rocketeer\Abstracts\AbstractCommand */ @@ -46,8 +46,8 @@ public function buildCommand($task, $slug = null) } // Get the command name - $name = $instance ? $instance->getName() : null; - $name = is_string($task) ? $task : $name; + $name = $instance ? $instance->getName() : null; + $name = is_string($task) ? $task : $name; $command = $this->findQualifiedName($name, array( 'Rocketeer\Console\Commands\%sCommand', 'Rocketeer\Console\Commands\BaseTaskCommand', @@ -237,7 +237,7 @@ public function buildTaskFromClass($task) /** * Get the handle of a task from its name * - * @param string $task + * @param string|AbstractTask $task * * @return string|null */ @@ -258,7 +258,7 @@ protected function getTaskHandle($task) /** * Check if a string is a command or a task * - * @param AbstractTask|Closure|string $string + * @param string|Closure|AbstractTask $string * * @return boolean */ diff --git a/src/Rocketeer/Tasks/Rollback.php b/src/Rocketeer/Tasks/Rollback.php index 02430c1cf..3d9ed0cee 100644 --- a/src/Rocketeer/Tasks/Rollback.php +++ b/src/Rocketeer/Tasks/Rollback.php @@ -28,7 +28,7 @@ class Rollback extends AbstractTask /** * Run the task * - * @return void + * @return string|null */ public function execute() { diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index ce19766ce..0fd3277bb 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -35,7 +35,7 @@ class Setup extends AbstractTask /** * Run the task * - * @return false|null + * @return string|false|null */ public function execute() { diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index f3e32eb32..096fbcc1b 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -178,7 +178,7 @@ public function runSilently($commands, $array = false) * @param string|null $folder * @param string|array $tasks * - * @return string + * @return string|null */ public function runInFolder($folder = null, $tasks = array()) { @@ -314,9 +314,9 @@ protected function cleanOutput($output) /** * Process the output of a command * - * @param string|array $output - * @param boolean $array Whether to return an array or a string - * @param boolean $trim Whether to trim the output or not + * @param string $output + * @param boolean $array Whether to return an array or a string + * @param boolean $trim Whether to trim the output or not * * @return string|array */ From 7e88780648f5ee19b0a94a69e6bd8180a9b7cac8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 01:25:50 +0200 Subject: [PATCH 308/424] Typehint all closures --- .gitignore | 3 --- src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- .../Strategies/Dependencies/PolyglotStrategy.php | 5 +++-- src/Rocketeer/Strategies/Deploy/SyncStrategy.php | 3 ++- src/config/config.php | 9 ++++++--- 5 files changed, 12 insertions(+), 10 deletions(-) diff --git a/.gitignore b/.gitignore index 9922bc96f..ef1d95d74 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,3 @@ -# Development -.idea - # Cache and compiled .rocketeer bin/phar diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 511b46da1..255f2fe02 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -178,7 +178,7 @@ protected function composeTask($task) public function buildTaskFromString($task) { $stringTask = $task; - $closure = function ($task) use ($stringTask) { + $closure = function (AbstractTask $task) use ($stringTask) { return $task->runForCurrentRelease($stringTask); }; diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index d56719467..0eb29d2a4 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -10,6 +10,7 @@ namespace Rocketeer\Strategies\Dependencies; use Closure; +use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; @@ -34,7 +35,7 @@ class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyI */ public function install() { - return $this->onManagers(function ($manager) { + return $this->onManagers(function (AbstractDependenciesStrategy $manager) { return $manager->install(); }); } @@ -46,7 +47,7 @@ public function install() */ public function update() { - return $this->onManagers(function ($manager) { + return $this->onManagers(function (AbstractDependenciesStrategy $manager) { return $manager->update(); }); } diff --git a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php index 6e3e19d60..a87ad585e 100644 --- a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php @@ -10,6 +10,7 @@ namespace Rocketeer\Strategies\Deploy; use Rocketeer\Abstracts\Strategies\AbstractStrategy; +use Rocketeer\Bash; use Rocketeer\Interfaces\Strategies\DeployStrategyInterface; class SyncStrategy extends AbstractStrategy implements DeployStrategyInterface @@ -79,7 +80,7 @@ protected function rsyncTo($destination) $rsync = $this->binary('rsync'); $rsync = $rsync->getCommand(null, ['./', $handle.':'.$destination], $options); - return $this->bash->onLocal(function ($bash) use ($rsync) { + return $this->bash->onLocal(function (Bash $bash) use ($rsync) { return $bash->run($rsync); }); } diff --git a/src/config/config.php b/src/config/config.php index b60c38618..a6e69bc91 100644 --- a/src/config/config.php +++ b/src/config/config.php @@ -1,4 +1,7 @@ - function ($rocketeer) { - return sprintf('%s-%s-%s.log', $rocketeer->getConnection(), $rocketeer->getStage(), date('Ymd')); + 'logs' => function (ConnectionsHandler $connections) { + return sprintf('%s-%s-%s.log', $connections->getConnection(), $connections->getStage(), date('Ymd')); }, // Remote access From 51a7fe3e56043a25c5c999c73ef4ec90b946f4f1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 01:36:01 +0200 Subject: [PATCH 309/424] Add rsync tests --- .../Strategies/Deploy/SyncStrategy.php | 2 +- tests/Strategies/Deploy/SyncStrategyTest.php | 46 +++++++++++++++++++ 2 files changed, 47 insertions(+), 1 deletion(-) create mode 100644 tests/Strategies/Deploy/SyncStrategyTest.php diff --git a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php index a87ad585e..7fa03d763 100644 --- a/src/Rocketeer/Strategies/Deploy/SyncStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/SyncStrategy.php @@ -64,7 +64,7 @@ protected function rsyncTo($destination) { // Build host handle $credentials = $this->connections->getServerCredentials(); - $handle = $credentials['host']; + $handle = array_get($credentials, 'host'); if ($user = array_get($credentials, 'username')) { $handle = $user.'@'.$handle; } diff --git a/tests/Strategies/Deploy/SyncStrategyTest.php b/tests/Strategies/Deploy/SyncStrategyTest.php new file mode 100644 index 000000000..29140371a --- /dev/null +++ b/tests/Strategies/Deploy/SyncStrategyTest.php @@ -0,0 +1,46 @@ +swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + 'host' => 'bar.com', + 'username' => 'foo', + ), + ), + )); + } + + public function testCanDeployRepository() + { + $task = $this->pretendTask('Deploy'); + $task->getStrategy('Deploy', 'Sync')->deploy(); + + $matcher = array( + 'mkdir {server}/releases/{release}', + 'rsync ./ foo@bar.com:{server}/releases/{release} --verbose --recursive --rsh="ssh" --exclude=".git" --exclude="vendor"', + ); + + $this->assertHistory($matcher); + } + + public function testCanUpdateRepository() + { + $task = $this->pretendTask('Deploy'); + $task->getStrategy('Deploy', 'Sync')->update(); + + $matcher = array( + 'rsync ./ foo@bar.com:{server}/releases/{release} --verbose --recursive --rsh="ssh" --exclude=".git" --exclude="vendor"', + ); + + $this->assertHistory($matcher); + } +} From ea60f817c67f222b9399c7342e6f67d73f276f84 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 01:36:45 +0200 Subject: [PATCH 310/424] Unused methods --- .../Services/Connections/Connection.php | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/src/Rocketeer/Services/Connections/Connection.php b/src/Rocketeer/Services/Connections/Connection.php index c3dd9147b..4c53d32bf 100644 --- a/src/Rocketeer/Services/Connections/Connection.php +++ b/src/Rocketeer/Services/Connections/Connection.php @@ -16,22 +16,6 @@ */ class Connection extends \Illuminate\Remote\Connection { - /** - * @return array - */ - public function getAuth() - { - return $this->auth; - } - - /** - * @return string - */ - public function getHost() - { - return $this->host; - } - /** * @return string */ From 6198364c504488979f6444a659df7c9bfd2f0dba Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 01:49:25 +0200 Subject: [PATCH 311/424] Add some tests --- .../Connections/LocalConnectionTest.php | 16 +++++++++++++++ tests/Tasks/Subtasks/PrimerTest.php | 20 +++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 tests/Services/Connections/LocalConnectionTest.php create mode 100644 tests/Tasks/Subtasks/PrimerTest.php diff --git a/tests/Services/Connections/LocalConnectionTest.php b/tests/Services/Connections/LocalConnectionTest.php new file mode 100644 index 000000000..fd723771e --- /dev/null +++ b/tests/Services/Connections/LocalConnectionTest.php @@ -0,0 +1,16 @@ +task; + $task->setLocal(true); + $task->run('ls'); + + $this->assertTrue($task->status()); + } +} diff --git a/tests/Tasks/Subtasks/PrimerTest.php b/tests/Tasks/Subtasks/PrimerTest.php new file mode 100644 index 000000000..c8cd1074d --- /dev/null +++ b/tests/Tasks/Subtasks/PrimerTest.php @@ -0,0 +1,20 @@ +swapConfig(array( + 'rocketeer::default' => 'production', + 'rocketeer::strategies.primer' => function () { + return 'ls'; + } + )); + + $this->assertTaskHistory('Primer', ['ls']); + } +} From 69f89aef2ed00c0c76955fb0b9b453066f664b1e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 01:49:33 +0200 Subject: [PATCH 312/424] Ignore some parts for coverage --- src/Rocketeer/Abstracts/AbstractTask.php | 2 ++ src/Rocketeer/Services/Connections/LocalConnection.php | 6 ++++++ 2 files changed, 8 insertions(+) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index d3495de1d..3ef6af38e 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -205,6 +205,8 @@ public function getQualifiedEvent($event) /** * Display a list of releases and their status + * + * @codeCoverageIgnore */ protected function displayReleases() { diff --git a/src/Rocketeer/Services/Connections/LocalConnection.php b/src/Rocketeer/Services/Connections/LocalConnection.php index 4f870bb5d..ec1e5c38c 100644 --- a/src/Rocketeer/Services/Connections/LocalConnection.php +++ b/src/Rocketeer/Services/Connections/LocalConnection.php @@ -36,6 +36,7 @@ class LocalConnection implements ConnectionInterface * @param string $task * @param string|array $commands * + * @codeCoverageIgnore * @return void */ public function define($task, $commands) @@ -49,6 +50,7 @@ public function define($task, $commands) * @param string $task * @param Closure|null $callback * + * @codeCoverageIgnore * @return void */ public function task($task, Closure $callback = null) @@ -96,6 +98,7 @@ public function status() * @param string $local * @param string $remote * + * @codeCoverageIgnore * @return integer */ public function put($local, $remote) @@ -110,6 +113,7 @@ public function put($local, $remote) * * @param string $remote * + * @codeCoverageIgnore * @return string */ public function getString($remote) @@ -122,6 +126,7 @@ public function getString($remote) * * @param string $line * + * @codeCoverageIgnore * @return void */ public function display($line) @@ -137,6 +142,7 @@ public function display($line) * @param string $remote * @param string $contents * + * @codeCoverageIgnore * @return integer */ public function putString($remote, $contents) From 8fda97705b408149051a59ce1b436ea2cbff1c3c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 02:05:06 +0200 Subject: [PATCH 313/424] Simpler server cleanup --- .gitignore | 3 + tests/TestCases/RocketeerTestCase.php | 47 +++---------- tests/_meta/coverage.txt | 68 ------------------- .../{foobar => foobar-stub}/current/.gitkeep | 0 .../foobar-stub}/deployments.json | 0 .../{foobar => foobar-stub}/releases/.gitkeep | 0 .../releases/10000000000000/.gitkeep | 0 .../releases/15000000000000/.gitkeep | 0 .../releases/20000000000000/.gitkeep | 0 .../{foobar => foobar-stub}/shared/.gitkeep | 0 .../{foobar => foobar-stub}/state.json | 0 11 files changed, 11 insertions(+), 107 deletions(-) delete mode 100644 tests/_meta/coverage.txt rename tests/_server/{foobar => foobar-stub}/current/.gitkeep (100%) rename tests/{_meta => _server/foobar-stub}/deployments.json (100%) rename tests/_server/{foobar => foobar-stub}/releases/.gitkeep (100%) rename tests/_server/{foobar => foobar-stub}/releases/10000000000000/.gitkeep (100%) rename tests/_server/{foobar => foobar-stub}/releases/15000000000000/.gitkeep (100%) rename tests/_server/{foobar => foobar-stub}/releases/20000000000000/.gitkeep (100%) rename tests/_server/{foobar => foobar-stub}/shared/.gitkeep (100%) rename tests/_server/{foobar => foobar-stub}/state.json (100%) diff --git a/.gitignore b/.gitignore index ef1d95d74..51072d51f 100644 --- a/.gitignore +++ b/.gitignore @@ -4,5 +4,8 @@ bin/phar bin/rocketeer.phar composer.lock +# Tests +tests/_server/foobar + # Dependencies vendor diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 6126c174a..97549dc98 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -45,7 +45,7 @@ public function setUp() // Setup local server $this->customConfig = __DIR__.'/../_meta/.rocketeer'; $this->server = __DIR__.'/../_server/foobar'; - $this->deploymentsFile = __DIR__.'/../_meta/deployments.json'; + $this->deploymentsFile = __DIR__.'/../_server/foobar/deployments.json'; // Bind new LocalStorage instance $this->app->bind('rocketeer.storage.local', function ($app) { @@ -80,46 +80,15 @@ protected function recreateVirtualServer() // Save superglobals $this->home = $_SERVER['HOME']; - // Recreate deployments file - $this->files->put($this->deploymentsFile, json_encode(array( - 'foo' => 'bar', - 'directory_separator' => '/', - 'is_setup' => true, - 'webuser' => array('username' => 'www-data', 'group' => 'www-data'), - 'line_endings' => "\n", - ))); - - $rootPath = $this->server.'/../../..'; + // Cleanup files created by tests + $this->files->deleteDirectory($this->server); + $this->files->deleteDirectory($this->customConfig); + if (is_link($this->server.'/current')) { + unlink($this->server.'/current'); + } // Recreate altered local server - $this->files->deleteDirectory($rootPath.'/storage'); - $this->files->deleteDirectory($this->server.'/logs'); - $folders = array( - 'current', - 'shared', - 'releases', - 'releases/10000000000000', - 'releases/15000000000000', - 'releases/20000000000000' - ); - foreach ($folders as $folder) { - $folder = $this->server.'/'.$folder; - - $this->files->deleteDirectory($folder); - $this->files->delete($folder); - $this->files->makeDirectory($folder, 0777, true); - file_put_contents($folder.'/.gitkeep', ''); - } - file_put_contents($this->server.'/state.json', json_encode(array( - '10000000000000' => true, - '15000000000000' => false, - '20000000000000' => true, - ))); - - // Delete rocketeer config - $binary = $rootPath.'/.rocketeer'; - $this->files->deleteDirectory($binary); - $this->files->deleteDirectory($this->customConfig); + $this->files->copyDirectory($this->server.'-stub', $this->server); } //////////////////////////////////////////////////////////////////// diff --git a/tests/_meta/coverage.txt b/tests/_meta/coverage.txt deleted file mode 100644 index 46a49e7e7..000000000 --- a/tests/_meta/coverage.txt +++ /dev/null @@ -1,68 +0,0 @@ - - -Code Coverage Report: - 2014-03-08 19:50:07 - - Summary: - Classes: 45.16% (14/31) - Methods: 80.30% (163/203) - Lines: 90.04% (967/1074) - -\Rocketeer::Igniter - Methods: 90.00% ( 9/10) Lines: 98.28% ( 57/ 58) -\Rocketeer::LogsHandler - Methods: 100.00% ( 6/ 6) Lines: 100.00% ( 27/ 27) -\Rocketeer::ReleasesManager - Methods: 94.12% (16/17) Lines: 97.14% ( 68/ 70) -\Rocketeer::Rocketeer - Methods: 96.00% (24/25) Lines: 98.31% (116/118) -\Rocketeer::LocalStorage - Methods: 69.23% ( 9/13) Lines: 86.49% ( 64/ 74) -\Rocketeer::TasksHandler - Methods: 81.82% ( 9/11) Lines: 91.94% ( 57/ 62) -\Rocketeer::TasksQueue - Methods: 63.64% ( 7/11) Lines: 89.33% ( 67/ 75) -\Rocketeer\Plugins::Notifier - Methods: 75.00% ( 3/ 4) Lines: 87.50% ( 21/ 24) -\Rocketeer\AbstractScm::Git - Methods: 100.00% ( 7/ 7) Lines: 100.00% ( 10/ 10) -\Rocketeer\Tasks::Check - Methods: 75.00% ( 6/ 8) Lines: 92.65% ( 63/ 68) -\Rocketeer\Tasks::Cleanup - Methods: 100.00% ( 2/ 2) Lines: 100.00% ( 11/ 11) -\Rocketeer\Tasks::Closure - Methods: 100.00% ( 5/ 5) Lines: 100.00% ( 9/ 9) -\Rocketeer\Tasks::CurrentRelease - Methods: 100.00% ( 1/ 1) Lines: 100.00% ( 11/ 11) -\Rocketeer\Tasks::Deploy - Methods: 40.00% ( 2/ 5) Lines: 81.40% ( 35/ 43) -\Rocketeer\Tasks::Ignite - Methods: 100.00% ( 4/ 4) Lines: 100.00% ( 20/ 20) -\Rocketeer\Tasks::Rollback - Methods: 50.00% ( 1/ 2) Lines: 61.11% ( 11/ 18) -\Rocketeer\Tasks::Setup - Methods: 50.00% ( 1/ 2) Lines: 96.30% ( 26/ 27) -\Rocketeer\Tasks::Teardown - Methods: 100.00% ( 1/ 1) Lines: 100.00% ( 7/ 7) -\Rocketeer\Tasks::Test - Methods: 100.00% ( 1/ 1) Lines: 100.00% ( 2/ 2) -\Rocketeer\Tasks::Update - Methods: 100.00% ( 1/ 1) Lines: 100.00% ( 10/ 10) -\Rocketeer\Abstracts::AbstractLocatorClass - Methods: 100.00% ( 4/ 4) Lines: 100.00% ( 19/ 19) -\Rocketeer\Abstracts::AbstractPlugin - Methods: 100.00% ( 2/ 2) Lines: 100.00% ( 5/ 5) -\Rocketeer\Abstracts::AbstractScm - Methods: 100.00% ( 3/ 3) Lines: 100.00% ( 9/ 9) -\Rocketeer\Abstracts::AbstractTask - Methods: 72.73% ( 8/11) Lines: 88.89% ( 32/ 36) -\Rocketeer\Abstracts\BashModules::Binaries - Methods: 50.00% ( 4/ 8) Lines: 89.09% ( 49/ 55) -\Rocketeer\Abstracts\BashModules::Core - Methods: 91.67% (11/12) Lines: 94.12% ( 64/ 68) -\Rocketeer\Abstracts\BashModules::Filesystem - Methods: 80.00% ( 8/10) Lines: 94.12% ( 32/ 34) -\Rocketeer\Abstracts\BashModules::Flow - Methods: 100.00% ( 6/ 6) Lines: 100.00% ( 22/ 22) -\Rocketeer\Abstracts\BashModules::AbstractScm - Methods: 66.67% ( 2/ 3) Lines: 96.88% ( 31/ 32) diff --git a/tests/_server/foobar/current/.gitkeep b/tests/_server/foobar-stub/current/.gitkeep similarity index 100% rename from tests/_server/foobar/current/.gitkeep rename to tests/_server/foobar-stub/current/.gitkeep diff --git a/tests/_meta/deployments.json b/tests/_server/foobar-stub/deployments.json similarity index 100% rename from tests/_meta/deployments.json rename to tests/_server/foobar-stub/deployments.json diff --git a/tests/_server/foobar/releases/.gitkeep b/tests/_server/foobar-stub/releases/.gitkeep similarity index 100% rename from tests/_server/foobar/releases/.gitkeep rename to tests/_server/foobar-stub/releases/.gitkeep diff --git a/tests/_server/foobar/releases/10000000000000/.gitkeep b/tests/_server/foobar-stub/releases/10000000000000/.gitkeep similarity index 100% rename from tests/_server/foobar/releases/10000000000000/.gitkeep rename to tests/_server/foobar-stub/releases/10000000000000/.gitkeep diff --git a/tests/_server/foobar/releases/15000000000000/.gitkeep b/tests/_server/foobar-stub/releases/15000000000000/.gitkeep similarity index 100% rename from tests/_server/foobar/releases/15000000000000/.gitkeep rename to tests/_server/foobar-stub/releases/15000000000000/.gitkeep diff --git a/tests/_server/foobar/releases/20000000000000/.gitkeep b/tests/_server/foobar-stub/releases/20000000000000/.gitkeep similarity index 100% rename from tests/_server/foobar/releases/20000000000000/.gitkeep rename to tests/_server/foobar-stub/releases/20000000000000/.gitkeep diff --git a/tests/_server/foobar/shared/.gitkeep b/tests/_server/foobar-stub/shared/.gitkeep similarity index 100% rename from tests/_server/foobar/shared/.gitkeep rename to tests/_server/foobar-stub/shared/.gitkeep diff --git a/tests/_server/foobar/state.json b/tests/_server/foobar-stub/state.json similarity index 100% rename from tests/_server/foobar/state.json rename to tests/_server/foobar-stub/state.json From b80412f5b9ed1af3060821d27a38b42496aab41b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 02:21:07 +0200 Subject: [PATCH 314/424] Cleanup some additional directories --- tests/TestCases/RocketeerTestCase.php | 21 +++++++++++++-------- tests/_server/foobar-stub/deployments.json | 2 +- 2 files changed, 14 insertions(+), 9 deletions(-) diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 97549dc98..312bed83d 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -43,9 +43,13 @@ public function setUp() parent::setUp(); // Setup local server - $this->customConfig = __DIR__.'/../_meta/.rocketeer'; $this->server = __DIR__.'/../_server/foobar'; - $this->deploymentsFile = __DIR__.'/../_server/foobar/deployments.json'; + $this->customConfig = $this->server.'/../.rocketeer'; + $this->deploymentsFile = $this->server.'/deployments.json'; + + // Bind dummy AbstractTask + $this->task = $this->task('Cleanup'); + $this->recreateVirtualServer(); // Bind new LocalStorage instance $this->app->bind('rocketeer.storage.local', function ($app) { @@ -53,10 +57,6 @@ public function setUp() return new LocalStorage($app, 'deployments', $folder); }); - - // Bind dummy AbstractTask - $this->task = $this->task('Cleanup'); - $this->recreateVirtualServer(); } /** @@ -81,8 +81,13 @@ protected function recreateVirtualServer() $this->home = $_SERVER['HOME']; // Cleanup files created by tests - $this->files->deleteDirectory($this->server); - $this->files->deleteDirectory($this->customConfig); + $cleanup = array( + realpath(__DIR__.'/../../.rocketeer'), + realpath(__DIR__.'/../.rocketeer'), + realpath($this->server), + realpath($this->customConfig), + ); + array_map([$this->files, 'deleteDirectory'], $cleanup); if (is_link($this->server.'/current')) { unlink($this->server.'/current'); } diff --git a/tests/_server/foobar-stub/deployments.json b/tests/_server/foobar-stub/deployments.json index 4b0a6a22b..565fc8656 100644 --- a/tests/_server/foobar-stub/deployments.json +++ b/tests/_server/foobar-stub/deployments.json @@ -1 +1 @@ -{"foo":"bar","current_release":{"production":20000000000000},"directory_separator":"\/","is_setup":true,"webuser":{"username":"www-data","group":"www-data"},"line_endings":"\n","hash":"d41d8cd98f00b204e9800998ecf8427e"} \ No newline at end of file +{"foo":"bar","directory_separator":"\/","is_setup":true,"webuser":{"username":"www-data","group":"www-data"},"line_endings":"\n"} From 6987616e372cb37c33b580b5cef3cd6fe897c28d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 02:26:44 +0200 Subject: [PATCH 315/424] Add some file docblocks --- src/Rocketeer/Binaries/Bower.php | 8 ++++++++ .../Console/Commands/StrategiesCommand.php | 13 +++++++++++++ .../Exceptions/MissingCredentialsException.php | 12 +++++++++++- src/Rocketeer/Services/StepsBuilder.php | 14 ++++++++++++++ src/Rocketeer/Tasks/Subtasks/Primer.php | 8 ++++++++ 5 files changed, 54 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Binaries/Bower.php b/src/Rocketeer/Binaries/Bower.php index e322f054c..cd805bea4 100644 --- a/src/Rocketeer/Binaries/Bower.php +++ b/src/Rocketeer/Binaries/Bower.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Binaries; use Rocketeer\Abstracts\AbstractBinary; diff --git a/src/Rocketeer/Console/Commands/StrategiesCommand.php b/src/Rocketeer/Console/Commands/StrategiesCommand.php index eff021074..84c5e0a64 100644 --- a/src/Rocketeer/Console/Commands/StrategiesCommand.php +++ b/src/Rocketeer/Console/Commands/StrategiesCommand.php @@ -1,9 +1,22 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Console\Commands; use Rocketeer\Abstracts\AbstractCommand; use Symfony\Component\Console\Helper\Table; +/** + * Lists the available options for each strategy + * + * @author Maxime Fabre + */ class StrategiesCommand extends AbstractCommand { /** diff --git a/src/Rocketeer/Exceptions/MissingCredentialsException.php b/src/Rocketeer/Exceptions/MissingCredentialsException.php index 3756a800e..52b8f5b6b 100644 --- a/src/Rocketeer/Exceptions/MissingCredentialsException.php +++ b/src/Rocketeer/Exceptions/MissingCredentialsException.php @@ -1,7 +1,17 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Exceptions; -class MissingCredentialsException extends \InvalidArgumentException +use InvalidArgumentException; + +class MissingCredentialsException extends InvalidArgumentException { // ... } diff --git a/src/Rocketeer/Services/StepsBuilder.php b/src/Rocketeer/Services/StepsBuilder.php index 4b2d125f6..e670505bb 100644 --- a/src/Rocketeer/Services/StepsBuilder.php +++ b/src/Rocketeer/Services/StepsBuilder.php @@ -1,6 +1,20 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Services; +/** + * Saves in an array methods the call signatures + * of the methods called on it + * + * @author Maxime Fabre + */ class StepsBuilder { /** diff --git a/src/Rocketeer/Tasks/Subtasks/Primer.php b/src/Rocketeer/Tasks/Subtasks/Primer.php index 658c3d7d0..691913a12 100644 --- a/src/Rocketeer/Tasks/Subtasks/Primer.php +++ b/src/Rocketeer/Tasks/Subtasks/Primer.php @@ -1,4 +1,12 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rocketeer\Tasks\Subtasks; use Rocketeer\Abstracts\AbstractTask; From d22e4618ed5bf4cca756a3ad439659dd64adbc1e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 02:28:33 +0200 Subject: [PATCH 316/424] Use Connections::getHandle --- src/Rocketeer/Services/Connections/RemoteHandler.php | 2 +- src/Rocketeer/Services/CredentialsGatherer.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index 8ef3afd60..baaef1607 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -43,7 +43,7 @@ public function connection($connection = null, $server = 0) { $name = $connection ?: $this->connections->getConnection(); $server = $server ?: $this->connections->getServer(); - $handle = $name.'#'.$server; + $handle = $this->connections->getHandle($name, $server); // Check the cache if (isset($this->active[$handle])) { diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 7d7390665..bb688f8e0 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -96,7 +96,7 @@ protected function getConnectionCredentials($connectionName, $server = null) $connection = Arr::get($connections, $connection, []); // Update connection name - $handle = !is_null($server) ? $connectionName.'#'.$server : $connectionName; + $handle = $this->connections->getHandle($connectionName, $server); // Gather credentials $credentials = $this->gatherCredentials(array( From 109211d716df33ddf10f98f1e5e0e7cedc9d617a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 02:33:00 +0200 Subject: [PATCH 317/424] Extract password/key fetching --- .../Services/CredentialsGatherer.php | 51 ++++++++++++++----- 1 file changed, 38 insertions(+), 13 deletions(-) diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index bb688f8e0..c34fa7b70 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -98,7 +98,7 @@ protected function getConnectionCredentials($connectionName, $server = null) // Update connection name $handle = $this->connections->getHandle($connectionName, $server); - // Gather credentials + // Gather common credentials $credentials = $this->gatherCredentials(array( 'host' => true, 'username' => true, @@ -109,17 +109,7 @@ protected function getConnectionCredentials($connectionName, $server = null) ), $connection, $handle); // Get password or key - if (!$credentials['password'] && !$credentials['key']) { - $types = ['key', 'password']; - $type = $this->command->askWith('No password or SSH key is set for ['.$handle.'], which would you use?', 'key', $types); - if ($type == 'key') { - $default = $this->rocketeer->getDefaultKeyPath(); - $credentials['key'] = $this->command->option('key') ?: $this->command->askWith('Please enter the full path to your key', $default); - $credentials['keyphrase'] = $this->gatherCredential($handle, 'keyphrase', 'If a keyphrase is required, provide it'); - } else { - $credentials['password'] = $this->gatherCredential($handle, 'password'); - } - } + $credentials = $this->getConnectionAuthentication($credentials, $handle); // Save credentials $this->connections->syncConnectionCredentials($connectionName, $credentials, $server); @@ -130,6 +120,41 @@ protected function getConnectionCredentials($connectionName, $server = null) ////////////////////////////// HELPERS /////////////////////////////// ////////////////////////////////////////////////////////////////////// + /** + * Smart fill-in of the key/password of a connection + * + * @param string[] $credentials + * @param string $handle + * + * @return string[] + */ + protected function getConnectionAuthentication(array $credentials, $handle) + { + // Cancel if already provided + if ($credentials['password'] || $credentials['key']) { + return $credentials; + } + + // Get which type of authentication to use + $types = ['key', 'password']; + $keyPath = $this->rocketeer->getDefaultKeyPath(); + $type = $this->command->askWith('No password or SSH key is set for ['.$handle.'], which would you use?', 'key', $types); + + // Gather the credentials for each + switch ($type) { + case 'key': + $credentials['key'] = $this->command->option('key') ?: $this->command->askWith('Please enter the full path to your key', $keyPath); + $credentials['keyphrase'] = $this->gatherCredential($handle, 'keyphrase', 'If a keyphrase is required, provide it'); + break; + + case 'password': + $credentials['password'] = $this->gatherCredential($handle, 'password'); + break; + } + + return $credentials; + } + /** * Loop through credentials and store the missing ones * @@ -137,7 +162,7 @@ protected function getConnectionCredentials($connectionName, $server = null) * @param string[] $current * @param string $handle * - * @return array + * @return string[] */ protected function gatherCredentials($credentials, $current, $handle) { From a8e7ef7fbdc673129a51d779bdfd0a16c10ff2f1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 02:47:01 +0200 Subject: [PATCH 318/424] Don't display server number if not multiserver --- .../Connections/ConnectionsHandler.php | 26 ++++++++++++++++--- .../Services/CredentialsGatherer.php | 1 + .../Connections/ConnectionsHandlerTest.php | 14 ++++++++++ tests/Services/CredentialsGathererTest.php | 6 ++--- 4 files changed, 40 insertions(+), 7 deletions(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 5ef38b55d..1f8e74f06 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -67,11 +67,17 @@ public function getHandle($connection = null, $server = null, $stage = null) $server = $server ?: $this->getServer(); $stage = $stage ?: $this->getStage(); - // Concatenate + // Filter values $handle = [$connection, $server, $stage]; - $handle = array_filter($handle, function ($value) { - return !is_null($value); - }); + if ($this->isMultiserver($connection)) { + $handle = array_filter($handle, function ($value) { + return !is_null($value); + }); + } else { + $handle = array_filter($handle); + } + + // Concatenate $handle = implode('/', $handle); return $handle; @@ -89,6 +95,18 @@ public function getServer() return $this->currentServer; } + /** + * Check if a connection is multiserver or not + * + * @param string $connection + * + * @return boolean + */ + public function isMultiserver($connection) + { + return (bool) count($this->getConnectionCredentials($connection)); + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// STAGES //////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index c34fa7b70..0979b41fc 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -147,6 +147,7 @@ protected function getConnectionAuthentication(array $credentials, $handle) $credentials['keyphrase'] = $this->gatherCredential($handle, 'keyphrase', 'If a keyphrase is required, provide it'); break; + default: case 'password': $credentials['password'] = $this->gatherCredential($handle, 'password'); break; diff --git a/tests/Services/Connections/ConnectionsHandlerTest.php b/tests/Services/Connections/ConnectionsHandlerTest.php index 1340fe489..6604f8be3 100644 --- a/tests/Services/Connections/ConnectionsHandlerTest.php +++ b/tests/Services/Connections/ConnectionsHandlerTest.php @@ -115,6 +115,20 @@ public function testFillsConnectionCredentialsHoles() $this->assertArrayHasKey('production', $connections); } + public function testCanCreateHandleForCurrent() + { + $handle = $this->connections->getHandle('foo', 2, 'staging'); + + $this->assertEquals('foo/2/staging', $handle); + } + + public function testDoesntDisplayServerNumberIfNotMultiserver() + { + $handle = $this->connections->getHandle('foo', 0, 'staging'); + + $this->assertEquals('foo/staging', $handle); + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index b048886f1..91b0c1946 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -163,8 +163,8 @@ public function testCanGetCredentialsForSpecifiedConnection() { $key = $this->rocketeer->getDefaultKeyPath(); $this->mockAnswers(array( - 'No host is set for [staging#0]' => $this->host, - 'No username is set for [staging#0]' => $this->username, + 'No host is set for [staging/0]' => $this->host, + 'No username is set for [staging/0]' => $this->username, 'If a keyphrase is required, provide it' => 'KEYPHRASE', )); @@ -174,7 +174,7 @@ public function testCanGetCredentialsForSpecifiedConnection() 'Please enter the full path to your key', $key )->andReturn($key); $this->command->shouldReceive('askWith')->with( - 'No password or SSH key is set for [staging#0], which would you use?', + 'No password or SSH key is set for [staging/0], which would you use?', 'key', ['key', 'password'] )->andReturn('key'); From 969314a7ae7ab6c5de600804ae528e74b97bab95 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 03:12:36 +0200 Subject: [PATCH 319/424] Remove default in switch case --- src/Rocketeer/Services/CredentialsGatherer.php | 1 - 1 file changed, 1 deletion(-) diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 0979b41fc..c34fa7b70 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -147,7 +147,6 @@ protected function getConnectionAuthentication(array $credentials, $handle) $credentials['keyphrase'] = $this->gatherCredential($handle, 'keyphrase', 'If a keyphrase is required, provide it'); break; - default: case 'password': $credentials['password'] = $this->gatherCredential($handle, 'password'); break; From f51bd467002398be56ae8170900bee4511ac3201 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 22:10:30 +0200 Subject: [PATCH 320/424] Move pathfinder method to a separate class --- .../AbstractDependenciesStrategy.php | 2 +- src/Rocketeer/Rocketeer.php | 114 --------------- src/Rocketeer/RocketeerServiceProvider.php | 5 + .../Services/CredentialsGatherer.php | 2 +- src/Rocketeer/Services/Pathfinder.php | 134 ++++++++++++++++++ src/Rocketeer/Services/ReleasesManager.php | 4 +- .../Services/Storages/LocalStorage.php | 2 +- .../Services/Storages/ServerStorage.php | 2 +- src/Rocketeer/Tasks/Setup.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 2 +- .../Traits/BashModules/Filesystem.php | 4 +- src/Rocketeer/Traits/BashModules/Flow.php | 4 +- src/Rocketeer/Traits/HasLocator.php | 6 +- tests/RocketeerTest.php | 81 ----------- tests/Services/CredentialsGathererTest.php | 2 +- tests/Services/PathfinderTest.php | 84 +++++++++++ tests/Services/Storages/LocalStorageTest.php | 2 +- 18 files changed, 242 insertions(+), 212 deletions(-) create mode 100644 src/Rocketeer/Services/Pathfinder.php create mode 100644 tests/Services/PathfinderTest.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 4a6dbeb1c..27c46da66 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -101,7 +101,7 @@ public function update() */ protected function hasManifest() { - $server = $this->rocketeer->getFolder('current/'.$this->manifest); + $server = $this->paths->getFolder('current/'.$this->manifest); $server = $this->bash->fileExists($server); $local = $this->app['path.base'].DS.$this->manifest; diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index f718410f8..81a22bb96 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -116,118 +116,4 @@ protected function getContextualOption($option, $type, $original = null) return $value; } - - //////////////////////////////////////////////////////////////////// - //////////////////////////////// PATHS ///////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Get a configured path - * - * @param string $path - * - * @return string - */ - public function getPath($path) - { - return $this->getOption('paths.'.$path); - } - - /** - * Replace patterns in a folder path - * - * @param string $path - * - * @return string - */ - public function replacePatterns($path) - { - $app = $this->app; - - // Replace folder patterns - return preg_replace_callback('/\{[a-z\.]+\}/', function ($match) use ($app) { - $folder = substr($match[0], 1, -1); - - if ($app->bound($folder)) { - return str_replace($app['path.base'].'/', null, $app->make($folder)); - } - - return false; - }, $path); - } - - /** - * Get the path to a folder, taking into account application name and stage - * - * @param string|null $folder - * - * @return string - */ - public function getFolder($folder = null) - { - $folder = $this->replacePatterns($folder); - - $base = $this->getHomeFolder().'/'; - $stage = $this->connections->getStage(); - if ($folder && $stage) { - $base .= $stage.'/'; - } - $folder = str_replace($base, null, $folder); - - return $base.$folder; - } - - /** - * Get the path to the root folder of the application - * - * @return string - */ - public function getHomeFolder() - { - $rootDirectory = $this->getOption('remote.root_directory'); - $rootDirectory = Str::finish($rootDirectory, '/'); - $appDirectory = $this->getOption('remote.app_directory') ?: $this->getApplicationName(); - - return $rootDirectory.$appDirectory; - } - - /** - * Get the default path for the SSH key - * - * @return string - * @throws \Exception - */ - public function getDefaultKeyPath() - { - return $this->getUserHomeFolder().'/.ssh/id_rsa'; - } - - /** - * Get the path to the Rocketeer config folder in the users home - * - * @return string - */ - public function getRocketeerConfigFolder() - { - return $this->getUserHomeFolder().'/.rocketeer'; - } - - /** - * Get the path to the users home folder - * - * @throws Exception - * @return string - */ - public function getUserHomeFolder() - { - // Get home folder if available (Unix) - if (!empty($_SERVER['HOME'])) { - return $_SERVER['HOME']; - // Else use the home drive (Windows) - } elseif (!empty($_SERVER['HOMEDRIVE']) && !empty($_SERVER['HOMEPATH'])) { - return $_SERVER['HOMEDRIVE'].$_SERVER['HOMEPATH']; - } else { - throw new Exception('Cannot determine user home directory.'); - } - } } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index e07baeb17..5b8758562 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -24,6 +24,7 @@ use Rocketeer\Services\Display\QueueTimer; use Rocketeer\Services\History\History; use Rocketeer\Services\History\LogsHandler; +use Rocketeer\Services\Pathfinder; use Rocketeer\Services\ReleasesManager; use Rocketeer\Services\Storages\LocalStorage; use Rocketeer\Services\Tasks\TasksBuilder; @@ -154,6 +155,10 @@ public function bindCoreClasses() return new Rocketeer($app); }); + $this->app->singleton('rocketeer.paths', function ($app) { + return new Pathfinder($app); + }); + $this->app->singleton('rocketeer.connections', function ($app) { return new ConnectionsHandler($app); }); diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index c34fa7b70..8875d13d8 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -137,7 +137,7 @@ protected function getConnectionAuthentication(array $credentials, $handle) // Get which type of authentication to use $types = ['key', 'password']; - $keyPath = $this->rocketeer->getDefaultKeyPath(); + $keyPath = $this->paths->getDefaultKeyPath(); $type = $this->command->askWith('No password or SSH key is set for ['.$handle.'], which would you use?', 'key', $types); // Gather the credentials for each diff --git a/src/Rocketeer/Services/Pathfinder.php b/src/Rocketeer/Services/Pathfinder.php new file mode 100644 index 000000000..73bed22e0 --- /dev/null +++ b/src/Rocketeer/Services/Pathfinder.php @@ -0,0 +1,134 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Services; + +use Exception; +use Illuminate\Support\Str; +use Rocketeer\Traits\HasLocator; + +/** + * Locates folders and paths on the server and locally + * + * @author Maxime Fabre + */ +class Pathfinder +{ + use HasLocator; + + /** + * Get a configured path + * + * @param string $path + * + * @return string + */ + public function getPath($path) + { + return $this->rocketeer->getOption('paths.'.$path); + } + + /** + * Replace patterns in a folder path + * + * @param string $path + * + * @return string + */ + public function replacePatterns($path) + { + $app = $this->app; + + // Replace folder patterns + return preg_replace_callback('/\{[a-z\.]+\}/', function ($match) use ($app) { + $folder = substr($match[0], 1, -1); + + if ($app->bound($folder)) { + return str_replace($app['path.base'].'/', null, $app->make($folder)); + } + + return false; + }, $path); + } + + /** + * Get the path to a folder, taking into account application name and stage + * + * @param string|null $folder + * + * @return string + */ + public function getFolder($folder = null) + { + $folder = $this->replacePatterns($folder); + + $base = $this->getHomeFolder().'/'; + $stage = $this->connections->getStage(); + if ($folder && $stage) { + $base .= $stage.'/'; + } + $folder = str_replace($base, null, $folder); + + return $base.$folder; + } + + /** + * Get the path to the root folder of the application + * + * @return string + */ + public function getHomeFolder() + { + $rootDirectory = $this->rocketeer->getOption('remote.root_directory'); + $rootDirectory = Str::finish($rootDirectory, '/'); + $appDirectory = $this->rocketeer->getOption('remote.app_directory') ?: $this->rocketeer->getApplicationName(); + + return $rootDirectory.$appDirectory; + } + + /** + * Get the default path for the SSH key + * + * @return string + * @throws Exception + */ + public function getDefaultKeyPath() + { + return $this->getUserHomeFolder().'/.ssh/id_rsa'; + } + + /** + * Get the path to the Rocketeer config folder in the users home + * + * @return string + */ + public function getRocketeerConfigFolder() + { + return $this->getUserHomeFolder().'/.rocketeer'; + } + + /** + * Get the path to the users home folder + * + * @throws Exception + * @return string + */ + public function getUserHomeFolder() + { + // Get home folder if available (Unix) + if (!empty($_SERVER['HOME'])) { + return $_SERVER['HOME']; + // Else use the home drive (Windows) + } elseif (!empty($_SERVER['HOMEDRIVE']) && !empty($_SERVER['HOMEPATH'])) { + return $_SERVER['HOMEDRIVE'].$_SERVER['HOMEPATH']; + } else { + throw new Exception('Cannot determine user home directory.'); + } + } +} diff --git a/src/Rocketeer/Services/ReleasesManager.php b/src/Rocketeer/Services/ReleasesManager.php index 658b7f968..322237d49 100644 --- a/src/Rocketeer/Services/ReleasesManager.php +++ b/src/Rocketeer/Services/ReleasesManager.php @@ -142,7 +142,7 @@ public function getInvalidReleases() */ public function getReleasesPath() { - return $this->rocketeer->getFolder('releases'); + return $this->paths->getFolder('releases'); } /** @@ -154,7 +154,7 @@ public function getReleasesPath() */ public function getPathToRelease($release) { - return $this->rocketeer->getFolder('releases/'.$release); + return $this->paths->getFolder('releases/'.$release); } /** diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index bf10714ff..621c5c873 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -48,7 +48,7 @@ public function __construct(Container $app, $file = 'deployments', $folder = nul // Create personal storage if necessary if (!$this->app->bound('path.storage')) { - $folder = $this->rocketeer->getRocketeerConfigFolder(); + $folder = $this->paths->getRocketeerConfigFolder(); $this->files->makeDirectory($folder, 0755, false, true); } diff --git a/src/Rocketeer/Services/Storages/ServerStorage.php b/src/Rocketeer/Services/Storages/ServerStorage.php index 779c34e54..632044fb6 100644 --- a/src/Rocketeer/Services/Storages/ServerStorage.php +++ b/src/Rocketeer/Services/Storages/ServerStorage.php @@ -42,7 +42,7 @@ public function destroy() */ public function getFilepath() { - return $this->rocketeer->getFolder($this->file.'.json'); + return $this->paths->getFolder($this->file.'.json'); } /** diff --git a/src/Rocketeer/Tasks/Setup.php b/src/Rocketeer/Tasks/Setup.php index 0fd3277bb..b1cafc236 100644 --- a/src/Rocketeer/Tasks/Setup.php +++ b/src/Rocketeer/Tasks/Setup.php @@ -58,7 +58,7 @@ public function execute() // Create confirmation message $application = $this->rocketeer->getApplicationName(); - $homeFolder = $this->rocketeer->getHomeFolder(); + $homeFolder = $this->paths->getHomeFolder(); $message = sprintf('Successfully setup "%s" at "%s"', $application, $homeFolder); return $this->explainer->success($message); diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index fa5f436bc..9213cf62d 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -100,7 +100,7 @@ public function which($binary, $fallback = null, $default = false) $location = false; $locations = array( [$this->localStorage, 'get', 'paths.'.$binary], - [$this->rocketeer, 'getPath', $binary], + [$this->paths, 'getPath', $binary], [$this, 'runSilently', 'which '.$binary], ); diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 096fbcc1b..e6cefad2d 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -188,7 +188,7 @@ public function runInFolder($folder = null, $tasks = array()) } // Prepend folder - array_unshift($tasks, 'cd '.$this->rocketeer->getFolder($folder)); + array_unshift($tasks, 'cd '.$this->paths->getFolder($folder)); return $this->run($tasks); } diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index 8fcc404fb..af3e773db 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -184,7 +184,7 @@ public function createFolder($folder = null, $recursive = false) { $recursive = $recursive ? '-p ' : null; - return $this->run('mkdir '.$recursive.$this->rocketeer->getFolder($folder)); + return $this->run('mkdir '.$recursive.$this->paths->getFolder($folder)); } /** @@ -196,7 +196,7 @@ public function createFolder($folder = null, $recursive = false) */ public function removeFolder($folder = null) { - return $this->run('rm -rf '.$this->rocketeer->getFolder($folder)); + return $this->run('rm -rf '.$this->paths->getFolder($folder)); } //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index 7a3c07f3e..b3f03448d 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -30,7 +30,7 @@ trait Flow */ public function isSetup() { - return $this->fileExists($this->rocketeer->getFolder('current')); + return $this->fileExists($this->paths->getFolder('current')); } /** @@ -92,7 +92,7 @@ public function updateSymlink($release = null) // Get path to current/ folder and latest release $currentReleasePath = $this->releasesManager->getCurrentReleasePath(); - $currentFolder = $this->rocketeer->getFolder('current'); + $currentFolder = $this->paths->getFolder('current'); return $this->symlink($currentReleasePath, $currentFolder); } diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 33d260300..2381a9659 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -32,6 +32,7 @@ * @property \Rocketeer\Services\Display\QueueExplainer explainer * @property \Rocketeer\Services\Display\QueueTimer timer * @property \Rocketeer\Services\History\History history + * @property \Rocketeer\Services\Pathfinder paths * @property \Rocketeer\Services\ReleasesManager releasesManager * @property \Rocketeer\Services\Storages\LocalStorage localStorage * @property \Rocketeer\Services\Tasks\TasksBuilder builder @@ -75,17 +76,18 @@ public function __get($key) 'console' => 'rocketeer.console', 'credentials' => 'rocketeer.credentials', 'explainer' => 'rocketeer.explainer', - 'timer' => 'rocketeer.timer', 'history' => 'rocketeer.history', 'localStorage' => 'rocketeer.storage.local', 'logs' => 'rocketeer.logs', + 'paths' => 'rocketeer.paths', 'queue' => 'rocketeer.queue', - 'remote' => 'rocketeer.remote', 'releasesManager' => 'rocketeer.releases', + 'remote' => 'rocketeer.remote', 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', 'strategy' => 'rocketeer.strategy', 'tasks' => 'rocketeer.tasks', + 'timer' => 'rocketeer.timer', ); // Replace shortcuts diff --git a/tests/RocketeerTest.php b/tests/RocketeerTest.php index 3b6d6e2e4..3922d47b8 100644 --- a/tests/RocketeerTest.php +++ b/tests/RocketeerTest.php @@ -5,46 +5,11 @@ class RocketeerTest extends RocketeerTestCase { - //////////////////////////////////////////////////////////////////// - //////////////////////////////// TESTS ///////////////////////////// - //////////////////////////////////////////////////////////////////// - public function testCanGetApplicationName() { $this->assertEquals('foobar', $this->rocketeer->getApplicationName()); } - public function testCanGetHomeFolder() - { - $this->assertEquals($this->server, $this->rocketeer->getHomeFolder()); - } - - public function testCanGetFolderWithStage() - { - $this->connections->setStage('test'); - - $this->assertEquals($this->server.'/test/current', $this->rocketeer->getFolder('current')); - } - - public function testCanGetAnyFolder() - { - $this->assertEquals($this->server.'/current', $this->rocketeer->getFolder('current')); - } - - public function testCanReplacePatternsInFolders() - { - $folder = $this->rocketeer->getFolder('{path.storage}'); - - $this->assertEquals($this->server.'/app/storage', $folder); - } - - public function testCannotReplaceUnexistingPatternsInFolders() - { - $folder = $this->rocketeer->getFolder('{path.foobar}'); - - $this->assertEquals($this->server.'/', $folder); - } - public function testCanUseRecursiveStageConfiguration() { $this->swapConfig(array( @@ -88,50 +53,4 @@ public function testRocketeerCanGuessWhichStageHesIn() $stage = Rocketeer::getDetectedStage('foobar', $path); $this->assertEquals(false, $stage); } - - public function testCanGetUserHomeFolder() - { - $_SERVER['HOME'] = '/some/folder'; - $home = $this->rocketeer->getUserHomeFolder(); - - $this->assertEquals('/some/folder', $home); - } - - public function testCanGetWindowsHomeFolder() - { - $_SERVER['HOME'] = null; - $_SERVER['HOMEDRIVE'] = 'C:'; - $_SERVER['HOMEPATH'] = '\Users\someuser'; - $home = $this->rocketeer->getUserHomeFolder(); - - $this->assertEquals('C:\Users\someuser', $home); - } - - public function testCancelsIfNoHomeFolder() - { - $this->setExpectedException('Exception'); - - $_SERVER['HOME'] = null; - $_SERVER['HOMEDRIVE'] = 'C:'; - $_SERVER['HOMEPATH'] = null; - $this->rocketeer->getUserHomeFolder(); - } - - public function testCanGetRocketeerFolder() - { - $_SERVER['HOME'] = '/some/folder'; - $rocketeer = $this->rocketeer->getRocketeerConfigFolder(); - - $this->assertEquals('/some/folder/.rocketeer', $rocketeer); - } - - public function testCanGetBoundPath() - { - $this->swapConfig(array( - 'rocketeer::paths.php' => '/bin/php', - )); - $path = $this->rocketeer->getPath('php'); - - $this->assertEquals('/bin/php', $path); - } } diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index 91b0c1946..c41029b99 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -161,7 +161,7 @@ public function testCanPassCredentialsAsFlags() public function testCanGetCredentialsForSpecifiedConnection() { - $key = $this->rocketeer->getDefaultKeyPath(); + $key = $this->paths->getDefaultKeyPath(); $this->mockAnswers(array( 'No host is set for [staging/0]' => $this->host, 'No username is set for [staging/0]' => $this->username, diff --git a/tests/Services/PathfinderTest.php b/tests/Services/PathfinderTest.php new file mode 100644 index 000000000..96a8cd514 --- /dev/null +++ b/tests/Services/PathfinderTest.php @@ -0,0 +1,84 @@ +assertEquals($this->server, $this->paths->getHomeFolder()); + } + + public function testCanGetFolderWithStage() + { + $this->connections->setStage('test'); + + $this->assertEquals($this->server.'/test/current', $this->paths->getFolder('current')); + } + + public function testCanGetAnyFolder() + { + $this->assertEquals($this->server.'/current', $this->paths->getFolder('current')); + } + + public function testCanReplacePatternsInFolders() + { + $folder = $this->paths->getFolder('{path.storage}'); + + $this->assertEquals($this->server.'/app/storage', $folder); + } + + public function testCannotReplaceUnexistingPatternsInFolders() + { + $folder = $this->paths->getFolder('{path.foobar}'); + + $this->assertEquals($this->server.'/', $folder); + } + + public function testCanGetUserHomeFolder() + { + $_SERVER['HOME'] = '/some/folder'; + $home = $this->paths->getUserHomeFolder(); + + $this->assertEquals('/some/folder', $home); + } + + public function testCanGetWindowsHomeFolder() + { + $_SERVER['HOME'] = null; + $_SERVER['HOMEDRIVE'] = 'C:'; + $_SERVER['HOMEPATH'] = '\Users\someuser'; + $home = $this->paths->getUserHomeFolder(); + + $this->assertEquals('C:\Users\someuser', $home); + } + + public function testCancelsIfNoHomeFolder() + { + $this->setExpectedException('Exception'); + + $_SERVER['HOME'] = null; + $_SERVER['HOMEDRIVE'] = 'C:'; + $_SERVER['HOMEPATH'] = null; + $this->paths->getUserHomeFolder(); + } + + public function testCanGetRocketeerFolder() + { + $_SERVER['HOME'] = '/some/folder'; + $rocketeer = $this->paths->getRocketeerConfigFolder(); + + $this->assertEquals('/some/folder/.rocketeer', $rocketeer); + } + + public function testCanGetBoundPath() + { + $this->swapConfig(array( + 'rocketeer::paths.php' => '/bin/php', + )); + $path = $this->paths->getPath('php'); + + $this->assertEquals('/bin/php', $path); + } +} diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index 9f0a216a1..fd68f26d4 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -24,7 +24,7 @@ public function testCanCreateDeploymentsFileAnywhere() new LocalStorage($this->app); - $storage = $this->rocketeer->getRocketeerConfigFolder(); + $storage = $this->paths->getRocketeerConfigFolder(); $exists = file_exists($storage); $this->files->deleteDirectory($storage); $this->assertTrue($exists); From d2eeadd0423a2bdce26a19d85626232ea26f0c0c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 22:10:40 +0200 Subject: [PATCH 321/424] Fix some namespaces in the tests --- src/Rocketeer/Rocketeer.php | 2 -- tests/Services/Connections/LocalConnectionTest.php | 2 +- tests/Services/Connections/RemoteHandlerTest.php | 2 +- tests/Tasks/Subtasks/PrimerTest.php | 2 +- tests/Traits/StepsRunnerTest.php | 2 +- 5 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Rocketeer.php b/src/Rocketeer/Rocketeer.php index 81a22bb96..5cf042732 100644 --- a/src/Rocketeer/Rocketeer.php +++ b/src/Rocketeer/Rocketeer.php @@ -9,8 +9,6 @@ */ namespace Rocketeer; -use Exception; -use Illuminate\Support\Str; use Rocketeer\Traits\HasLocator; /** diff --git a/tests/Services/Connections/LocalConnectionTest.php b/tests/Services/Connections/LocalConnectionTest.php index fd723771e..177f26fc9 100644 --- a/tests/Services/Connections/LocalConnectionTest.php +++ b/tests/Services/Connections/LocalConnectionTest.php @@ -1,5 +1,5 @@ Date: Tue, 19 Aug 2014 22:27:49 +0200 Subject: [PATCH 322/424] Work on windows path issues --- src/Rocketeer/Igniter.php | 49 +------ src/Rocketeer/RocketeerServiceProvider.php | 8 +- src/Rocketeer/Services/Pathfinder.php | 147 +++++++++++++++------ tests/Services/PathfinderTest.php | 8 ++ 4 files changed, 117 insertions(+), 95 deletions(-) diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 059d594c7..1515cd08e 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -146,39 +146,6 @@ public function updateConfiguration($folder, array $values = array()) //////////////////////////////// PATHS ///////////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Get the base path - * - * @return string - */ - public function getBasePath() - { - $base = $this->app['path.base'] ? $this->app['path.base'].'/' : ''; - $base = $this->unifySlashes($base); - - return $base; - } - - /** - * Get path to the storage folder - * - * @return string - */ - public function getStoragePath() - { - // If no path is bound, default to the Rocketeer folder - if (!$this->app->bound('path.storage')) { - return '.rocketeer'; - } - - // Unify slashes - $storage = $this->app['path.storage']; - $storage = $this->unifySlashes($storage); - $storage = str_replace($this->getBasePath(), null, $storage); - - return $storage; - } - /** * Bind the base path to the Container */ @@ -199,9 +166,9 @@ protected function bindConfiguration() // Bind path to the configuration directory if ($this->isInsideLaravel()) { $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; - $storage = $this->getStoragePath(); + $storage = $this->paths->getStoragePath(); } else { - $path = $this->getBasePath().'.rocketeer'; + $path = $this->paths->getBasePath().'.rocketeer'; $storage = $path; } @@ -277,18 +244,6 @@ protected function loadFileOrFolder($handle) } } - /** - * Unify the slashes to the UNIX mode (forward slashes) - * - * @param string $path - * - * @return string - */ - protected function unifySlashes($path) - { - return str_replace('\\', '/', $path); - } - /** * Check if this is in Laravel * diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 5b8758562..48816f6e6 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -101,6 +101,10 @@ public function provides() */ public function bindPaths() { + $this->app->singleton('rocketeer.paths', function ($app) { + return new Pathfinder($app); + }); + $this->app->bind('rocketeer.igniter', function ($app) { return new Igniter($app); }); @@ -155,10 +159,6 @@ public function bindCoreClasses() return new Rocketeer($app); }); - $this->app->singleton('rocketeer.paths', function ($app) { - return new Pathfinder($app); - }); - $this->app->singleton('rocketeer.connections', function ($app) { return new ConnectionsHandler($app); }); diff --git a/src/Rocketeer/Services/Pathfinder.php b/src/Rocketeer/Services/Pathfinder.php index 73bed22e0..a10d0daf4 100644 --- a/src/Rocketeer/Services/Pathfinder.php +++ b/src/Rocketeer/Services/Pathfinder.php @@ -22,6 +22,10 @@ class Pathfinder { use HasLocator; + ////////////////////////////////////////////////////////////////////// + //////////////////////////////// LOCAL /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** * Get a configured path * @@ -34,50 +38,6 @@ public function getPath($path) return $this->rocketeer->getOption('paths.'.$path); } - /** - * Replace patterns in a folder path - * - * @param string $path - * - * @return string - */ - public function replacePatterns($path) - { - $app = $this->app; - - // Replace folder patterns - return preg_replace_callback('/\{[a-z\.]+\}/', function ($match) use ($app) { - $folder = substr($match[0], 1, -1); - - if ($app->bound($folder)) { - return str_replace($app['path.base'].'/', null, $app->make($folder)); - } - - return false; - }, $path); - } - - /** - * Get the path to a folder, taking into account application name and stage - * - * @param string|null $folder - * - * @return string - */ - public function getFolder($folder = null) - { - $folder = $this->replacePatterns($folder); - - $base = $this->getHomeFolder().'/'; - $stage = $this->connections->getStage(); - if ($folder && $stage) { - $base .= $stage.'/'; - } - $folder = str_replace($base, null, $folder); - - return $base.$folder; - } - /** * Get the path to the root folder of the application * @@ -131,4 +91,103 @@ public function getUserHomeFolder() throw new Exception('Cannot determine user home directory.'); } } + + /** + * Get the base path + * + * @return string + */ + public function getBasePath() + { + $base = $this->app['path.base'] ? $this->app['path.base'].'/' : ''; + $base = $this->unifySlashes($base); + + return $base; + } + + /** + * Get path to the storage folder + * + * @return string + */ + public function getStoragePath() + { + // If no path is bound, default to the Rocketeer folder + if (!$this->app->bound('path.storage')) { + return '.rocketeer'; + } + + // Unify slashes + $storage = $this->app['path.storage']; + $storage = $this->unifySlashes($storage); + $storage = str_replace($this->getBasePath(), null, $storage); + + return $storage; + } + + ////////////////////////////////////////////////////////////////////// + /////////////////////////////// SERVER /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the path to a folder, taking into account application name and stage + * + * @param string|null $folder + * + * @return string + */ + public function getFolder($folder = null) + { + $folder = $this->replacePatterns($folder); + + $base = $this->getHomeFolder().'/'; + $stage = $this->connections->getStage(); + if ($folder && $stage) { + $base .= $stage.'/'; + } + $folder = str_replace($base, null, $folder); + + return $base.$folder; + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Unify the slashes to the UNIX mode (forward slashes) + * + * @param string $path + * + * @return string + */ + public function unifySlashes($path) + { + return str_replace('\\', '/', $path); + } + + /** + * Replace patterns in a folder path + * + * @param string $path + * + * @return string + */ + public function replacePatterns($path) + { + $base = $this->getBasePath(); + + // Replace folder patterns + return preg_replace_callback('/\{[a-z\.]+\}/', function ($match) use ($base) { + $folder = substr($match[0], 1, -1); + + // Replace paths from the container + if ($this->app->bound($folder)) { + $path = $this->app->make($folder); + return str_replace($base, null, $this->unifySlashes($path)); + } + + return false; + }, $path); + } } diff --git a/tests/Services/PathfinderTest.php b/tests/Services/PathfinderTest.php index 96a8cd514..96d9fb8fc 100644 --- a/tests/Services/PathfinderTest.php +++ b/tests/Services/PathfinderTest.php @@ -36,6 +36,14 @@ public function testCannotReplaceUnexistingPatternsInFolders() $this->assertEquals($this->server.'/', $folder); } + public function testCanReplacePlaceholdersOnWindows() + { + $this->app['path.base'] = 'c:\xampp\htdocs\project'; + $this->app['path.foobar'] = 'c:\xampp\htdocs\project\lol'; + + $this->assertEquals($this->server.'/lol', $this->paths->getFolder('{path.foobar}')); + } + public function testCanGetUserHomeFolder() { $_SERVER['HOME'] = '/some/folder'; From 0262a090ff5a4f48bba9dfdab416f16b57d829b3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 22:29:25 +0200 Subject: [PATCH 323/424] Move tests --- tests/IgniterTest.php | 35 ------------------------------- tests/Services/PathfinderTest.php | 35 +++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+), 35 deletions(-) diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index 2c3e74578..a1f6f7437 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -99,41 +99,6 @@ public function testCanSetCurrentApplication() $this->assertContains('foobar', file_get_contents(__DIR__.'/../.rocketeer/config.php')); } - public function testCanGetStoragePathWhenNoneBound() - { - unset($this->app['path.storage']); - - $storage = $this->igniter->getStoragePath(); - $this->assertEquals('.rocketeer', $storage); - } - - public function testCanGetStoragePathIfUnix() - { - $this->app['path.base'] = '/app'; - $this->app['path.storage'] = '/app/local/folder'; - - $storage = $this->igniter->getStoragePath(); - $this->assertEquals('local/folder', $storage); - } - - public function testCanGetStorageIfWindows() - { - $this->app['path.base'] = 'C:\Sites\app'; - $this->app['path.storage'] = 'C:\Sites\app\local\folder'; - - $storage = $this->igniter->getStoragePath(); - $this->assertEquals('local/folder', $storage); - } - - public function testCanGetStorageWhenBothForSomeReason() - { - $this->app['path.base'] = 'C:\Sites\app'; - $this->app['path.storage'] = 'C:/Sites/app/local/folder'; - - $storage = $this->igniter->getStoragePath(); - $this->assertEquals('local/folder', $storage); - } - public function testCanLoadFilesOrFolder() { $config = $this->customConfig; diff --git a/tests/Services/PathfinderTest.php b/tests/Services/PathfinderTest.php index 96d9fb8fc..5e8127a70 100644 --- a/tests/Services/PathfinderTest.php +++ b/tests/Services/PathfinderTest.php @@ -89,4 +89,39 @@ public function testCanGetBoundPath() $this->assertEquals('/bin/php', $path); } + + public function testCanGetStoragePathWhenNoneBound() + { + unset($this->app['path.storage']); + + $storage = $this->paths->getStoragePath(); + $this->assertEquals('.rocketeer', $storage); + } + + public function testCanGetStoragePathIfUnix() + { + $this->app['path.base'] = '/app'; + $this->app['path.storage'] = '/app/local/folder'; + + $storage = $this->paths->getStoragePath(); + $this->assertEquals('local/folder', $storage); + } + + public function testCanGetStorageIfWindows() + { + $this->app['path.base'] = 'C:\Sites\app'; + $this->app['path.storage'] = 'C:\Sites\app\local\folder'; + + $storage = $this->paths->getStoragePath(); + $this->assertEquals('local/folder', $storage); + } + + public function testCanGetStorageWhenBothForSomeReason() + { + $this->app['path.base'] = 'C:\Sites\app'; + $this->app['path.storage'] = 'C:/Sites/app/local/folder'; + + $storage = $this->paths->getStoragePath(); + $this->assertEquals('local/folder', $storage); + } } From a538fbbd98fb86b854f975fa9020166369e07b64 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 19 Aug 2014 23:55:10 +0200 Subject: [PATCH 324/424] Work on windows igniter --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- src/Rocketeer/Igniter.php | 61 +++++-------------- src/Rocketeer/Services/Pathfinder.php | 29 +++++++++ .../Services/Storages/LocalStorage.php | 2 +- src/Rocketeer/Traits/HasLocator.php | 18 ++++++ tests/IgniterTest.php | 5 +- tests/Tasks/IgniteTest.php | 40 +++++++++++- 7 files changed, 106 insertions(+), 51 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index c22351881..92bf8ab6e 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -145,7 +145,7 @@ protected function fireTasksQueue($tasks) // Run tasks and display timer $status = $this->time(function () use ($tasks) { - return $this->laravel['rocketeer.tasks']->run($tasks, $this); + return $this->laravel['rocketeer.queue']->run($tasks); }); // Remove command instance diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Igniter.php index 1515cd08e..5ec291658 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Igniter.php @@ -67,14 +67,16 @@ public function mergeContextualConfigurations() { // Cancel if not ignited yet $storage = $this->app['path.rocketeer.config']; - if (!is_dir($storage) || (!is_dir($storage.'/stages') && !is_dir($storage.'/connections'))) { + if (!is_dir($storage) || (!is_dir($storage.DS.'stages') && !is_dir($storage.DS.'connections'))) { return; } + // Get folders to glob + $folders = $this->paths->unifyLocalSlashes($storage.'/{stages,connections}/*'); + // Gather custom files $finder = new Finder(); - $files = $finder->in($storage.'/{stages,connections}/*')->notName('config.php')->files(); - $files = iterator_to_array($files); + $files = $finder->in($folders)->notName('config.php')->files(); // Bind their contents to the "on" array foreach ($files as $file) { @@ -89,21 +91,6 @@ public function mergeContextualConfigurations() ///////////////////////////// CONFIGURATION //////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Get the path to the configuration folder - * - * @return string - */ - public function getConfigurationPath() - { - // Return path to Laravel configuration - if ($this->isInsideLaravel()) { - return $this->app['path'].'/config/packages/anahkiasen/rocketeer'; - } - - return $this->app['path.rocketeer.config']; - } - /** * Export the configuration files * @@ -111,8 +98,9 @@ public function getConfigurationPath() */ public function exportConfiguration() { - $source = __DIR__.'/../config'; - $destination = $this->getConfigurationPath(); + $source = $this->paths->unifyLocalSlashes(__DIR__.'/../config'); + $source = realpath($source); + $destination = $this->paths->getConfigurationPath(); // Unzip configuration files $this->files->copyDirectory($source, $destination); @@ -165,19 +153,20 @@ protected function bindConfiguration() { // Bind path to the configuration directory if ($this->isInsideLaravel()) { - $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + $path = $this->paths->getConfigurationPath(); $storage = $this->paths->getStoragePath(); } else { - $path = $this->paths->getBasePath().'.rocketeer'; + $path = $this->paths->getBasePath().'.rocketeer'; + $storage = $path; } // Build paths $paths = array( 'config' => $path.'', - 'events' => $path.'/events', - 'tasks' => $path.'/tasks', - 'logs' => $storage.'/logs', + 'events' => $path.DS.'events', + 'tasks' => $path.DS.'tasks', + 'logs' => $storage.DS.'logs', ); foreach ($paths as $key => $file) { @@ -188,7 +177,7 @@ protected function bindConfiguration() } // Use configuration in current folder if none found - $realpath = realpath('.').'/'.basename($file); + $realpath = realpath('.').DS.basename($file); if (!file_exists($file) && file_exists($realpath)) { $file = $realpath; } @@ -237,28 +226,10 @@ protected function loadFileOrFolder($handle) include $file; } // Else include its contents elseif (is_dir($file)) { - $folder = glob($file.'/*.php'); + $folder = glob($file.DS.'*.php'); foreach ($folder as $file) { include $file; } } } - - /** - * Check if this is in Laravel - * - * @return boolean - */ - protected function isInsideLaravel() - { - // Return path to Laravel configuration - if ($this->app->bound('path')) { - $laravel = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; - if (file_exists($laravel)) { - return true; - } - } - - return false; - } } diff --git a/src/Rocketeer/Services/Pathfinder.php b/src/Rocketeer/Services/Pathfinder.php index a10d0daf4..b9a4bf450 100644 --- a/src/Rocketeer/Services/Pathfinder.php +++ b/src/Rocketeer/Services/Pathfinder.php @@ -105,6 +105,23 @@ public function getBasePath() return $base; } + /** + * Get the path to the configuration folder + * + * @return string + */ + public function getConfigurationPath() + { + // Return path to Laravel configuration + if ($this->isInsideLaravel()) { + $configuration = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; + } else { + $configuration = $this->app['path.rocketeer.config']; + } + + return $this->unifyLocalSlashes($configuration); + } + /** * Get path to the storage folder * @@ -166,6 +183,18 @@ public function unifySlashes($path) return str_replace('\\', '/', $path); } + /** + * Unify paths to the local DS + * + * @param string $path + * + * @return string + */ + public function unifyLocalSlashes($path) + { + return preg_replace('#(/|\\\)#', DS, $path); + } + /** * Replace patterns in a folder path * diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index 621c5c873..16529aebb 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -81,7 +81,7 @@ public function getHash() // Get the contents of the configuration folder $salt = ''; - $folder = $this->app['rocketeer.igniter']->getConfigurationPath(); + $folder = $this->paths->getConfigurationPath(); $files = $this->files->glob($folder.'/*.php'); // Remove custom files and folders diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 2381a9659..6e29a20a6 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -109,6 +109,10 @@ public function __set($key, $value) $this->app[$key] = $value; } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// COMMAND /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** * Check if the current instance has a Command bound * @@ -135,4 +139,18 @@ protected function getOption($option, $loose = false) return $loose ? Arr::get($this->command->option(), $option) : $this->command->option($option); } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// CONTEXT /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check if the class is executed inside a Laravel application + * + * @return boolean + */ + public function isInsideLaravel() + { + return $this->app->bound('path'); + } } diff --git a/tests/IgniterTest.php b/tests/IgniterTest.php index a1f6f7437..0b52f934f 100644 --- a/tests/IgniterTest.php +++ b/tests/IgniterTest.php @@ -21,6 +21,7 @@ public function setUp() $this->igniter = new Igniter($this->app); unset($this->app['path.base']); + unset($this->app['path']); } //////////////////////////////////////////////////////////////////// @@ -58,8 +59,8 @@ public function testCanBindTasksAndEventsPaths() // Create some fake files $root = realpath(__DIR__.'/../.rocketeer'); - $this->app['files']->put($root.'/events.php', ''); - $this->app['files']->makeDirectory($root.'/tasks'); + $this->files->put($root.'/events.php', ''); + $this->files->makeDirectory($root.'/tasks'); $this->igniter->bindPaths(); diff --git a/tests/Tasks/IgniteTest.php b/tests/Tasks/IgniteTest.php index 038918485..cfb11a685 100644 --- a/tests/Tasks/IgniteTest.php +++ b/tests/Tasks/IgniteTest.php @@ -1,10 +1,48 @@ app['path']); + $this->app['path.base'] = 'E:\workspace\test'; + + $provider = new RocketeerServiceProvider($this->app); + $provider->bindPaths(); + + $this->mock('files', 'Filesystem', function ($mock) { + return $mock + ->shouldReceive('files')->andReturn([]) + ->shouldReceive('glob')->andReturn([]) + ->shouldReceive('copyDirectory')->once()->with(realpath(__DIR__.'/../../src/config'), 'E:/workspace/test/.rocketeer'); + }); + + $this->pretendTask('Ignite')->execute(); + } + + public function testCanIgniteConfigurationOnWindowsInLaravel() + { + $this->app['path.base'] = 'E:\workspace\test'; + $this->app['path'] = 'E:\workspace\test\app'; + + $provider = new RocketeerServiceProvider($this->app); + $provider->bindPaths(); + + $this->mock('files', 'Filesystem', function ($mock) { + return $mock + ->shouldReceive('exists')->andReturn(true) + ->shouldReceive('files')->andReturn([]) + ->shouldReceive('glob')->andReturn([]) + ->shouldReceive('copyDirectory')->once()->with(realpath(__DIR__.'/../../src/config'), 'E:/workspace/test/app/config/packages/anahkiasen/rocketeer'); + }); + + $this->pretendTask('Ignite')->execute(); + } + public function testCanIgniteConfigurationOutsideLaravel() { $command = $this->getCommand(array('ask' => 'foobar')); @@ -12,7 +50,6 @@ public function testCanIgniteConfigurationOutsideLaravel() $server = $this->server; $this->mock('rocketeer.igniter', 'Igniter', function ($mock) use ($server) { return $mock - ->shouldReceive('getConfigurationPath')->twice() ->shouldReceive('exportConfiguration')->once()->andReturn($server) ->shouldReceive('updateConfiguration')->once()->with($server, array( 'connection' => 'production', @@ -34,7 +71,6 @@ public function testCanIgniteConfigurationInLaravel() $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; $this->mock('rocketeer.igniter', 'Igniter', function ($mock) use ($path) { return $mock - ->shouldReceive('getConfigurationPath')->twice() ->shouldReceive('exportConfiguration')->never() ->shouldReceive('updateConfiguration')->once()->with($path, array( 'connection' => 'production', From 770c46561072bfcbaedbe72a56d0452155f4fb12 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 00:12:19 +0200 Subject: [PATCH 325/424] Fix #249 - Ignite command not running without preset connection --- src/Rocketeer/Abstracts/AbstractCommand.php | 24 ++++++++++++------- .../Console/Commands/IgniteCommand.php | 13 ++++++++++ 2 files changed, 29 insertions(+), 8 deletions(-) create mode 100644 src/Rocketeer/Console/Commands/IgniteCommand.php diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 92bf8ab6e..b1c78479c 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -21,6 +21,14 @@ */ abstract class AbstractCommand extends Command { + /** + * Whether the command's task should be built + * into a pipeline or run straight + * + * @type boolean + */ + protected $straight = false; + /** * the task to execute on fire * @@ -138,16 +146,16 @@ protected function fireTasksQueue($tasks) $this->laravel['rocketeer.credentials']->getServerCredentials(); $this->laravel['rocketeer.credentials']->getRepositoryCredentials(); - // Convert tasks to array if necessary - if (!is_array($tasks)) { - $tasks = array($tasks); + if ($this->straight) { + // If we only have a single task, run it + $status = $this->laravel['rocketeer.builder']->buildTask($tasks)->fire(); + } else { + // Run tasks and display timer + $status = $this->time(function () use ($tasks) { + return $this->laravel['rocketeer.queue']->run($tasks); + }); } - // Run tasks and display timer - $status = $this->time(function () use ($tasks) { - return $this->laravel['rocketeer.queue']->run($tasks); - }); - // Remove command instance unset($this->laravel['rocketeer.command']); diff --git a/src/Rocketeer/Console/Commands/IgniteCommand.php b/src/Rocketeer/Console/Commands/IgniteCommand.php new file mode 100644 index 000000000..2ec3f99c4 --- /dev/null +++ b/src/Rocketeer/Console/Commands/IgniteCommand.php @@ -0,0 +1,13 @@ + Date: Wed, 20 Aug 2014 01:41:47 +0200 Subject: [PATCH 326/424] Work on README --- README.md | 49 ++++++++++++++++++++++++++++++++----------------- 1 file changed, 32 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index 876fb9841..14796c357 100644 --- a/README.md +++ b/README.md @@ -8,13 +8,27 @@ [![Dependency Status](https://www.versioneye.com/user/projects/53f1c65f13bb0677b1000744/badge.svg?style=flat)](https://www.versioneye.com/user/projects/53f1c65f13bb0677b1000744) [![Support via Gittip](http://img.shields.io/gittip/Anahkiasen.svg?style=flat)](https://www.gittip.com/Anahkiasen/) -**Rocketeer** is a task runner and deployment package for the PHP world. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. +**Rocketeer** is a modern PHP task runner and deployment package. It is inspired by the [Laravel Framework](http://laravel.com/) philosophy and thus aims to be fast, elegant, and more importantly easy to use. + +Like the latter, emphasis is put on smart defaults and modern development. While it is coded in PHP, it can deploy any project from small HTML/CSS websites to large Rails applications. + +## Main features + +- **Versatile**, support for multiple connections, multiserver connections, multiple stages per server, etc. +- **Fast**, queue tasks and run them in parallel across all your servers and stages +- **Modulable**, not only can you add custom tasks and components, every core part of Rocketeer can be hot swapped, extended, hacked to bits, etc. +- **Preconfigured**, tired of defining the same routines again and again ? Rocketeer is made for modern development and comes with smart defaults and built-in tasks such as installing your application's dependencies +- **Powerful**, releases management, server checks, rollbacks, etc. Every feature you'd expect from a deployment tool is there ## Installation -The easiest way is to get the latest compiled version [from the website](http://rocketeer.autopergamene.eu/versions/rocketeer.phar), put it at the root of the project you want to deploy, and hit `php rocketeer.phar ignite`. You'll get asked a series of questions that should get you up and running in no time. +The fastest way is to grab the binary: + +```bash +curl http://rocketeer.autopergamene.eu/versions/rocketeer.phar > /usr/local/bin/rocketeer && chmod 755 /usr/local/bin/rocketeer +``` -Rocketeer also integrates nicely with the Laravel framework, for that refer to the [Getting Started](https://github.com/rocketeers/rocketeer/wiki/Getting-started) pages of the documentation. +More ways to setup Rocketeer can be found in the [official documentation](http://rocketeer.autopergamene.eu/#/docs/I-Introduction/Getting-started). ## Usage @@ -22,19 +36,20 @@ The available commands in Rocketeer are : ``` $ php rocketeer - check Check if the server is ready to receive the application - cleanup Clean up old releases from the server - current Display what the current release is - deploy Deploy the website. - flush Flushes Rocketeer's cache of credentials - help Displays help for a command - ignite Creates Rocketeer's configuration - list Lists commands - rollback Rollback to the previous release, or to a specific one - setup Set up the remote server for deployment - teardown Remove the remote applications and existing caches - test Run the tests on the server and displays the output - update Update the remote server without doing a new release. + check Check if the server is ready to receive the application + cleanup Clean up old releases from the server + current Display what the current release is + deploy Deploys the website + flush Flushes Rocketeer's cache of credentials + help Displays help for a command + ignite Creates Rocketeer's configuration + list Lists commands + rollback Rollback to the previous release, or to a specific one + setup Set up the remote server for deployment + strategies Lists the available options for each strategy + teardown Remove the remote applications and existing caches + test Run the tests on the server and displays the output + update Update the remote server without doing a new release ``` ## Testing @@ -72,4 +87,4 @@ That's a question that's been asked to me, why not simply use Capistrano ? I've But, it remains a Ruby package and one that's tightly coupled to Rails in some ways; Rocketeer makes it so that you don't have Ruby files hanging around your app. That way you configure it once and can use it wherever you want in the realm of your application, even outside of the deploy routine. It's also meant to be a lot easier to comprehend, for first-time users or novices, Capistrano is a lot to take at once – Rocketeer aims to be as simple as possible by providing smart defaults and speeding up the time between installing it and first hitting `deploy`. -It's also more thought out for the PHP world – although you can configure Capistrano to run Composer and PHPUnit, that's not something it expects from the get go, while those tasks that are a part of every PHP developer are integrated in Rocketeer's core deploy process. +It's also more thought out for the PHP world – although you can configure Capistrano to run Composer and PHPUnit, that's not something it expects from the get go, while those tasks that are a part of every developer are integrated in Rocketeer's core deploy process. From 107430841cdefc66f2d77c0553c42f9d78649a36 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 02:26:40 +0200 Subject: [PATCH 327/424] Work on decoupling Check --- .../AbstractDependenciesStrategy.php | 12 +- .../Strategies/CheckStrategyInterface.php | 35 +++ .../Strategies/Check/PhpStrategy.php | 245 ++++++++++++++++++ src/Rocketeer/Tasks/Check.php | 233 +++-------------- src/config/strategies.php | 9 +- 5 files changed, 328 insertions(+), 206 deletions(-) create mode 100644 src/Rocketeer/Interfaces/Strategies/CheckStrategyInterface.php create mode 100644 src/Rocketeer/Strategies/Check/PhpStrategy.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 27c46da66..703e306e8 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -91,7 +91,7 @@ public function update() } ////////////////////////////////////////////////////////////////////// - ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////// MANIFEST ////////////////////////////// ////////////////////////////////////////////////////////////////////// /** @@ -99,7 +99,7 @@ public function update() * * @return bool */ - protected function hasManifest() + public function hasManifest() { $server = $this->paths->getFolder('current/'.$this->manifest); $server = $this->bash->fileExists($server); @@ -110,6 +110,14 @@ protected function hasManifest() return $local || $server; } + /** + * @return string + */ + public function getManifest() + { + return $this->manifest; + } + /** * Get an instance of the Binary * diff --git a/src/Rocketeer/Interfaces/Strategies/CheckStrategyInterface.php b/src/Rocketeer/Interfaces/Strategies/CheckStrategyInterface.php new file mode 100644 index 000000000..6e297ac8c --- /dev/null +++ b/src/Rocketeer/Interfaces/Strategies/CheckStrategyInterface.php @@ -0,0 +1,35 @@ +app = $app; + $this->manager = $this->builder->buildStrategy('Dependencies', 'Composer'); + } + + /** + * @return \Rocketeer\Strategies\Dependencies\ComposerStrategy + */ + public function getManager() + { + return $this->manager; + } + + /** + * @return string + */ + public function getLanguage() + { + return $this->language; + } + + ////////////////////////////////////////////////////////////////////// + /////////////////////////////// CHECKS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check that the PM that'll install + * the app's dependencies is present + * + * @return boolean + */ + public function manager() + { + return $this->manager->isExecutable(); + } + + /** + * Check that the language used by the + * application is at the required version + * + * @return boolean + */ + public function language() + { + $required = null; + + // Get the minimum PHP version of the application + $composer = $this->app['path.base'].DS.$this->manager->getManifest(); + if ($this->app['files']->exists($composer)) { + $composer = $this->app['files']->get($composer); + $composer = json_decode($composer, true); + + // Strip versions of constraints + $required = (string) Arr::get($composer, 'require.php'); + $required = preg_replace('/>=/', '', $required); + } + + // Cancel if no PHP version found + if (!$required) { + return true; + } + + $version = $this->bash->runLast($this->php()->version()); + + return version_compare($version, $required, '>='); + } + + /** + * Check for the required extensions + * + * @return array + */ + public function extensions() + { + $extensions = array( + 'mcrypt' => ['checkPhpExtension', 'mcrypt'], + 'database' => ['checkDatabaseDriver', $this->app['config']->get('database.default')], + 'cache' => ['checkCacheDriver', $this->app['config']->get('cache.driver')], + 'session' => ['checkCacheDriver', $this->app['config']->get('session.driver')], + ); + + // Check PHP extensions + $errors = []; + foreach ($extensions as $check) { + list ($method, $extension) = $check; + + if (!$this->$method($extension)) { + $errors[] = $extension; + } + } + + return $errors; + } + + /** + * Check for the required drivers + * + * @return array + */ + public function drivers() + { + return []; + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check the presence of the correct database PHP extension + * + * @param string $database + * + * @return boolean + */ + public function checkDatabaseDriver($database) + { + switch ($database) { + case 'sqlite': + return $this->checkPhpExtension('pdo_sqlite'); + + case 'mysql': + return $this->checkPhpExtension('mysql') && $this->checkPhpExtension('pdo_mysql'); + + default: + return true; + } + } + + /** + * Check the presence of the correct cache PHP extension + * + * @param string $cache + * + * @return boolean|string + */ + public function checkCacheDriver($cache) + { + switch ($cache) { + case 'memcached': + case 'apc': + return $this->checkPhpExtension($cache); + + case 'redis': + return $this->which('redis-server'); + + default: + return true; + } + } + + /** + * Check the presence of a PHP extension + * + * @param string $extension The extension + * + * @return boolean + */ + public function checkPhpExtension($extension) + { + // Check for HHVM and built-in extensions + if ($this->php()->isHhvm()) { + $this->extensions = array( + '_hhvm', + 'apache', + 'asio', + 'bcmath', + 'bz2', + 'ctype', + 'curl', + 'debugger', + 'fileinfo', + 'filter', + 'gd', + 'hash', + 'hh', + 'iconv', + 'icu', + 'imagick', + 'imap', + 'json', + 'mailparse', + 'mcrypt', + 'memcache', + 'memcached', + 'mysql', + 'odbc', + 'openssl', + 'pcre', + 'phar', + 'reflection', + 'session', + 'soap', + 'std', + 'stream', + 'thrift', + 'url', + 'wddx', + 'xdebug', + 'zip', + 'zlib', + ); + } + + // Get the PHP extensions available + if (!$this->extensions) { + $this->extensions = (array) $this->bash->run($this->php()->extensions(), false, true); + } + + return in_array($extension, $this->extensions); + } +} diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index ee231288b..59cd9d1b9 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Tasks; -use Illuminate\Support\Arr; use Rocketeer\Abstracts\AbstractTask; /** @@ -19,12 +18,6 @@ */ class Check extends AbstractTask { - /** - * The PHP extensions loaded on server - * - * @var array - */ - protected $extensions = array(); /** * A description of what the task does @@ -47,22 +40,41 @@ class Check extends AbstractTask */ public function execute() { - $errors = array(); - $checks = $this->getChecks(); + $check = $this->getStrategy('Check'); + $errors = []; + + // Check the depoy strategy + if ($this->rocketeer->getOption('strategies.deploy') !== 'sync' && !$this->checkScm()) { + $errors[] = $this->scm->getBinary().' could not be found'; + } - foreach ($checks as $check) { - list($check, $error) = $check; + // Check package manager + $manager = class_basename($check->getManager()); + $manager = str_replace('Strategy', null, $manager); + $this->explainer->line('Checking presence of '.$manager); + if (!$check->manager()) { + $errors[] = sprintf('The %s package manager could not be found', $manager); + } - $argument = null; - if (is_array($error)) { - $argument = $error[0]; - $error = $error[1]; - } + // Check language + $language = $check->getLanguage(); + $this->explainer->line('Checking '.$language. ' version'); + if (!$check->language()) { + $errors[] = $language.' is not at the required version'; + } - // If the check fail, print an error message - if (!$this->$check($argument)) { - $errors[] = $error; - } + // Check extensions + $this->explainer->line('Checking presence of required extensions'); + $extensions = $check->extensions(); + if (!empty($extensions)) { + $errors[] = 'The following extensions could not be found: '.implode(', ', $extensions); + } + + // Check drivers + $this->explainer->line('Checking presence of required drivers'); + $drivers = $check->drivers(); + if (!empty($drivers)) { + $errors[] = 'The following drivers could not be found: '.implode(', ', $drivers); } // Return false if any error @@ -74,29 +86,6 @@ public function execute() $this->explainer->line('Your server is ready to deploy'); } - /** - * Get the checks to execute - * - * @return array - */ - protected function getChecks() - { - $extension = 'The %s extension does not seem to be loaded on the server'; - $database = $this->app['config']->get('database.default'); - $cache = $this->app['config']->get('cache.driver'); - $session = $this->app['config']->get('session.driver'); - - return array( - ['checkScm', $this->scm->getBinary().' could not be found'], - ['checkPhpVersion', 'The version of PHP on the server does not match Laravel\'s requirements'], - ['checkComposer', 'Composer does not seem to be present on the server'], - ['checkPhpExtension', ['mcrypt', sprintf($extension, 'mcrypt')]], - ['checkDatabaseDriver', [$database, sprintf($extension, $database)]], - ['checkCacheDriver', [$cache, sprintf($extension, $cache)]], - ['checkCacheDriver', [$session, sprintf($extension, $session)]], - ); - } - //////////////////////////////////////////////////////////////////// /////////////////////////////// CHECKS ///////////////////////////// //////////////////////////////////////////////////////////////////// @@ -114,162 +103,4 @@ public function checkScm() return $this->getConnection()->status() == 0; } - - /** - * Check if Composer is on the server - * - * @return boolean|string - */ - public function checkComposer() - { - $composer = $this->app['path.base'].DIRECTORY_SEPARATOR.'composer.json'; - if (!file_exists($composer)) { - return true; - } - - $this->explainer->line('Checking presence of Composer'); - - return $this->composer()->getBinary(); - } - - /** - * Check if the server is ready to support PHP - * - * @return boolean - */ - public function checkPhpVersion() - { - $required = null; - - // Get the minimum PHP version of the application - $composer = $this->app['path.base'].'/composer.json'; - if ($this->app['files']->exists($composer)) { - $composer = $this->app['files']->get($composer); - $composer = json_decode($composer, true); - - // Strip versions of constraints - $required = (string) Arr::get($composer, 'require.php'); - $required = preg_replace('/>=/', '', $required); - } - - // Cancel if no PHP version found - if (!$required) { - return true; - } - - $this->command->info('Checking PHP version'); - $version = $this->bash->runLast($this->php()->version()); - - return version_compare($version, $required, '>='); - } - - //////////////////////////////////////////////////////////////////// - /////////////////////////////// HELPERS //////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Check the presence of the correct database PHP extension - * - * @param string $database - * - * @return boolean - */ - public function checkDatabaseDriver($database) - { - switch ($database) { - case 'sqlite': - return $this->checkPhpExtension('pdo_sqlite'); - - case 'mysql': - return $this->checkPhpExtension('mysql') && $this->checkPhpExtension('pdo_mysql'); - - default: - return true; - } - } - - /** - * Check the presence of the correct cache PHP extension - * - * @param string $cache - * - * @return boolean|string - */ - public function checkCacheDriver($cache) - { - switch ($cache) { - case 'memcached': - case 'apc': - return $this->checkPhpExtension($cache); - - case 'redis': - return $this->which('redis-server'); - - default: - return true; - } - } - - /** - * Check the presence of a PHP extension - * - * @param string $extension The extension - * - * @return boolean - */ - public function checkPhpExtension($extension) - { - $this->explainer->line('Checking presence of '.$extension.' extension'); - - // Check for HHVM and built-in extensions - if ($this->php()->isHhvm()) { - $this->extensions = array( - '_hhvm', - 'apache', - 'asio', - 'bcmath', - 'bz2', - 'ctype', - 'curl', - 'debugger', - 'fileinfo', - 'filter', - 'gd', - 'hash', - 'hh', - 'iconv', - 'icu', - 'imagick', - 'imap', - 'json', - 'mailparse', - 'mcrypt', - 'memcache', - 'memcached', - 'mysql', - 'odbc', - 'openssl', - 'pcre', - 'phar', - 'reflection', - 'session', - 'soap', - 'std', - 'stream', - 'thrift', - 'url', - 'wddx', - 'xdebug', - 'zip', - 'zlib', - ); - } - - // Get the PHP extensions available - if (!$this->extensions) { - $this->extensions = (array) $this->bash->run($this->php()->extensions(), false, true); - } - - return in_array($extension, $this->extensions); - } } diff --git a/src/config/strategies.php b/src/config/strategies.php index e8a18c268..63c280638 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -10,6 +10,9 @@ // execute various core parts of your deployment's flow ////////////////////////////////////////////////////////////////////// + // Which strategy to use to check the server + 'check' => 'Php', + // Which strategy to use to create a new release 'deploy' => 'Clone', @@ -25,16 +28,16 @@ // Execution hooks ////////////////////////////////////////////////////////////////////// - 'composer' => array( + 'composer' => array( 'install' => function (Composer $composer, $task) { return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); }, - 'update' => function (Composer $composer) { + 'update' => function (Composer $composer) { return $composer->update(); }, ), - 'primer' => function (Primer $task) { + 'primer' => function (Primer $task) { return array( // $task->executeTask('Test'), // $task->binary('grunt')->execute('lint'), From db354a8ac26caefaaf8b5d472b9797683b538e71 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 02:38:35 +0200 Subject: [PATCH 328/424] Update tests --- tests/Strategies/Check/PhpTest.php | 62 ++++++++++++++++++++++++++++++ tests/Tasks/CheckTest.php | 41 ++------------------ 2 files changed, 65 insertions(+), 38 deletions(-) create mode 100644 tests/Strategies/Check/PhpTest.php diff --git a/tests/Strategies/Check/PhpTest.php b/tests/Strategies/Check/PhpTest.php new file mode 100644 index 000000000..8bad7b3ac --- /dev/null +++ b/tests/Strategies/Check/PhpTest.php @@ -0,0 +1,62 @@ +strategy = $this->builder->buildStrategy('Check', 'Php'); + } + + public function testCanCheckPhpVersion() + { + $this->mock('files', 'Filesystem', function ($mock) { + return $mock + ->shouldReceive('put') + ->shouldReceive('glob')->andReturn(array()) + ->shouldReceive('exists')->andReturn(true) + ->shouldReceive('get')->andReturn('{"require":{"php":">=5.3.0"}}'); + }); + $this->assertTrue($this->strategy->language()); + + // This is is going to come bite me in the ass in 10 years + $this->mock('files', 'Filesystem', function ($mock) { + return $mock + ->shouldReceive('put') + ->shouldReceive('glob')->andReturn(array()) + ->shouldReceive('exists')->andReturn(true) + ->shouldReceive('get')->andReturn('{"require":{"php":">=5.9.0"}}'); + }); + $this->assertFalse($this->strategy->language()); + } + + public function testCanCheckPhpExtensions() + { + $this->swapConfig(array( + 'database.default' => 'sqlite', + 'cache.driver' => 'redis', + 'session.driver' => 'apc', + )); + + $this->strategy->extensions(); + + $this->assertHistory(['{php} -m']); + } + + public function testCanCheckForHhvmExtensions() + { + $this->app['rocketeer.remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); + $exists = $this->strategy->checkPhpExtension('_hhvm'); + + $this->assertTrue($exists); + } +} diff --git a/tests/Tasks/CheckTest.php b/tests/Tasks/CheckTest.php index a0e1a0f27..e79292366 100644 --- a/tests/Tasks/CheckTest.php +++ b/tests/Tasks/CheckTest.php @@ -5,7 +5,7 @@ class CheckTest extends RocketeerTestCase { - public function testCanDoBasicCheck() + public function testCanCheckScmVersionIfRequired() { $this->assertTaskHistory('Check', array( 'git --version', @@ -13,49 +13,14 @@ public function testCanDoBasicCheck() )); } - public function testCanCheckPhpVersion() - { - $check = new Check($this->app); - - $this->mock('files', 'Filesystem', function ($mock) { - return $mock - ->shouldReceive('put') - ->shouldReceive('glob')->andReturn(array()) - ->shouldReceive('exists')->andReturn(true) - ->shouldReceive('get')->andReturn('{"require":{"php":">=5.3.0"}}'); - }); - $this->assertTrue($check->checkPhpVersion()); - - // This is is going to come bite me in the ass in 10 years - $this->mock('files', 'Filesystem', function ($mock) { - return $mock - ->shouldReceive('put') - ->shouldReceive('glob')->andReturn(array()) - ->shouldReceive('exists')->andReturn(true) - ->shouldReceive('get')->andReturn('{"require":{"php":">=5.9.0"}}'); - }); - $this->assertFalse($check->checkPhpVersion()); - } - - public function testCanCheckPhpExtensions() + public function testSkipsScmCheckIfNotRequired() { $this->swapConfig(array( - 'database.default' => 'sqlite', - 'cache.driver' => 'redis', - 'session.driver' => 'apc', + 'rocketeer::strategies.deploy' => 'sync', )); $this->assertTaskHistory('Check', array( - 'git --version', '{php} -m', )); } - - public function testCanCheckForHhvmExtensions() - { - $this->app['rocketeer.remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); - $exists = $this->task('Check')->checkPhpExtension('_hhvm'); - - $this->assertTrue($exists); - } } From a959a1f01edd5f52e24179644ef1de5bff91e871 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 02:40:30 +0200 Subject: [PATCH 329/424] Add AbstractCheckStrategy --- .../Strategies/AbstractCheckStrategy.php | 48 +++++++++++++++++++ .../Strategies/Check/PhpStrategy.php | 35 +------------- 2 files changed, 50 insertions(+), 33 deletions(-) create mode 100644 src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php new file mode 100644 index 000000000..2bac73aba --- /dev/null +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -0,0 +1,48 @@ +manager; + } + + /** + * @return string + */ + public function getLanguage() + { + return $this->language; + } + + ////////////////////////////////////////////////////////////////////// + /////////////////////////////// CHECKS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check that the PM that'll install + * the app's dependencies is present + * + * @return boolean + */ + public function manager() + { + return $this->manager->isExecutable(); + } +} diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index cce525c85..260b5b1af 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -3,16 +3,12 @@ use Illuminate\Container\Container; use Illuminate\Support\Arr; +use Rocketeer\Abstracts\Strategies\AbstractCheckStrategy; use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\CheckStrategyInterface; -class PhpStrategy extends AbstractStrategy implements CheckStrategyInterface +class PhpStrategy extends AbstractCheckStrategy implements CheckStrategyInterface { - /** - * @type \Rocketeer\Strategies\Dependencies\ComposerStrategy - */ - protected $manager; - /** * The language of the strategy * @@ -36,37 +32,10 @@ public function __construct(Container $app) $this->manager = $this->builder->buildStrategy('Dependencies', 'Composer'); } - /** - * @return \Rocketeer\Strategies\Dependencies\ComposerStrategy - */ - public function getManager() - { - return $this->manager; - } - - /** - * @return string - */ - public function getLanguage() - { - return $this->language; - } - ////////////////////////////////////////////////////////////////////// /////////////////////////////// CHECKS /////////////////////////////// ////////////////////////////////////////////////////////////////////// - /** - * Check that the PM that'll install - * the app's dependencies is present - * - * @return boolean - */ - public function manager() - { - return $this->manager->isExecutable(); - } - /** * Check that the language used by the * application is at the required version From 031ad6c1c30d9b4a9eee9e4a62aed9dab37b1cc5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 13:50:21 +0200 Subject: [PATCH 330/424] Work on Ruby strategy --- .../Strategies/Check/PhpStrategy.php | 6 +- .../Strategies/Check/RubyStrategy.php | 89 +++++++++++++++++++ src/config/remote.php | 4 +- 3 files changed, 94 insertions(+), 5 deletions(-) create mode 100644 src/Rocketeer/Strategies/Check/RubyStrategy.php diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index 260b5b1af..0a791bd28 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -48,8 +48,8 @@ public function language() // Get the minimum PHP version of the application $composer = $this->app['path.base'].DS.$this->manager->getManifest(); - if ($this->app['files']->exists($composer)) { - $composer = $this->app['files']->get($composer); + if ($this->files->exists($composer)) { + $composer = $this->files->get($composer); $composer = json_decode($composer, true); // Strip versions of constraints @@ -62,7 +62,7 @@ public function language() return true; } - $version = $this->bash->runLast($this->php()->version()); + $version = $this->php()->runLast('version'); return version_compare($version, $required, '>='); } diff --git a/src/Rocketeer/Strategies/Check/RubyStrategy.php b/src/Rocketeer/Strategies/Check/RubyStrategy.php new file mode 100644 index 000000000..1364232cc --- /dev/null +++ b/src/Rocketeer/Strategies/Check/RubyStrategy.php @@ -0,0 +1,89 @@ +app = $app; + $this->manager = $this->builder->buildStrategy('Dependencies', 'Bundler'); + } + + ////////////////////////////////////////////////////////////////////// + /////////////////////////////// CHECKS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Check that the language used by the + * application is at the required version + * + * @return boolean + */ + public function language() + { + $required = null; + + // Get the minimum PHP version of the application + $gemfile = $this->app['path.base'].DS.$this->manager->getManifest(); + if ($this->app['files']->exists($gemfile)) { + $gemfile = $this->files->get($gemfile); + + // Strip versions of constraints + preg_match('/ruby \'(.+)\'/', $gemfile, $matches); + $required = Arr::get($matches, 1); + } + + // Cancel if no PHP version found + if (!$required) { + return true; + } + + $version = $this->binary('ruby')->run('--version'); + $version = preg_replace('/ruby ([0-9\.]+)p?.+/', '$1', $version); + + return version_compare($version, $required, '>='); + } + + /** + * Check for the required extensions + * + * @return array + */ + public function extensions() + { + return []; + } + + /** + * Check for the required drivers + * + * @return array + */ + public function drivers() + { + return []; + } +} diff --git a/src/config/remote.php b/src/config/remote.php index f81bdc322..e2a026261 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -41,9 +41,9 @@ 'shell' => false, // An array of commands to run under shell - 'shelled' => ['npm ', 'bundle ', 'grunt'], + 'shelled' => ['ruby', 'npm ', 'bundle ', 'grunt'], - // Permissions + // Permissions$ //////////////////////////////////////////////////////////////////// 'permissions' => array( From 6ee35dcef70f4f81f7e3f1c029417a89f3d0b3a9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 14:04:27 +0200 Subject: [PATCH 331/424] Work on package managers --- .../Abstracts/AbstractPackageManager.php | 52 ++++++++++++++++ .../Strategies/AbstractCheckStrategy.php | 4 +- .../AbstractDependenciesStrategy.php | 61 ++++--------------- .../Binaries/{ => PackageManagers}/Bower.php | 13 +++- .../Binaries/PackageManagers/Bundler.php | 36 +++++++++++ .../{ => PackageManagers}/Composer.php | 13 +++- .../Binaries/PackageManagers/Npm.php | 36 +++++++++++ .../Strategies/Check/PhpStrategy.php | 6 +- .../Strategies/Check/RubyStrategy.php | 12 ++-- .../Strategies/Dependencies/BowerStrategy.php | 7 --- .../Dependencies/BundlerStrategy.php | 7 --- .../Dependencies/ComposerStrategy.php | 7 --- .../Strategies/Dependencies/NpmStrategy.php | 7 --- src/Rocketeer/Traits/BashModules/Binaries.php | 16 +++-- src/config/strategies.php | 2 +- tests/Binaries/ComposerTest.php | 1 + .../Dependencies/BowerStrategyTest.php | 2 +- 17 files changed, 180 insertions(+), 102 deletions(-) create mode 100644 src/Rocketeer/Abstracts/AbstractPackageManager.php rename src/Rocketeer/Binaries/{ => PackageManagers}/Bower.php (64%) create mode 100644 src/Rocketeer/Binaries/PackageManagers/Bundler.php rename src/Rocketeer/Binaries/{ => PackageManagers}/Composer.php (73%) create mode 100644 src/Rocketeer/Binaries/PackageManagers/Npm.php diff --git a/src/Rocketeer/Abstracts/AbstractPackageManager.php b/src/Rocketeer/Abstracts/AbstractPackageManager.php new file mode 100644 index 000000000..7b9414b68 --- /dev/null +++ b/src/Rocketeer/Abstracts/AbstractPackageManager.php @@ -0,0 +1,52 @@ +paths->getFolder('current/'.$this->manifest); + $server = $this->bash->fileExists($server); + + $local = $this->app['path.base'].DS.$this->manifest; + $local = $this->files->exists($local); + + return $local || $server; + } + + /** + * Get the contents of the manifest file + * + * @return string|null + * @throws \Illuminate\Filesystem\FileNotFoundException + */ + public function getManifestContents() + { + $manifest = $this->app['path.base'].DS.$this->manifest; + if ($this->files->exists($manifest)) { + return $this->files->get($manifest); + } + + return null; + } + + /** + * @return string + */ + public function getManifest() + { + return $this->manifest; + } +} diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php index 2bac73aba..b30e0af10 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -4,7 +4,7 @@ class AbstractCheckStrategy extends AbstractStrategy { /** - * @type \Rocketeer\Strategies\Dependencies\ComposerStrategy + * @type \Rocketeer\Abstracts\AbstractPackageManager */ protected $manager; @@ -16,7 +16,7 @@ class AbstractCheckStrategy extends AbstractStrategy protected $language; /** - * @return \Rocketeer\Strategies\Dependencies\ComposerStrategy + * @return \Rocketeer\Abstracts\AbstractPackageManager */ public function getManager() { diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 703e306e8..67c79b890 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -18,13 +18,6 @@ */ abstract class AbstractDependenciesStrategy extends AbstractStrategy { - /** - * The name of the manifest file to look for - * - * @type string - */ - protected $manifest; - /** * The name of the binary * @@ -35,7 +28,7 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy /** * The package manager instance * - * @type \Rocketeer\Abstracts\AbstractBinary + * @type \Rocketeer\Abstracts\AbstractPackageManager */ protected $manager; @@ -49,13 +42,23 @@ public function __construct(Container $app) } /** - * @param \Rocketeer\Abstracts\AbstractBinary $manager + * @param \Rocketeer\Abstracts\AbstractPackageManager $manager */ public function setManager($manager) { $this->manager = $manager; } + /** + * Get an instance of the Binary + * + * @return \Rocketeer\Abstracts\AbstractPackageManager + */ + protected function getManager() + { + return $this->manager; + } + /** * Whether this particular strategy is runnable or not * @@ -63,7 +66,7 @@ public function setManager($manager) */ public function isExecutable() { - return $this->manager->getBinary() && $this->hasManifest(); + return $this->manager->getBinary() && $this->manager->hasManifest(); } ////////////////////////////////////////////////////////////////////// @@ -89,42 +92,4 @@ public function update() { return $this->manager->runForCurrentRelease('update'); } - - ////////////////////////////////////////////////////////////////////// - ////////////////////////////// MANIFEST ////////////////////////////// - ////////////////////////////////////////////////////////////////////// - - /** - * Check if the manifest file exists, locally or on server - * - * @return bool - */ - public function hasManifest() - { - $server = $this->paths->getFolder('current/'.$this->manifest); - $server = $this->bash->fileExists($server); - - $local = $this->app['path.base'].DS.$this->manifest; - $local = $this->files->exists($local); - - return $local || $server; - } - - /** - * @return string - */ - public function getManifest() - { - return $this->manifest; - } - - /** - * Get an instance of the Binary - * - * @return \Rocketeer\Abstracts\AbstractBinary - */ - protected function getManager() - { - return $this->binary($this->binary); - } } diff --git a/src/Rocketeer/Binaries/Bower.php b/src/Rocketeer/Binaries/PackageManagers/Bower.php similarity index 64% rename from src/Rocketeer/Binaries/Bower.php rename to src/Rocketeer/Binaries/PackageManagers/Bower.php index cd805bea4..b55c27631 100644 --- a/src/Rocketeer/Binaries/Bower.php +++ b/src/Rocketeer/Binaries/PackageManagers/Bower.php @@ -7,12 +7,19 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Binaries; +namespace Rocketeer\Binaries\PackageManagers; -use Rocketeer\Abstracts\AbstractBinary; +use Rocketeer\Abstracts\AbstractPackageManager; -class Bower extends AbstractBinary +class Bower extends AbstractPackageManager { + /** + * The name of the manifest file to look for + * + * @type string + */ + protected $manifest = 'bower.json'; + /** * Get an array of default paths to look for * diff --git a/src/Rocketeer/Binaries/PackageManagers/Bundler.php b/src/Rocketeer/Binaries/PackageManagers/Bundler.php new file mode 100644 index 000000000..51d7ea172 --- /dev/null +++ b/src/Rocketeer/Binaries/PackageManagers/Bundler.php @@ -0,0 +1,36 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Binaries\PackageManagers; + +use Rocketeer\Abstracts\AbstractBinary; +use Rocketeer\Abstracts\AbstractPackageManager; +use Rocketeer\Binaries\Php; + +class Bundler extends AbstractPackageManager +{ + /** + * The name of the manifest file to look for + * + * @type string + */ + protected $manifest = 'Gemfile'; + + /** + * Get an array of default paths to look for + * + * @return string[] + */ + protected function getKnownPaths() + { + return array( + 'bundle', + ); + } +} diff --git a/src/Rocketeer/Binaries/Composer.php b/src/Rocketeer/Binaries/PackageManagers/Composer.php similarity index 73% rename from src/Rocketeer/Binaries/Composer.php rename to src/Rocketeer/Binaries/PackageManagers/Composer.php index 203eb4a21..6941c07a1 100644 --- a/src/Rocketeer/Binaries/Composer.php +++ b/src/Rocketeer/Binaries/PackageManagers/Composer.php @@ -7,12 +7,21 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Binaries; +namespace Rocketeer\Binaries\PackageManagers; use Rocketeer\Abstracts\AbstractBinary; +use Rocketeer\Abstracts\AbstractPackageManager; +use Rocketeer\Binaries\Php; -class Composer extends AbstractBinary +class Composer extends AbstractPackageManager { + /** + * The name of the manifest file to look for + * + * @type string + */ + protected $manifest = 'composer.json'; + /** * Get an array of default paths to look for * diff --git a/src/Rocketeer/Binaries/PackageManagers/Npm.php b/src/Rocketeer/Binaries/PackageManagers/Npm.php new file mode 100644 index 000000000..5abcf3828 --- /dev/null +++ b/src/Rocketeer/Binaries/PackageManagers/Npm.php @@ -0,0 +1,36 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Binaries\PackageManagers; + +use Rocketeer\Abstracts\AbstractBinary; +use Rocketeer\Abstracts\AbstractPackageManager; +use Rocketeer\Binaries\Php; + +class Npm extends AbstractPackageManager +{ + /** + * The name of the manifest file to look for + * + * @type string + */ + protected $manifest = 'package.json'; + + /** + * Get an array of default paths to look for + * + * @return string[] + */ + protected function getKnownPaths() + { + return array( + 'npm', + ); + } +} diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index 0a791bd28..7fe1c91db 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -29,7 +29,7 @@ class PhpStrategy extends AbstractCheckStrategy implements CheckStrategyInterfac public function __construct(Container $app) { $this->app = $app; - $this->manager = $this->builder->buildStrategy('Dependencies', 'Composer'); + $this->manager = $this->binary('composer'); } ////////////////////////////////////////////////////////////////////// @@ -47,9 +47,7 @@ public function language() $required = null; // Get the minimum PHP version of the application - $composer = $this->app['path.base'].DS.$this->manager->getManifest(); - if ($this->files->exists($composer)) { - $composer = $this->files->get($composer); + if ($composer = $this->manager->getManifestContents()) { $composer = json_decode($composer, true); // Strip versions of constraints diff --git a/src/Rocketeer/Strategies/Check/RubyStrategy.php b/src/Rocketeer/Strategies/Check/RubyStrategy.php index 1364232cc..09806ca63 100644 --- a/src/Rocketeer/Strategies/Check/RubyStrategy.php +++ b/src/Rocketeer/Strategies/Check/RubyStrategy.php @@ -29,7 +29,7 @@ class RubyStrategy extends AbstractCheckStrategy implements CheckStrategyInterfa public function __construct(Container $app) { $this->app = $app; - $this->manager = $this->builder->buildStrategy('Dependencies', 'Bundler'); + $this->manager = $this->binary('bundler'); } ////////////////////////////////////////////////////////////////////// @@ -46,17 +46,13 @@ public function language() { $required = null; - // Get the minimum PHP version of the application - $gemfile = $this->app['path.base'].DS.$this->manager->getManifest(); - if ($this->app['files']->exists($gemfile)) { - $gemfile = $this->files->get($gemfile); - - // Strip versions of constraints + // Get the minimum Ruby version of the application + if ($gemfile = $this->manager->getManifestContents()) { preg_match('/ruby \'(.+)\'/', $gemfile, $matches); $required = Arr::get($matches, 1); } - // Cancel if no PHP version found + // Cancel if no Ruby version found if (!$required) { return true; } diff --git a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php index cc3aa703a..ff623a100 100644 --- a/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BowerStrategy.php @@ -20,13 +20,6 @@ class BowerStrategy extends AbstractDependenciesStrategy implements Dependencies */ protected $description = 'Installs dependencies with Bower'; - /** - * The name of the manifest file to look for - * - * @type string - */ - protected $manifest = 'bower.json'; - /** * The name of the binary * diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 789441402..8c9a4e35a 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -19,13 +19,6 @@ class BundlerStrategy extends AbstractDependenciesStrategy implements Dependenci */ protected $description = 'Installs dependencies with Bundler'; - /** - * The name of the manifest file to look for - * - * @type string - */ - protected $manifest = 'Gemfile'; - /** * The name of the binary * diff --git a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php index 5dbc02420..e67c82383 100644 --- a/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/ComposerStrategy.php @@ -19,13 +19,6 @@ class ComposerStrategy extends AbstractDependenciesStrategy implements Dependenc */ protected $description = 'Installs dependencies with Composer'; - /** - * The name of the manifest file to look for - * - * @type string - */ - protected $manifest = 'composer.json'; - /** * The name of the binary * diff --git a/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php b/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php index 8cabaf841..b3dd47865 100644 --- a/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/NpmStrategy.php @@ -19,13 +19,6 @@ class NpmStrategy extends AbstractDependenciesStrategy implements DependenciesSt */ protected $description = 'Installs dependencies with NPM'; - /** - * The name of the manifest file to look for - * - * @type string - */ - protected $manifest = 'package.json'; - /** * The name of the binary * diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 9213cf62d..399daf65f 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -32,11 +32,17 @@ trait Binaries public function binary($binary) { // Check for an existing Binary - $core = sprintf('Rocketeer\Binaries\%s', ucfirst($binary)); - if (class_exists($core)) { - return new $core($this->app); - } elseif (class_exists($binary)) { - return new $binary($this->app); + $paths = array( + 'Rocketeer\Binaries\PackageManagers\%s', + 'Rocketeer\Binaries\%s', + '%s', + ); + + foreach ($paths as $path) { + $path = sprintf($path, ucfirst($binary)); + if (class_exists($path)) { + return new $path($this->app); + } } // Else wrap the command in an AnonymousBinary diff --git a/src/config/strategies.php b/src/config/strategies.php index 63c280638..6bb2440b1 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -1,5 +1,5 @@ Date: Wed, 20 Aug 2014 18:45:30 +0200 Subject: [PATCH 332/424] Update tests --- .../Dependencies/BundlerStrategy.php | 2 +- .../Dependencies/BundlerStrategyTest.php | 20 +++++++++++++++---- .../Dependencies/PolyglotStrategyTest.php | 2 +- 3 files changed, 18 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php index 8c9a4e35a..76b2b7c1e 100644 --- a/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/BundlerStrategy.php @@ -24,5 +24,5 @@ class BundlerStrategy extends AbstractDependenciesStrategy implements Dependenci * * @type string */ - protected $binary = 'bundle'; + protected $binary = 'bundler'; } diff --git a/tests/Strategies/Dependencies/BundlerStrategyTest.php b/tests/Strategies/Dependencies/BundlerStrategyTest.php index e1da7deca..5ee7e6303 100644 --- a/tests/Strategies/Dependencies/BundlerStrategyTest.php +++ b/tests/Strategies/Dependencies/BundlerStrategyTest.php @@ -1,15 +1,28 @@ app); + $bundler->setBinary('bundle'); + + $this->bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); + $this->bundler->setManager($bundler); + } + public function testCanInstallDependencies() { $this->pretend(); - $bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); - $bundler->install(); + $this->bundler->install(); $this->assertHistory(array( array( @@ -22,8 +35,7 @@ public function testCanInstallDependencies() public function testCanUpdateDependencies() { $this->pretend(); - $bundler = $this->builder->buildStrategy('Dependencies', 'Bundler'); - $bundler->update(); + $this->bundler->update(); $this->assertHistory(array( array( diff --git a/tests/Strategies/Dependencies/PolyglotStrategyTest.php b/tests/Strategies/Dependencies/PolyglotStrategyTest.php index 09d92a3d7..1828cb88c 100644 --- a/tests/Strategies/Dependencies/PolyglotStrategyTest.php +++ b/tests/Strategies/Dependencies/PolyglotStrategyTest.php @@ -16,7 +16,7 @@ public function testCanInstallAllDependencies() $this->assertHistory(array( array( 'cd {server}/releases/{release}', - 'bundle install', + exec('which bundle').' install', ), array( 'cd {server}/releases/{release}', From 69e7682bb6699f2910f5bafb438d0231d278cfbc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 18:48:07 +0200 Subject: [PATCH 333/424] Add which to shelled --- src/config/remote.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/config/remote.php b/src/config/remote.php index e2a026261..98c634832 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -41,7 +41,7 @@ 'shell' => false, // An array of commands to run under shell - 'shelled' => ['ruby', 'npm ', 'bundle ', 'grunt'], + 'shelled' => ['which', 'ruby', 'npm', 'bundle', 'grunt'], // Permissions$ //////////////////////////////////////////////////////////////////// From 11cab02b301760f019c96e49646ec6342398db41 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 18:55:39 +0200 Subject: [PATCH 334/424] Work on polyglot Check strategy --- .../Strategies/AbstractPolyglotStrategy.php | 68 +++++++++++++++++++ .../Strategies/Check/PolyglotStrategy.php | 66 ++++++++++++++++++ .../Strategies/Check/RubyStrategy.php | 7 -- .../Dependencies/PolyglotStrategy.php | 33 ++------- 4 files changed, 140 insertions(+), 34 deletions(-) create mode 100644 src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php create mode 100644 src/Rocketeer/Strategies/Check/PolyglotStrategy.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php new file mode 100644 index 000000000..3c559ca0b --- /dev/null +++ b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php @@ -0,0 +1,68 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Abstracts\Strategies; + +use Closure; + +class AbstractPolyglotStrategy extends AbstractStrategy +{ + /** + * The various strategies to call + * + * @type array + */ + protected $strategies = []; + + /** + * Execute a method on all sub-strategies + * + * @param string $method + * + * @return array + */ + protected function executeStrategiesMethod($method) + { + return $this->onStrategies(function (AbstractStrategy $strategy) use ($method) { + return $strategy->$method(); + }); + } + + /** + * Assert that the results of a command are all true + * + * @param boolean[] $results + * + * @return boolean + */ + protected function checkStrategiesResults($results) + { + $results = array_filter($results); + + return count($results) == count($this->strategies); + } + + /** + * @param Closure $callback + * + * @return array + */ + protected function onStrategies(Closure $callback) + { + $results = []; + foreach ($this->strategies as $strategy) { + $instance = $this->getStrategy('Dependencies', $strategy); + if ($instance) { + $results[$strategy] = $callback($instance); + } + } + + return $results; + } +} diff --git a/src/Rocketeer/Strategies/Check/PolyglotStrategy.php b/src/Rocketeer/Strategies/Check/PolyglotStrategy.php new file mode 100644 index 000000000..97bf30331 --- /dev/null +++ b/src/Rocketeer/Strategies/Check/PolyglotStrategy.php @@ -0,0 +1,66 @@ +executeStrategiesMethod('manager'); + + return $this->checkStrategiesResults($results); + } + + /** + * Check that the language used by the + * application is at the required version + * + * @return boolean + */ + public function language() + { + $results = $this->executeStrategiesMethod('language'); + + return $this->checkStrategiesResults($results); + } + + /** + * Check for the required extensions + * + * @return array + */ + public function extensions() + { + $missing = []; + $extensions = $this->executeStrategiesMethod('extensions'); + foreach ($extensions as $extension) { + $missing = array_merge($missing, $extension); + } + + return $missing; + } + + /** + * Check for the required drivers + * + * @return array + */ + public function drivers() + { + $missing = []; + $drivers = $this->executeStrategiesMethod('drivers'); + foreach ($drivers as $driver) { + $missing = array_merge($missing, $driver); + } + + return $missing; + } +} diff --git a/src/Rocketeer/Strategies/Check/RubyStrategy.php b/src/Rocketeer/Strategies/Check/RubyStrategy.php index 09806ca63..e062b23dd 100644 --- a/src/Rocketeer/Strategies/Check/RubyStrategy.php +++ b/src/Rocketeer/Strategies/Check/RubyStrategy.php @@ -16,13 +16,6 @@ class RubyStrategy extends AbstractCheckStrategy implements CheckStrategyInterfa */ protected $language = 'Ruby'; - /** - * The PHP extensions loaded on server - * - * @var array - */ - protected $extensions = array(); - /** * @param Container $app */ diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index 0eb29d2a4..7ff800c7b 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -11,10 +11,11 @@ use Closure; use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; +use Rocketeer\Abstracts\Strategies\AbstractPolyglotStrategy; use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; -class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyInterface +class PolyglotStrategy extends AbstractPolyglotStrategy implements DependenciesStrategyInterface { /** * @type string @@ -22,11 +23,11 @@ class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyI protected $description = 'Runs all of the above package managers if necessary'; /** - * The various dependencies managers + * The various strategies to call * * @type array */ - protected $managers = ['Bundler', 'Composer', 'Npm', 'Bower']; + protected $strategies = ['Bundler', 'Composer', 'Npm', 'Bower']; /** * Install the dependencies @@ -35,9 +36,7 @@ class PolyglotStrategy extends AbstractStrategy implements DependenciesStrategyI */ public function install() { - return $this->onManagers(function (AbstractDependenciesStrategy $manager) { - return $manager->install(); - }); + return $this->executeStrategiesMethod('install'); } /** @@ -47,26 +46,6 @@ public function install() */ public function update() { - return $this->onManagers(function (AbstractDependenciesStrategy $manager) { - return $manager->update(); - }); - } - - /** - * @param Closure $callback - * - * @return array - */ - protected function onManagers(Closure $callback) - { - $results = []; - foreach ($this->managers as $manager) { - $strategy = $this->getStrategy('Dependencies', $manager); - if ($strategy) { - $results[$manager] = $callback($strategy); - } - } - - return $results; + return $this->executeStrategiesMethod('update'); } } From 1bea403bc85de6d015bbd72115464c5ede696166 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 19:51:53 +0200 Subject: [PATCH 335/424] CS fixes --- src/Rocketeer/Binaries/PackageManagers/Bundler.php | 2 -- src/Rocketeer/Binaries/PackageManagers/Composer.php | 1 - src/Rocketeer/Binaries/PackageManagers/Npm.php | 2 -- src/Rocketeer/Services/Pathfinder.php | 1 + src/Rocketeer/Strategies/Check/PhpStrategy.php | 1 - src/Rocketeer/Strategies/Check/RubyStrategy.php | 1 - src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php | 3 --- src/Rocketeer/Tasks/Check.php | 6 +++--- tests/Services/Connections/RemoteHandlerTest.php | 4 +--- tests/Services/ReleasesManagerTest.php | 3 +-- tests/Tasks/Subtasks/PrimerTest.php | 3 +-- 11 files changed, 7 insertions(+), 20 deletions(-) diff --git a/src/Rocketeer/Binaries/PackageManagers/Bundler.php b/src/Rocketeer/Binaries/PackageManagers/Bundler.php index 51d7ea172..c1875d5c6 100644 --- a/src/Rocketeer/Binaries/PackageManagers/Bundler.php +++ b/src/Rocketeer/Binaries/PackageManagers/Bundler.php @@ -9,9 +9,7 @@ */ namespace Rocketeer\Binaries\PackageManagers; -use Rocketeer\Abstracts\AbstractBinary; use Rocketeer\Abstracts\AbstractPackageManager; -use Rocketeer\Binaries\Php; class Bundler extends AbstractPackageManager { diff --git a/src/Rocketeer/Binaries/PackageManagers/Composer.php b/src/Rocketeer/Binaries/PackageManagers/Composer.php index 6941c07a1..761d53eba 100644 --- a/src/Rocketeer/Binaries/PackageManagers/Composer.php +++ b/src/Rocketeer/Binaries/PackageManagers/Composer.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Binaries\PackageManagers; -use Rocketeer\Abstracts\AbstractBinary; use Rocketeer\Abstracts\AbstractPackageManager; use Rocketeer\Binaries\Php; diff --git a/src/Rocketeer/Binaries/PackageManagers/Npm.php b/src/Rocketeer/Binaries/PackageManagers/Npm.php index 5abcf3828..c52f647a4 100644 --- a/src/Rocketeer/Binaries/PackageManagers/Npm.php +++ b/src/Rocketeer/Binaries/PackageManagers/Npm.php @@ -9,9 +9,7 @@ */ namespace Rocketeer\Binaries\PackageManagers; -use Rocketeer\Abstracts\AbstractBinary; use Rocketeer\Abstracts\AbstractPackageManager; -use Rocketeer\Binaries\Php; class Npm extends AbstractPackageManager { diff --git a/src/Rocketeer/Services/Pathfinder.php b/src/Rocketeer/Services/Pathfinder.php index b9a4bf450..1ba5074b1 100644 --- a/src/Rocketeer/Services/Pathfinder.php +++ b/src/Rocketeer/Services/Pathfinder.php @@ -213,6 +213,7 @@ public function replacePatterns($path) // Replace paths from the container if ($this->app->bound($folder)) { $path = $this->app->make($folder); + return str_replace($base, null, $this->unifySlashes($path)); } diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index 7fe1c91db..94612949f 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -4,7 +4,6 @@ use Illuminate\Container\Container; use Illuminate\Support\Arr; use Rocketeer\Abstracts\Strategies\AbstractCheckStrategy; -use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\CheckStrategyInterface; class PhpStrategy extends AbstractCheckStrategy implements CheckStrategyInterface diff --git a/src/Rocketeer/Strategies/Check/RubyStrategy.php b/src/Rocketeer/Strategies/Check/RubyStrategy.php index e062b23dd..4d29873b1 100644 --- a/src/Rocketeer/Strategies/Check/RubyStrategy.php +++ b/src/Rocketeer/Strategies/Check/RubyStrategy.php @@ -4,7 +4,6 @@ use Illuminate\Container\Container; use Illuminate\Support\Arr; use Rocketeer\Abstracts\Strategies\AbstractCheckStrategy; -use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\CheckStrategyInterface; class RubyStrategy extends AbstractCheckStrategy implements CheckStrategyInterface diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index 7ff800c7b..acaf99112 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -9,10 +9,7 @@ */ namespace Rocketeer\Strategies\Dependencies; -use Closure; -use Rocketeer\Abstracts\Strategies\AbstractDependenciesStrategy; use Rocketeer\Abstracts\Strategies\AbstractPolyglotStrategy; -use Rocketeer\Abstracts\Strategies\AbstractStrategy; use Rocketeer\Interfaces\Strategies\DependenciesStrategyInterface; class PolyglotStrategy extends AbstractPolyglotStrategy implements DependenciesStrategyInterface diff --git a/src/Rocketeer/Tasks/Check.php b/src/Rocketeer/Tasks/Check.php index 59cd9d1b9..bc2260ca7 100644 --- a/src/Rocketeer/Tasks/Check.php +++ b/src/Rocketeer/Tasks/Check.php @@ -49,8 +49,8 @@ public function execute() } // Check package manager - $manager = class_basename($check->getManager()); - $manager = str_replace('Strategy', null, $manager); + $manager = class_basename($check->getManager()); + $manager = str_replace('Strategy', null, $manager); $this->explainer->line('Checking presence of '.$manager); if (!$check->manager()) { $errors[] = sprintf('The %s package manager could not be found', $manager); @@ -58,7 +58,7 @@ public function execute() // Check language $language = $check->getLanguage(); - $this->explainer->line('Checking '.$language. ' version'); + $this->explainer->line('Checking '.$language.' version'); if (!$check->language()) { $errors[] = $language.' is not at the required version'; } diff --git a/tests/Services/Connections/RemoteHandlerTest.php b/tests/Services/Connections/RemoteHandlerTest.php index db3261dbb..b665918bd 100644 --- a/tests/Services/Connections/RemoteHandlerTest.php +++ b/tests/Services/Connections/RemoteHandlerTest.php @@ -1,7 +1,6 @@ swapConfig(array( 'rocketeer::connections' => array( - 'production' => array( - ), + 'production' => array(), ), )); diff --git a/tests/Services/ReleasesManagerTest.php b/tests/Services/ReleasesManagerTest.php index 7840f3a32..37f2444fc 100644 --- a/tests/Services/ReleasesManagerTest.php +++ b/tests/Services/ReleasesManagerTest.php @@ -146,8 +146,7 @@ public function testCanReturnPreviousReleaseIfNoReleases() ->shouldReceive('listContents')->once()->with($this->server.'/releases')->andReturn([]); }); - $this->mockState(array( - )); + $this->mockState(array()); $previous = $this->releasesManager->getPreviousRelease(); $this->assertNull($previous); diff --git a/tests/Tasks/Subtasks/PrimerTest.php b/tests/Tasks/Subtasks/PrimerTest.php index c4f1eacc3..644ecc44d 100644 --- a/tests/Tasks/Subtasks/PrimerTest.php +++ b/tests/Tasks/Subtasks/PrimerTest.php @@ -1,7 +1,6 @@ swapConfig(array( - 'rocketeer::default' => 'production', + 'rocketeer::default' => 'production', 'rocketeer::strategies.primer' => function () { return 'ls'; } From 6d33eeee4eee98da0b760dacef5a62bdd6ef15a4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 20:03:43 +0200 Subject: [PATCH 336/424] Abstract Check::language logic --- .../Abstracts/AbstractPackageManager.php | 10 ++++ .../Strategies/AbstractCheckStrategy.php | 47 +++++++++++++++++++ .../AbstractDependenciesStrategy.php | 2 +- .../Strategies/Check/PhpStrategy.php | 39 ++++++++------- .../Strategies/Check/RubyStrategy.php | 33 ++++++------- src/Rocketeer/Traits/BashModules/Binaries.php | 2 +- 6 files changed, 95 insertions(+), 38 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractPackageManager.php b/src/Rocketeer/Abstracts/AbstractPackageManager.php index 7b9414b68..c8f97aecc 100644 --- a/src/Rocketeer/Abstracts/AbstractPackageManager.php +++ b/src/Rocketeer/Abstracts/AbstractPackageManager.php @@ -10,6 +10,16 @@ class AbstractPackageManager extends AbstractBinary */ protected $manifest; + /** + * Whether the manager is enabled or not + * + * @return boolean + */ + public function isExecutable() + { + return $this->getBinary() && $this->hasManifest(); + } + /** * Check if the manifest file exists, locally or on server * diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php index b30e0af10..28ad7608b 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -45,4 +45,51 @@ public function manager() { return $this->manager->isExecutable(); } + + /** + * Check that the language used by the + * application is at the required version + * + * @return boolean + */ + public function language() + { + $required = null; + + $required = null; + + // Get the minimum version of the application + if ($manifest = $this->manager->getManifestContents()) { + $required = $this->getLanguageConstraint($manifest); + } + + // Cancel if no version constraint + if (!$required) { + return true; + } + + $version = $this->getCurrentVersion(); + + return version_compare($version, $required, '>='); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// LANGUAGE ////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Get the version constraint which should be checked against + * + * @param string $manifest + * + * @return string + */ + abstract protected function getLanguageConstraint($manifest); + + /** + * Get the current version in use + * + * @return string + */ + abstract protected function getCurrentVersion(); } diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 67c79b890..09adfdd5f 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -66,7 +66,7 @@ protected function getManager() */ public function isExecutable() { - return $this->manager->getBinary() && $this->manager->hasManifest(); + return $this->manager->isExecutable(); } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index 94612949f..54cf73435 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -36,32 +36,31 @@ public function __construct(Container $app) ////////////////////////////////////////////////////////////////////// /** - * Check that the language used by the - * application is at the required version + * Get the version constraint which should be checked against * - * @return boolean + * @param string $manifest + * + * @return string */ - public function language() + protected function getLanguageConstraint($manifest) { - $required = null; - - // Get the minimum PHP version of the application - if ($composer = $this->manager->getManifestContents()) { - $composer = json_decode($composer, true); + $manifest = json_decode($manifest, true); - // Strip versions of constraints - $required = (string) Arr::get($composer, 'require.php'); - $required = preg_replace('/>=/', '', $required); - } - - // Cancel if no PHP version found - if (!$required) { - return true; - } + // Strip versions of constraints + $required = (string) Arr::get($manifest, 'require.php'); + $required = preg_replace('/>=/', '', $required); - $version = $this->php()->runLast('version'); + return $required; + } - return version_compare($version, $required, '>='); + /** + * Get the current version in use + * + * @return string + */ + protected function getCurrentVersion() + { + return $this->php()->runLast('version'); } /** diff --git a/src/Rocketeer/Strategies/Check/RubyStrategy.php b/src/Rocketeer/Strategies/Check/RubyStrategy.php index 4d29873b1..63d830863 100644 --- a/src/Rocketeer/Strategies/Check/RubyStrategy.php +++ b/src/Rocketeer/Strategies/Check/RubyStrategy.php @@ -29,30 +29,31 @@ public function __construct(Container $app) ////////////////////////////////////////////////////////////////////// /** - * Check that the language used by the - * application is at the required version + * Get the version constraint which should be checked against * - * @return boolean + * @param string $manifest + * + * @return string */ - public function language() + protected function getLanguageConstraint($manifest) { - $required = null; - - // Get the minimum Ruby version of the application - if ($gemfile = $this->manager->getManifestContents()) { - preg_match('/ruby \'(.+)\'/', $gemfile, $matches); - $required = Arr::get($matches, 1); - } + preg_match('/ruby \'(.+)\'/', $manifest, $matches); + $required = Arr::get((array) $matches, 1); - // Cancel if no Ruby version found - if (!$required) { - return true; - } + return $required; + } + /** + * Get the current version in use + * + * @return string + */ + protected function getCurrentVersion() + { $version = $this->binary('ruby')->run('--version'); $version = preg_replace('/ruby ([0-9\.]+)p?.+/', '$1', $version); - return version_compare($version, $required, '>='); + return $version; } /** diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 399daf65f..c1b492739 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -27,7 +27,7 @@ trait Binaries * * @param string $binary * - * @return \Rocketeer\Abstracts\AbstractBinary + * @return \Rocketeer\Abstracts\AbstractBinary|\Rocketeer\Abstracts\AbstractPackageManager */ public function binary($binary) { From 8e4178c6afc8052311d5bf3a94bac25d63cd5e36 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 20:05:26 +0200 Subject: [PATCH 337/424] Don't exclude patchwork from PHAR --- src/Rocketeer/Console/Compiler.php | 1 - 1 file changed, 1 deletion(-) diff --git a/src/Rocketeer/Console/Compiler.php b/src/Rocketeer/Console/Compiler.php index 6dfa5c124..4e0acaedf 100644 --- a/src/Rocketeer/Console/Compiler.php +++ b/src/Rocketeer/Console/Compiler.php @@ -102,7 +102,6 @@ public function compile() 'johnkary', 'mockery', 'nesbot', - 'patchwork', 'phine', 'raveren', )); From eb0dda460847ae28a427bbfdcf4ae7397aeebe03 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 20:05:32 +0200 Subject: [PATCH 338/424] Missing abstract keywoards --- src/Rocketeer/Abstracts/AbstractBinary.php | 2 +- src/Rocketeer/Abstracts/AbstractPackageManager.php | 2 +- src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php | 2 +- src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 513f14844..22dfca1eb 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -19,7 +19,7 @@ * * @author Maxime Fabre */ -class AbstractBinary +abstract class AbstractBinary { use HasLocator; diff --git a/src/Rocketeer/Abstracts/AbstractPackageManager.php b/src/Rocketeer/Abstracts/AbstractPackageManager.php index c8f97aecc..ae83e8d2f 100644 --- a/src/Rocketeer/Abstracts/AbstractPackageManager.php +++ b/src/Rocketeer/Abstracts/AbstractPackageManager.php @@ -1,7 +1,7 @@ Date: Wed, 20 Aug 2014 20:17:38 +0200 Subject: [PATCH 339/424] Remove null assignment --- .../Abstracts/Strategies/AbstractCheckStrategy.php | 2 -- .../Abstracts/Strategies/AbstractDependenciesStrategy.php | 7 ++++--- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php index 65d425b5e..3338b71bf 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -56,8 +56,6 @@ public function language() { $required = null; - $required = null; - // Get the minimum version of the application if ($manifest = $this->manager->getManifestContents()) { $required = $this->getLanguageConstraint($manifest); diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php index 09adfdd5f..ee9927140 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractDependenciesStrategy.php @@ -10,6 +10,7 @@ namespace Rocketeer\Abstracts\Strategies; use Illuminate\Container\Container; +use Rocketeer\Abstracts\AbstractPackageManager; /** * Abstract class for Dependencies strategies @@ -28,7 +29,7 @@ abstract class AbstractDependenciesStrategy extends AbstractStrategy /** * The package manager instance * - * @type \Rocketeer\Abstracts\AbstractPackageManager + * @type AbstractPackageManager */ protected $manager; @@ -42,7 +43,7 @@ public function __construct(Container $app) } /** - * @param \Rocketeer\Abstracts\AbstractPackageManager $manager + * @param AbstractPackageManager $manager */ public function setManager($manager) { @@ -52,7 +53,7 @@ public function setManager($manager) /** * Get an instance of the Binary * - * @return \Rocketeer\Abstracts\AbstractPackageManager + * @return AbstractPackageManager */ protected function getManager() { From b39eccf2a7e906e89fda9f25f5d80b4eea83ae06 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 20:26:55 +0200 Subject: [PATCH 340/424] Fix strategies command --- src/Rocketeer/Abstracts/AbstractBinary.php | 2 +- src/Rocketeer/Console/Commands/StrategiesCommand.php | 1 + src/Rocketeer/Services/Connections/RemoteHandler.php | 10 ++++++++++ src/Rocketeer/Strategies/Check/PhpStrategy.php | 5 +++++ src/Rocketeer/Strategies/Check/RubyStrategy.php | 5 +++++ 5 files changed, 22 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 22dfca1eb..2b056cb46 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -45,7 +45,7 @@ public function __construct(Container $app) $this->app = $app; // Assign default paths - if ($paths = $this->getKnownPaths()) { + if ($this->remote->connected() && $paths = $this->getKnownPaths()) { $binary = call_user_func_array([$this->bash, 'which'], $paths); $this->setBinary($binary); } diff --git a/src/Rocketeer/Console/Commands/StrategiesCommand.php b/src/Rocketeer/Console/Commands/StrategiesCommand.php index 84c5e0a64..ffda744d5 100644 --- a/src/Rocketeer/Console/Commands/StrategiesCommand.php +++ b/src/Rocketeer/Console/Commands/StrategiesCommand.php @@ -41,6 +41,7 @@ class StrategiesCommand extends AbstractCommand public function fire() { $strategies = array( + 'check' => ['Php', 'Ruby'], 'deploy' => ['Clone', 'Copy', 'Sync'], 'test' => ['Phpunit'], 'migrate' => ['Artisan'], diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index baaef1607..29eea7872 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -31,6 +31,16 @@ class RemoteHandler */ protected $active = []; + /** + * Whether the handler is currently connected to any server + * + * @return boolean + */ + public function connected() + { + return (bool) $this->active; + } + /** * Create a specific connection or the default one * diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index 54cf73435..4540f1891 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -8,6 +8,11 @@ class PhpStrategy extends AbstractCheckStrategy implements CheckStrategyInterface { + /** + * @type string + */ + protected $description = 'Checks if the server is ready to receive a PHP application'; + /** * The language of the strategy * diff --git a/src/Rocketeer/Strategies/Check/RubyStrategy.php b/src/Rocketeer/Strategies/Check/RubyStrategy.php index 63d830863..733eddb36 100644 --- a/src/Rocketeer/Strategies/Check/RubyStrategy.php +++ b/src/Rocketeer/Strategies/Check/RubyStrategy.php @@ -8,6 +8,11 @@ class RubyStrategy extends AbstractCheckStrategy implements CheckStrategyInterface { + /** + * @type string + */ + protected $description = 'Checks if the server is ready to receive a Ruby application'; + /** * The language of the strategy * From 94e01ba3b195ef731ea86f4f0670d224d02ca941 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 21:41:00 +0200 Subject: [PATCH 341/424] Add deploy tag --- composer.json | 1 + 1 file changed, 1 insertion(+) diff --git a/composer.json b/composer.json index 1076dc535..1c88b92e1 100644 --- a/composer.json +++ b/composer.json @@ -4,6 +4,7 @@ "license": "MIT", "keywords": [ "laravel", + "deploy", "deployment", "ssh" ], From a94a86a4ccd5a4dc1597308fd31ba4aa91bac442 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 21:43:12 +0200 Subject: [PATCH 342/424] Update tests --- tests/TestCases/ContainerTestCase.php | 1 + 1 file changed, 1 insertion(+) diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 4468671b6..4e113aa24 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -210,6 +210,7 @@ protected function getRemote($mockedOutput = null) }; $remote = Mockery::mock('Illuminate\Remote\Connection'); + $remote->shouldReceive('connected')->andReturn(true); $remote->shouldReceive('into')->andReturn(Mockery::self()); $remote->shouldReceive('status')->andReturn(0)->byDefault(); $remote->shouldReceive('run')->andReturnUsing($run)->byDefault(); From fcdf52b441bc28030d367a28713d48e59f33de2e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 21:54:33 +0200 Subject: [PATCH 343/424] Enable debug mode --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 9ed1f8c0e..dad16d49b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -15,4 +15,4 @@ matrix: - php: hhvm-nightly fast_finish: true -script: phpunit --verbose +script: phpunit --debug From 4499e0e7e129abdbc86e67e838f540291d131ebf Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 22:01:12 +0200 Subject: [PATCH 344/424] Fix HHVM check? --- src/Rocketeer/Binaries/Php.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Binaries/Php.php b/src/Rocketeer/Binaries/Php.php index cfa40f6f6..fe78eb9a5 100644 --- a/src/Rocketeer/Binaries/Php.php +++ b/src/Rocketeer/Binaries/Php.php @@ -30,7 +30,7 @@ protected function getKnownPaths() */ public function version() { - return $this->getCommand(null, null, ['-r' => 'print PHP_VERSION;']); + return $this->getCommand(null, null, ['-r' => "print defined('HHVM_VERSION') ? HHVM_VERSION : PHP_VERSION;"]); } /** From 23941064097a625b8a6c3ce06c287efab42961a9 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 20 Aug 2014 22:15:14 +0200 Subject: [PATCH 345/424] Fix setBinary --- src/Rocketeer/Abstracts/AbstractBinary.php | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 2b056cb46..000dbedc3 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -45,9 +45,12 @@ public function __construct(Container $app) $this->app = $app; // Assign default paths - if ($this->remote->connected() && $paths = $this->getKnownPaths()) { + $paths = $this->getKnownPaths(); + if ($this->connections->getConnection() && $paths) { $binary = call_user_func_array([$this->bash, 'which'], $paths); $this->setBinary($binary); + } elseif ($paths) { + $this->setBinary($paths[0]); } } From eef7453c1d36b2cbdce625a44be6873f3043efd4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 00:55:52 +0200 Subject: [PATCH 346/424] Work on Bash::which --- src/Rocketeer/Abstracts/AbstractBinary.php | 5 ++- src/Rocketeer/Binaries/Artisan.php | 3 +- src/Rocketeer/Traits/BashModules/Binaries.php | 32 +++++++++++++------ 3 files changed, 28 insertions(+), 12 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractBinary.php b/src/Rocketeer/Abstracts/AbstractBinary.php index 000dbedc3..73acb1236 100644 --- a/src/Rocketeer/Abstracts/AbstractBinary.php +++ b/src/Rocketeer/Abstracts/AbstractBinary.php @@ -47,7 +47,10 @@ public function __construct(Container $app) // Assign default paths $paths = $this->getKnownPaths(); if ($this->connections->getConnection() && $paths) { - $binary = call_user_func_array([$this->bash, 'which'], $paths); + $binary = Arr::get($paths, 0); + $fallback = Arr::get($paths, 1); + $binary = $this->bash->which($binary, $fallback, false); + $this->setBinary($binary); } elseif ($paths) { $this->setBinary($paths[0]); diff --git a/src/Rocketeer/Binaries/Artisan.php b/src/Rocketeer/Binaries/Artisan.php index 5fa22ff44..930e7478b 100644 --- a/src/Rocketeer/Binaries/Artisan.php +++ b/src/Rocketeer/Binaries/Artisan.php @@ -35,8 +35,7 @@ protected function getKnownPaths() { return array( 'artisan', - $this->releasesManager->getCurrentReleasePath().'/artisan', - 'artisan' + $this->releasesManager->getCurrentReleasePath().'/artisan' ); } diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index c1b492739..426c73e10 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -95,15 +95,14 @@ public function artisan() /** * Get the path to a binary * - * @param string $binary The name of the binary - * @param string|null $fallback A fallback location - * @param string|boolean $default A last resort place to use as binary + * @param string $binary The name of the binary + * @param string|null $fallback A fallback location + * @param boolean $prompt * * @return string */ - public function which($binary, $fallback = null, $default = false) + public function which($binary, $fallback = null, $prompt = true) { - $location = false; $locations = array( [$this->localStorage, 'get', 'paths.'.$binary], [$this->paths, 'getPath', $binary], @@ -112,15 +111,30 @@ public function which($binary, $fallback = null, $default = false) // Add fallback if provided if ($fallback) { - $locations[] = array($this, 'runSilently', 'which '.$fallback); + $locations[] = [$this, 'runSilently', 'which '.$fallback]; } // Add command prompt if possible - if ($this->hasCommand()) { + if ($this->hasCommand() && $prompt) { $prompt = $binary.' could not be found, please enter the path to it'; - $locations[] = array($this->command, 'ask', $prompt); + $locations[] = [$this->command, 'ask', $prompt]; } + return $this->whichFrom($binary, $locations); + } + + /** + * Scan an array of locations for a binary + * + * @param string $binary + * @param array $locations + * + * @return string + */ + protected function whichFrom($binary, array $locations) + { + $location = false; + // Look in all the locations $tryout = 0; while (!$location && array_key_exists($tryout, $locations)) { @@ -136,7 +150,7 @@ public function which($binary, $fallback = null, $default = false) $this->localStorage->set('paths.'.$binary, $location); } - return $location ?: $default; + return $location ?: $binary; } /** From b0affae0b8e7b44f13f4252fcab02e64ad8cad8f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 00:58:27 +0200 Subject: [PATCH 347/424] Fix Migrate task --- .../Strategies/Migrate/ArtisanStrategy.php | 4 ++-- src/Rocketeer/Tasks/Migrate.php | 21 ++++++++++++++----- 2 files changed, 18 insertions(+), 7 deletions(-) diff --git a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php index e1a14da60..e3ae7d883 100644 --- a/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php +++ b/src/Rocketeer/Strategies/Migrate/ArtisanStrategy.php @@ -36,7 +36,7 @@ public function isExecutable() */ public function migrate() { - $this->artisan()->runForCurrentRelease('migrate'); + return $this->artisan()->runForCurrentRelease('migrate'); } /** @@ -46,6 +46,6 @@ public function migrate() */ public function seed() { - $this->artisan()->runForCurrentRelease('seed'); + return $this->artisan()->runForCurrentRelease('seed'); } } diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index 31f5d4f54..0e7a890e0 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -27,19 +27,30 @@ class Migrate extends AbstractTask */ public function execute() { + $results = []; + + // Get strategy and options + $migrate = $this->getOption('migrate'); + $seed = $this->getOption('seed'); $strategy = $this->getStrategy('Migrate'); - if (!$strategy) { + + // Cancel if nothing to run + if (!$strategy || (!$migrate && !$seed)) { return true; } - if ($this->getOption('migrate')) { + // Migrate the database + if ($migrate) { $this->command->comment('Running outstanding migrations'); - $strategy->migrate(); + $results[] = $strategy->migrate(); } - if ($this->getOption('seed')) { + // Seed it + if ($seed) { $this->command->comment('Seeding database'); - $strategy->seed(); + $results[] = $strategy->seed(); } + + return $results; } } From b80c7d688906c887a6b615dc5b4f8e25a027a18b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 13:09:05 +0200 Subject: [PATCH 348/424] Silent Migrate task if no flag --- src/Rocketeer/Tasks/Deploy.php | 4 +++- src/Rocketeer/Tasks/Update.php | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/Rocketeer/Tasks/Deploy.php b/src/Rocketeer/Tasks/Deploy.php index f7e96ce44..f87998b3a 100644 --- a/src/Rocketeer/Tasks/Deploy.php +++ b/src/Rocketeer/Tasks/Deploy.php @@ -58,7 +58,9 @@ public function execute() $this->steps()->setApplicationPermissions(); // Run migrations - $this->steps()->executeTask('Migrate'); + if ($this->getOption('migrate') || $this->getOption('seed')) { + $this->steps()->executeTask('Migrate'); + } // Synchronize shared folders and files $this->steps()->syncSharedFolders(); diff --git a/src/Rocketeer/Tasks/Update.php b/src/Rocketeer/Tasks/Update.php index 8080af759..8b736d833 100644 --- a/src/Rocketeer/Tasks/Update.php +++ b/src/Rocketeer/Tasks/Update.php @@ -50,7 +50,9 @@ public function execute() $this->steps()->setApplicationPermissions(); // Run migrations - $this->steps()->executeTask('Migrate'); + if ($this->getOption('migrate') || $this->getOption('seed')) { + $this->steps()->executeTask('Migrate'); + } // Run the steps if (!$this->runSteps()) { From 539306b013d683820eb242201e025528b96fb154 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 13:25:16 +0200 Subject: [PATCH 349/424] Better connection exceptions --- .../Exceptions/ConnectionException.php | 30 +++++++++++++++++++ .../Services/Connections/RemoteHandler.php | 12 +++++++- 2 files changed, 41 insertions(+), 1 deletion(-) create mode 100644 src/Rocketeer/Exceptions/ConnectionException.php diff --git a/src/Rocketeer/Exceptions/ConnectionException.php b/src/Rocketeer/Exceptions/ConnectionException.php new file mode 100644 index 000000000..7302cb210 --- /dev/null +++ b/src/Rocketeer/Exceptions/ConnectionException.php @@ -0,0 +1,30 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Exceptions; + +use Exception; + +/** + * Exception when Rocketeer can't connect to a server + * + * @author Maxime Fabre + */ +class ConnectionException extends Exception +{ + /** + * Set the credentials that failed to connect + * + * @param array $credentials + */ + public function setCredentials(array $credentials) + { + $this->message .= PHP_EOL.'With credentials:'.PHP_EOL.json_encode($credentials); + } +} diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index 29eea7872..1170e4036 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -9,7 +9,9 @@ */ namespace Rocketeer\Services\Connections; +use Exception; use InvalidArgumentException; +use Rocketeer\Exceptions\ConnectionException; use Rocketeer\Exceptions\MissingCredentialsException; use Rocketeer\Traits\HasLocator; use Symfony\Component\Console\Output\NullOutput; @@ -126,10 +128,18 @@ protected function getAuth(array $config) * @param string $method * @param array $parameters * + * @throws \Rocketeer\Exceptions\ConnectionException * @return mixed */ public function __call($method, $parameters) { - return call_user_func_array([$this->connection(), $method], $parameters); + try { + return call_user_func_array([$this->connection(), $method], $parameters); + } catch (Exception $exception) { + $exception = new ConnectionException($exception->getMessage()); + $exception->setCredentials($this->connections->getServerCredentials()); + + throw $exception; + } } } From 8ae1e1d9737c4c3c6fcfedf3efdd2c12b4e117b3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 13:44:56 +0200 Subject: [PATCH 350/424] Remove deprecated test --- tests/Traits/BashModules/BinariesTest.php | 9 --------- 1 file changed, 9 deletions(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 9e3e98599..e6c6726d4 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -39,15 +39,6 @@ public function testCanGetBinary() $this->assertEquals($whichGrep, $grep); } - public function testCanGetFallbackForBinary() - { - $whichGrep = exec('which grep'); - $grep = $this->task->which('foobar', $whichGrep); - - $this->assertEquals($whichGrep, $grep); - $this->assertFalse($this->task->which('fdsf')); - } - public function testCanRunComposer() { $this->usesComposer(true); From bd1b0dfd5afa4fa0ad53440360ada26594958e7e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 20:09:04 +0200 Subject: [PATCH 351/424] Display events one level below --- src/Rocketeer/Abstracts/AbstractTask.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 3ef6af38e..fffb73781 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -177,7 +177,9 @@ public function fireEvent($event) { // Fire the event $event = $this->getQualifiedEvent($event); - $result = $this->events->fire($event, [$this]); + $result = $this->explainer->displayBelow(function () use ($event) { + return $this->events->fire($event, [$this]); + }); // If the event returned a strict false, halt the task if ($result === false) { From f6f233a44106abf88720ff06f9cad731638c39b1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 20:31:06 +0200 Subject: [PATCH 352/424] Display the origin event of tasks --- src/Rocketeer/Abstracts/AbstractTask.php | 17 ++++++++++++++++- .../Services/Display/QueueExplainer.php | 6 +++++- src/Rocketeer/Services/TasksHandler.php | 3 ++- 3 files changed, 23 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index fffb73781..db5d936d5 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -38,6 +38,13 @@ abstract class AbstractTask extends Bash */ protected $description; + /** + * The event this task is answering to + * + * @type string + */ + protected $event; + /** * Whether the task was halted mid-course * @@ -92,6 +99,14 @@ public function setName($name) $this->name = ucfirst($name) ?: $this->name; } + /** + * @param string $event + */ + public function setEvent($event) + { + $this->event = $event; + } + /** * @param string $description */ @@ -255,6 +270,6 @@ protected function displayStatus() $description = $this->getDescription(); $time = $this->timer->getTaskTime($this); - $this->explainer->display($name, $description, $time); + $this->explainer->display($name, $description, $this->event, $time); } } diff --git a/src/Rocketeer/Services/Display/QueueExplainer.php b/src/Rocketeer/Services/Display/QueueExplainer.php index a0f1c5d9d..e548a9567 100644 --- a/src/Rocketeer/Services/Display/QueueExplainer.php +++ b/src/Rocketeer/Services/Display/QueueExplainer.php @@ -65,9 +65,10 @@ public function displayBelow(Closure $callback) * * @param string|null $info * @param string|null $details + * @param string|null $origin * @param float|null $time */ - public function display($info = null, $details = null, $time = null) + public function display($info = null, $details = null, $origin = null, $time = null) { if (!$this->hasCommand()) { return; @@ -83,6 +84,9 @@ public function display($info = null, $details = null, $time = null) if ($details) { $comment .= ' ('.$details.')'; } + if ($origin) { + $comment .= ' fired by '.$origin.''; + } if ($time) { $comment .= ' [~'.$time.'s]'; } diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 95b152ea0..63c8f9219 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -170,11 +170,12 @@ public function registerConfiguredEvents() */ public function listenTo($event, $listeners, $priority = 0) { - // Create array if it doesn't exist + /** @type AbstractTask[] $listeners */ $listeners = $this->builder->buildTasks((array) $listeners); // Register events foreach ($listeners as $listener) { + $listener->setEvent($event); $this->events->listen('rocketeer.'.$event, [$listener, 'fire'], $priority); } From f3eb011883f5a7f72883e2150a7ec634fcbde1d1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 21:42:06 +0200 Subject: [PATCH 353/424] Link to upgrade path --- CHANGELOG.md | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 79e668201..283a2da6c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,13 +2,7 @@ ### 2.0.0 -#### Breaking changes - -- Minimum requirement is now PHP 5.4+ -- The `Traits` folder was renamed to `Abstracts`, if you were extending `Rocketeer\Traits\Task`, change that accordingly to `Rocketeer\Abstracts\AbstractTask` -- Connections and stages handling was moved to a ConnectionsHandler class. If you were doing per example `$task->rocketeer->getStage()` you'll need to change it to `$task->connections->getStage()`, etc. - -#### Features and bugfixes +For breaking changes, see the [Upgrade Path](http://rocketeer.autopergamene.eu/#/docs/III-Further/Upgrade-Path) - **Added ability to run tasks in parallel via the `--parallel` flag (or `-P`)** - **Added ability to have multiple servers for one connection, just define them in a `servers` array in your connection, each entry being an usual connection credentials array** From adf751ba4822b3535c38da4e1d51aa3297a04031 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 22:24:09 +0200 Subject: [PATCH 354/424] Add bower to shelled --- src/config/remote.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/config/remote.php b/src/config/remote.php index 98c634832..fba2b6e8b 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -41,7 +41,7 @@ 'shell' => false, // An array of commands to run under shell - 'shelled' => ['which', 'ruby', 'npm', 'bundle', 'grunt'], + 'shelled' => ['which', 'ruby', 'npm', 'bower', 'bundle', 'grunt'], // Permissions$ //////////////////////////////////////////////////////////////////// From e050fffab123350fb93e5e317ccc74946f80ca7f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 22:32:43 +0200 Subject: [PATCH 355/424] Make Cleanup task remove all folders at once --- src/Rocketeer/Tasks/Cleanup.php | 5 ++--- src/Rocketeer/Tasks/Teardown.php | 2 +- .../Traits/BashModules/Filesystem.php | 10 +++++++--- tests/Tasks/CleanupTest.php | 18 ++++++++++++++++++ 4 files changed, 28 insertions(+), 7 deletions(-) diff --git a/src/Rocketeer/Tasks/Cleanup.php b/src/Rocketeer/Tasks/Cleanup.php index abaf11cd4..026638660 100644 --- a/src/Rocketeer/Tasks/Cleanup.php +++ b/src/Rocketeer/Tasks/Cleanup.php @@ -38,9 +38,8 @@ public function execute() } // Prune releases - foreach ($trash as $release) { - $this->removeFolder($this->releasesManager->getPathToRelease($release)); - } + $trash = array_map([$this->releasesManager, 'getPathToRelease'], $trash); + $this->removeFolder($trash); // Create final message $trash = count($trash); diff --git a/src/Rocketeer/Tasks/Teardown.php b/src/Rocketeer/Tasks/Teardown.php index 90b81e6fd..6146dcf5c 100644 --- a/src/Rocketeer/Tasks/Teardown.php +++ b/src/Rocketeer/Tasks/Teardown.php @@ -49,7 +49,7 @@ public function execute() } // Remove remote folders - $this->removeFolder(); + $this->removeFolder($this->paths->getFolder()); // Remove deployments file $this->localStorage->destroy(); diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index af3e773db..5f3c16d49 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -190,13 +190,17 @@ public function createFolder($folder = null, $recursive = false) /** * Remove a folder in the application's folder * - * @param string|null $folder The folder to remove + * @param array|string|null $folders The folder to remove * * @return string The task */ - public function removeFolder($folder = null) + public function removeFolder($folders = null) { - return $this->run('rm -rf '.$this->paths->getFolder($folder)); + $folders = (array) $folders; + $folders = array_map([$this->paths, 'getFolder'], $folders); + $folders = implode(' ', $folders); + + return $this->run('rm -rf '.$folders); } //////////////////////////////////////////////////////////////////// diff --git a/tests/Tasks/CleanupTest.php b/tests/Tasks/CleanupTest.php index 1fca6c40a..dcc962024 100644 --- a/tests/Tasks/CleanupTest.php +++ b/tests/Tasks/CleanupTest.php @@ -41,6 +41,24 @@ public function testCanPruneAllReleasesIfCleanAll() ob_end_clean(); } + public function testCanRemoveAllReleasesAtOnce() + { + $this->mockReleases(function ($mock) { + return $mock + ->shouldReceive('getDeprecatedReleases')->never() + ->shouldReceive('getDeprecatedReleases')->once()->andReturn(array(1, 2)) + ->shouldReceive('getPathToRelease')->times(2)->andReturnUsing(function ($release) { + return $release; + }); + }); + + $this->pretendTask('Cleanup')->execute(); + + $this->assertHistory(array( + 'rm -rf {server}/1 {server}/2' + )); + } + public function testPrintsMessageIfNoCleanup() { $this->mockReleases(function ($mock) { From 8ca851e28b0269acf54af502e2e486366ddf262a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 23:34:18 +0200 Subject: [PATCH 356/424] Fix registered plugins being forgot when switching connection --- src/Rocketeer/Services/TasksHandler.php | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 63c8f9219..14b776146 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -32,6 +32,13 @@ class TasksHandler */ protected $registeredEvents = array(); + /** + * The registered plugins + * + * @type array + */ + protected $registeredPlugins = array(); + /** * Build a new TasksQueue Instance * @@ -147,6 +154,15 @@ public function registerConfiguredEvents() $this->events->forget('rocketeer.'.$event); } + // Clean previously registered plugins + $plugins = $this->registeredPlugins; + $this->registeredPlugins = []; + + // Register plugins again + foreach ($plugins as $plugin) { + $this->plugin($plugin['plugin'], $plugin['configuration']); + } + // Get the registered events $hooks = (array) $this->rocketeer->getOption('hooks'); unset($hooks['custom']); @@ -256,9 +272,12 @@ public function getTasksListeners($task, $event, $flatten = false) */ public function plugin($plugin, array $configuration = array()) { + // Store registration of plugin + $this->registeredPlugins[] = ['plugin' => $plugin, 'configuration' => $configuration]; + // Build plugin if (is_string($plugin)) { - $plugin = $this->app->make($plugin, array($this->app)); + $plugin = $this->app->make($plugin, [$this->app]); } // Register configuration From e9d6fe63a603ee986049f17926fe14304187ea50 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 23:47:27 +0200 Subject: [PATCH 357/424] Add test for failing notifier --- tests/Services/TasksHandlerTest.php | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index a1d659c69..bc5cc2472 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -1,6 +1,7 @@ assertEquals($tasks, $events); } + + public function testPluginsArentDeregisteredWhenSwitchingConnection() + { + $this->swapConfig(array( + 'rocketeer::hooks' => ['before' => ['deploy' => 'ls']], + )); + + $this->tasks->plugin(new DummyNotifier($this->app)); + + $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); + $this->assertEquals('ls', $listeners[0]); + $this->assertCount(2, $listeners); + $this->assertCount(2, $listeners[1]); + + $this->connections->setConnection('production'); + + $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); + $this->assertEquals('ls', $listeners[0]); + $this->assertCount(2, $listeners); + $this->assertCount(2, $listeners[1]); + } } From 5dcdfd2a779672f55bc1d957b091fd915a04bae6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Thu, 21 Aug 2014 23:56:47 +0200 Subject: [PATCH 358/424] Fix plugins registered twice --- src/Rocketeer/Services/TasksHandler.php | 14 +++++++++++--- tests/Plugins/AbstractNotifierTest.php | 2 +- tests/Services/TasksHandlerTest.php | 15 +++++++++++++++ 3 files changed, 27 insertions(+), 4 deletions(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 14b776146..3fcf7e04c 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -272,14 +272,22 @@ public function getTasksListeners($task, $event, $flatten = false) */ public function plugin($plugin, array $configuration = array()) { - // Store registration of plugin - $this->registeredPlugins[] = ['plugin' => $plugin, 'configuration' => $configuration]; - // Build plugin if (is_string($plugin)) { $plugin = $this->app->make($plugin, [$this->app]); } + // Store registration of plugin + $identifier = get_class($plugin); + if (isset($this->registeredPlugins[$identifier])) { + return; + } + + $this->registeredPlugins[$identifier] = array( + 'plugin' => $plugin, + 'configuration' => $configuration + ); + // Register configuration $vendor = $plugin->getNamespace(); $this->config->package('rocketeer/'.$vendor, $plugin->configurationFolder); diff --git a/tests/Plugins/AbstractNotifierTest.php b/tests/Plugins/AbstractNotifierTest.php index 5ff8e5b2c..76fcf87b2 100644 --- a/tests/Plugins/AbstractNotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -53,8 +53,8 @@ public function testCanAppendStageToDetails() { $this->expectOutputString('Jean Eude finished deploying branch "master" on "staging@production" (foo.bar.com)'); $this->localStorage->set('notifier.name', 'Jean Eude'); + $this->tasks->registerConfiguredEvents(); $this->connections->setStage('staging'); - $this->notifier = new DummyNotifier($this->app); $this->task('Deploy')->fireEvent('before'); } diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index bc5cc2472..d1a7e3c4a 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -183,4 +183,19 @@ public function testPluginsArentDeregisteredWhenSwitchingConnection() $this->assertCount(2, $listeners); $this->assertCount(2, $listeners[1]); } + + public function testDoesntRegisterPluginsTwice() + { + $this->swapConfig(array( + 'rocketeer::hooks' => [], + )); + + $this->tasks->plugin(new DummyNotifier($this->app)); + $this->tasks->plugin(new DummyNotifier($this->app)); + $this->tasks->plugin(new DummyNotifier($this->app)); + + $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); + $this->assertCount(1, $listeners); + $this->assertCount(2, $listeners[0]); + } } From e9b31017961a706a359522ec47d4ba0241719295 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 22 Aug 2014 00:09:24 +0200 Subject: [PATCH 359/424] More work on events --- src/Rocketeer/Plugins/AbstractNotifier.php | 8 ++++---- src/Rocketeer/Services/TasksHandler.php | 15 +++++++++++---- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/src/Rocketeer/Plugins/AbstractNotifier.php b/src/Rocketeer/Plugins/AbstractNotifier.php index 19edb0974..ecba0f380 100644 --- a/src/Rocketeer/Plugins/AbstractNotifier.php +++ b/src/Rocketeer/Plugins/AbstractNotifier.php @@ -28,13 +28,13 @@ abstract class AbstractNotifier extends AbstractPlugin */ public function onQueue(TasksHandler $queue) { - $queue->before('deploy', function ($task) { + $queue->addTaskListeners('deploy', 'before', function ($task) { $this->prepareThenSend($task, 'before_deploy'); - }, -10); + }, -10, true); - $queue->after('deploy', function ($task) { + $queue->addTaskListeners('deploy', 'after', function ($task) { $this->prepareThenSend($task, 'after_deploy'); - }, -10); + }, -10, true); } /** diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 3fcf7e04c..16908fbe4 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -155,7 +155,7 @@ public function registerConfiguredEvents() } // Clean previously registered plugins - $plugins = $this->registeredPlugins; + $plugins = $this->registeredPlugins; $this->registeredPlugins = []; // Register plugins again @@ -170,7 +170,7 @@ public function registerConfiguredEvents() // Bind events foreach ($hooks as $event => $tasks) { foreach ($tasks as $task => $listeners) { - $this->registeredEvents[] = $this->addTaskListeners($task, $event, $listeners); + $this->addTaskListeners($task, $event, $listeners, 0, true); } } } @@ -205,15 +205,17 @@ public function listenTo($event, $listeners, $priority = 0) * @param string $event * @param array|callable $listeners * @param integer $priority + * @param boolean $register * + * @throws \Rocketeer\Exceptions\TaskCompositionException * @return string|null */ - public function addTaskListeners($task, $event, $listeners, $priority = 0) + public function addTaskListeners($task, $event, $listeners, $priority = 0, $register = false) { // Recursive call if (is_array($task)) { foreach ($task as $t) { - $this->addTaskListeners($t, $event, $listeners, $priority); + $this->addTaskListeners($t, $event, $listeners, $priority, $register); } return; @@ -229,6 +231,11 @@ public function addTaskListeners($task, $event, $listeners, $priority = 0) $event = $slug.'.'.$event; $event = $this->listenTo($event, $listeners, $priority); + // Store registered event + if ($register) { + $this->registeredEvents[] = $event; + } + return $event; } From 56d47a26ecb17f7111baaaa1ed3455e39b77dbd8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 22 Aug 2014 00:15:19 +0200 Subject: [PATCH 360/424] Fix events being re-registered when staying on the same connection/stage --- .../Connections/ConnectionsHandler.php | 6 ++++- .../Connections/ConnectionsHandlerTest.php | 24 +++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 1f8e74f06..29301ea1d 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -118,6 +118,10 @@ public function isMultiserver($connection) */ public function setStage($stage) { + if ($stage == $this->stage) { + return; + } + $this->stage = $stage; // If we do have a stage, cleanup previous events @@ -326,7 +330,7 @@ public function setConnections($connections) */ public function setConnection($connection, $server = 0) { - if (!$this->isValidConnection($connection)) { + if (!$this->isValidConnection($connection) || $this->connection == $connection) { return; } diff --git a/tests/Services/Connections/ConnectionsHandlerTest.php b/tests/Services/Connections/ConnectionsHandlerTest.php index 6604f8be3..5ff54af06 100644 --- a/tests/Services/Connections/ConnectionsHandlerTest.php +++ b/tests/Services/Connections/ConnectionsHandlerTest.php @@ -129,6 +129,30 @@ public function testDoesntDisplayServerNumberIfNotMultiserver() $this->assertEquals('foo/staging', $handle); } + public function testDoesntResetConnectionIfSameAsCurrent() + { + $this->mock('rocketeer.tasks', 'TasksHandler', function ($mock) { + return $mock + ->shouldReceive('registerConfiguredEvents')->once(); + }, false); + + $this->connections->setConnection('production'); + $this->connections->setConnection('production'); + $this->connections->setConnection('production'); + } + + public function testDoesntResetStageIfSameAsCurrent() + { + $this->mock('rocketeer.tasks', 'TasksHandler', function ($mock) { + return $mock + ->shouldReceive('registerConfiguredEvents')->once(); + }, false); + + $this->connections->setStage('foobar'); + $this->connections->setStage('foobar'); + $this->connections->setStage('foobar'); + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// HELPERS /////////////////////////// //////////////////////////////////////////////////////////////////// From f1858dfe6d5db22a986b83ecd98b914f418fb6e5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 22 Aug 2014 13:40:05 +0200 Subject: [PATCH 361/424] Remove deprecated accessor --- src/Rocketeer/Traits/HasLocator.php | 2 -- tests/Strategies/Deploy/CopyStrategyTest.php | 10 +++------- 2 files changed, 3 insertions(+), 9 deletions(-) diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 6e29a20a6..4645dd4eb 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -24,7 +24,6 @@ * @property \Rocketeer\Bash bash * @property \Rocketeer\Console\Console console * @property \Rocketeer\Interfaces\ScmInterface scm - * @property \Rocketeer\Interfaces\Strategies\DeployStrategyInterface strategy * @property \Rocketeer\Rocketeer rocketeer * @property \Rocketeer\Services\Connections\ConnectionsHandler connections * @property \Rocketeer\Services\Connections\RemoteHandler remote @@ -85,7 +84,6 @@ public function __get($key) 'remote' => 'rocketeer.remote', 'rocketeer' => 'rocketeer.rocketeer', 'scm' => 'rocketeer.scm', - 'strategy' => 'rocketeer.strategy', 'tasks' => 'rocketeer.tasks', 'timer' => 'rocketeer.timer', ); diff --git a/tests/Strategies/Deploy/CopyStrategyTest.php b/tests/Strategies/Deploy/CopyStrategyTest.php index 1aead9242..1e42398c6 100644 --- a/tests/Strategies/Deploy/CopyStrategyTest.php +++ b/tests/Strategies/Deploy/CopyStrategyTest.php @@ -10,16 +10,12 @@ public function setUp() { parent::setUp(); - $this->app->bind('rocketeer.strategy', function ($app) { - return new CopyStrategy($app); - }); - $this->pretend(); } public function testCanCopyPreviousRelease() { - $this->strategy->deploy(); + $this->builder->buildStrategy('Deploy', 'Copy')->deploy(); $matcher = array( 'cp -r {server}/releases/10000000000000 {server}/releases/20000000000000', @@ -40,7 +36,7 @@ public function testClonesIfNoPreviousRelease() ->shouldReceive('getCurrentReleasePath')->andReturn($this->server.'/releases/10000000000000'); }); - $this->strategy->deploy(); + $this->builder->buildStrategy('Deploy', 'Copy')->deploy(); $matcher = array( 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', @@ -62,7 +58,7 @@ public function testCanCloneIfPreviousReleaseIsInvalid() ->shouldReceive('getCurrentReleasePath')->andReturn($this->server.'/releases/10000000000000'); }); - $this->strategy->deploy(); + $this->builder->buildStrategy('Deploy', 'Copy')->deploy(); $matcher = array( 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', From f9dce0d0230659dccde5cc7f6571f8768b64ff4a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 22 Aug 2014 23:00:50 +0200 Subject: [PATCH 362/424] Make the AbstractNotifier fire an actual Notify task --- src/Rocketeer/Plugins/AbstractNotifier.php | 74 ++---------- src/Rocketeer/Services/Tasks/TasksBuilder.php | 5 + .../Tasks/Subtasks/CreateRelease.php | 5 + src/Rocketeer/Tasks/Subtasks/Notify.php | 113 ++++++++++++++++++ tests/Dummies/DummyNotifier.php | 2 +- 5 files changed, 131 insertions(+), 68 deletions(-) create mode 100644 src/Rocketeer/Tasks/Subtasks/Notify.php diff --git a/src/Rocketeer/Plugins/AbstractNotifier.php b/src/Rocketeer/Plugins/AbstractNotifier.php index ecba0f380..3dd8f37da 100644 --- a/src/Rocketeer/Plugins/AbstractNotifier.php +++ b/src/Rocketeer/Plugins/AbstractNotifier.php @@ -9,10 +9,9 @@ */ namespace Rocketeer\Plugins; -use Illuminate\Support\Arr; use Rocketeer\Abstracts\AbstractPlugin; -use Rocketeer\Abstracts\AbstractTask; use Rocketeer\Services\TasksHandler; +use Rocketeer\Tasks\Subtasks\Notify; /** * A base class for notification services to extends @@ -28,13 +27,12 @@ abstract class AbstractNotifier extends AbstractPlugin */ public function onQueue(TasksHandler $queue) { - $queue->addTaskListeners('deploy', 'before', function ($task) { - $this->prepareThenSend($task, 'before_deploy'); - }, -10, true); + // Create the task instance + $notify = new Notify($this->app); + $notify->setNotifier($this); - $queue->addTaskListeners('deploy', 'after', function ($task) { - $this->prepareThenSend($task, 'after_deploy'); - }, -10, true); + $queue->addTaskListeners('deploy', 'before', [$notify], -10, true); + $queue->addTaskListeners('deploy', 'after', [$notify], -10, true); } /** @@ -46,40 +44,6 @@ public function onQueue(TasksHandler $queue) */ abstract public function send($message); - //////////////////////////////////////////////////////////////////// - /////////////////////////////// MESSAGE //////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Get the message's components - * - * @return string[] - */ - protected function getComponents() - { - // Get user name - $user = $this->localStorage->get('notifier.name'); - if (!$user) { - $user = $this->command->ask('Who is deploying ?'); - $this->localStorage->set('notifier.name', $user); - } - - // Get what was deployed - $branch = $this->connections->getRepositoryBranch(); - $stage = $this->connections->getStage(); - $connection = $this->connections->getConnection(); - $server = $this->connections->getServer(); - - // Get hostname - $credentials = $this->connections->getServerCredentials($connection, $server); - $host = Arr::get($credentials, 'host'); - if ($stage) { - $connection = $stage.'@'.$connection; - } - - return compact('user', 'branch', 'connection', 'host'); - } - /** * Get the default message format * @@ -87,29 +51,5 @@ protected function getComponents() * * @return string */ - abstract protected function getMessageFormat($message); - - /** - * Prepare and send a message - * - * @param AbstractTask $task - * @param string $message - * - * @return void - */ - public function prepareThenSend(AbstractTask $task, $message) - { - // Don't send a notification if pretending to deploy - if ($task->command->option('pretend')) { - return; - } - - // Build message - $message = $this->getMessageFormat($message); - $message = preg_replace('#\{([0-9])\}#', '%$1\$s', $message); - $message = vsprintf($message, $this->getComponents()); - - // Send it - $this->send($message); - } + abstract public function getMessageFormat($message); } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index 255f2fe02..d22063ff2 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -147,6 +147,11 @@ public function buildTask($task, $name = null, $description = null) */ protected function composeTask($task) { + // If already built, return it + if ($task instanceof AbstractTask) { + return $task; + } + // If we provided a Closure, build a ClosureTask if ($task instanceof Closure) { return $this->buildTaskFromClosure($task); diff --git a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php index 9c1e7cdb1..a07d297e8 100644 --- a/src/Rocketeer/Tasks/Subtasks/CreateRelease.php +++ b/src/Rocketeer/Tasks/Subtasks/CreateRelease.php @@ -11,6 +11,11 @@ use Rocketeer\Abstracts\AbstractTask; +/** + * Creates a new release on the server + * + * @author Maxime Fabre + */ class CreateRelease extends AbstractTask { /** diff --git a/src/Rocketeer/Tasks/Subtasks/Notify.php b/src/Rocketeer/Tasks/Subtasks/Notify.php new file mode 100644 index 000000000..147211d52 --- /dev/null +++ b/src/Rocketeer/Tasks/Subtasks/Notify.php @@ -0,0 +1,113 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ +namespace Rocketeer\Tasks\Subtasks; + +use Illuminate\Support\Arr; +use Rocketeer\Abstracts\AbstractTask; +use Rocketeer\Plugins\AbstractNotifier; + +/** + * Notify a third-party service + * + * @author Maxime Fabre + */ +class Notify extends AbstractTask +{ + /** + * The message format + * + * @type AbstractNotifier + */ + protected $notifier; + + /** + * A description of what the task does + * + * @var string + */ + protected $description = 'Notify a third-party service'; + + /** + * Run the task + * + * @return string + */ + public function execute() + { + $hook = str_replace('deploy.', null, $this->event).'_deploy'; + + $this->prepareThenSend($hook); + } + + /** + * @param AbstractNotifier $notifier + */ + public function setNotifier($notifier) + { + $this->notifier = $notifier; + } + + //////////////////////////////////////////////////////////////////// + /////////////////////////////// MESSAGE //////////////////////////// + //////////////////////////////////////////////////////////////////// + + /** + * Get the message's components + * + * @return string[] + */ + protected function getComponents() + { + // Get user name + $user = $this->localStorage->get('notifier.name'); + if (!$user) { + $user = $this->command->ask('Who is deploying ?'); + $this->localStorage->set('notifier.name', $user); + } + + // Get what was deployed + $branch = $this->connections->getRepositoryBranch(); + $stage = $this->connections->getStage(); + $connection = $this->connections->getConnection(); + $server = $this->connections->getServer(); + + // Get hostname + $credentials = $this->connections->getServerCredentials($connection, $server); + $host = Arr::get($credentials, 'host'); + if ($stage) { + $connection = $stage.'@'.$connection; + } + + return compact('user', 'branch', 'connection', 'host'); + } + + /** + * Prepare and send a message + * + * @param string $message + * + * @return void + */ + public function prepareThenSend($message) + { + // Don't send a notification if pretending to deploy + if ($this->command->option('pretend')) { + return; + } + + // Build message + $message = $this->notifier->getMessageFormat($message); + $message = preg_replace('#\{([0-9])\}#', '%$1\$s', $message); + $message = vsprintf($message, $this->getComponents()); + + // Send it + $this->notifier->send($message); + } +} diff --git a/tests/Dummies/DummyNotifier.php b/tests/Dummies/DummyNotifier.php index 03ac797a1..548218438 100644 --- a/tests/Dummies/DummyNotifier.php +++ b/tests/Dummies/DummyNotifier.php @@ -12,7 +12,7 @@ class DummyNotifier extends AbstractNotifier * * @return string */ - protected function getMessageFormat($message) + public function getMessageFormat($message) { return '{1} finished deploying branch "{2}" on "{3}" ({4})'; } From 933d27cf5c621e57233400c4accf7396747c3e95 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 22 Aug 2014 23:07:08 +0200 Subject: [PATCH 363/424] Add NodeStrategy --- .../Console/Commands/StrategiesCommand.php | 2 +- .../Strategies/Check/NodeStrategy.php | 75 +++++++++++++++++++ 2 files changed, 76 insertions(+), 1 deletion(-) create mode 100644 src/Rocketeer/Strategies/Check/NodeStrategy.php diff --git a/src/Rocketeer/Console/Commands/StrategiesCommand.php b/src/Rocketeer/Console/Commands/StrategiesCommand.php index ffda744d5..848bc2514 100644 --- a/src/Rocketeer/Console/Commands/StrategiesCommand.php +++ b/src/Rocketeer/Console/Commands/StrategiesCommand.php @@ -41,7 +41,7 @@ class StrategiesCommand extends AbstractCommand public function fire() { $strategies = array( - 'check' => ['Php', 'Ruby'], + 'check' => ['Php', 'Ruby', 'Node'], 'deploy' => ['Clone', 'Copy', 'Sync'], 'test' => ['Phpunit'], 'migrate' => ['Artisan'], diff --git a/src/Rocketeer/Strategies/Check/NodeStrategy.php b/src/Rocketeer/Strategies/Check/NodeStrategy.php new file mode 100644 index 000000000..778ffdeb1 --- /dev/null +++ b/src/Rocketeer/Strategies/Check/NodeStrategy.php @@ -0,0 +1,75 @@ + + */ +class NodeStrategy extends AbstractCheckStrategy implements CheckStrategyInterface +{ + /** + * @type string + */ + protected $description = 'Checks if the server is ready to receive a Node application'; + + /** + * The language of the strategy + * + * @type string + */ + protected $language = 'Node'; + + /** + * Get the version constraint which should be checked against + * + * @param string $manifest + * + * @return string + */ + protected function getLanguageConstraint($manifest) + { + $manifest = json_decode($manifest, true); + $constraint = Arr::get($manifest, 'engines.node'); + $constraint = preg_replace('/[~>= ]+ ?(.+)/', '$1', $constraint); + + return $constraint; + } + + /** + * Get the current version in use + * + * @return string + */ + protected function getCurrentVersion() + { + $version = $this->binary('node')->run('--version'); + $version = str_replace('v', null, $version); + + return $version; + } + + /** + * Check for the required extensions + * + * @return array + */ + public function extensions() + { + return []; + } + + /** + * Check for the required drivers + * + * @return array + */ + public function drivers() + { + return []; + } +} From 5e1e66d3ce4949e46d9fdf430ebb33c49ee97b3c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 01:47:42 +0200 Subject: [PATCH 364/424] Deduplicate JSON language constraints --- .../Strategies/AbstractCheckStrategy.php | 19 +++++++++++++++++++ src/Rocketeer/Services/Tasks/TasksBuilder.php | 2 +- .../Strategies/Check/NodeStrategy.php | 6 +----- .../Strategies/Check/PhpStrategy.php | 8 +------- src/Rocketeer/Tasks/Migrate.php | 2 +- src/Rocketeer/Tasks/Subtasks/Notify.php | 2 +- 6 files changed, 24 insertions(+), 15 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php index 3338b71bf..6afd8c665 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -90,4 +90,23 @@ abstract protected function getLanguageConstraint($manifest); * @return string */ abstract protected function getCurrentVersion(); + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * @param string $manifest + * @param string $handle + * + * @return string + */ + protected function getLanguageConstraintFromJson($manifest, $handle) + { + $manifest = json_decode($manifest, true); + $constraint = (string) Arr::get($manifest, $handle); + $constraint = preg_replace('/[~>= ]+ ?(.+)/', '$1', $constraint); + + return $constraint; + } } diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index d22063ff2..d9512edc6 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -176,7 +176,7 @@ protected function composeTask($task) /** * Build a task from a string * - * @param string $task + * @param string|string[] $task * * @return AbstractTask */ diff --git a/src/Rocketeer/Strategies/Check/NodeStrategy.php b/src/Rocketeer/Strategies/Check/NodeStrategy.php index 778ffdeb1..517cd1aa3 100644 --- a/src/Rocketeer/Strategies/Check/NodeStrategy.php +++ b/src/Rocketeer/Strategies/Check/NodeStrategy.php @@ -33,11 +33,7 @@ class NodeStrategy extends AbstractCheckStrategy implements CheckStrategyInterfa */ protected function getLanguageConstraint($manifest) { - $manifest = json_decode($manifest, true); - $constraint = Arr::get($manifest, 'engines.node'); - $constraint = preg_replace('/[~>= ]+ ?(.+)/', '$1', $constraint); - - return $constraint; + return $this->getLanguageConstraintFromJson($manifest, 'engines.node'); } /** diff --git a/src/Rocketeer/Strategies/Check/PhpStrategy.php b/src/Rocketeer/Strategies/Check/PhpStrategy.php index 4540f1891..82b4bd786 100644 --- a/src/Rocketeer/Strategies/Check/PhpStrategy.php +++ b/src/Rocketeer/Strategies/Check/PhpStrategy.php @@ -49,13 +49,7 @@ public function __construct(Container $app) */ protected function getLanguageConstraint($manifest) { - $manifest = json_decode($manifest, true); - - // Strip versions of constraints - $required = (string) Arr::get($manifest, 'require.php'); - $required = preg_replace('/>=/', '', $required); - - return $required; + return $this->getLanguageConstraintFromJson($manifest, 'require.php'); } /** diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index 0e7a890e0..36499080f 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -23,7 +23,7 @@ class Migrate extends AbstractTask /** * Run the task * - * @return boolean|null + * @return boolean|boolean[] */ public function execute() { diff --git a/src/Rocketeer/Tasks/Subtasks/Notify.php b/src/Rocketeer/Tasks/Subtasks/Notify.php index 147211d52..2c6bbba98 100644 --- a/src/Rocketeer/Tasks/Subtasks/Notify.php +++ b/src/Rocketeer/Tasks/Subtasks/Notify.php @@ -37,7 +37,7 @@ class Notify extends AbstractTask /** * Run the task * - * @return string + * @return string|null */ public function execute() { From d6e87cbe7961984d0c612ba7a97581b88c137b9e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 01:53:52 +0200 Subject: [PATCH 365/424] Missing use --- bin/compile | 4 ++-- .../Abstracts/Strategies/AbstractCheckStrategy.php | 2 ++ src/Rocketeer/Strategies/Check/NodeStrategy.php | 1 - src/Rocketeer/Strategies/Check/PhpStrategy.php | 1 - src/config/config.php | 12 +++++------- src/config/strategies.php | 4 ++++ 6 files changed, 13 insertions(+), 11 deletions(-) diff --git a/bin/compile b/bin/compile index b67c97911..f88350e72 100755 --- a/bin/compile +++ b/bin/compile @@ -4,7 +4,7 @@ require __DIR__.'/../vendor/autoload.php'; // Create Phar $compiler = new Rocketeer\Console\Compiler; -$phar = $compiler->compile(); +$phar = $compiler->compile(); // Set permissions -chmod($phar, 0755); \ No newline at end of file +chmod($phar, 0755); diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php index 6afd8c665..f073df93d 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -1,6 +1,8 @@ function (ConnectionsHandler $connections) { + 'logs' => function (ConnectionsHandler $connections) { return sprintf('%s-%s-%s.log', $connections->getConnection(), $connections->getStage(), date('Ymd')); }, @@ -22,13 +22,13 @@ //////////////////////////////////////////////////////////////////// // The default remote connection(s) to execute tasks on - 'default' => array('{connection}'), + 'default' => array('{connection}'), // The various connections you defined // You can leave all of this empty or remove it entirely if you don't want // to track files with credentials : Rocketeer will prompt you for your credentials // and store them locally - 'connections' => array( + 'connections' => array( 'production' => array( 'host' => '{host}', 'username' => '{username}', @@ -57,12 +57,10 @@ 'on' => array( // Stages configurations - 'stages' => array( - ), + 'stages' => array(), // Connections configuration - 'connections' => array( - ), + 'connections' => array(), ), diff --git a/src/config/strategies.php b/src/config/strategies.php index 6bb2440b1..2e8ff01f1 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -37,6 +37,10 @@ }, ), + // Here you can configure the Primer tasks + // which will run a set of commands on the local + // machine, determining whether the deploy can proceed + // or not 'primer' => function (Primer $task) { return array( // $task->executeTask('Test'), From 94def7912c78cae3316e978a74f033f9b99ada4b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 02:18:11 +0200 Subject: [PATCH 366/424] Update CHANGELOG format to keepachangelog --- CHANGELOG.md | 252 ++++++++++++++++++++++++++++++++++----------------- 1 file changed, 170 insertions(+), 82 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 283a2da6c..a454b490e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,14 +1,19 @@ -### Changelog +# Changelog -### 2.0.0 +2.0.0 +----- -For breaking changes, see the [Upgrade Path](http://rocketeer.autopergamene.eu/#/docs/III-Further/Upgrade-Path) - -- **Added ability to run tasks in parallel via the `--parallel` flag (or `-P`)** -- **Added ability to have multiple servers for one connection, just define them in a `servers` array in your connection, each entry being an usual connection credentials array** +### Added +- Added ability to run tasks in parallel via the `--parallel` flag (or `-P`) +- Added ability to have multiple servers for one connection, just define them in a `servers` array in your connection, each entry being an usual connection credentials array - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions - Added `Task::upload(file, destination)` to upload files to remote, destination can be null and the basename of the file would then be used + +### Changed +- For breaking changes, see the [Upgrade Path](http://rocketeer.autopergamene.eu/#/docs/III-Further/Upgrade-Path) + +### Fixed - Fixed a bug where `rocketeer current` would fail to find the related task - Fixed a bug where Artisan wouldn't be found even if at the default location - Fixed a bug where ignition would fail when the default connection isn't `production` @@ -18,192 +23,275 @@ For breaking changes, see the [Upgrade Path](http://rocketeer.autopergamene.eu/# - Fixed a bug where events wouldn't be properly rebooted when using connections other than the default ones - Fixed a bug where Rocketeer would ask for credentials again after switching connection -### 1.2.2 +1.2.2 - 2014-06-05 +------------------ -- **The Notifier plugin module now has a hook for before and after deployment** +### Added - Add ability to disable composer completely - Add support for ssh-agent for secure connections + +### Changed +- The Notifier plugin module now has a hook for before and after deployment + +### Fixed - Fixed a bug that prevented the `--seed` option from working - Fixed a bug when getting the user's home folder on Windows - Fixed a bug where Composer-related tasks would be run even without a `composer.json` is found - Fixed some compatibility issue with Laravel 4.2 -### 1.2.1 +1.2.1 - 2014-03-31 +------------------ +### Changed +- Split `remote/application_name` in `config/application_name` and `remote/app_directory` to allow contextual application folder name +- The `composer self-update` command is now commented out by default + +### Fixed - Fixed a bug where `composer install` wouldn't return the proper status code and would cancel deployment - Fixed a bug where empty arrays wouldn't override defaults in the configuration - Fixed path to home folder not being properly found in Windows environment -- Split `remote/application_name` in `config/application_name` and `remote/app_directory` to allow contextual application folder name -- The `composer self-update` command is now commented out by default -### 1.2.0 +1.2.0 - 2014-03-08 +------------------ -- **Added various SSH task-running helpers such as `Rocketeer::task(taskname, task)`** -- **Rocketeer now has a `copy` strategy that copies the previous release instead of cloning a new one on deploy** -- **Composer execution is now configurable via a callback** +### Added +- Added various SSH task-running helpers such as `Rocketeer::task(taskname, task)` +- Rocketeer now has a `copy` strategy that copies the previous release instead of cloning a new one on deploy +- Composer execution is now configurable via a callback - Added an option to disable recursive git clone (submodules) - Releases are now sorted by date when printed out in `rollback` and `current` + +### Fixed - Fixed a bug when running Setup would cancel the `--stage` option - Fixed a bug where contextual options weren't properly merged with default ones -### 1.1.2 +1.1.2 - 2014-02-12 +------------------ +### Added - Added a `Rocketeer\Plugins\Notifier` class to easily add third-party deployment notification plugins + +### Fixed - Fixed a bug where the custom tasks/events file/folders might not exist -### 1.1.1 +1.1.1 - 2014-02-08 +------------------ +### Fixed - Fixed a bug where the `before` event if halting wouldn't cancel the Task firing - Fixed a bug where some calls to the facade would crash in `tasks.php` -### 1.1.0 +1.1.0 - 2014-02-08 +------------------ -- **Events can now cancel the queue by returning false or returning `$task->halt(error)`** -- **Rocketeer now logs its output and commands** -- **Releases are now marked as completed or halted to avoid rollback to releases that errored** +### Added +- Events can now cancel the queue by returning false or returning `$task->halt(error)` +- Rocketeer now logs its output and commands +- Releases are now marked as completed or halted to avoid rollback to releases that errored - Rocketeer will now automatically load `.rocketeer/tasks.php`/`.rocketeer/events.php` _or_ the contents of `.rocketeer/tasks`/`.rocketeer/events` if they're folders - Hash is now computed with the actual configuration instead of the modification times to avoid unecessary reflushes - Check task now uses the PHP version required in your `composer.json` file if the latter exists + +### Fixed - Use the server's time to timestamp releases instead of the local time - Fixed a bug where incorrect current release would be returned for multi-servers setups -### 1.0.0 +1.0.0 - 2014-01-13 +------------------ -**Note : Configuration is now split in multiple files, you'll need to redeploy the configuration files** - -- **Rocketeer is now available as a [standalone PHAR](http://rocketeer.autopergamene.eu/versions/rocketeer.phar)** -- **Revamped plugin system** -- **Rocketeer hooks now use `illuminate/event` system, and can fire events during tasks (instead of just before and after)** -- **Permissions setting is now set in a callback to allow custom permissions routines** +### Added +- Rocketeer is now available as a [standalone PHAR](http://rocketeer.autopergamene.eu/versions/rocketeer.phar) +- Revamped plugin system +- Rocketeer hooks now use `illuminate/event` system, and can fire events during tasks (instead of just before and after) +- Permissions setting is now set in a callback to allow custom permissions routines - Rocketeer now looks into `~/.ssh` by default for keys instead of asking - Added the `--clean-all` flag to the `Cleanup` task to prune all but the latest release - Deployments file is now cleared when the config files are changed - Added an option to disable shallow clone as it caused some problems on some servers + +### Deprecated +- Configuration is now split in multiple files, you'll need to redeploy the configuration files + +### Fixed - Fixed a bug where `CurrentRelease` wouldn't show any release with an empty/fresh deployments file - Fix some multiconnections related bugs - Fixed some minor behaviors that were causing `--pretend` and/or `--verbose` to not output SCM commands -### 0.9.0 +0.9.0 - 2013-11-15 +------------------ -- **Rocketeer now supports SVN** -- **Rocketeer now has a [Campfire plugin](https://github.com/Anahkiasen/rocketeer-campfire)** +### Added +- Rocketeer now supports SVN +- Rocketeer now has a [Campfire plugin](https://github.com/Anahkiasen/rocketeer-campfire) - Add option to manually set remote variables when encountering problems - Add keyphrase support -### 0.8.0 +0.8.0 - 2013-10-19 +------------------ -- **Rocketeer can now have specific configurations for stages and connections** -- **Better handling of multiple connections** -- **Added facade shortcuts `Rocketeer::execute(Task)` and `Rocketeer::on(connection[s], Task)` to execute commands on the remote servers** +### Added +- Rocketeer can now have specific configurations for stages and connections +- Better handling of multiple connections +- Added facade shortcuts `Rocketeer::execute(Task)` and `Rocketeer::on(connection[s], Task)` to execute commands on the remote servers - Added the `--list` flag on the `rollback` command to show a list of available releases and pick one to rollback to - Added the `--on` flag to all commands to specify which connections the task should be executed on (ex. `production`, `staging,production`) - Added `deploy:flush` to clear Rocketeer's cache of credentials -### 0.7.0 +0.7.0 - 2013-08-16 +------------------ -- **Rocketeer can now work outside of Laravel** -- **Better handling of SSH keys** +### Added +- Rocketeer can now work outside of Laravel +- Better handling of SSH keys - Permissions are now entirely configurable - Rocketeer now prompts for confirmation before executing the Teardown task - Allow the use of patterns in shared folders -- Share `sessions` folder by default - Rocketeer now prompts for binaries it can't find (composer, phpunit, etc) -### 0.6.5 +### Changed +- Share `sessions` folder by default + +0.6.5 - 2013-07-29 +------------------ -- **Make Rocketeer prompt for both server and SCM credentials if they're not stored** -- **`artisan deploy` now deploys the project if the `--version` flat is not passed** +### Added +- Make Rocketeer prompt for both server and SCM credentials if they're not stored +- `artisan deploy` now deploys the project if the `--version` flat is not passed - Make Rocketeer forget invalid credentials provided by prompt + +### Fixed - Fix a bug where incorrect SCM urls would be generated -### 0.6.4 +0.6.4 - 2013-07-16 +------------------ +### Added - Make the output of commands in realtime when `--verbose` instead of when the command is done + +### Changed +- Reverse sluggification of application name + +### Fixed - Fix a bug where custom Task classes would be analyzed as string commands - Fix Rocketeeer not taking into account custom paths to **app/**, **storage/**, **public/** etc. -- Reverse sluggification of application name -### 0.6.3 +0.6.3 - 2013-07-11 +------------------ +### Changed - Application name is now always sluggified as a security + +### Fixed - Fix a bug where the Check task would fail on pretend mode - Fix a bug where invalid directory separators would get cached and used -### 0.6.2 +0.6.2 - 2013-07-11 +------------------ +### Added - Make the Check task check for the remote presence of the configured SCM + +### Fixed - Fix Rocketeer not being able to use a `composer.phar` on the server -### 0.6.1 +0.6.1 - 2013-07-10 +------------------ -- Fix a bug where the configured user would not have the rights to set permissions +### Fixed +- Fixed a bug where the configured user would not have the rights to set permissions -### 0.6.0 +0.6.0 - 2013-07-06 +------------------ -- **Add multistage strategy** -- **Add compatibility to Laravel 4.0** -- Migrations are now under a `--migrate` flag +### Added +- Add multistage strategy +- Add compatibility to Laravel 4.0 - Split Git from the SCM implementation (**requires a config update**) + +### Changed +- Migrations are now under a `--migrate` flag - Releases are now named as `YmdHis` instead of `time()` - If the `scm.branch` option is empty, Rocketeer will now use the current Git branch -- Fix a delay where the `current` symlink would get updated before the complete end of the deploy -- Fix errors with Git and Composer not canceling deploy -- Fix some compatibility problems with Windows -- Fix a bug where string tasks would not be run in latest release folder -- Fix Apache username and group using `www-data` by default -### 0.5.0 +### Fixed +- Fixed a delay where the `current` symlink would get updated before the complete end of the deploy +- Fixed errors with Git and Composer not canceling deploy +- Fixed some compatibility problems with Windows +- Fixed a bug where string tasks would not be run in latest release folder +- Fixed Apache username and group using `www-data` by default + +0.5.0 - 2013-07-01 +------------------ -- **Add a `deploy:update` task that updates the remote server without doing a new release** -- **Add a `deploy:test` to run the tests on the server** -- **Rocketeer can now prompt for Git credentials if you don't want to store them in the config** +### Added +- Added a `deploy:update` task that updates the remote server without doing a new release +- Added a `deploy:test` to run the tests on the server +- Rocketeer can now prompt for Git credentials if you don't want to store them in the config - The `deploy:check` command now checks PHP extensions for the cache/database/session drivers you set - Rocketeer now share logs by default between releases - Add ability to specify an array of Tasks in Rocketeer::before|after - Added a `$silent` flag to make a `Task::run` call silent no matter what - Rocketeer now displays how long the task took -### 0.4.0 +0.4.0 - 2013-06-26 +------------------ -- **Add ability to share files and folders between releases** -- **Add ability to create custom tasks integrated in the CLI** -- **Add a `deploy:check` Task that checks if the server is ready to receive a Laravel app** -- Add `Task::listContents` and `Task::fileExists` helpers -- Add Task helper to run outstanding migrations -- Add `Rocketeer::add` method on the facade to register custom Tasks -- Fix `Task::runComposer` not taking into account a local `composer.phar` +### Added +- Added ability to share files and folders between releases +- Added ability to create custom tasks integrated in the CLI +- Added a `deploy:check` Task that checks if the server is ready to receive a Laravel app +- Added `Task::listContents` and `Task::fileExists` helpers +- Added Task helper to run outstanding migrations +- Added `Rocketeer::add` method on the facade to register custom Tasks -### 0.3.2 +### Fixed +- Fixed `Task::runComposer` not taking into account a local `composer.phar` +0.3.2 - 2013-06-25 +------------------ + +### Fixed - Fixed wrong tag used in `deploy:cleanup` -### 0.3.1 +0.3.1 - 2013-06-24 +------------------ +### Added - Added `--pretend` flag on all commands to print out a list of the commands that would have been executed instead of running them -### 0.3.0 +0.3.0 - 2013-06-24 +------------------ +### Added - Added `Task::runInFolder` to run tasks in a specific folder - Added `Task::runForCurrentRelease` Task helper -- Fixed a bug where `Task::run` would only return the last line of the command's output - Added `Task::runTests` methods to run the PHPUnit tests of the application - Integrated `Task::runTests` in the `Deploy` task under the `--tests` flag ; failing tests will cancel deploy and rollback -### 0.2.0 +### Fixed +- Fixed a bug where `Task::run` would only return the last line of the command's output + +0.2.0 - 2013-06-24 +------------------ +### Added - The core of Rocketeer's actions is now split into a system of Tasks for flexibility - Added a `Rocketeer` facade to easily add tasks via `before` and `after` (see Tasks docs) -### 0.1.1 +0.1.1 - 2013-06-23 +------------------ +### Fixed - Fixed a bug where the commands would try to connect to the remote hosts on construct - Fixed `ReleasesManager::getPreviousRelease` returning the wrong release -### 0.1.0 +0.1.0 - 2013-06-23 +------------------ -- Add `deploy:teardown` to remove the application from remote servers -- Add support for the connections defined in the remote config file -- Add `deploy:rollback` and `deploy:current` commands -- Add `deploy:cleanup` command -- Add config file -- Add `deploy:setup` and `deploy:deploy` commands +### Added +- Added `deploy:teardown` to remove the application from remote servers +- Added support for the connections defined in the remote config file +- Added `deploy:rollback` and `deploy:current` commands +- Added `deploy:cleanup` command +- Added config file +- Added `deploy:setup` and `deploy:deploy` commands From 3e6e0ebaf57d4b82bde3e26df4f8d9afe1da2007 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 02:31:01 +0200 Subject: [PATCH 367/424] Update CHANGELOG --- CHANGELOG.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index a454b490e..88222a515 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,14 +6,20 @@ ### Added - Added ability to run tasks in parallel via the `--parallel` flag (or `-P`) - Added ability to have multiple servers for one connection, just define them in a `servers` array in your connection, each entry being an usual connection credentials array +- Added support for defining contextual configurations in files (`.rocketeer/connections/{connection}/scm.php`, same for stages) +- Core tasks (Deploy, Check, Test, Migrate) now use a module system called Strategies +- Added a `Sync` DeployStrategy in addition to `Clone` and `Copy` that uses rsync to create a new release - Added static helper `Rocketeer::getDetectedStage` to get the stage Rocketeer think's he's in on the server (for environment mappings) - Added support for checking of HHVM extensions - Added `Task::upload(file, destination)` to upload files to remote, destination can be null and the basename of the file would then be used ### Changed +- Output now lists which tasks were fired by which task/events, how long they should take, in a tree-like format that clarifies tasks and subtasks - For breaking changes, see the [Upgrade Path](http://rocketeer.autopergamene.eu/#/docs/III-Further/Upgrade-Path) ### Fixed +- Fixed the `Copy` strategy +- Fixed a bug where registered events in `hooks` would make the notifier plugins fail - Fixed a bug where `rocketeer current` would fail to find the related task - Fixed a bug where Artisan wouldn't be found even if at the default location - Fixed a bug where ignition would fail when the default connection isn't `production` From e62a745d5c2ac11d050d5eb65a5609cac4ca76a7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 03:02:30 +0200 Subject: [PATCH 368/424] Add some tests and move mockery helpers --- .../Strategies/AbstractCheckStrategy.php | 8 ++ .../Connections/RemoteHandlerTest.php | 17 ++++ tests/Strategies/Check/NodeStrategyTest.php | 36 +++++++ .../{PhpTest.php => PhpStrategyTest.php} | 6 +- tests/Strategies/Check/RubyStrategyTest.php | 35 +++++++ tests/TestCases/ContainerTestCase.php | 11 ++- .../{ => Modules}/RocketeerAssertions.php | 4 +- .../TestCases/Modules/RocketeerMockeries.php | 98 +++++++++++++++++++ tests/TestCases/RocketeerTestCase.php | 81 +-------------- tests/Traits/BashModules/CoreTest.php | 8 +- 10 files changed, 216 insertions(+), 88 deletions(-) create mode 100644 tests/Strategies/Check/NodeStrategyTest.php rename tests/Strategies/Check/{PhpTest.php => PhpStrategyTest.php} (86%) create mode 100644 tests/Strategies/Check/RubyStrategyTest.php rename tests/TestCases/{ => Modules}/RocketeerAssertions.php (97%) create mode 100644 tests/TestCases/Modules/RocketeerMockeries.php diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php index f073df93d..fc5f43823 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractCheckStrategy.php @@ -25,6 +25,14 @@ public function getManager() return $this->manager; } + /** + * @param \Rocketeer\Abstracts\AbstractPackageManager $manager + */ + public function setManager($manager) + { + $this->manager = $manager; + } + /** * @return string */ diff --git a/tests/Services/Connections/RemoteHandlerTest.php b/tests/Services/Connections/RemoteHandlerTest.php index b665918bd..46281dd42 100644 --- a/tests/Services/Connections/RemoteHandlerTest.php +++ b/tests/Services/Connections/RemoteHandlerTest.php @@ -95,4 +95,21 @@ public function testCachesConnections() $this->assertInstanceOf('Rocketeer\Services\Connections\Connection', $connection); $this->assertEquals('production', $connection->getName()); } + + public function testThrowsExceptionIfUnableToConnect() + { + $this->setExpectedException('Rocketeer\Exceptions\ConnectionException'); + + $this->swapConfig(array( + 'rocketeer::connections' => array( + 'production' => array( + 'host' => 'foobar.com', + 'username' => 'foobar', + 'password' => 'foobar', + ), + ), + )); + + $this->handler->run('ls'); + } } diff --git a/tests/Strategies/Check/NodeStrategyTest.php b/tests/Strategies/Check/NodeStrategyTest.php new file mode 100644 index 000000000..cfe47578d --- /dev/null +++ b/tests/Strategies/Check/NodeStrategyTest.php @@ -0,0 +1,36 @@ +strategy = $this->builder->buildStrategy('Check', 'Node'); + } + + public function testCanParseLanguageConstraint() + { + $manager = Mockery::mock('Npm', array( + 'getBinary' => 'npm', + 'getManifestContents' => json_encode(['engines' => ['node' => '0.10.30']]), + )); + $this->strategy->setManager($manager); + + $this->mockRemote('0.8.0'); + + $this->assertFalse($this->strategy->language()); + + $this->mockRemote('0.11.0'); + $this->assertTrue($this->strategy->language()); + } +} diff --git a/tests/Strategies/Check/PhpTest.php b/tests/Strategies/Check/PhpStrategyTest.php similarity index 86% rename from tests/Strategies/Check/PhpTest.php rename to tests/Strategies/Check/PhpStrategyTest.php index 8bad7b3ac..f2b755366 100644 --- a/tests/Strategies/Check/PhpTest.php +++ b/tests/Strategies/Check/PhpStrategyTest.php @@ -3,7 +3,7 @@ use Rocketeer\TestCases\RocketeerTestCase; -class PhpTest extends RocketeerTestCase +class PhpStrategyTest extends RocketeerTestCase { /** * @type \Rocketeer\Strategies\Check\PhpStrategy @@ -54,8 +54,8 @@ public function testCanCheckPhpExtensions() public function testCanCheckForHhvmExtensions() { - $this->app['rocketeer.remote'] = $this->getRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); - $exists = $this->strategy->checkPhpExtension('_hhvm'); + $this->mockRemote('HipHop VM 3.0.1 (rel)'.PHP_EOL.'Some more stuff'); + $exists = $this->strategy->checkPhpExtension('_hhvm'); $this->assertTrue($exists); } diff --git a/tests/Strategies/Check/RubyStrategyTest.php b/tests/Strategies/Check/RubyStrategyTest.php new file mode 100644 index 000000000..7562bbca8 --- /dev/null +++ b/tests/Strategies/Check/RubyStrategyTest.php @@ -0,0 +1,35 @@ +strategy = $this->builder->buildStrategy('Check', 'Ruby'); + } + + public function testCanParseLanguageConstraint() + { + $manager = Mockery::mock('Bundler', array( + 'getBinary' => 'bundle', + 'getManifestContents' => '# Some comments'.PHP_EOL."ruby '2.0.0'", + )); + $this->strategy->setManager($manager); + + $this->mockRemote('1.9.3'); + $this->assertFalse($this->strategy->language()); + + $this->mockRemote('2.1.0'); + $this->assertTrue($this->strategy->language()); + } +} diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 4e113aa24..b0653a54d 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -194,7 +194,7 @@ protected function swapConfig($config) /** * Mock the Remote component * - * @param null $mockedOutput + * @param string|array|null $mockedOutput * * @return Mockery */ @@ -213,7 +213,6 @@ protected function getRemote($mockedOutput = null) $remote->shouldReceive('connected')->andReturn(true); $remote->shouldReceive('into')->andReturn(Mockery::self()); $remote->shouldReceive('status')->andReturn(0)->byDefault(); - $remote->shouldReceive('run')->andReturnUsing($run)->byDefault(); $remote->shouldReceive('runRaw')->andReturnUsing($run)->byDefault(); $remote->shouldReceive('getString')->andReturnUsing(function ($file) { return file_get_contents($file); @@ -225,6 +224,14 @@ protected function getRemote($mockedOutput = null) print $line.PHP_EOL; }); + if (is_array($mockedOutput)) { + foreach ($mockedOutput as $command => $output) { + $remote->shouldReceive('run')->with($command)->andReturn($output); + } + } else { + $remote->shouldReceive('run')->andReturnUsing($run)->byDefault(); + } + return $remote; } diff --git a/tests/TestCases/RocketeerAssertions.php b/tests/TestCases/Modules/RocketeerAssertions.php similarity index 97% rename from tests/TestCases/RocketeerAssertions.php rename to tests/TestCases/Modules/RocketeerAssertions.php index 902b6cc64..187b9e5ac 100644 --- a/tests/TestCases/RocketeerAssertions.php +++ b/tests/TestCases/Modules/RocketeerAssertions.php @@ -1,7 +1,9 @@ server.'/current/composer.json'; + if ($uses) { + $this->files->put($composer, '{}'); + } else { + $this->files->delete($composer); + } + } + + /** + * @param array $state + */ + protected function mockState(array $state) + { + file_put_contents($this->server.'/state.json', json_encode($state)); + } + + /** + * Set Rocketeer in pretend mode + * + * @param array $options + * @param array $expectations + */ + protected function pretend($options = array(), $expectations = array()) + { + $options['pretend'] = true; + + $this->mockCommand($options, $expectations); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// SERVICES ////////////////////////////// + ////////////////////////////////////////////////////////////////////// + + /** + * Mock the ReleasesManager + * + * @param Closure $expectations + * + * @return Mockery + */ + protected function mockReleases(Closure $expectations) + { + return $this->mock('rocketeer.releases', 'ReleasesManager', $expectations); + } + + /** + * Mock a Command + * + * @param array $options + * @param array $expectations + */ + protected function mockCommand($options = array(), $expectations = array()) + { + // Default options + $options = array_merge(array( + 'pretend' => false, + 'verbose' => false, + 'tests' => false, + 'migrate' => false, + 'seed' => false, + 'stage' => false, + 'parallel' => false, + 'update' => false, + ), $options); + + $this->app['rocketeer.command'] = $this->getCommand($expectations, $options); + } + + /** + * Mock the RemoteHandler + * + * @param string|array|null $expectations + */ + protected function mockRemote($expectations = null) + { + $this->app['rocketeer.remote'] = $this->getRemote($expectations); + } +} diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 312bed83d..450cc22b7 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -1,13 +1,15 @@ files->copyDirectory($this->server.'-stub', $this->server); } - //////////////////////////////////////////////////////////////////// - ////////////////////////////// MOCKERIES /////////////////////////// - //////////////////////////////////////////////////////////////////// - - /** - * Mock the ReleasesManager - * - * @param Closure $expectations - * - * @return Mockery - */ - protected function mockReleases(Closure $expectations) - { - return $this->mock('rocketeer.releases', 'ReleasesManager', $expectations); - } - - /** - * Mock a Command - * - * @param array $options - * @param array $expectations - */ - protected function mockCommand($options = array(), $expectations = array()) - { - // Default options - $options = array_merge(array( - 'pretend' => false, - 'verbose' => false, - 'tests' => false, - 'migrate' => false, - 'seed' => false, - 'stage' => false, - 'parallel' => false, - 'update' => false, - ), $options); - - $this->app['rocketeer.command'] = $this->getCommand($expectations, $options); - } - - /** - * @param array $state - */ - protected function mockState(array $state) - { - file_put_contents($this->server.'/state.json', json_encode($state)); - } - //////////////////////////////////////////////////////////////////// /////////////////////////////// HELPERS //////////////////////////// //////////////////////////////////////////////////////////////////// - /** - * Mock the Composer check - * - * @param boolean $uses - * - * @return void - */ - protected function usesComposer($uses = true) - { - $composer = $this->server.'/current/composer.json'; - if ($uses) { - $this->files->put($composer, '{}'); - } else { - $this->files->delete($composer); - } - } - - /** - * Set Rocketeer in pretend mode - * - * @param array $options - * @param array $expectations - */ - protected function pretend($options = array(), $expectations = array()) - { - $options['pretend'] = true; - - $this->mockCommand($options, $expectations); - } - /** * Get a pretend AbstractTask to run bogus commands * diff --git a/tests/Traits/BashModules/CoreTest.php b/tests/Traits/BashModules/CoreTest.php index 1c586cba7..f54e8842c 100644 --- a/tests/Traits/BashModules/CoreTest.php +++ b/tests/Traits/BashModules/CoreTest.php @@ -37,8 +37,8 @@ public function testCanGetTimestampOffServer() public function testCanGetLocalTimestampIfError() { - $this->app['rocketeer.remote'] = $this->getRemote('NOPE'); - $timestamp = $this->task->getTimestamp(); + $this->mockRemote('NOPE'); + $timestamp = $this->task->getTimestamp(); $this->assertEquals(date('YmdHis'), $timestamp); } @@ -59,8 +59,8 @@ public function testDoesntAppendEnvironmentToStandardTasks() public function testCanRemoveCommonPollutingOutput() { - $this->app['rocketeer.remote'] = $this->getRemote('stdin: is not a tty'.PHP_EOL.'something'); - $result = $this->bash->run('ls'); + $this->mockRemote('stdin: is not a tty'.PHP_EOL.'something'); + $result = $this->bash->run('ls'); $this->assertEquals('something', $result); } From fb8fec12294b00bb775ffc38a25d3b9256621709 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 03:45:00 +0200 Subject: [PATCH 369/424] Make flatten for event listeners return task names --- src/Rocketeer/Services/TasksHandler.php | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 16908fbe4..21d54249f 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -259,6 +259,8 @@ public function getTasksListeners($task, $event, $flatten = false) $task = $event[0]; if ($flatten && $task instanceof Tasks\Closure && $stringTask = $task->getStringTask()) { $events[$key] = $stringTask; + } elseif ($flatten && $task instanceof AbstractTask) { + $events[$key] = $task->getSlug(); } } From 4a599acd13ef8acce370965a95dbfacca896ab53 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 03:49:36 +0200 Subject: [PATCH 370/424] Fix halting events --- src/Rocketeer/Abstracts/AbstractTask.php | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index db5d936d5..d05927325 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -190,10 +190,19 @@ public function wasHalted() */ public function fireEvent($event) { + $event = $this->getQualifiedEvent($event); + $listeners = $this->events->getListeners($event); + // Fire the event - $event = $this->getQualifiedEvent($event); - $result = $this->explainer->displayBelow(function () use ($event) { - return $this->events->fire($event, [$this]); + $result = $this->explainer->displayBelow(function () use ($listeners) { + foreach ($listeners as $listener) { + $response = call_user_func_array($listener, [$this]); + if ($response === false) { + return false; + } + } + + return true; }); // If the event returned a strict false, halt the task From 4daf5b2ef877095252cc35b182e6783511aa5f06 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 03:56:09 +0200 Subject: [PATCH 371/424] Add halt event --- src/Rocketeer/Abstracts/AbstractTask.php | 1 + tests/Abstracts/AbstractTaskTest.php | 13 +++++++++++++ 2 files changed, 14 insertions(+) diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index d05927325..6de8d37fa 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -162,6 +162,7 @@ public function halt($errors = null) $this->command->error($errors); } + $this->fireEvent('halt'); $this->halted = true; return false; diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 3adce181a..20f854323 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -109,4 +109,17 @@ public function testDoesntDuplicateQueuesOnSubtasks() $this->assertCount(24, $this->history->getFlattenedHistory()); } + + public function testCanHookIntoHaltingEvent() + { + $this->expectOutputString('halted'); + + $this->tasks->before('deploy', 'Rocketeer\Dummies\MyCustomHaltingTask'); + + $this->tasks->listenTo('deploy.halt', function () { + echo 'halted'; + }); + + $this->pretendTask('Deploy')->fire(); + } } From 28d60229d5d5f9c40f6f775731959ce1d4f6c4ec Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 03:59:00 +0200 Subject: [PATCH 372/424] Update tests --- tests/Services/TasksHandlerTest.php | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index d1a7e3c4a..3cdcc7370 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -172,16 +172,12 @@ public function testPluginsArentDeregisteredWhenSwitchingConnection() $this->tasks->plugin(new DummyNotifier($this->app)); $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); - $this->assertEquals('ls', $listeners[0]); - $this->assertCount(2, $listeners); - $this->assertCount(2, $listeners[1]); + $this->assertEquals(['ls', 'notify'], $listeners); $this->connections->setConnection('production'); $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); - $this->assertEquals('ls', $listeners[0]); - $this->assertCount(2, $listeners); - $this->assertCount(2, $listeners[1]); + $this->assertEquals(['ls', 'notify'], $listeners); } public function testDoesntRegisterPluginsTwice() @@ -195,7 +191,6 @@ public function testDoesntRegisterPluginsTwice() $this->tasks->plugin(new DummyNotifier($this->app)); $listeners = $this->tasks->getTasksListeners('deploy', 'before', true); - $this->assertCount(1, $listeners); - $this->assertCount(2, $listeners[0]); + $this->assertEquals(['notify'], $listeners); } } From c3c402eba755422cfa37e8497290a5e504085bbf Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 16:45:46 +0200 Subject: [PATCH 373/424] Fix Notifier sending the same message twice --- src/Rocketeer/Plugins/AbstractNotifier.php | 4 +-- tests/Dummies/DummyBeforeAfterNotifier.php | 33 ++++++++++++++++++++++ tests/Plugins/AbstractNotifierTest.php | 1 + tests/Tasks/Subtasks/NotifyTest.php | 23 +++++++++++++++ 4 files changed, 59 insertions(+), 2 deletions(-) create mode 100644 tests/Dummies/DummyBeforeAfterNotifier.php create mode 100644 tests/Tasks/Subtasks/NotifyTest.php diff --git a/src/Rocketeer/Plugins/AbstractNotifier.php b/src/Rocketeer/Plugins/AbstractNotifier.php index 3dd8f37da..af12d5241 100644 --- a/src/Rocketeer/Plugins/AbstractNotifier.php +++ b/src/Rocketeer/Plugins/AbstractNotifier.php @@ -31,8 +31,8 @@ public function onQueue(TasksHandler $queue) $notify = new Notify($this->app); $notify->setNotifier($this); - $queue->addTaskListeners('deploy', 'before', [$notify], -10, true); - $queue->addTaskListeners('deploy', 'after', [$notify], -10, true); + $queue->addTaskListeners('deploy', 'before', [clone $notify], -10, true); + $queue->addTaskListeners('deploy', 'after', [clone $notify], -10, true); } /** diff --git a/tests/Dummies/DummyBeforeAfterNotifier.php b/tests/Dummies/DummyBeforeAfterNotifier.php new file mode 100644 index 000000000..b607851a0 --- /dev/null +++ b/tests/Dummies/DummyBeforeAfterNotifier.php @@ -0,0 +1,33 @@ +swapConfig(array( + 'rocketeer::hooks' => array(), + )); + + $this->tasks->plugin(new DummyBeforeAfterNotifier($this->app)); + + $this->expectOutputString('before_deployafter_deploy'); + $this->localStorage->set('notifier.name', 'Jean Eude'); + + $this->task('Deploy')->fireEvent('before'); + $this->task('Deploy')->fireEvent('after'); + } +} From 64f4d4e035a67cc0d9a9525db029a2a87dab143d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 19:53:07 +0200 Subject: [PATCH 374/424] Unused use --- tests/Plugins/AbstractNotifierTest.php | 1 - 1 file changed, 1 deletion(-) diff --git a/tests/Plugins/AbstractNotifierTest.php b/tests/Plugins/AbstractNotifierTest.php index 6d4359f36..76fcf87b2 100644 --- a/tests/Plugins/AbstractNotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -1,7 +1,6 @@ Date: Sat, 23 Aug 2014 21:23:06 +0200 Subject: [PATCH 375/424] Fallback to synchronous tasks if async fails --- src/Rocketeer/Services/Tasks/TasksQueue.php | 11 ++++++++--- tests/Services/Tasks/TasksQueueTest.php | 13 +++++++++++++ 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Services/Tasks/TasksQueue.php b/src/Rocketeer/Services/Tasks/TasksQueue.php index 959bff105..75ceb3a40 100644 --- a/src/Rocketeer/Services/Tasks/TasksQueue.php +++ b/src/Rocketeer/Services/Tasks/TasksQueue.php @@ -12,6 +12,7 @@ use Closure; use Exception; use KzykHys\Parallel\Parallel; +use LogicException; use Rocketeer\Connection; use Rocketeer\Traits\HasHistory; use Rocketeer\Traits\HasLocator; @@ -245,9 +246,13 @@ protected function runAsynchronously(Pipeline $pipeline) throw new Exception('Parallel jobs require the PCNTL extension'); } - $this->parallel = $this->parallel ?: new Parallel(); - $results = $this->parallel->values($pipeline->all()); - $pipeline->setResults($results); + try { + $this->parallel = $this->parallel ?: new Parallel(); + $results = $this->parallel->values($pipeline->all()); + $pipeline->setResults($results); + } catch (LogicException $exception) { + return $this->runSynchronously($pipeline); + } return $pipeline; } diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 2ec2a51c8..88b9fbcd0 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -125,4 +125,17 @@ public function testCanCancelQueueIfTaskFails() $this->assertTrue($pipeline->failed()); $this->assertEquals([false], $this->history->getFlattenedOutput()); } + + public function testFallbacksToSynchonousIfErrorWhenRunningParallels() + { + $parallel = Mockery::mock('Parallel') + ->shouldReceive('isSupported')->andReturn(true) + ->shouldReceive('values')->once()->andThrow('LogicException') + ->mock(); + + $this->mockCommand(['parallel' => true]); + $this->queue->setParallel($parallel); + + $this->queue->run(['ls']); + } } From 2e28147c8e4cb89b88166f9d613d4176b98f43e5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 21:28:04 +0200 Subject: [PATCH 376/424] Don't try to move files that don't exist --- src/Rocketeer/Traits/BashModules/Filesystem.php | 4 ++++ tests/Traits/BashModules/FilesystemTest.php | 7 +++++++ 2 files changed, 11 insertions(+) diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index 5f3c16d49..bc5b8cc28 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -54,6 +54,10 @@ public function symlink($folder, $symlink) */ public function move($origin, $destination) { + if (!$this->fileExists($origin)) { + return; + } + return $this->fromTo('mv', $origin, $destination); } diff --git a/tests/Traits/BashModules/FilesystemTest.php b/tests/Traits/BashModules/FilesystemTest.php index b8e77e919..b974c3923 100644 --- a/tests/Traits/BashModules/FilesystemTest.php +++ b/tests/Traits/BashModules/FilesystemTest.php @@ -44,4 +44,11 @@ public function testCanCheckIfFileExists() $this->assertTrue($this->task->fileExists($this->server)); $this->assertFalse($this->task->fileExists($this->server.'/nope')); } + + public function testDoesntTryToMoveUnexistingFolders() + { + $this->pretendTask()->move('foobar', 'bazqux'); + + $this->assertEmpty($this->history->getFlattenedOutput()); + } } From 2296508a7301701b66541df81acd8a080a4c256e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 21:32:14 +0200 Subject: [PATCH 377/424] Update tests --- tests/Abstracts/AbstractTaskTest.php | 2 +- tests/Tasks/DeployTest.php | 8 -------- tests/Tasks/UpdateTest.php | 2 -- 3 files changed, 1 insertion(+), 11 deletions(-) diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 20f854323..808e26ef9 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -107,7 +107,7 @@ public function testDoesntDuplicateQueuesOnSubtasks() $this->pretend(); $this->queue->run('Deploy'); - $this->assertCount(24, $this->history->getFlattenedHistory()); + $this->assertCount(20, $this->history->getFlattenedHistory()); } public function testCanHookIntoHaltingEvent() diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 64a893657..1bf3b84de 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -38,8 +38,6 @@ public function testCanDeployToServer() "cd {server}/releases/{release}", "{php} artisan db:seed" ), - "mkdir -p {server}/shared/tests", - "mv {server}/releases/{release}/tests/Elements {server}/shared/tests/Elements", "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", "ln -s {server}/releases/{release} {server}/current", @@ -121,8 +119,6 @@ public function testCanDisableGitOptions() "cd {server}/releases/{release}", "{php} artisan db:seed" ), - "mkdir -p {server}/shared/tests", - "mv {server}/releases/{release}/tests/Elements {server}/shared/tests/Elements", "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", "ln -s {server}/releases/{release} {server}/current", @@ -164,8 +160,6 @@ public function testCanUseCopyStrategy() "chmod -R g+s {server}/releases/{release}/tests", "chown -R www-data:www-data {server}/releases/{release}/tests" ), - "mkdir -p {server}/shared/tests", - "mv {server}/releases/{release}/tests/Elements {server}/shared/tests/Elements", "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", "ln -s {server}/releases/{release} {server}/current", @@ -196,8 +190,6 @@ public function testCanRunDeployWithSeed() "cd {server}/releases/{release}", "{php} artisan db:seed" ), - "mkdir -p {server}/shared/tests", - "mv {server}/releases/{release}/tests/Elements {server}/shared/tests/Elements", "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", "ln -s {server}/releases/{release} {server}/current", diff --git a/tests/Tasks/UpdateTest.php b/tests/Tasks/UpdateTest.php index e2741a1d3..c34c5d793 100644 --- a/tests/Tasks/UpdateTest.php +++ b/tests/Tasks/UpdateTest.php @@ -18,8 +18,6 @@ public function testCanUpdateRepository() "git reset --hard", "git pull" ), - "mkdir -p {server}/shared/tests", - "mv {server}/releases/20000000000000/tests/Elements {server}/shared/tests/Elements", array( "cd {server}/releases/20000000000000", "chmod -R 755 {server}/releases/20000000000000/tests", From 127fe97cacd142a626a4e2689324976a0fca9168 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 21:34:44 +0200 Subject: [PATCH 378/424] Update some remaining direct calls to command --- src/Rocketeer/Strategies/Deploy/CopyStrategy.php | 2 +- src/Rocketeer/Tasks/Migrate.php | 4 ++-- src/Rocketeer/Traits/BashModules/Core.php | 2 +- src/Rocketeer/Traits/BashModules/Filesystem.php | 2 +- src/Rocketeer/Traits/BashModules/Flow.php | 2 +- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Strategies/Deploy/CopyStrategy.php b/src/Rocketeer/Strategies/Deploy/CopyStrategy.php index a15f70846..1e8fe2587 100644 --- a/src/Rocketeer/Strategies/Deploy/CopyStrategy.php +++ b/src/Rocketeer/Strategies/Deploy/CopyStrategy.php @@ -46,7 +46,7 @@ public function deploy($destination = null) } // Copy old release into new one - $this->command->comment('Copying previous release "'.$previous.'" in "'.$destination.'"'); + $this->explainer->success('Copying previous release "'.$previous.'" in "'.$destination.'"'); $this->bash->copy($previous, $destination); // Update repository diff --git a/src/Rocketeer/Tasks/Migrate.php b/src/Rocketeer/Tasks/Migrate.php index 36499080f..5db14f074 100644 --- a/src/Rocketeer/Tasks/Migrate.php +++ b/src/Rocketeer/Tasks/Migrate.php @@ -41,13 +41,13 @@ public function execute() // Migrate the database if ($migrate) { - $this->command->comment('Running outstanding migrations'); + $this->explainer->line('Running outstanding migrations'); $results[] = $strategy->migrate(); } // Seed it if ($seed) { - $this->command->comment('Seeding database'); + $this->explainer->line('Seeding database'); $results[] = $strategy->seed(); } diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index e6cefad2d..04b033152 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -217,7 +217,7 @@ public function checkStatus($error, $output = null, $success = null) // If all went well if ($this->status()) { if ($success) { - $this->command->comment($success); + $this->explainer->success($success); } return $output || true; diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index bc5b8cc28..dacfbecaf 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -111,7 +111,7 @@ public function setPermissions($folder) { // Get path to folder $folder = $this->releasesManager->getCurrentReleasePath($folder); - $this->command->comment('Setting permissions for '.$folder); + $this->explainer->line('Setting permissions for '.$folder); // Get permissions options $callback = $this->rocketeer->getOption('remote.permissions.callback'); diff --git a/src/Rocketeer/Traits/BashModules/Flow.php b/src/Rocketeer/Traits/BashModules/Flow.php index b3f03448d..1b3a0f60c 100644 --- a/src/Rocketeer/Traits/BashModules/Flow.php +++ b/src/Rocketeer/Traits/BashModules/Flow.php @@ -115,7 +115,7 @@ public function share($file) $this->move($currentFile, $sharedFile); } - $this->command->comment('Sharing file '.$currentFile); + $this->explainer->line('Sharing file '.$currentFile); return $this->symlink($sharedFile, $currentFile); } From 3dc34a4e37aaa8475706b2e29d067e2742f7467e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 21:55:38 +0200 Subject: [PATCH 379/424] Work on logs --- src/Rocketeer/Abstracts/AbstractCommand.php | 3 ++ src/Rocketeer/Services/History/History.php | 44 +++++++++++++-- .../Services/History/LogsHandler.php | 53 +++---------------- 3 files changed, 51 insertions(+), 49 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index b1c78479c..e671339c0 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -159,6 +159,9 @@ protected function fireTasksQueue($tasks) // Remove command instance unset($this->laravel['rocketeer.command']); + // Save history to logs + $this->laravel['rocketeer.logs']->fromHistory(); + return $status ? 0 : 1; } diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 4bb2a75f0..2cee269a3 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Services\History; +use Illuminate\Support\Arr; use Illuminate\Support\Collection; class History extends Collection @@ -33,14 +34,46 @@ public function getFlattenedOutput() return $this->getFlattened('output'); } + /** + * Get the merged logs of history/output + * + * @return array + */ + public function getLogs() + { + // Fetch history + $history = $this->getFlattened('history', true); + $history = Arr::dot($history); + + // Fetch output + $output = $this->getFlattened('output', true); + $output = Arr::dot($output); + + // Add command marker to history + $history = array_map(function ($command) { + return '$ '.$command; + }, $history); + + // Merge and sort + $logs = array_merge($history, $output); + ksort($logs); + + return array_values($logs); + } + + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** * Get a flattened list of a certain type * - * @param string $type + * @param string $type + * @param boolean $timestamps * * @return string[]|string[][] */ - protected function getFlattened($type) + protected function getFlattened($type, $timestamps = false) { $history = []; foreach ($this->items as $class => $entries) { @@ -49,6 +82,11 @@ protected function getFlattened($type) ksort($history); - return array_values($history); + // Prune timestamps if necessary + if (!$timestamps) { + $history = array_values($history); + } + + return $history; } } diff --git a/src/Rocketeer/Services/History/LogsHandler.php b/src/Rocketeer/Services/History/LogsHandler.php index fbf6caec4..856176286 100644 --- a/src/Rocketeer/Services/History/LogsHandler.php +++ b/src/Rocketeer/Services/History/LogsHandler.php @@ -19,34 +19,14 @@ class LogsHandler use HasLocator; /** - * The loggers instances - * - * @var array - */ - protected $loggers = array(); - - /** - * Log by level - * - * @param string $method - * @param array $parameters + * Create logs from the History */ - public function __call($method, $parameters) + public function fromHistory() { - $this->log($parameters[0], $method); - } + $file = $this->getCurrentLogsFile(); + $history = $this->history->getLogs(); - /** - * Log a piece of text - * - * @param string $informations - * @param string $level - */ - public function log($informations, $level = 'info') - { - if ($file = $this->getCurrentLogsFile()) { - $this->getLogger($file)->$level($informations); - } + $this->files->put($file, implode(PHP_EOL, $history)); } /** @@ -64,30 +44,11 @@ public function getCurrentLogsFile() $file = $logs($this->connections); $file = $this->app['path.rocketeer.logs'].'/'.$file; - - return $file; - } - - /** - * Get a logger instance by context - * - * @param string $file - * - * @return \Illuminate\Log\Writer - */ - protected function getLogger($file) - { - // Create logger instance if necessary - if (!array_key_exists($file, $this->loggers)) { + if (!$this->files->exists($file)) { $this->createLogsFile($file); - - // Store specific logger instance - $logger = clone $this->log; - $logger->useFiles($file); - $this->loggers[$file] = $logger; } - return $this->loggers[$file]; + return $file; } /** From 281938e586133ec36d083c36e1b1a04c8e07320e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 21:56:41 +0200 Subject: [PATCH 380/424] Work on logs --- src/Rocketeer/Abstracts/AbstractCommand.php | 5 +- src/Rocketeer/Services/History/History.php | 36 +---------- .../Services/History/LogsHandler.php | 62 +++++++++++++++---- src/Rocketeer/Traits/HasHistory.php | 13 +++- 4 files changed, 68 insertions(+), 48 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index e671339c0..a765d6700 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -160,7 +160,10 @@ protected function fireTasksQueue($tasks) unset($this->laravel['rocketeer.command']); // Save history to logs - $this->laravel['rocketeer.logs']->fromHistory(); + $logs = $this->laravel['rocketeer.logs']->write(); + foreach ($logs as $log) { + $this->info('Saved logs to '.$log); + } return $status ? 0 : 1; } diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 2cee269a3..1e14f82b6 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -34,33 +34,6 @@ public function getFlattenedOutput() return $this->getFlattened('output'); } - /** - * Get the merged logs of history/output - * - * @return array - */ - public function getLogs() - { - // Fetch history - $history = $this->getFlattened('history', true); - $history = Arr::dot($history); - - // Fetch output - $output = $this->getFlattened('output', true); - $output = Arr::dot($output); - - // Add command marker to history - $history = array_map(function ($command) { - return '$ '.$command; - }, $history); - - // Merge and sort - $logs = array_merge($history, $output); - ksort($logs); - - return array_values($logs); - } - ////////////////////////////////////////////////////////////////////// ////////////////////////////// HELPERS /////////////////////////////// ////////////////////////////////////////////////////////////////////// @@ -73,7 +46,7 @@ public function getLogs() * * @return string[]|string[][] */ - protected function getFlattened($type, $timestamps = false) + protected function getFlattened($type) { $history = []; foreach ($this->items as $class => $entries) { @@ -82,11 +55,6 @@ protected function getFlattened($type, $timestamps = false) ksort($history); - // Prune timestamps if necessary - if (!$timestamps) { - $history = array_values($history); - } - - return $history; + return array_values($history); } } diff --git a/src/Rocketeer/Services/History/LogsHandler.php b/src/Rocketeer/Services/History/LogsHandler.php index 856176286..9915511d7 100644 --- a/src/Rocketeer/Services/History/LogsHandler.php +++ b/src/Rocketeer/Services/History/LogsHandler.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Services\History; +use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; /** @@ -19,14 +20,52 @@ class LogsHandler use HasLocator; /** - * Create logs from the History + * Cache of the logs file to be written + * + * @type array + */ + protected $logs = []; + + /** + * The closure used to name logs + * + * @type \Closure */ - public function fromHistory() + protected $namer; + + /** + * Save something for the logs + * + * @param string $string + */ + public function log($string) { + // Create entry in the logs $file = $this->getCurrentLogsFile(); - $history = $this->history->getLogs(); + if (!isset($this->logs[$file])) { + $this->logs[$file] = []; + } + + $this->logs[$file][] = $string; + } + + /** + * Write the stored logs + * + * @return array + */ + public function write() + { + foreach ($this->logs as $file => $entries) { + $entries = Arr::flatten($entries); + if (!$this->files->exists($file)) { + $this->createLogsFile($file); + } - $this->files->put($file, implode(PHP_EOL, $history)); + $this->files->put($file, implode(PHP_EOL, $entries)); + } + + return array_keys($this->logs); } /** @@ -36,17 +75,18 @@ public function fromHistory() */ public function getCurrentLogsFile() { - /** @type \Callable $logs */ - $logs = $this->config->get('rocketeer::logs'); - if (!$logs) { + if (!$this->namer) { + $this->namer = $this->config->get('rocketeer::logs'); + } + + // Cancel if invalid namer + if (!$this->namer || !is_callable($this->namer)) { return false; } - $file = $logs($this->connections); + $namer = $this->namer; + $file = $namer($this->connections); $file = $this->app['path.rocketeer.logs'].'/'.$file; - if (!$this->files->exists($file)) { - $this->createLogsFile($file); - } return $file; } diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index 3cac9d46b..2110f8690 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -86,7 +86,16 @@ protected function appendTo($type, $command) // Flatten one-liners $command = (array) $command; $command = array_values($command); - $command = count($command) == 1 ? $command[0] : $command; + $flattened = count($command) == 1 ? $command[0] : $command; + + // Save to logs + if ($type == 'history') { + $command = array_map(function ($command) { + return '$ '.$command; + }, $command); + } + + $this->logs->log($command); // Get the various handles $handle = $this->getHistoryHandle(); @@ -94,7 +103,7 @@ protected function appendTo($type, $command) $timestamp = (string) microtime(true); // Set new history on correct handle - $history[$type][$timestamp] = $command; + $history[$type][$timestamp] = $flattened; $this->history[$handle] = $history; } From 4776b158d692f1940db6dca959e0a3cbf330bad4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 22:33:56 +0200 Subject: [PATCH 381/424] Display strategies executed by Polyglots one level below --- .../Strategies/AbstractPolyglotStrategy.php | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php index 80ee899a7..8f41b1daa 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php @@ -55,14 +55,16 @@ protected function checkStrategiesResults($results) */ protected function onStrategies(Closure $callback) { - $results = []; - foreach ($this->strategies as $strategy) { - $instance = $this->getStrategy('Dependencies', $strategy); - if ($instance) { - $results[$strategy] = $callback($instance); + return $this->explainer->displayBelow(function() use ($callback) { + $results = []; + foreach ($this->strategies as $strategy) { + $instance = $this->getStrategy('Dependencies', $strategy); + if ($instance) { + $results[$strategy] = $callback($instance); + } } - } - return $results; + return $results; + }); } } From ecb8b44fc37df5934bc6f53119261e48750873cd Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 22:35:25 +0200 Subject: [PATCH 382/424] Cache connection handles --- .../Connections/ConnectionsHandler.php | 107 ++++++++++-------- 1 file changed, 61 insertions(+), 46 deletions(-) diff --git a/src/Rocketeer/Services/Connections/ConnectionsHandler.php b/src/Rocketeer/Services/Connections/ConnectionsHandler.php index 29301ea1d..5caffcea0 100644 --- a/src/Rocketeer/Services/Connections/ConnectionsHandler.php +++ b/src/Rocketeer/Services/Connections/ConnectionsHandler.php @@ -23,6 +23,13 @@ class ConnectionsHandler { use HasLocator; + /** + * The current handle + * + * @type string + */ + protected $handle; + /** * The current stage * @@ -62,6 +69,10 @@ class ConnectionsHandler */ public function getHandle($connection = null, $server = null, $stage = null) { + if ($this->handle) { + return $this->handle; + } + // Get identifiers $connection = $connection ?: $this->getConnection(); $server = $server ?: $this->getServer(); @@ -78,7 +89,8 @@ public function getHandle($connection = null, $server = null, $stage = null) } // Concatenate - $handle = implode('/', $handle); + $handle = implode('/', $handle); + $this->handle = $handle; return $handle; } @@ -111,6 +123,16 @@ public function isMultiserver($connection) //////////////////////////////// STAGES //////////////////////////// //////////////////////////////////////////////////////////////////// + /** + * Get the current stage + * + * @return string + */ + public function getStage() + { + return $this->stage; + } + /** * Set the stage Tasks will execute on * @@ -122,7 +144,8 @@ public function setStage($stage) return; } - $this->stage = $stage; + $this->stage = $stage; + $this->handle = null; // If we do have a stage, cleanup previous events if ($stage) { @@ -130,16 +153,6 @@ public function setStage($stage) } } - /** - * Get the current stage - * - * @return string - */ - public function getStage() - { - return $this->stage; - } - /** * Get the various stages provided by the User * @@ -239,6 +252,21 @@ public function getConnections() return $connections; } + /** + * Set the active connections + * + * @param string|string[] $connections + */ + public function setConnections($connections) + { + if (!is_array($connections)) { + $connections = explode(',', $connections); + } + + $this->connections = $connections; + $this->handle = null; + } + /** * Get the active connection * @@ -257,6 +285,27 @@ public function getConnection() return $this->connection; } + /** + * Set the current connection + * + * @param string $connection + * @param int $server + */ + public function setConnection($connection, $server = 0) + { + if (!$this->isValidConnection($connection) || $this->connection == $connection) { + return; + } + + // Set the connection + $this->handle = null; + $this->connection = $connection; + $this->localStorage = $server; + + // Update events + $this->tasks->registerConfiguredEvents(); + } + /** * Get the credentials for a particular connection * @@ -308,40 +357,6 @@ public function syncConnectionCredentials($connection = null, array $credentials $this->config->set('remote.connections.'.$connection, $credentials); } - /** - * Set the active connections - * - * @param string|string[] $connections - */ - public function setConnections($connections) - { - if (!is_array($connections)) { - $connections = explode(',', $connections); - } - - $this->connections = $connections; - } - - /** - * Set the current connection - * - * @param string $connection - * @param int $server - */ - public function setConnection($connection, $server = 0) - { - if (!$this->isValidConnection($connection) || $this->connection == $connection) { - return; - } - - // Set the connection - $this->connection = $connection; - $this->localStorage = $server; - - // Update events - $this->tasks->registerConfiguredEvents(); - } - /** * Flush active connection(s) */ From 58dc42b50f395d0e0a79bd8ad678ebdc96300c72 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 22:41:56 +0200 Subject: [PATCH 383/424] Update tests --- tests/Services/History/LogsHandlerTest.php | 17 +++++------------ tests/TestCases/ContainerTestCase.php | 1 + 2 files changed, 6 insertions(+), 12 deletions(-) diff --git a/tests/Services/History/LogsHandlerTest.php b/tests/Services/History/LogsHandlerTest.php index e1a4ebd4f..d3ebd6212 100644 --- a/tests/Services/History/LogsHandlerTest.php +++ b/tests/Services/History/LogsHandlerTest.php @@ -30,26 +30,19 @@ public function testCanGetCurrentLogsFile() public function testCanLogInformations() { - $this->logs->log('foobar', 'error'); + $this->logs->log('foobar'); + $this->logs->write(); $logs = $this->logs->getCurrentLogsFile(); $logs = file_get_contents($logs); - $this->assertContains('rocketeer.ERROR: foobar [] []', $logs); - } - - public function testCanLogViaMagicMethods() - { - $this->logs->error('foobar'); - $logs = $this->logs->getCurrentLogsFile(); - $logs = file_get_contents($logs); - - $this->assertContains('rocketeer.ERROR: foobar [] []', $logs); + $this->assertContains('foobar', $logs); } public function testCanCreateLogsFolderIfItDoesntExistAlready() { $this->app['path.rocketeer.logs'] = $this->server.'/newlogs'; - $this->logs->error('foobar'); + $this->logs->log('foobar'); + $this->logs->write(); $logs = $this->logs->getCurrentLogsFile(); $this->assertFileExists($logs); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index b0653a54d..5bac2c767 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -284,6 +284,7 @@ protected function getFactoryConfiguration() 'staging' => [] ), 'rocketeer::application_name' => 'foobar', + 'rocketeer::logs' => null, 'rocketeer::remote.permissions.files' => ['tests'], 'rocketeer::remote.shared' => ['tests/Elements'], 'rocketeer::remote.keep_releases' => 1, From 3fd0b04702817d045d381a788422802357740e7a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 23 Aug 2014 22:51:34 +0200 Subject: [PATCH 384/424] Code tweaks --- .../Abstracts/Strategies/AbstractPolyglotStrategy.php | 2 +- src/Rocketeer/Services/CredentialsGatherer.php | 2 +- src/Rocketeer/Services/History/History.php | 2 -- src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php | 4 ++-- src/Rocketeer/Traits/BashModules/Filesystem.php | 2 +- src/Rocketeer/Traits/HasHistory.php | 4 ++-- tests/TestCases/ContainerTestCase.php | 2 +- 7 files changed, 8 insertions(+), 10 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php index 8f41b1daa..87e6b090c 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php @@ -25,7 +25,7 @@ abstract class AbstractPolyglotStrategy extends AbstractStrategy * * @param string $method * - * @return array + * @return boolean[] */ protected function executeStrategiesMethod($method) { diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 8875d13d8..584a4b4dc 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -166,7 +166,7 @@ protected function getConnectionAuthentication(array $credentials, $handle) */ protected function gatherCredentials($credentials, $current, $handle) { - // Loop throguh credentials and ask missing ones + // Loop through credentials and ask missing ones foreach ($credentials as $credential => $required) { $$credential = $this->getCredential($current, $credential); if ($required && !$$credential) { diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 1e14f82b6..9709f2b7c 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -9,7 +9,6 @@ */ namespace Rocketeer\Services\History; -use Illuminate\Support\Arr; use Illuminate\Support\Collection; class History extends Collection @@ -42,7 +41,6 @@ public function getFlattenedOutput() * Get a flattened list of a certain type * * @param string $type - * @param boolean $timestamps * * @return string[]|string[][] */ diff --git a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php index acaf99112..a3650a0ad 100644 --- a/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php +++ b/src/Rocketeer/Strategies/Dependencies/PolyglotStrategy.php @@ -29,7 +29,7 @@ class PolyglotStrategy extends AbstractPolyglotStrategy implements DependenciesS /** * Install the dependencies * - * @return boolean + * @return boolean[] */ public function install() { @@ -39,7 +39,7 @@ public function install() /** * Update the dependencies * - * @return boolean + * @return boolean[] */ public function update() { diff --git a/src/Rocketeer/Traits/BashModules/Filesystem.php b/src/Rocketeer/Traits/BashModules/Filesystem.php index dacfbecaf..a0b67c912 100644 --- a/src/Rocketeer/Traits/BashModules/Filesystem.php +++ b/src/Rocketeer/Traits/BashModules/Filesystem.php @@ -50,7 +50,7 @@ public function symlink($folder, $symlink) * @param string $origin * @param string $destination * - * @return string + * @return string|null */ public function move($origin, $destination) { diff --git a/src/Rocketeer/Traits/HasHistory.php b/src/Rocketeer/Traits/HasHistory.php index 2110f8690..cb452da65 100644 --- a/src/Rocketeer/Traits/HasHistory.php +++ b/src/Rocketeer/Traits/HasHistory.php @@ -84,8 +84,8 @@ protected function getHistoryHandle() protected function appendTo($type, $command) { // Flatten one-liners - $command = (array) $command; - $command = array_values($command); + $command = (array) $command; + $command = array_values($command); $flattened = count($command) == 1 ? $command[0] : $command; // Save to logs diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 5bac2c767..7c3d2a686 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -284,7 +284,7 @@ protected function getFactoryConfiguration() 'staging' => [] ), 'rocketeer::application_name' => 'foobar', - 'rocketeer::logs' => null, + 'rocketeer::logs' => null, 'rocketeer::remote.permissions.files' => ['tests'], 'rocketeer::remote.shared' => ['tests/Elements'], 'rocketeer::remote.keep_releases' => 1, From ef82ec56fb7baaebc1d718e592e20089b8248015 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 24 Aug 2014 14:03:03 +0200 Subject: [PATCH 385/424] Work on plugins system --- src/Rocketeer/Abstracts/AbstractCommand.php | 11 ++-- .../Plugins/ConfigPublisherCommand.php | 54 +++++++++++++++++++ src/Rocketeer/{ => Ignition}/Igniter.php | 19 ++++--- .../PluginsConfigurationPublisher.php | 51 ++++++++++++++++++ src/Rocketeer/RocketeerServiceProvider.php | 4 +- src/Rocketeer/Services/TasksHandler.php | 2 +- src/config/config.php | 8 +++ tests/{ => Ignition}/IgniterTest.php | 2 +- 8 files changed, 138 insertions(+), 13 deletions(-) create mode 100644 src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php rename src/Rocketeer/{ => Ignition}/Igniter.php (94%) create mode 100644 src/Rocketeer/Ignition/PluginsConfigurationPublisher.php rename tests/{ => Ignition}/IgniterTest.php (99%) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index a765d6700..b78d045a1 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -72,12 +72,15 @@ public function getTask() */ public function getName() { - // Return commands without namespace if standalone - if (!$this->isInsideLaravel()) { - return str_replace('deploy:', null, $this->name); + // Return commands as is in Laravel + if ($this->isInsideLaravel()) { + return $this->name; } - return $this->name; + $name = str_replace('deploy:', null, $this->name); + $name = str_replace('-', ':', $name); + + return $name; } ////////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php b/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php new file mode 100644 index 000000000..17a8d2b28 --- /dev/null +++ b/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php @@ -0,0 +1,54 @@ +laravel); + $publisher->publish($this->argument('package')); + } + + /** + * Get the console command arguments. + * + * @return string[][] + */ + protected function getArguments() + { + return array( + ['package', InputArgument::REQUIRED, 'The package to publish the configuration for'], + ); + } +} diff --git a/src/Rocketeer/Igniter.php b/src/Rocketeer/Ignition/Igniter.php similarity index 94% rename from src/Rocketeer/Igniter.php rename to src/Rocketeer/Ignition/Igniter.php index 5ec291658..a0c7acbf0 100644 --- a/src/Rocketeer/Igniter.php +++ b/src/Rocketeer/Ignition/Igniter.php @@ -7,9 +7,10 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer; +namespace Rocketeer\Ignition; use Illuminate\Support\Arr; +use Rocketeer\Facades; use Rocketeer\Traits\HasLocator; use Symfony\Component\Finder\Finder; use Symfony\Component\Finder\SplFileInfo; @@ -56,6 +57,11 @@ public function loadUserConfiguration() $fileLoaders(); } + // Load plugins + foreach ($this->config->get('rocketeer::plugins') as $plugin) { + $this->tasks->plugin($plugin); + } + // Merge contextual configurations $this->mergeContextualConfigurations(); } @@ -72,7 +78,7 @@ public function mergeContextualConfigurations() } // Get folders to glob - $folders = $this->paths->unifyLocalSlashes($storage.'/{stages,connections}/*'); + $folders = $this->paths->unifyLocalSlashes($storage.'/{stages,connections,plugins}/*'); // Gather custom files $finder = new Finder(); @@ -163,10 +169,11 @@ protected function bindConfiguration() // Build paths $paths = array( - 'config' => $path.'', - 'events' => $path.DS.'events', - 'tasks' => $path.DS.'tasks', - 'logs' => $storage.DS.'logs', + 'config' => $path.'', + 'events' => $path.DS.'events', + 'plugins' => $path.DS.'plugins', + 'tasks' => $path.DS.'tasks', + 'logs' => $storage.DS.'logs', ); foreach ($paths as $key => $file) { diff --git a/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php b/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php new file mode 100644 index 000000000..5dfcfc276 --- /dev/null +++ b/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php @@ -0,0 +1,51 @@ + +* +* For the full copyright and license information, please view the LICENSE +* file that was distributed with this source code. +*/ +namespace Rocketeer\Ignition; + +use Rocketeer\Traits\HasLocator; + +/** + * Publishes the plugin's configurations in user-land + * + * @author Maxime Fabre + */ +class PluginsConfigurationPublisher +{ + use HasLocator; + + /** + * Publishes a package's configuration + * + * @param string $package + */ + public function publish($package) + { + if ($this->isInsideLaravel()) { + $this->publishLaravelConfiguration($package); + } + } + + /** + * Publishes a configuration within a Laravel application + * + * @param string $package + */ + protected function publishLaravelConfiguration($package) + { + // Publish initial configuration + $this->artisan->call('config:publish', ['package' => $package]); + + // Move under Rocketeer namespace + $path = $this->app['path'].'/config/packages/'.$package; + $destination = preg_replace('/packages\/([^\/]+)/', 'packages/rocketeers', $path); + + $this->files->move($path, $destination); + } +} diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index 48816f6e6..bf6b6ea5e 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -16,6 +16,7 @@ use Illuminate\Log\Writer; use Illuminate\Support\ServiceProvider; use Monolog\Logger; +use Rocketeer\Ignition\Igniter; use Rocketeer\Services\Connections\ConnectionsHandler; use Rocketeer\Services\Connections\LocalConnection; use Rocketeer\Services\Connections\RemoteHandler; @@ -75,7 +76,7 @@ public function boot() $this->bindConsoleClasses(); $this->bindStrategies(); - // Load the user's events, tasks, and configurations + // Load the user's events, tasks, plugins, and configurations $this->app['rocketeer.igniter']->loadUserConfiguration(); // Bind commands @@ -270,6 +271,7 @@ public function bindCommands() 'teardown' => 'Teardown', 'test' => 'Test', 'update' => 'Update', + 'plugin-config' => 'Plugins\ConfigPublisher', ); // Add User commands diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 21d54249f..078049a41 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -299,7 +299,7 @@ public function plugin($plugin, array $configuration = array()) // Register configuration $vendor = $plugin->getNamespace(); - $this->config->package('rocketeer/'.$vendor, $plugin->configurationFolder); + $this->config->package('rocketeers/'.$vendor, $plugin->configurationFolder); if ($configuration) { $this->config->set($vendor.'::config', $configuration); } diff --git a/src/config/config.php b/src/config/config.php index d9352c21a..0765eebdd 100644 --- a/src/config/config.php +++ b/src/config/config.php @@ -8,6 +8,14 @@ // configured above, so be careful about the characters used 'application_name' => '{application_name}', + // Plugins + //////////////////////////////////////////////////////////////////// + + // The plugins to load + 'plugins' => array( + // 'Rocketeer\Plugins\Slack\RocketeerSlack', + ), + // Logging //////////////////////////////////////////////////////////////////// diff --git a/tests/IgniterTest.php b/tests/Ignition/IgniterTest.php similarity index 99% rename from tests/IgniterTest.php rename to tests/Ignition/IgniterTest.php index 0b52f934f..5055e55d6 100644 --- a/tests/IgniterTest.php +++ b/tests/Ignition/IgniterTest.php @@ -1,5 +1,5 @@ Date: Sun, 24 Aug 2014 16:24:31 +0200 Subject: [PATCH 386/424] More work on plugins --- src/Rocketeer/Ignition/Igniter.php | 33 ++++++++++-- .../PluginsConfigurationPublisher.php | 50 ++++++++++++++++++- 2 files changed, 78 insertions(+), 5 deletions(-) diff --git a/src/Rocketeer/Ignition/Igniter.php b/src/Rocketeer/Ignition/Igniter.php index a0c7acbf0..9d816c680 100644 --- a/src/Rocketeer/Ignition/Igniter.php +++ b/src/Rocketeer/Ignition/Igniter.php @@ -58,12 +58,14 @@ public function loadUserConfiguration() } // Load plugins + var_dump($this->config->get('rocketeer::config')); foreach ($this->config->get('rocketeer::plugins') as $plugin) { $this->tasks->plugin($plugin); } // Merge contextual configurations $this->mergeContextualConfigurations(); + $this->mergePluginsConfiguration(); } /** @@ -72,13 +74,13 @@ public function loadUserConfiguration() public function mergeContextualConfigurations() { // Cancel if not ignited yet - $storage = $this->app['path.rocketeer.config']; - if (!is_dir($storage) || (!is_dir($storage.DS.'stages') && !is_dir($storage.DS.'connections'))) { + $configuration = $this->app['path.rocketeer.config']; + if (!is_dir($configuration) || (!is_dir($configuration.DS.'stages') && !is_dir($configuration.DS.'connections'))) { return; } // Get folders to glob - $folders = $this->paths->unifyLocalSlashes($storage.'/{stages,connections,plugins}/*'); + $folders = $this->paths->unifyLocalSlashes($configuration.'/{stages,connections}/*'); // Gather custom files $finder = new Finder(); @@ -93,6 +95,31 @@ public function mergeContextualConfigurations() } } + public function mergePluginsConfiguration() + { + // Cancel if no plugins + $configuration = $this->app['path.rocketeer.config']; + if (!is_dir($configuration) || !is_dir($configuration.DS.'plugins')) { + return; + } + + // Get folders to glob + $folders = $this->paths->unifyLocalSlashes($configuration.'/plugins/*'); + + // Gather custom files + $finder = new Finder(); + $files = $finder->in($folders)->files(); + + // Bind their contents to the "on" array + foreach ($files as $file) { + $contents = include $file->getPathname(); + $handle = basename(dirname($file->getPathname())); + $handle .= '::'.$file->getBasename('.php'); + + $this->config->set($handle, $contents); + } + } + //////////////////////////////////////////////////////////////////// ///////////////////////////// CONFIGURATION //////////////////////// //////////////////////////////////////////////////////////////////// diff --git a/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php b/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php index 5dfcfc276..baee07ef9 100644 --- a/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php +++ b/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Ignition; +use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; /** @@ -24,18 +25,40 @@ class PluginsConfigurationPublisher * Publishes a package's configuration * * @param string $package + * + * @return boolean */ public function publish($package) { if ($this->isInsideLaravel()) { - $this->publishLaravelConfiguration($package); + return $this->publishLaravelConfiguration($package); + } + + // Find the plugin's configuration + $paths = array( + $this->app['path.base'].'/vendor/%s/src/config', + $this->app['path.base'].'/vendor/%s/config', + $this->paths->getHomeFolder().'/.composer/vendor/%s/src/config', + $this->paths->getHomeFolder().'/.composer/vendor/%s/config', + ); + + foreach ($paths as &$path) { + $path = sprintf($path, $package); + } + $paths = array_filter($paths, 'is_dir'); + if (empty($paths)) { + return $this->command->error('No configuration found for '.$package); } + + return $this->publishConfiguration($paths[0]); } /** * Publishes a configuration within a Laravel application * * @param string $package + * + * @return boolean */ protected function publishLaravelConfiguration($package) { @@ -46,6 +69,29 @@ protected function publishLaravelConfiguration($package) $path = $this->app['path'].'/config/packages/'.$package; $destination = preg_replace('/packages\/([^\/]+)/', 'packages/rocketeers', $path); - $this->files->move($path, $destination); + return $this->files->copyDirectory($path, $destination); + } + + /** + * Publishes a configuration within a classic application + * + * @param string $path + * + * @return boolean + */ + protected function publishConfiguration($path) + { + // Get the vendor and package + preg_match('/vendor\/([^\/]+)\/([^\/]+)/', $path, $handle); + $package = Arr::get($handle, 2); + + // Compute and create the destination foldser + $destination = $this->app['path.rocketeer.config']; + $destination = $destination.'/plugins/rocketeers/'.$package; + if (!$this->files->exists($destination)) { + $this->files->makeDirectory($destination, 0755, true); + } + + return $this->files->copyDirectory($path, $destination); } } From 1f25c7085321ae0be254ba74551ac639002b3d7f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 24 Aug 2014 16:36:20 +0200 Subject: [PATCH 387/424] Move some files around --- .../Console/Commands/Plugins/ConfigPublisherCommand.php | 4 ++-- src/Rocketeer/RocketeerServiceProvider.php | 4 ++-- .../Igniter.php => Services/Ignition/Configuration.php} | 4 ++-- .../Ignition/Plugins.php} | 4 ++-- .../Ignition/ConfigurationTest.php} | 8 ++++---- tests/Tasks/IgniteTest.php | 4 ++-- 6 files changed, 14 insertions(+), 14 deletions(-) rename src/Rocketeer/{Ignition/Igniter.php => Services/Ignition/Configuration.php} (99%) rename src/Rocketeer/{Ignition/PluginsConfigurationPublisher.php => Services/Ignition/Plugins.php} (97%) rename tests/{Ignition/IgniterTest.php => Services/Ignition/ConfigurationTest.php} (96%) diff --git a/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php b/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php index 17a8d2b28..3d0c46689 100644 --- a/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php @@ -2,7 +2,7 @@ namespace Rocketeer\Console\Commands\Plugins; use Rocketeer\Abstracts\AbstractCommand; -use Rocketeer\Ignition\PluginsConfigurationPublisher; +use Rocketeer\Services\Ignition\Plugins; use Symfony\Component\Console\Input\InputArgument; class ConfigPublisherCommand extends AbstractCommand @@ -36,7 +36,7 @@ class ConfigPublisherCommand extends AbstractCommand */ public function fire() { - $publisher = new PluginsConfigurationPublisher($this->laravel); + $publisher = new Plugins($this->laravel); $publisher->publish($this->argument('package')); } diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index bf6b6ea5e..b2dd97f27 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -16,7 +16,7 @@ use Illuminate\Log\Writer; use Illuminate\Support\ServiceProvider; use Monolog\Logger; -use Rocketeer\Ignition\Igniter; +use Rocketeer\Services\Ignition\Configuration; use Rocketeer\Services\Connections\ConnectionsHandler; use Rocketeer\Services\Connections\LocalConnection; use Rocketeer\Services\Connections\RemoteHandler; @@ -107,7 +107,7 @@ public function bindPaths() }); $this->app->bind('rocketeer.igniter', function ($app) { - return new Igniter($app); + return new Configuration($app); }); // Bind paths diff --git a/src/Rocketeer/Ignition/Igniter.php b/src/Rocketeer/Services/Ignition/Configuration.php similarity index 99% rename from src/Rocketeer/Ignition/Igniter.php rename to src/Rocketeer/Services/Ignition/Configuration.php index 9d816c680..50f3d520d 100644 --- a/src/Rocketeer/Ignition/Igniter.php +++ b/src/Rocketeer/Services/Ignition/Configuration.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Ignition; +namespace Rocketeer\Services\Ignition; use Illuminate\Support\Arr; use Rocketeer\Facades; @@ -21,7 +21,7 @@ * * @author Maxime Fabre */ -class Igniter +class Configuration { use HasLocator; diff --git a/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php b/src/Rocketeer/Services/Ignition/Plugins.php similarity index 97% rename from src/Rocketeer/Ignition/PluginsConfigurationPublisher.php rename to src/Rocketeer/Services/Ignition/Plugins.php index baee07ef9..5a357aae6 100644 --- a/src/Rocketeer/Ignition/PluginsConfigurationPublisher.php +++ b/src/Rocketeer/Services/Ignition/Plugins.php @@ -7,7 +7,7 @@ * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ -namespace Rocketeer\Ignition; +namespace Rocketeer\Services\Ignition; use Illuminate\Support\Arr; use Rocketeer\Traits\HasLocator; @@ -17,7 +17,7 @@ * * @author Maxime Fabre */ -class PluginsConfigurationPublisher +class Plugins { use HasLocator; diff --git a/tests/Ignition/IgniterTest.php b/tests/Services/Ignition/ConfigurationTest.php similarity index 96% rename from tests/Ignition/IgniterTest.php rename to tests/Services/Ignition/ConfigurationTest.php index 5055e55d6..ca3c4be74 100644 --- a/tests/Ignition/IgniterTest.php +++ b/tests/Services/Ignition/ConfigurationTest.php @@ -1,14 +1,14 @@ igniter = new Igniter($this->app); + $this->igniter = new Configuration($this->app); unset($this->app['path.base']); unset($this->app['path']); } diff --git a/tests/Tasks/IgniteTest.php b/tests/Tasks/IgniteTest.php index cfb11a685..bba83da1e 100644 --- a/tests/Tasks/IgniteTest.php +++ b/tests/Tasks/IgniteTest.php @@ -48,7 +48,7 @@ public function testCanIgniteConfigurationOutsideLaravel() $command = $this->getCommand(array('ask' => 'foobar')); $server = $this->server; - $this->mock('rocketeer.igniter', 'Igniter', function ($mock) use ($server) { + $this->mock('rocketeer.igniter', 'Configuration', function ($mock) use ($server) { return $mock ->shouldReceive('exportConfiguration')->once()->andReturn($server) ->shouldReceive('updateConfiguration')->once()->with($server, array( @@ -69,7 +69,7 @@ public function testCanIgniteConfigurationInLaravel() $command->shouldReceive('call')->with('config:publish', array('package' => 'anahkiasen/rocketeer'))->andReturn('foobar'); $path = $this->app['path'].'/config/packages/anahkiasen/rocketeer'; - $this->mock('rocketeer.igniter', 'Igniter', function ($mock) use ($path) { + $this->mock('rocketeer.igniter', 'Configuration', function ($mock) use ($path) { return $mock ->shouldReceive('exportConfiguration')->never() ->shouldReceive('updateConfiguration')->once()->with($path, array( From 211380f9b91e2a278d009e82ecf8a6c7ac447dc6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 24 Aug 2014 18:08:57 +0200 Subject: [PATCH 388/424] Work on plugins installation --- bin/rocketeer | 12 ++++- .../Commands/Plugins/InstallCommand.php | 53 +++++++++++++++++++ .../Console/Commands/Plugins/ListCommand.php | 41 ++++++++++++++ ...ublisherCommand.php => PublishCommand.php} | 4 +- src/Rocketeer/RocketeerServiceProvider.php | 32 +++++------ .../Services/Ignition/Configuration.php | 5 +- src/Rocketeer/Services/Ignition/Plugins.php | 1 + src/Rocketeer/Services/Tasks/TasksBuilder.php | 29 +++++++++- src/Rocketeer/Services/TasksHandler.php | 9 ++++ src/Rocketeer/Tasks/Plugins/Installer.php | 38 +++++++++++++ src/Rocketeer/Traits/BashModules/Binaries.php | 20 +------ src/Rocketeer/Traits/BashModules/Core.php | 14 ++++- 12 files changed, 216 insertions(+), 42 deletions(-) create mode 100644 src/Rocketeer/Console/Commands/Plugins/InstallCommand.php create mode 100644 src/Rocketeer/Console/Commands/Plugins/ListCommand.php rename src/Rocketeer/Console/Commands/Plugins/{ConfigPublisherCommand.php => PublishCommand.php} (88%) create mode 100644 src/Rocketeer/Tasks/Plugins/Installer.php diff --git a/bin/rocketeer b/bin/rocketeer index 624f1e04c..c2b8cb879 100755 --- a/bin/rocketeer +++ b/bin/rocketeer @@ -2,18 +2,26 @@ fireTasksQueue('Plugins\Installer'); + } + + /** + * Get the console command arguments. + * + * @return string[][] + */ + protected function getArguments() + { + return array( + ['package', InputArgument::REQUIRED, 'The package to publish the configuration for'], + ); + } +} diff --git a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php new file mode 100644 index 000000000..e1854e8d9 --- /dev/null +++ b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php @@ -0,0 +1,41 @@ +laravel['rocketeer.tasks']->getRegisteredPlugins(); + !dd($plugins); + } +} diff --git a/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php b/src/Rocketeer/Console/Commands/Plugins/PublishCommand.php similarity index 88% rename from src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php rename to src/Rocketeer/Console/Commands/Plugins/PublishCommand.php index 3d0c46689..e321ac6ef 100644 --- a/src/Rocketeer/Console/Commands/Plugins/ConfigPublisherCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/PublishCommand.php @@ -5,7 +5,7 @@ use Rocketeer\Services\Ignition\Plugins; use Symfony\Component\Console\Input\InputArgument; -class ConfigPublisherCommand extends AbstractCommand +class PublishCommand extends AbstractCommand { /** * The default name @@ -19,7 +19,7 @@ class ConfigPublisherCommand extends AbstractCommand * * @var string */ - protected $description = 'Publishes the configuration of packages'; + protected $description = 'Publishes the configuration of a plugin'; /** * Whether the command's task should be built diff --git a/src/Rocketeer/RocketeerServiceProvider.php b/src/Rocketeer/RocketeerServiceProvider.php index b2dd97f27..2051236a9 100644 --- a/src/Rocketeer/RocketeerServiceProvider.php +++ b/src/Rocketeer/RocketeerServiceProvider.php @@ -16,7 +16,6 @@ use Illuminate\Log\Writer; use Illuminate\Support\ServiceProvider; use Monolog\Logger; -use Rocketeer\Services\Ignition\Configuration; use Rocketeer\Services\Connections\ConnectionsHandler; use Rocketeer\Services\Connections\LocalConnection; use Rocketeer\Services\Connections\RemoteHandler; @@ -25,6 +24,7 @@ use Rocketeer\Services\Display\QueueTimer; use Rocketeer\Services\History\History; use Rocketeer\Services\History\LogsHandler; +use Rocketeer\Services\Ignition\Configuration; use Rocketeer\Services\Pathfinder; use Rocketeer\Services\ReleasesManager; use Rocketeer\Services\Storages\LocalStorage; @@ -258,20 +258,22 @@ public function bindCommands() { // Base commands $tasks = array( - '' => 'Rocketeer', - 'check' => 'Check', - 'cleanup' => 'Cleanup', - 'current' => 'CurrentRelease', - 'deploy' => 'Deploy', - 'flush' => 'Flush', - 'ignite' => 'Ignite', - 'rollback' => 'Rollback', - 'setup' => 'Setup', - 'strategies' => 'Strategies', - 'teardown' => 'Teardown', - 'test' => 'Test', - 'update' => 'Update', - 'plugin-config' => 'Plugins\ConfigPublisher', + '' => 'Rocketeer', + 'check' => 'Check', + 'cleanup' => 'Cleanup', + 'current' => 'CurrentRelease', + 'deploy' => 'Deploy', + 'flush' => 'Flush', + 'ignite' => 'Ignite', + 'rollback' => 'Rollback', + 'setup' => 'Setup', + 'strategies' => 'Strategies', + 'teardown' => 'Teardown', + 'test' => 'Test', + 'update' => 'Update', + 'plugin-publish' => 'Plugins\Publish', + 'plugin-list' => 'Plugins\List', + 'plugin-install' => 'Plugins\Install', ); // Add User commands diff --git a/src/Rocketeer/Services/Ignition/Configuration.php b/src/Rocketeer/Services/Ignition/Configuration.php index 50f3d520d..3694f868f 100644 --- a/src/Rocketeer/Services/Ignition/Configuration.php +++ b/src/Rocketeer/Services/Ignition/Configuration.php @@ -58,8 +58,9 @@ public function loadUserConfiguration() } // Load plugins - var_dump($this->config->get('rocketeer::config')); - foreach ($this->config->get('rocketeer::plugins') as $plugin) { + $plugins = $this->config->get('rocketeer::plugins'); + $plugins = array_filter($plugins, 'class_exists'); + foreach ($plugins as $plugin) { $this->tasks->plugin($plugin); } diff --git a/src/Rocketeer/Services/Ignition/Plugins.php b/src/Rocketeer/Services/Ignition/Plugins.php index 5a357aae6..3626ed92b 100644 --- a/src/Rocketeer/Services/Ignition/Plugins.php +++ b/src/Rocketeer/Services/Ignition/Plugins.php @@ -10,6 +10,7 @@ namespace Rocketeer\Services\Ignition; use Illuminate\Support\Arr; +use Rocketeer\Tasks\Plugins\Installer; use Rocketeer\Traits\HasLocator; /** diff --git a/src/Rocketeer/Services/Tasks/TasksBuilder.php b/src/Rocketeer/Services/Tasks/TasksBuilder.php index d9512edc6..66bf9a826 100644 --- a/src/Rocketeer/Services/Tasks/TasksBuilder.php +++ b/src/Rocketeer/Services/Tasks/TasksBuilder.php @@ -12,6 +12,7 @@ use Closure; use Illuminate\Support\Str; use Rocketeer\Abstracts\AbstractTask; +use Rocketeer\Binaries\AnonymousBinary; use Rocketeer\Exceptions\TaskCompositionException; use Rocketeer\Traits\HasLocator; @@ -24,6 +25,32 @@ class TasksBuilder { use HasLocator; + /** + * Build a binary + * + * @param string $binary + * + * @return \Rocketeer\Abstracts\AbstractBinary|\Rocketeer\Abstracts\AbstractPackageManager + */ + public function buildBinary($binary) + { + $class = $this->findQualifiedName($binary, array( + 'Rocketeer\Binaries\PackageManagers\%s', + 'Rocketeer\Binaries\%s', + )); + + // If there is a class by that name + if ($class) { + return new $class($this->app); + } + + // Else wrap the command in an AnonymousBinary + $anonymous = new AnonymousBinary($this->app); + $anonymous->setBinary($binary); + + return $anonymous; + } + ////////////////////////////////////////////////////////////////////// ////////////////////////////// COMMANDS ////////////////////////////// ////////////////////////////////////////////////////////////////////// @@ -91,7 +118,7 @@ public function buildStrategy($strategy, $concrete = null) } //////////////////////////////////////////////////////////////////// - /////////////////////////////// BUILDING /////////////////////////// + //////////////////////////////// TASKS ///////////////////////////// //////////////////////////////////////////////////////////////////// /** diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 078049a41..3843c08ce 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -271,6 +271,15 @@ public function getTasksListeners($task, $event, $flatten = false) /////////////////////////////// PLUGINS //////////////////////////// //////////////////////////////////////////////////////////////////// + + /** + * @return array + */ + public function getRegisteredPlugins() + { + return $this->registeredPlugins; + } + /** * Register a Rocketeer plugin with Rocketeer * diff --git a/src/Rocketeer/Tasks/Plugins/Installer.php b/src/Rocketeer/Tasks/Plugins/Installer.php new file mode 100644 index 000000000..240dd2ff2 --- /dev/null +++ b/src/Rocketeer/Tasks/Plugins/Installer.php @@ -0,0 +1,38 @@ +command->argument('package'); + $folder = $this->paths->getRocketeerConfigFolder(); + + // Add version if necessary + if (strpos($package, ':') === false) { + $package .= ':dev-master'; + } + + $command = $this->composer()->require($package, array( + '--working-dir' => $folder + )); + + return $this->run($this->shellCommand($command)); + } +} diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 426c73e10..5c9c8e0b8 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -31,25 +31,7 @@ trait Binaries */ public function binary($binary) { - // Check for an existing Binary - $paths = array( - 'Rocketeer\Binaries\PackageManagers\%s', - 'Rocketeer\Binaries\%s', - '%s', - ); - - foreach ($paths as $path) { - $path = sprintf($path, ucfirst($binary)); - if (class_exists($path)) { - return new $path($this->app); - } - } - - // Else wrap the command in an AnonymousBinary - $anonymous = new AnonymousBinary($this->app); - $anonymous->setBinary($binary); - - return $anonymous; + return $this->builder->buildBinary($binary); } /** diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 04b033152..963ad6822 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -290,7 +290,7 @@ public function processCommands($commands) // Create shell if asked if ($shell && Str::contains($command, $shelled)) { - $command = "bash --login -c '".$command."'"; + $command = $this->shellCommand($command); } } @@ -311,6 +311,18 @@ protected function cleanOutput($output) )); } + /** + * Pass a command through shell execution + * + * @param string $command + * + * @return string + */ + protected function shellCommand($command) + { + return "bash --login -c '".$command."'"; + } + /** * Process the output of a command * From 5eac02c7683ac1f6f883d058c1cd580dc9ff6cfb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 24 Aug 2014 18:24:34 +0200 Subject: [PATCH 389/424] Enabled plugins list --- .../Console/Commands/Plugins/ListCommand.php | 12 ++++++++++-- src/Rocketeer/Tasks/Plugins/Installer.php | 6 +++++- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php index e1854e8d9..74f82d14a 100644 --- a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php @@ -2,6 +2,7 @@ namespace Rocketeer\Console\Commands\Plugins; use Rocketeer\Abstracts\AbstractCommand; +use Symfony\Component\Console\Helper\Table; class ListCommand extends AbstractCommand { @@ -34,8 +35,15 @@ class ListCommand extends AbstractCommand */ public function fire() { - !dd(class_exists('Rocketeer\Plugins\Slack\RocketeerSlack')); + $rows = []; $plugins = $this->laravel['rocketeer.tasks']->getRegisteredPlugins(); - !dd($plugins); + foreach ($plugins as $plugin => $instance) { + $rows[] = [$plugin]; + } + + $table = new Table($this->getOutput()); + $table->setHeaders(['Plugin']); + $table->addRows($rows); + $table->render(); } } diff --git a/src/Rocketeer/Tasks/Plugins/Installer.php b/src/Rocketeer/Tasks/Plugins/Installer.php index 240dd2ff2..b86f0830e 100644 --- a/src/Rocketeer/Tasks/Plugins/Installer.php +++ b/src/Rocketeer/Tasks/Plugins/Installer.php @@ -33,6 +33,10 @@ public function execute() '--working-dir' => $folder )); - return $this->run($this->shellCommand($command)); + // Install plugin + $this->run($this->shellCommand($command)); + + // Prune duplicate Rocketeer + $this->files->deleteDirectory($folder.'/vendor/anahkiasen/rocketeer'); } } From a9dd4336c693fa9dcf695b080155e9d8e6efd852 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sun, 24 Aug 2014 18:46:46 +0200 Subject: [PATCH 390/424] Code tweaks --- src/Rocketeer/Services/TasksHandler.php | 1 - src/Rocketeer/Tasks/Plugins/Installer.php | 2 +- src/Rocketeer/Traits/BashModules/Binaries.php | 2 -- 3 files changed, 1 insertion(+), 4 deletions(-) diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 3843c08ce..78569d4c6 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -271,7 +271,6 @@ public function getTasksListeners($task, $event, $flatten = false) /////////////////////////////// PLUGINS //////////////////////////// //////////////////////////////////////////////////////////////////// - /** * @return array */ diff --git a/src/Rocketeer/Tasks/Plugins/Installer.php b/src/Rocketeer/Tasks/Plugins/Installer.php index b86f0830e..5b7802842 100644 --- a/src/Rocketeer/Tasks/Plugins/Installer.php +++ b/src/Rocketeer/Tasks/Plugins/Installer.php @@ -22,7 +22,7 @@ public function execute() { // Get package and destination folder $package = $this->command->argument('package'); - $folder = $this->paths->getRocketeerConfigFolder(); + $folder = $this->paths->getRocketeerConfigFolder(); // Add version if necessary if (strpos($package, ':') === false) { diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index 5c9c8e0b8..aff1224fc 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -9,8 +9,6 @@ */ namespace Rocketeer\Traits\BashModules; -use Rocketeer\Binaries\AnonymousBinary; - /** * Handles finding and calling binaries * From 3c27f2b993b9b5a47d874f3532d39e02471b3e95 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 25 Aug 2014 22:39:42 +0200 Subject: [PATCH 391/424] Add plugins installer description --- src/Rocketeer/Tasks/Plugins/Installer.php | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/Rocketeer/Tasks/Plugins/Installer.php b/src/Rocketeer/Tasks/Plugins/Installer.php index 5b7802842..c1126571d 100644 --- a/src/Rocketeer/Tasks/Plugins/Installer.php +++ b/src/Rocketeer/Tasks/Plugins/Installer.php @@ -5,6 +5,13 @@ class Installer extends AbstractTask { + /** + * The console command description. + * + * @var string + */ + protected $description = 'Installs plugins'; + /** * Whether to run the commands locally * or on the server @@ -34,6 +41,7 @@ public function execute() )); // Install plugin + $this->explainer->line('Installing '.$package); $this->run($this->shellCommand($command)); // Prune duplicate Rocketeer From e207358fe979db8b7612bc3c4321195cde9fe9c5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 25 Aug 2014 22:50:46 +0200 Subject: [PATCH 392/424] Fix some path issues --- .../Services/Ignition/Configuration.php | 6 +++--- tests/Services/Ignition/ConfigurationTest.php | 16 ++++++++-------- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/Rocketeer/Services/Ignition/Configuration.php b/src/Rocketeer/Services/Ignition/Configuration.php index 3694f868f..3610fabae 100644 --- a/src/Rocketeer/Services/Ignition/Configuration.php +++ b/src/Rocketeer/Services/Ignition/Configuration.php @@ -58,8 +58,8 @@ public function loadUserConfiguration() } // Load plugins - $plugins = $this->config->get('rocketeer::plugins'); - $plugins = array_filter($plugins, 'class_exists'); + $plugins = (array) $this->config->get('rocketeer::plugins'); + $plugins = array_filter($plugins, 'class_exists'); foreach ($plugins as $plugin) { $this->tasks->plugin($plugin); } @@ -132,7 +132,7 @@ public function mergePluginsConfiguration() */ public function exportConfiguration() { - $source = $this->paths->unifyLocalSlashes(__DIR__.'/../config'); + $source = $this->paths->unifyLocalSlashes(__DIR__.'/../../../config'); $source = realpath($source); $destination = $this->paths->getConfigurationPath(); diff --git a/tests/Services/Ignition/ConfigurationTest.php b/tests/Services/Ignition/ConfigurationTest.php index ca3c4be74..d8de045af 100644 --- a/tests/Services/Ignition/ConfigurationTest.php +++ b/tests/Services/Ignition/ConfigurationTest.php @@ -41,14 +41,14 @@ public function testCanBindBasePath() { $this->igniter->bindPaths(); - $this->assertEquals(realpath(__DIR__.'/..'), $this->app['path.base']); + $this->assertEquals(realpath(__DIR__.'/../../..'), $this->app['path.base']); } public function testCanBindConfigurationPaths() { $this->igniter->bindPaths(); - $root = realpath(__DIR__.'/..'); + $root = realpath(__DIR__.'/../../..'); $this->assertEquals($root.'/.rocketeer', $this->app['path.rocketeer.config']); } @@ -58,7 +58,7 @@ public function testCanBindTasksAndEventsPaths() $this->igniter->exportConfiguration(); // Create some fake files - $root = realpath(__DIR__.'/../.rocketeer'); + $root = realpath(__DIR__.'/../../../.rocketeer'); $this->files->put($root.'/events.php', ''); $this->files->makeDirectory($root.'/tasks'); @@ -73,7 +73,7 @@ public function testCanExportConfiguration() $this->igniter->bindPaths(); $this->igniter->exportConfiguration(); - $this->assertFileExists(__DIR__.'/../.rocketeer'); + $this->assertFileExists(__DIR__.'/../../../.rocketeer'); } public function testCanReplaceStubsInConfigurationFile() @@ -82,8 +82,8 @@ public function testCanReplaceStubsInConfigurationFile() $path = $this->igniter->exportConfiguration(); $this->igniter->updateConfiguration($path, array('scm_username' => 'foobar')); - $this->assertFileExists(__DIR__.'/../.rocketeer'); - $this->assertContains('foobar', file_get_contents(__DIR__.'/../.rocketeer/scm.php')); + $this->assertFileExists(__DIR__.'/../../../.rocketeer'); + $this->assertContains('foobar', file_get_contents(__DIR__.'/../../../.rocketeer/scm.php')); } public function testCanSetCurrentApplication() @@ -96,8 +96,8 @@ public function testCanSetCurrentApplication() $path = $this->igniter->exportConfiguration(); $this->igniter->updateConfiguration($path, array('application_name' => 'foobar', 'scm_username' => 'foobar')); - $this->assertFileExists(__DIR__.'/../.rocketeer'); - $this->assertContains('foobar', file_get_contents(__DIR__.'/../.rocketeer/config.php')); + $this->assertFileExists(__DIR__.'/../../../.rocketeer'); + $this->assertContains('foobar', file_get_contents(__DIR__.'/../../../.rocketeer/config.php')); } public function testCanLoadFilesOrFolder() From 81c341f6f5192b956eeb1222de25a05ed7390f42 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 25 Aug 2014 23:39:21 +0200 Subject: [PATCH 393/424] Docblocks fixes --- src/Rocketeer/Console/Commands/Plugins/InstallCommand.php | 2 +- src/Rocketeer/Services/Ignition/Plugins.php | 3 +-- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php b/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php index 422a7a399..fd06fb248 100644 --- a/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php @@ -32,7 +32,7 @@ class InstallCommand extends AbstractCommand /** * Run the tasks * - * @return void + * @return integer */ public function fire() { diff --git a/src/Rocketeer/Services/Ignition/Plugins.php b/src/Rocketeer/Services/Ignition/Plugins.php index 3626ed92b..f5398c93d 100644 --- a/src/Rocketeer/Services/Ignition/Plugins.php +++ b/src/Rocketeer/Services/Ignition/Plugins.php @@ -10,7 +10,6 @@ namespace Rocketeer\Services\Ignition; use Illuminate\Support\Arr; -use Rocketeer\Tasks\Plugins\Installer; use Rocketeer\Traits\HasLocator; /** @@ -27,7 +26,7 @@ class Plugins * * @param string $package * - * @return boolean + * @return boolean|null */ public function publish($package) { From 36f61208389c6eb64c58fae2326ad66e0270f8d3 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 25 Aug 2014 23:51:11 +0200 Subject: [PATCH 394/424] Deduplicate code --- .../Services/Ignition/Configuration.php | 101 ++++++++++-------- 1 file changed, 58 insertions(+), 43 deletions(-) diff --git a/src/Rocketeer/Services/Ignition/Configuration.php b/src/Rocketeer/Services/Ignition/Configuration.php index 3610fabae..344ab56b7 100644 --- a/src/Rocketeer/Services/Ignition/Configuration.php +++ b/src/Rocketeer/Services/Ignition/Configuration.php @@ -9,6 +9,7 @@ */ namespace Rocketeer\Services\Ignition; +use Closure; use Illuminate\Support\Arr; use Rocketeer\Facades; use Rocketeer\Traits\HasLocator; @@ -74,57 +75,24 @@ public function loadUserConfiguration() */ public function mergeContextualConfigurations() { - // Cancel if not ignited yet - $configuration = $this->app['path.rocketeer.config']; - if (!is_dir($configuration) || (!is_dir($configuration.DS.'stages') && !is_dir($configuration.DS.'connections'))) { - return; - } - - // Get folders to glob - $folders = $this->paths->unifyLocalSlashes($configuration.'/{stages,connections}/*'); - - // Gather custom files - $finder = new Finder(); - $files = $finder->in($folders)->notName('config.php')->files(); - - // Bind their contents to the "on" array - foreach ($files as $file) { - $contents = include $file->getPathname(); - $handle = $this->computeHandleFromPath($file); - - $this->config->set($handle, $contents); - } + $this->mergeConfigurationFolders(['plugins'], function (SplFileInfo $file) { + return $this->computeHandleFromPath($file); + }, 'config.php'); } + /** + * Merge the plugin configurations defined in userland + */ public function mergePluginsConfiguration() { - // Cancel if no plugins - $configuration = $this->app['path.rocketeer.config']; - if (!is_dir($configuration) || !is_dir($configuration.DS.'plugins')) { - return; - } - - // Get folders to glob - $folders = $this->paths->unifyLocalSlashes($configuration.'/plugins/*'); - - // Gather custom files - $finder = new Finder(); - $files = $finder->in($folders)->files(); - - // Bind their contents to the "on" array - foreach ($files as $file) { - $contents = include $file->getPathname(); - $handle = basename(dirname($file->getPathname())); + $this->mergeConfigurationFolders(['plugins'], function (SplFileInfo $file) { + $handle = basename(dirname($file->getPathname())); $handle .= '::'.$file->getBasename('.php'); - $this->config->set($handle, $contents); - } + return $handle; + }); } - //////////////////////////////////////////////////////////////////// - ///////////////////////////// CONFIGURATION //////////////////////// - //////////////////////////////////////////////////////////////////// - /** * Export the configuration files * @@ -142,6 +110,10 @@ public function exportConfiguration() return $destination; } + //////////////////////////////////////////////////////////////////// + ///////////////////////////// CONFIGURATION //////////////////////// + //////////////////////////////////////////////////////////////////// + /** * Replace placeholders in configuration * @@ -164,6 +136,49 @@ public function updateConfiguration($folder, array $values = array()) $this->localStorage->setFile($application); } + /** + * Merge configuration files from userland + * + * @param array $folders + * @param callable $computeHandle + * @param string|null $exclude + */ + protected function mergeConfigurationFolders(array $folders = [], Closure $computeHandle, $exclude = null) + { + // Cancel if not ignited yet + $configuration = $this->app['path.rocketeer.config']; + if (!is_dir($configuration)) { + return; + } + + // Cancel if the subfolders don't exist + $existing = array_filter($folders, function ($path) use ($configuration) { + return is_dir($configuration.DS.$path); + }); + if (!$existing) { + return; + } + + // Get folders to glob + $folders = $this->paths->unifyLocalSlashes($configuration.'/{'.implode(',', $folders).'}/*'); + + // Gather custom files + $finder = new Finder(); + $finder = $finder->in($folders); + if ($exclude) { + $finder = $finder->notName($exclude); + } + + // Bind their contents to the "on" array + $files = $finder->files(); + foreach ($files as $file) { + $contents = include $file->getPathname(); + $handle = $computeHandle($file); + + $this->config->set($handle, $contents); + } + } + //////////////////////////////////////////////////////////////////// //////////////////////////////// PATHS ///////////////////////////// //////////////////////////////////////////////////////////////////// From 19ff6ea3090a9aeb4f6be60c95c241a293d16b7b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Mon, 25 Aug 2014 23:52:54 +0200 Subject: [PATCH 395/424] Code tweaks --- src/Rocketeer/Services/Ignition/Plugins.php | 1 + src/Rocketeer/Tasks/Plugins/Installer.php | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Ignition/Plugins.php b/src/Rocketeer/Services/Ignition/Plugins.php index f5398c93d..65562b911 100644 --- a/src/Rocketeer/Services/Ignition/Plugins.php +++ b/src/Rocketeer/Services/Ignition/Plugins.php @@ -83,6 +83,7 @@ protected function publishConfiguration($path) { // Get the vendor and package preg_match('/vendor\/([^\/]+)\/([^\/]+)/', $path, $handle); + $handle = (array) $handle; $package = Arr::get($handle, 2); // Compute and create the destination foldser diff --git a/src/Rocketeer/Tasks/Plugins/Installer.php b/src/Rocketeer/Tasks/Plugins/Installer.php index c1126571d..f508b7499 100644 --- a/src/Rocketeer/Tasks/Plugins/Installer.php +++ b/src/Rocketeer/Tasks/Plugins/Installer.php @@ -23,7 +23,7 @@ class Installer extends AbstractTask /** * Run the task * - * @return string + * @return null */ public function execute() { From eebfccdc649b9de42e916902e9900cb0fcc039ec Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 00:01:34 +0200 Subject: [PATCH 396/424] Fix mistake --- src/Rocketeer/Services/Ignition/Configuration.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Ignition/Configuration.php b/src/Rocketeer/Services/Ignition/Configuration.php index 344ab56b7..835a98ecc 100644 --- a/src/Rocketeer/Services/Ignition/Configuration.php +++ b/src/Rocketeer/Services/Ignition/Configuration.php @@ -75,7 +75,7 @@ public function loadUserConfiguration() */ public function mergeContextualConfigurations() { - $this->mergeConfigurationFolders(['plugins'], function (SplFileInfo $file) { + $this->mergeConfigurationFolders(['stages', 'connections'], function (SplFileInfo $file) { return $this->computeHandleFromPath($file); }, 'config.php'); } From b57cd4739854cfb38b28bf3c3f9f7553ea65b1fe Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 17:13:12 +0200 Subject: [PATCH 397/424] Make getOption public --- src/Rocketeer/Traits/HasLocator.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Traits/HasLocator.php b/src/Rocketeer/Traits/HasLocator.php index 4645dd4eb..5ada3039a 100644 --- a/src/Rocketeer/Traits/HasLocator.php +++ b/src/Rocketeer/Traits/HasLocator.php @@ -129,7 +129,7 @@ protected function hasCommand() * * @return string */ - protected function getOption($option, $loose = false) + public function getOption($option, $loose = false) { if (!$this->hasCommand()) { return null; From db4a1ca22010bc1d5abbe0af1c73b8a21c0d2e01 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 22:05:47 +0200 Subject: [PATCH 398/424] Code tweaks --- .../Abstracts/Strategies/AbstractPolyglotStrategy.php | 2 +- src/Rocketeer/Console/Commands/Plugins/InstallCommand.php | 1 - src/Rocketeer/Console/Commands/Plugins/ListCommand.php | 2 +- src/Rocketeer/Services/History/History.php | 2 +- src/Rocketeer/Services/History/LogsHandler.php | 4 ++-- 5 files changed, 5 insertions(+), 6 deletions(-) diff --git a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php index 87e6b090c..d91b5e84f 100644 --- a/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php +++ b/src/Rocketeer/Abstracts/Strategies/AbstractPolyglotStrategy.php @@ -55,7 +55,7 @@ protected function checkStrategiesResults($results) */ protected function onStrategies(Closure $callback) { - return $this->explainer->displayBelow(function() use ($callback) { + return $this->explainer->displayBelow(function () use ($callback) { $results = []; foreach ($this->strategies as $strategy) { $instance = $this->getStrategy('Dependencies', $strategy); diff --git a/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php b/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php index fd06fb248..17c040a57 100644 --- a/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/InstallCommand.php @@ -2,7 +2,6 @@ namespace Rocketeer\Console\Commands\Plugins; use Rocketeer\Abstracts\AbstractCommand; -use Rocketeer\Services\Ignition\Plugins; use Symfony\Component\Console\Input\InputArgument; class InstallCommand extends AbstractCommand diff --git a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php index 74f82d14a..ad638b903 100644 --- a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php @@ -35,7 +35,7 @@ class ListCommand extends AbstractCommand */ public function fire() { - $rows = []; + $rows = []; $plugins = $this->laravel['rocketeer.tasks']->getRegisteredPlugins(); foreach ($plugins as $plugin => $instance) { $rows[] = [$plugin]; diff --git a/src/Rocketeer/Services/History/History.php b/src/Rocketeer/Services/History/History.php index 9709f2b7c..4ec34f490 100644 --- a/src/Rocketeer/Services/History/History.php +++ b/src/Rocketeer/Services/History/History.php @@ -40,7 +40,7 @@ public function getFlattenedOutput() /** * Get a flattened list of a certain type * - * @param string $type + * @param string $type * * @return string[]|string[][] */ diff --git a/src/Rocketeer/Services/History/LogsHandler.php b/src/Rocketeer/Services/History/LogsHandler.php index 9915511d7..e2ffcafd0 100644 --- a/src/Rocketeer/Services/History/LogsHandler.php +++ b/src/Rocketeer/Services/History/LogsHandler.php @@ -85,8 +85,8 @@ public function getCurrentLogsFile() } $namer = $this->namer; - $file = $namer($this->connections); - $file = $this->app['path.rocketeer.logs'].'/'.$file; + $file = $namer($this->connections); + $file = $this->app['path.rocketeer.logs'].'/'.$file; return $file; } From a694550c99fe566e6411f37f321af9a38e7f45ac Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 22:06:37 +0200 Subject: [PATCH 399/424] Make parameter required --- src/Rocketeer/Services/Ignition/Configuration.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Ignition/Configuration.php b/src/Rocketeer/Services/Ignition/Configuration.php index 835a98ecc..be2d8fd28 100644 --- a/src/Rocketeer/Services/Ignition/Configuration.php +++ b/src/Rocketeer/Services/Ignition/Configuration.php @@ -143,7 +143,7 @@ public function updateConfiguration($folder, array $values = array()) * @param callable $computeHandle * @param string|null $exclude */ - protected function mergeConfigurationFolders(array $folders = [], Closure $computeHandle, $exclude = null) + protected function mergeConfigurationFolders(array $folders, Closure $computeHandle, $exclude = null) { // Cancel if not ignited yet $configuration = $this->app['path.rocketeer.config']; From 735784266a17f9d08958a3322df66ecbd0380c1d Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 22:29:06 +0200 Subject: [PATCH 400/424] Add mockFiles helper --- tests/Services/Storages/LocalStorageTest.php | 2 +- tests/Strategies/Check/PhpStrategyTest.php | 4 ++-- tests/Tasks/IgniteTest.php | 4 ++-- tests/TestCases/Modules/RocketeerMockeries.php | 8 ++++++++ 4 files changed, 13 insertions(+), 5 deletions(-) diff --git a/tests/Services/Storages/LocalStorageTest.php b/tests/Services/Storages/LocalStorageTest.php index fd68f26d4..d41bd1f65 100644 --- a/tests/Services/Storages/LocalStorageTest.php +++ b/tests/Services/Storages/LocalStorageTest.php @@ -46,7 +46,7 @@ public function testCanGetSeparators() public function testCanComputeHashAccordingToContentsOfFiles() { - $this->mock('files', 'Filesystem', function ($mock) { + $this->mockFiles(function ($mock) { return $mock ->shouldReceive('put')->once() ->shouldReceive('exists')->twice()->andReturn(false) diff --git a/tests/Strategies/Check/PhpStrategyTest.php b/tests/Strategies/Check/PhpStrategyTest.php index f2b755366..b5a22e951 100644 --- a/tests/Strategies/Check/PhpStrategyTest.php +++ b/tests/Strategies/Check/PhpStrategyTest.php @@ -19,7 +19,7 @@ public function setUp() public function testCanCheckPhpVersion() { - $this->mock('files', 'Filesystem', function ($mock) { + $this->mockFiles(function ($mock) { return $mock ->shouldReceive('put') ->shouldReceive('glob')->andReturn(array()) @@ -29,7 +29,7 @@ public function testCanCheckPhpVersion() $this->assertTrue($this->strategy->language()); // This is is going to come bite me in the ass in 10 years - $this->mock('files', 'Filesystem', function ($mock) { + $this->mockFiles(function ($mock) { return $mock ->shouldReceive('put') ->shouldReceive('glob')->andReturn(array()) diff --git a/tests/Tasks/IgniteTest.php b/tests/Tasks/IgniteTest.php index bba83da1e..6f9850f2a 100644 --- a/tests/Tasks/IgniteTest.php +++ b/tests/Tasks/IgniteTest.php @@ -14,7 +14,7 @@ public function testCanIgniteConfigurationOnWindows() $provider = new RocketeerServiceProvider($this->app); $provider->bindPaths(); - $this->mock('files', 'Filesystem', function ($mock) { + $this->mockFiles(function ($mock) { return $mock ->shouldReceive('files')->andReturn([]) ->shouldReceive('glob')->andReturn([]) @@ -32,7 +32,7 @@ public function testCanIgniteConfigurationOnWindowsInLaravel() $provider = new RocketeerServiceProvider($this->app); $provider->bindPaths(); - $this->mock('files', 'Filesystem', function ($mock) { + $this->mockFiles(function ($mock) { return $mock ->shouldReceive('exists')->andReturn(true) ->shouldReceive('files')->andReturn([]) diff --git a/tests/TestCases/Modules/RocketeerMockeries.php b/tests/TestCases/Modules/RocketeerMockeries.php index 904f1c7cc..72b99f293 100644 --- a/tests/TestCases/Modules/RocketeerMockeries.php +++ b/tests/TestCases/Modules/RocketeerMockeries.php @@ -95,4 +95,12 @@ protected function mockRemote($expectations = null) { $this->app['rocketeer.remote'] = $this->getRemote($expectations); } + + /** + * @param Closure|null $expectations + */ + protected function mockFiles(Closure $expectations = null) + { + $this->mock('files', 'Illuminate\Filesystem\Filesystem', $expectations); + } } From 84cdecc349283bb1c934108f5de1c458a900e0b7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 22:29:17 +0200 Subject: [PATCH 401/424] Fix duplication of plugins configurations --- src/Rocketeer/Services/Ignition/Plugins.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Services/Ignition/Plugins.php b/src/Rocketeer/Services/Ignition/Plugins.php index 65562b911..763592d92 100644 --- a/src/Rocketeer/Services/Ignition/Plugins.php +++ b/src/Rocketeer/Services/Ignition/Plugins.php @@ -69,7 +69,7 @@ protected function publishLaravelConfiguration($package) $path = $this->app['path'].'/config/packages/'.$package; $destination = preg_replace('/packages\/([^\/]+)/', 'packages/rocketeers', $path); - return $this->files->copyDirectory($path, $destination); + return $this->files->move($path, $destination); } /** From 956e979152158648eea58bf71d613bf5c0b4f922 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Tue, 26 Aug 2014 22:42:30 +0200 Subject: [PATCH 402/424] Add some tests for the plugin class --- src/Rocketeer/Services/Ignition/Plugins.php | 13 ++-- tests/Services/Ignition/PluginsTest.php | 72 +++++++++++++++++++++ tests/TestCases/ContainerTestCase.php | 7 +- 3 files changed, 85 insertions(+), 7 deletions(-) create mode 100644 tests/Services/Ignition/PluginsTest.php diff --git a/src/Rocketeer/Services/Ignition/Plugins.php b/src/Rocketeer/Services/Ignition/Plugins.php index 763592d92..e81d352b1 100644 --- a/src/Rocketeer/Services/Ignition/Plugins.php +++ b/src/Rocketeer/Services/Ignition/Plugins.php @@ -42,10 +42,13 @@ public function publish($package) $this->paths->getHomeFolder().'/.composer/vendor/%s/config', ); - foreach ($paths as &$path) { - $path = sprintf($path, $package); - } - $paths = array_filter($paths, 'is_dir'); + // Check for the first configuration path that exists + $paths = array_filter($paths, function ($path) use ($package) { + return $this->files->isDirectory(sprintf($path, $package)); + }); + $paths = array_values($paths); + + // Cancel if no valid paths if (empty($paths)) { return $this->command->error('No configuration found for '.$package); } @@ -89,7 +92,7 @@ protected function publishConfiguration($path) // Compute and create the destination foldser $destination = $this->app['path.rocketeer.config']; $destination = $destination.'/plugins/rocketeers/'.$package; - if (!$this->files->exists($destination)) { + if (!$this->files->isDirectory($destination)) { $this->files->makeDirectory($destination, 0755, true); } diff --git a/tests/Services/Ignition/PluginsTest.php b/tests/Services/Ignition/PluginsTest.php new file mode 100644 index 000000000..8a0138334 --- /dev/null +++ b/tests/Services/Ignition/PluginsTest.php @@ -0,0 +1,72 @@ +plugins = new Plugins($this->app); + $this->from = $this->app['path.base'].'/vendor/anahkiasen/rocketeer-slack/config'; + } + + public function testCanPublishClassicPluginConfiguration() + { + unset($this->app['path']); + + $this->mockFiles(function ($mock) { + $destination = $this->app['path.rocketeer.config'].'/plugins/rocketeers/rocketeer-slack'; + + return $mock + ->shouldReceive('isDirectory')->with($this->from)->andReturn(true) + ->shouldReceive('isDirectory')->with($destination)->andReturn(false) + ->shouldReceive('makeDirectory')->with($destination)->andReturn(true) + ->shouldReceive('copyDirectory')->with($this->from, $destination); + }); + + $this->plugins->publish('anahkiasen/rocketeer-slack'); + } + + public function testCancelsIfNoValidConfigurationPath() + { + unset($this->app['path']); + + $this->mockFiles(function ($mock) { + return $mock + ->shouldReceive('isDirectory')->with($this->from)->andReturn(false) + ->shouldReceive('copyDirectory')->never(); + }); + + $this->plugins->publish('anahkiasen/rocketeer-slack'); + } + + public function testCanPublishLaravelConfiguration() + { + $this->mock('artisan'); + + $this->mockFiles(function ($mock) { + $destination = $this->app['path'].'/config/packages/rocketeers/rocketeer-slack'; + + return $mock + ->shouldReceive('isDirectory')->with($this->from)->andReturn(true) + ->shouldReceive('isDirectory')->with($destination)->andReturn(false) + ->shouldReceive('makeDirectory')->with($destination)->andReturn(true) + ->shouldReceive('copyDirectory')->with($this->from, $destination); + }); + + $this->plugins->publish('anahkiasen/rocketeer-slack'); + } +} diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 7c3d2a686..266e62ead 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -88,14 +88,17 @@ public function tearDown() * * @return Mockery */ - protected function mock($handle, $class, Closure $expectations, $partial = true) + protected function mock($handle, $class = null, Closure $expectations = null, $partial = true) { + $class = $class ?: $handle; $mockery = Mockery::mock($class); if ($partial) { $mockery = $mockery->shouldIgnoreMissing(); } - $mockery = $expectations($mockery)->mock(); + if ($expectations) { + $mockery = $expectations($mockery)->mock(); + } $this->app[$handle] = $mockery; From f858596713cace108e7a3e3eab64c84139c03dc4 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 5 Sep 2014 10:43:17 +0200 Subject: [PATCH 403/424] Delete .gitmodules --- .gitmodules | 3 --- 1 file changed, 3 deletions(-) delete mode 100644 .gitmodules diff --git a/.gitmodules b/.gitmodules deleted file mode 100644 index 91e45b800..000000000 --- a/.gitmodules +++ /dev/null @@ -1,3 +0,0 @@ -[submodule "docs"] - path = docs - url = https://github.com/Anahkiasen/rocketeer.wiki.git From 4ae54d19171a86b9437bc618b38b2bad813f447b Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 12 Sep 2014 18:23:21 +0200 Subject: [PATCH 404/424] Fix typo --- src/config/remote.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/config/remote.php b/src/config/remote.php index fba2b6e8b..e19ab39fb 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -37,7 +37,7 @@ ////////////////////////////////////////////////////////////////////// // If enabled will force a shell to be created - // which is requried for some tools like RVM or NVM + // which is required for some tools like RVM or NVM 'shell' => false, // An array of commands to run under shell From d28fac446b898add45fa49484354eb7cea83c824 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 5 Sep 2014 22:13:14 +0200 Subject: [PATCH 405/424] Code tweaks --- src/Rocketeer/Binaries/Artisan.php | 2 +- .../Binaries/PackageManagers/Bower.php | 2 +- .../Binaries/PackageManagers/Composer.php | 2 +- src/Rocketeer/Binaries/Phpunit.php | 2 +- .../Services/CredentialsGatherer.php | 2 +- src/Rocketeer/Services/TasksHandler.php | 2 +- src/Rocketeer/Tasks/Plugins/Installer.php | 2 +- src/config/strategies.php | 2 +- tests/Plugins/AbstractNotifierTest.php | 2 +- .../Connections/ConnectionsHandlerTest.php | 2 +- tests/Services/CredentialsGathererTest.php | 6 +-- tests/Services/Tasks/TasksBuilderTest.php | 2 +- tests/Services/Tasks/TasksQueueTest.php | 8 ++-- tests/Services/TasksHandlerTest.php | 2 +- tests/Strategies/Deploy/CloneStrategyTest.php | 4 +- tests/Strategies/Deploy/CopyStrategyTest.php | 4 +- tests/Tasks/CleanupTest.php | 2 +- tests/Tasks/DeployTest.php | 46 +++++++++---------- tests/Tasks/RollbackTest.php | 1 - tests/Tasks/Subtasks/PrimerTest.php | 2 +- tests/Tasks/UpdateTest.php | 14 +++--- tests/TestCases/ContainerTestCase.php | 8 ++-- tests/TestCases/RocketeerTestCase.php | 1 - tests/Traits/BashModules/CoreTest.php | 2 +- tests/Traits/StepsRunnerTest.php | 4 +- 25 files changed, 62 insertions(+), 64 deletions(-) diff --git a/src/Rocketeer/Binaries/Artisan.php b/src/Rocketeer/Binaries/Artisan.php index 930e7478b..5c2efdfe6 100644 --- a/src/Rocketeer/Binaries/Artisan.php +++ b/src/Rocketeer/Binaries/Artisan.php @@ -35,7 +35,7 @@ protected function getKnownPaths() { return array( 'artisan', - $this->releasesManager->getCurrentReleasePath().'/artisan' + $this->releasesManager->getCurrentReleasePath().'/artisan', ); } diff --git a/src/Rocketeer/Binaries/PackageManagers/Bower.php b/src/Rocketeer/Binaries/PackageManagers/Bower.php index b55c27631..3037b9f98 100644 --- a/src/Rocketeer/Binaries/PackageManagers/Bower.php +++ b/src/Rocketeer/Binaries/PackageManagers/Bower.php @@ -29,7 +29,7 @@ protected function getKnownPaths() { return array( 'bower', - $this->releasesManager->getCurrentReleasePath().'/node_modules/.bin/bower' + $this->releasesManager->getCurrentReleasePath().'/node_modules/.bin/bower', ); } } diff --git a/src/Rocketeer/Binaries/PackageManagers/Composer.php b/src/Rocketeer/Binaries/PackageManagers/Composer.php index 761d53eba..bd8bc9f67 100644 --- a/src/Rocketeer/Binaries/PackageManagers/Composer.php +++ b/src/Rocketeer/Binaries/PackageManagers/Composer.php @@ -30,7 +30,7 @@ protected function getKnownPaths() { return array( 'composer', - $this->releasesManager->getCurrentReleasePath().'/composer.phar' + $this->releasesManager->getCurrentReleasePath().'/composer.phar', ); } diff --git a/src/Rocketeer/Binaries/Phpunit.php b/src/Rocketeer/Binaries/Phpunit.php index b855cbbc0..baa0adc81 100644 --- a/src/Rocketeer/Binaries/Phpunit.php +++ b/src/Rocketeer/Binaries/Phpunit.php @@ -22,7 +22,7 @@ protected function getKnownPaths() { return array( 'phpunit', - $this->releasesManager->getCurrentReleasePath().'/vendor/bin/phpunit' + $this->releasesManager->getCurrentReleasePath().'/vendor/bin/phpunit', ); } } diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 584a4b4dc..19e72d600 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -105,7 +105,7 @@ protected function getConnectionCredentials($connectionName, $server = null) 'password' => false, 'keyphrase' => null, 'key' => false, - 'agent' => false + 'agent' => false, ), $connection, $handle); // Get password or key diff --git a/src/Rocketeer/Services/TasksHandler.php b/src/Rocketeer/Services/TasksHandler.php index 78569d4c6..8d1a55e16 100644 --- a/src/Rocketeer/Services/TasksHandler.php +++ b/src/Rocketeer/Services/TasksHandler.php @@ -302,7 +302,7 @@ public function plugin($plugin, array $configuration = array()) $this->registeredPlugins[$identifier] = array( 'plugin' => $plugin, - 'configuration' => $configuration + 'configuration' => $configuration, ); // Register configuration diff --git a/src/Rocketeer/Tasks/Plugins/Installer.php b/src/Rocketeer/Tasks/Plugins/Installer.php index f508b7499..5c67a0a9a 100644 --- a/src/Rocketeer/Tasks/Plugins/Installer.php +++ b/src/Rocketeer/Tasks/Plugins/Installer.php @@ -37,7 +37,7 @@ public function execute() } $command = $this->composer()->require($package, array( - '--working-dir' => $folder + '--working-dir' => $folder, )); // Install plugin diff --git a/src/config/strategies.php b/src/config/strategies.php index 2e8ff01f1..82205d883 100644 --- a/src/config/strategies.php +++ b/src/config/strategies.php @@ -46,6 +46,6 @@ // $task->executeTask('Test'), // $task->binary('grunt')->execute('lint'), ); - } + }, ); diff --git a/tests/Plugins/AbstractNotifierTest.php b/tests/Plugins/AbstractNotifierTest.php index 76fcf87b2..43367f32d 100644 --- a/tests/Plugins/AbstractNotifierTest.php +++ b/tests/Plugins/AbstractNotifierTest.php @@ -15,7 +15,7 @@ public function setUp() 'rocketeer::hooks' => array(), 'rocketeer::connections' => array( 'production' => array( - 'host' => 'foo.bar.com' + 'host' => 'foo.bar.com', ), ), )); diff --git a/tests/Services/Connections/ConnectionsHandlerTest.php b/tests/Services/Connections/ConnectionsHandlerTest.php index 5ff54af06..264ace472 100644 --- a/tests/Services/Connections/ConnectionsHandlerTest.php +++ b/tests/Services/Connections/ConnectionsHandlerTest.php @@ -108,7 +108,7 @@ public function testFillsConnectionCredentialsHoles() 'password' => '', 'keyphrase' => '', 'key' => '/Users/user/.ssh/id_rsa', - 'agent' => '' + 'agent' => '', ), )); $connections = $this->connections->getAvailableConnections(); diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index c41029b99..1501ab725 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -31,7 +31,7 @@ public function testIgnoresPlaceholdersWhenFillingCredentials() $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, 'username' => $this->username, - 'password' => $this->password + 'password' => $this->password, )); $this->credentials->getRepositoryCredentials(); @@ -51,7 +51,7 @@ public function testCanGetRepositoryCredentials() $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, 'username' => $this->username, - 'password' => $this->password + 'password' => $this->password, )); $this->credentials->getRepositoryCredentials(); @@ -65,7 +65,7 @@ public function testDoesntAskForRepositoryCredentialsIfUneeded() $this->givenConfiguredRepositoryCredentials([ 'repository' => $this->repository, 'username' => null, - 'password' => null + 'password' => null, ], false); $this->assertStoredCredentialsEquals(array( 'repository' => $this->repository, diff --git a/tests/Services/Tasks/TasksBuilderTest.php b/tests/Services/Tasks/TasksBuilderTest.php index 3fbb75e94..3d45f97d3 100644 --- a/tests/Services/Tasks/TasksBuilderTest.php +++ b/tests/Services/Tasks/TasksBuilderTest.php @@ -54,7 +54,7 @@ public function testCanBuildTasks() function () { return 'lol'; }, - 'Rocketeer\Tasks\Deploy' + 'Rocketeer\Tasks\Deploy', ); $queue = $this->builder->buildTasks($queue); diff --git a/tests/Services/Tasks/TasksQueueTest.php b/tests/Services/Tasks/TasksQueueTest.php index 88b9fbcd0..e0d5fd659 100644 --- a/tests/Services/Tasks/TasksQueueTest.php +++ b/tests/Services/Tasks/TasksQueueTest.php @@ -17,7 +17,7 @@ public function testCanRunQueue() $this->queue->run(array( function () { print 'JOEY DOESNT SHARE FOOD'; - } + }, ), $this->getCommand()); } @@ -32,7 +32,7 @@ public function testCanRunQueueOnDifferentConnectionsAndStages() $queue = array( function ($task) use (&$output) { $output[] = $task->connections->getConnection().' - '.$task->connections->getStage(); - } + }, ); $pipeline = $this->queue->run($queue); @@ -56,7 +56,7 @@ public function testCanRunQueueViaExecute() 'ls -a', function () { return 'JOEY DOESNT SHARE FOOD'; - } + }, )); $output = array_slice($this->history->getFlattenedOutput(), 2, 3); @@ -103,7 +103,7 @@ public function testCanRunTasksInParallel() $this->queue->execute(array( $task, - $task + $task, )); } diff --git a/tests/Services/TasksHandlerTest.php b/tests/Services/TasksHandlerTest.php index 3cdcc7370..5e06bd145 100644 --- a/tests/Services/TasksHandlerTest.php +++ b/tests/Services/TasksHandlerTest.php @@ -38,7 +38,7 @@ public function testCanAddMultipleTasksViaFacade() $after = $this->tasks->getTasksListeners($task, 'after', true); $this->tasks->after('deploy', array( 'composer install', - 'bower install' + 'bower install', )); $newAfter = array_merge($after, array('composer install', 'bower install')); diff --git a/tests/Strategies/Deploy/CloneStrategyTest.php b/tests/Strategies/Deploy/CloneStrategyTest.php index 131687011..3c3a0c377 100644 --- a/tests/Strategies/Deploy/CloneStrategyTest.php +++ b/tests/Strategies/Deploy/CloneStrategyTest.php @@ -14,7 +14,7 @@ public function testCanDeployRepository() 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", - "git submodule update --init --recursive" + "git submodule update --init --recursive", ), ); @@ -31,7 +31,7 @@ public function testCanUpdateRepository() "cd $this->server/releases/20000000000000", "git reset --hard", "git pull", - ) + ), ); $this->assertHistory($matcher); diff --git a/tests/Strategies/Deploy/CopyStrategyTest.php b/tests/Strategies/Deploy/CopyStrategyTest.php index 1e42398c6..396382035 100644 --- a/tests/Strategies/Deploy/CopyStrategyTest.php +++ b/tests/Strategies/Deploy/CopyStrategyTest.php @@ -42,7 +42,7 @@ public function testClonesIfNoPreviousRelease() 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", - "git submodule update --init --recursive" + "git submodule update --init --recursive", ), ); @@ -64,7 +64,7 @@ public function testCanCloneIfPreviousReleaseIsInvalid() 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", - "git submodule update --init --recursive" + "git submodule update --init --recursive", ), ); diff --git a/tests/Tasks/CleanupTest.php b/tests/Tasks/CleanupTest.php index dcc962024..e0c8f201f 100644 --- a/tests/Tasks/CleanupTest.php +++ b/tests/Tasks/CleanupTest.php @@ -55,7 +55,7 @@ public function testCanRemoveAllReleasesAtOnce() $this->pretendTask('Cleanup')->execute(); $this->assertHistory(array( - 'rm -rf {server}/1 {server}/2' + 'rm -rf {server}/1 {server}/2', )); } diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index 1bf3b84de..badb7fa8a 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -18,25 +18,25 @@ public function testCanDeployToServer() 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", - "git submodule update --init --recursive" + "git submodule update --init --recursive", ), array( "cd {server}/releases/{release}", - exec('which phpunit')." --stop-on-failure" + exec('which phpunit')." --stop-on-failure", ), array( "cd {server}/releases/{release}", "chmod -R 755 {server}/releases/{release}/tests", "chmod -R g+s {server}/releases/{release}/tests", - "chown -R www-data:www-data {server}/releases/{release}/tests" + "chown -R www-data:www-data {server}/releases/{release}/tests", ), array( "cd {server}/releases/{release}", - "{php} artisan migrate" + "{php} artisan migrate", ), array( "cd {server}/releases/{release}", - "{php} artisan db:seed" + "{php} artisan db:seed", ), "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", @@ -46,7 +46,7 @@ public function testCanDeployToServer() $this->assertTaskHistory('Deploy', $matcher, array( 'tests' => true, 'seed' => true, - 'migrate' => true + 'migrate' => true, )); } @@ -61,19 +61,19 @@ public function testStepsRunnerDoesntCancelWithPermissionsAndShared() 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", - "git submodule update --init --recursive" + "git submodule update --init --recursive", ), array( "cd {server}/releases/{release}", - exec('which phpunit')." --stop-on-failure" + exec('which phpunit')." --stop-on-failure", ), array( "cd {server}/releases/{release}", - "{php} artisan migrate" + "{php} artisan migrate", ), array( "cd {server}/releases/{release}", - "{php} artisan db:seed" + "{php} artisan db:seed", ), "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", @@ -83,7 +83,7 @@ public function testStepsRunnerDoesntCancelWithPermissionsAndShared() $this->assertTaskHistory('Deploy', $matcher, array( 'tests' => true, 'seed' => true, - 'migrate' => true + 'migrate' => true, )); } @@ -96,28 +96,28 @@ public function testCanDisableGitOptions() 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', - ) + ), )); $matcher = array( 'git clone "{repository}" "{server}/releases/{release}" --branch="master"', array( "cd {server}/releases/{release}", - exec('which phpunit').' --stop-on-failure' + exec('which phpunit').' --stop-on-failure', ), array( "cd {server}/releases/{release}", "chmod -R 755 {server}/releases/{release}/tests", "chmod -R g+s {server}/releases/{release}/tests", - "chown -R www-data:www-data {server}/releases/{release}/tests" + "chown -R www-data:www-data {server}/releases/{release}/tests", ), array( "cd {server}/releases/{release}", - "{php} artisan migrate" + "{php} artisan migrate", ), array( "cd {server}/releases/{release}", - "{php} artisan db:seed" + "{php} artisan db:seed", ), "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", @@ -127,7 +127,7 @@ public function testCanDisableGitOptions() $this->assertTaskHistory('Deploy', $matcher, array( 'tests' => true, 'seed' => true, - 'migrate' => true + 'migrate' => true, )); } @@ -138,7 +138,7 @@ public function testCanUseCopyStrategy() 'repository' => 'https://github.com/'.$this->repository, 'username' => '', 'password' => '', - ) + ), )); $this->app['rocketeer.strategies.deploy'] = new CopyStrategy($this->app); @@ -158,7 +158,7 @@ public function testCanUseCopyStrategy() "cd {server}/releases/{release}", "chmod -R 755 {server}/releases/{release}/tests", "chmod -R g+s {server}/releases/{release}/tests", - "chown -R www-data:www-data {server}/releases/{release}/tests" + "chown -R www-data:www-data {server}/releases/{release}/tests", ), "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", @@ -168,7 +168,7 @@ public function testCanUseCopyStrategy() $this->assertTaskHistory('Deploy', $matcher, array( 'tests' => false, 'seed' => false, - 'migrate' => false + 'migrate' => false, )); } @@ -178,17 +178,17 @@ public function testCanRunDeployWithSeed() 'git clone "{repository}" "{server}/releases/{release}" --branch="master" --depth="1"', array( "cd {server}/releases/{release}", - "git submodule update --init --recursive" + "git submodule update --init --recursive", ), array( "cd {server}/releases/{release}", "chmod -R 755 {server}/releases/{release}/tests", "chmod -R g+s {server}/releases/{release}/tests", - "chown -R www-data:www-data {server}/releases/{release}/tests" + "chown -R www-data:www-data {server}/releases/{release}/tests", ), array( "cd {server}/releases/{release}", - "{php} artisan db:seed" + "{php} artisan db:seed", ), "mv {server}/current {server}/releases/{release}", "rm -rf {server}/current", diff --git a/tests/Tasks/RollbackTest.php b/tests/Tasks/RollbackTest.php index 36b82ee4d..5846cd5e7 100644 --- a/tests/Tasks/RollbackTest.php +++ b/tests/Tasks/RollbackTest.php @@ -1,7 +1,6 @@ 'production', 'rocketeer::strategies.primer' => function () { return 'ls'; - } + }, )); $this->assertTaskHistory('Primer', ['ls']); diff --git a/tests/Tasks/UpdateTest.php b/tests/Tasks/UpdateTest.php index c34c5d793..372952590 100644 --- a/tests/Tasks/UpdateTest.php +++ b/tests/Tasks/UpdateTest.php @@ -9,33 +9,33 @@ public function testCanUpdateRepository() { $task = $this->pretendTask('Update', array( 'migrate' => true, - 'seed' => true + 'seed' => true, )); $matcher = array( array( "cd {server}/releases/20000000000000", "git reset --hard", - "git pull" + "git pull", ), array( "cd {server}/releases/20000000000000", "chmod -R 755 {server}/releases/20000000000000/tests", "chmod -R g+s {server}/releases/20000000000000/tests", - "chown -R www-data:www-data {server}/releases/20000000000000/tests" + "chown -R www-data:www-data {server}/releases/20000000000000/tests", ), array( "cd {server}/releases/{release}", - "{php} artisan migrate" + "{php} artisan migrate", ), array( "cd {server}/releases/{release}", - "{php} artisan db:seed" + "{php} artisan db:seed", ), array( "cd {server}/releases/20000000000000", - "{php} artisan cache:clear" - ) + "{php} artisan cache:clear", + ), ); $this->assertTaskHistory($task, $matcher); diff --git a/tests/TestCases/ContainerTestCase.php b/tests/TestCases/ContainerTestCase.php index 266e62ead..f46882796 100644 --- a/tests/TestCases/ContainerTestCase.php +++ b/tests/TestCases/ContainerTestCase.php @@ -90,7 +90,7 @@ public function tearDown() */ protected function mock($handle, $class = null, Closure $expectations = null, $partial = true) { - $class = $class ?: $handle; + $class = $class ?: $handle; $mockery = Mockery::mock($class); if ($partial) { $mockery = $mockery->shouldIgnoreMissing(); @@ -284,7 +284,7 @@ protected function getFactoryConfiguration() 'session.driver' => 'file', 'remote.connections' => array( 'production' => [], - 'staging' => [] + 'staging' => [], ), 'rocketeer::application_name' => 'foobar', 'rocketeer::logs' => null, @@ -304,7 +304,7 @@ protected function getFactoryConfiguration() 'before' => array( 'deploy' => array( 'before', - 'foobar' + 'foobar', ), ), 'after' => array( @@ -313,7 +313,7 @@ protected function getFactoryConfiguration() ), 'deploy' => array( 'after', - 'foobar' + 'foobar', ), ), ), diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index 450cc22b7..b4327a21a 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -1,7 +1,6 @@ mockCommand([], array( 'line' => function ($error) { echo $error; - } + }, )); $status = $this->task('Deploy')->checkStatus('Oh noes', 'git clone'); diff --git a/tests/Traits/StepsRunnerTest.php b/tests/Traits/StepsRunnerTest.php index 84ed3ca07..20ee453b7 100644 --- a/tests/Traits/StepsRunnerTest.php +++ b/tests/Traits/StepsRunnerTest.php @@ -23,12 +23,12 @@ public function testStepsAreClearedOnceRun() $task->steps()->run('ls'); $this->assertEquals(array( - ['run', ['ls']] + ['run', ['ls']], ), $task->steps()->getSteps()); $task->runSteps(); $task->steps()->run('php --version'); $this->assertEquals(array( - ['run', ['php --version']] + ['run', ['php --version']], ), $task->steps()->getSteps()); } } From 22aab59182d50a5e52f53b322d86a2b969493a1a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 12 Sep 2014 18:32:44 +0200 Subject: [PATCH 406/424] Close #296 - Hide input when asking for passwords --- src/Rocketeer/Abstracts/AbstractCommand.php | 40 +++++++++++++++++-- .../Services/CredentialsGatherer.php | 3 +- 2 files changed, 39 insertions(+), 4 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index b78d045a1..e2ec124d7 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -185,6 +185,42 @@ protected function fireTasksQueue($tasks) * @return string */ public function askWith($question, $default = null, $choices = array()) + { + $question = $this->formatQuestion($question, $default, $choices); + + // If we provided choices, autocomplete + if ($choices) { + return $this->askWithCompletion($question, $choices, $default); + } + + return $this->ask($question, $default); + } + + /** + * Ask a question to the user, hiding the input + * + * @param string $question + * @param string|null $default + * + * @return string + */ + public function askSecretly($question, $default = null) + { + $question = $this->formatQuestion($question, $default); + + return $this->secret($question, $default); + } + + /** + * Adds additional information to a question + * + * @param string $question + * @param string $default + * @param array $choices + * + * @return string + */ + protected function formatQuestion($question, $default, $choices = array()) { // If default, show it in the question if (!is_null($default)) { @@ -194,11 +230,9 @@ public function askWith($question, $default = null, $choices = array()) // If multiple choices, show them if ($choices) { $question .= ' ['.implode('/', $choices).']'; - - return $this->askWithCompletion($question, $choices, $default); } - return $this->ask($question, $default); + return $question; } /** diff --git a/src/Rocketeer/Services/CredentialsGatherer.php b/src/Rocketeer/Services/CredentialsGatherer.php index 19e72d600..429f463f1 100644 --- a/src/Rocketeer/Services/CredentialsGatherer.php +++ b/src/Rocketeer/Services/CredentialsGatherer.php @@ -193,8 +193,9 @@ protected function gatherCredential($handle, $credential, $question = null) { $question = $question ?: 'No '.$credential.' is set for ['.$handle.'], please provide one:'; $option = $this->command->option($credential); + $method = $credential == 'password' ? 'askSecretly' : 'askWith'; - return $option ?: $this->command->askWith($question); + return $option ?: $this->command->$method($question); } /** From f0ebf98791c3d286b374e7f405eb16ef3a04705a Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 12 Sep 2014 18:36:24 +0200 Subject: [PATCH 407/424] Close #297 - Fix reference to SERVER.HOME in bin/rocketeer --- bin/rocketeer | 2 +- src/Rocketeer/Services/Pathfinder.php | 2 +- tests/Services/PathfinderTest.php | 14 +++++++++++++- 3 files changed, 15 insertions(+), 3 deletions(-) diff --git a/bin/rocketeer b/bin/rocketeer index c2b8cb879..8fc2b5ce8 100755 --- a/bin/rocketeer +++ b/bin/rocketeer @@ -18,7 +18,7 @@ foreach ($vendors as $vendor) { } // Load plugins -$plugins = $_SERVER['HOME'].'/.rocketeer/vendor/autoload.php'; +$plugins = Pathfinder::getUserHomeFolder().'/.rocketeer/vendor/autoload.php'; if (file_exists($plugins)) { require_once $plugins; } diff --git a/src/Rocketeer/Services/Pathfinder.php b/src/Rocketeer/Services/Pathfinder.php index 1ba5074b1..03b1b26c7 100644 --- a/src/Rocketeer/Services/Pathfinder.php +++ b/src/Rocketeer/Services/Pathfinder.php @@ -79,7 +79,7 @@ public function getRocketeerConfigFolder() * @throws Exception * @return string */ - public function getUserHomeFolder() + public static function getUserHomeFolder() { // Get home folder if available (Unix) if (!empty($_SERVER['HOME'])) { diff --git a/tests/Services/PathfinderTest.php b/tests/Services/PathfinderTest.php index 5e8127a70..6d2a8bc5c 100644 --- a/tests/Services/PathfinderTest.php +++ b/tests/Services/PathfinderTest.php @@ -54,7 +54,8 @@ public function testCanGetUserHomeFolder() public function testCanGetWindowsHomeFolder() { - $_SERVER['HOME'] = null; + unset($_SERVER['HOME']); + $_SERVER['HOMEDRIVE'] = 'C:'; $_SERVER['HOMEPATH'] = '\Users\someuser'; $home = $this->paths->getUserHomeFolder(); @@ -62,6 +63,17 @@ public function testCanGetWindowsHomeFolder() $this->assertEquals('C:\Users\someuser', $home); } + public function testCanGetWindowsHomeFolderStatically() + { + unset($_SERVER['HOME']); + + $_SERVER['HOMEDRIVE'] = 'C:'; + $_SERVER['HOMEPATH'] = '\Users\someuser'; + $home = Pathfinder::getUserHomeFolder(); + + $this->assertEquals('C:\Users\someuser', $home); + } + public function testCancelsIfNoHomeFolder() { $this->setExpectedException('Exception'); From 29dc63daf8e6bc1c6524d8f9607ef8f305b7943c Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 12 Sep 2014 18:41:25 +0200 Subject: [PATCH 408/424] Fix missing namespace --- bin/rocketeer | 2 +- tests/Services/CredentialsGathererTest.php | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/bin/rocketeer b/bin/rocketeer index 8fc2b5ce8..b86ca0ca8 100755 --- a/bin/rocketeer +++ b/bin/rocketeer @@ -18,7 +18,7 @@ foreach ($vendors as $vendor) { } // Load plugins -$plugins = Pathfinder::getUserHomeFolder().'/.rocketeer/vendor/autoload.php'; +$plugins = Rocketeer\Services\Pathfinder::getUserHomeFolder().'/.rocketeer/vendor/autoload.php'; if (file_exists($plugins)) { require_once $plugins; } diff --git a/tests/Services/CredentialsGathererTest.php b/tests/Services/CredentialsGathererTest.php index 1501ab725..43afc54df 100644 --- a/tests/Services/CredentialsGathererTest.php +++ b/tests/Services/CredentialsGathererTest.php @@ -209,7 +209,8 @@ protected function mockAnswers($answers = array()) foreach ($answers as $question => $answer) { $question = strpos($question, 'is set for') !== false ? $question.', please provide one:' : $question; - $mock = $mock->shouldReceive('askWith')->with($question)->andReturn($answer); + $method = strpos($question, 'password') !== false ? 'askSecretly' : 'askWith'; + $mock = $mock->shouldReceive($method)->with($question)->andReturn($answer); } return $mock; From 2442350fa4c294a5a27462ec5bde726c8eacc7b8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 12 Sep 2014 18:42:28 +0200 Subject: [PATCH 409/424] Add note about root folder --- src/config/remote.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/config/remote.php b/src/config/remote.php index e19ab39fb..340558715 100644 --- a/src/config/remote.php +++ b/src/config/remote.php @@ -19,6 +19,7 @@ //////////////////////////////////////////////////////////////////// // The root directory where your applications will be deployed + // This path *needs* to start at the root, ie. start with a / 'root_directory' => '/home/www/', // The folder the application will be cloned in From cd4494c227503043aaba5d809874118c09fa987e Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Fri, 12 Sep 2014 18:47:04 +0200 Subject: [PATCH 410/424] Cache binaries for tests --- src/Rocketeer/Services/Storages/LocalStorage.php | 2 +- src/Rocketeer/Traits/BashModules/Core.php | 3 ++- tests/Abstracts/AbstractTaskTest.php | 2 +- tests/Binaries/ArtisanTest.php | 2 +- tests/Binaries/ComposerTest.php | 2 +- .../Dependencies/PolyglotStrategyTest.php | 2 +- tests/Tasks/DeployTest.php | 6 +++--- tests/TestCases/Modules/RocketeerAssertions.php | 7 ++++--- tests/TestCases/RocketeerTestCase.php | 15 +++++++++++++++ 9 files changed, 29 insertions(+), 12 deletions(-) diff --git a/src/Rocketeer/Services/Storages/LocalStorage.php b/src/Rocketeer/Services/Storages/LocalStorage.php index 16529aebb..cfeb4ff8b 100644 --- a/src/Rocketeer/Services/Storages/LocalStorage.php +++ b/src/Rocketeer/Services/Storages/LocalStorage.php @@ -170,7 +170,7 @@ public function getLineEndings() $endings = $this->bash->runRaw('php -r "echo PHP_EOL;"'); $this->set('line_endings', $endings); - return $endings; + return $endings ?: PHP_EOL; }); } diff --git a/src/Rocketeer/Traits/BashModules/Core.php b/src/Rocketeer/Traits/BashModules/Core.php index 963ad6822..707bb7d62 100644 --- a/src/Rocketeer/Traits/BashModules/Core.php +++ b/src/Rocketeer/Traits/BashModules/Core.php @@ -339,7 +339,8 @@ protected function processOutput($output, $array = false, $trim = true) // Explode output if necessary if ($array) { - $output = explode($this->localStorage->getLineEndings(), $output); + $delimiter = $this->localStorage->getLineEndings() ?: PHP_EOL; + $output = explode($delimiter, $output); } // Trim output diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index 808e26ef9..dfb0f6d55 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -95,7 +95,7 @@ public function testCanListenToSubtasks() $this->assertHistory(array( 'cd {server}/releases/{release}', 'ls', - ), $history[3]); + ), array_get($history, 3)); } public function testDoesntDuplicateQueuesOnSubtasks() diff --git a/tests/Binaries/ArtisanTest.php b/tests/Binaries/ArtisanTest.php index 09f804e16..b278dc5a8 100644 --- a/tests/Binaries/ArtisanTest.php +++ b/tests/Binaries/ArtisanTest.php @@ -7,7 +7,7 @@ class ArtisanTest extends RocketeerTestCase { public function testCanRunMigrations() { - $php = exec('which php'); + $php = $this->binaries['php']; $artisan = new Artisan($this->app); $commands = $artisan->migrate(); diff --git a/tests/Binaries/ComposerTest.php b/tests/Binaries/ComposerTest.php index cef6fa86f..0766f7dd0 100644 --- a/tests/Binaries/ComposerTest.php +++ b/tests/Binaries/ComposerTest.php @@ -11,6 +11,6 @@ public function testCanWrapWithPhpIfArchive() $composer = new Composer($this->app); $composer->setBinary('composer.phar'); - $this->assertEquals(exec('which php').' composer.phar install', $composer->install()); + $this->assertEquals($this->binaries['php'].' composer.phar install', $composer->install()); } } diff --git a/tests/Strategies/Dependencies/PolyglotStrategyTest.php b/tests/Strategies/Dependencies/PolyglotStrategyTest.php index 1828cb88c..755e418f1 100644 --- a/tests/Strategies/Dependencies/PolyglotStrategyTest.php +++ b/tests/Strategies/Dependencies/PolyglotStrategyTest.php @@ -16,7 +16,7 @@ public function testCanInstallAllDependencies() $this->assertHistory(array( array( 'cd {server}/releases/{release}', - exec('which bundle').' install', + '{bundle} install', ), array( 'cd {server}/releases/{release}', diff --git a/tests/Tasks/DeployTest.php b/tests/Tasks/DeployTest.php index badb7fa8a..b56ec0bb4 100644 --- a/tests/Tasks/DeployTest.php +++ b/tests/Tasks/DeployTest.php @@ -22,7 +22,7 @@ public function testCanDeployToServer() ), array( "cd {server}/releases/{release}", - exec('which phpunit')." --stop-on-failure", + "{phpunit} --stop-on-failure", ), array( "cd {server}/releases/{release}", @@ -65,7 +65,7 @@ public function testStepsRunnerDoesntCancelWithPermissionsAndShared() ), array( "cd {server}/releases/{release}", - exec('which phpunit')." --stop-on-failure", + "{phpunit} --stop-on-failure", ), array( "cd {server}/releases/{release}", @@ -103,7 +103,7 @@ public function testCanDisableGitOptions() 'git clone "{repository}" "{server}/releases/{release}" --branch="master"', array( "cd {server}/releases/{release}", - exec('which phpunit').' --stop-on-failure', + '{phpunit} --stop-on-failure', ), array( "cd {server}/releases/{release}", diff --git a/tests/TestCases/Modules/RocketeerAssertions.php b/tests/TestCases/Modules/RocketeerAssertions.php index 187b9e5ac..822d1e54f 100644 --- a/tests/TestCases/Modules/RocketeerAssertions.php +++ b/tests/TestCases/Modules/RocketeerAssertions.php @@ -142,12 +142,13 @@ protected function replaceHistoryPlaceholders($history, $release = null) } $replaced[$key] = strtr($entries, array( - '{php}' => exec('which php'), - '{phpunit}' => exec('which phpunit'), + '{php}' => $this->binaries['php'], + '{bundle}' => $this->binaries['bundle'], + '{phpunit}' => $this->binaries['phpunit'], '{repository}' => 'https://github.com/'.$this->repository, '{server}' => $this->server, '{release}' => $release, - '{composer}' => exec('which composer'), + '{composer}' => $this->binaries['composer'], )); } diff --git a/tests/TestCases/RocketeerTestCase.php b/tests/TestCases/RocketeerTestCase.php index b4327a21a..6b6420e31 100644 --- a/tests/TestCases/RocketeerTestCase.php +++ b/tests/TestCases/RocketeerTestCase.php @@ -36,6 +36,13 @@ abstract class RocketeerTestCase extends ContainerTestCase */ protected $task; + /** + * Cache of the paths to binaries + * + * @type array + */ + protected $binaries = []; + /** * Set up the tests */ @@ -58,6 +65,14 @@ public function setUp() return new LocalStorage($app, 'deployments', $folder); }); + + // Cache paths + $this->binaries = array( + 'php' => exec('which php') ?: 'php', + 'bundle' => exec('which bundle') ?: 'bundle', + 'phpunit' => exec('which phpunit') ?: 'phpunit', + 'composer' => exec('which composer') ?: 'composer', + ); } /** From ecfde5ae1beccdb4e1932239527cb9789c72b6d2 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 10:50:56 +0200 Subject: [PATCH 411/424] Close #300 - Remove stored paths if incorrect --- src/Rocketeer/Traits/BashModules/Binaries.php | 16 +++++++++++--- .../TestCases/Modules/RocketeerMockeries.php | 8 +++++++ tests/Traits/BashModules/BinariesTest.php | 22 +++++++++++++------ 3 files changed, 36 insertions(+), 10 deletions(-) diff --git a/src/Rocketeer/Traits/BashModules/Binaries.php b/src/Rocketeer/Traits/BashModules/Binaries.php index aff1224fc..9924727da 100644 --- a/src/Rocketeer/Traits/BashModules/Binaries.php +++ b/src/Rocketeer/Traits/BashModules/Binaries.php @@ -120,14 +120,24 @@ protected function whichFrom($binary, array $locations) while (!$location && array_key_exists($tryout, $locations)) { list($object, $method, $argument) = $locations[$tryout]; + // Execute method $location = $object->$method($argument); - $location = strpos($location, 'not found') !== false ? null : $location; + + // Verify existence of returned path + if (strpos($location, 'not found') !== false || !$this->fileExists($location)) { + $location = null; + } + $tryout++; } - // Store found location + // Store found location or remove it if invalid if (!$this->local) { - $this->localStorage->set('paths.'.$binary, $location); + if ($location) { + $this->localStorage->set('paths.'.$binary, $location); + } else { + $this->localStorage->forget('paths.'.$binary); + } } return $location ?: $binary; diff --git a/tests/TestCases/Modules/RocketeerMockeries.php b/tests/TestCases/Modules/RocketeerMockeries.php index 72b99f293..723445643 100644 --- a/tests/TestCases/Modules/RocketeerMockeries.php +++ b/tests/TestCases/Modules/RocketeerMockeries.php @@ -103,4 +103,12 @@ protected function mockFiles(Closure $expectations = null) { $this->mock('files', 'Illuminate\Filesystem\Filesystem', $expectations); } + + /** + * @param array $configuration + */ + public function mockConfig(array $configuration) + { + $this->app['config'] = $this->getConfig($configuration); + } } diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index e6c6726d4..176419d75 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -7,24 +7,32 @@ class BinariesTest extends RocketeerTestCase { public function testCanSetCustomPathsForBinaries() { - $this->app['config'] = $this->getConfig(array('rocketeer::paths.composer' => 'foobar')); + $this->mockConfig(['rocketeer::paths.composer' => __FILE__]); - $this->assertEquals('foobar', $this->task->which('composer')); + $this->assertEquals(__FILE__, $this->task->which('composer')); + } + + public function testStoredPathsAreInvalidatedIfIncorrect() + { + $this->localStorage->set('paths.composer', 'foobar'); + + $this->assertEquals($this->binaries['composer'], $this->task->which('composer')); + $this->assertNull($this->localStorage->get('paths.composer')); } public function testCanSetPathToPhpAndArtisan() { - $this->app['config'] = $this->getConfig(array( - 'rocketeer::paths.php' => '/usr/local/bin/php', - 'rocketeer::paths.artisan' => './laravel/artisan', + $this->mockConfig(array( + 'rocketeer::paths.php' => $this->binaries['php'], + 'rocketeer::paths.artisan' => $this->binaries['php'], )); - $this->assertEquals('/usr/local/bin/php ./laravel/artisan migrate', $this->task->artisan()->migrate()); + $this->assertEquals($this->binaries['php']. ' ' .$this->binaries['php']. ' migrate', $this->task->artisan()->migrate()); } public function testFetchesBinaryIfNotSpecifiedOrNull() { - $this->app['config'] = $this->getConfig(array( + $this->mockConfig(array( 'rocketeer::paths.php' => '/usr/local/bin/php', )); From ef8b728f143e6146587c0d5941bd6d73a23a6ac8 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 10:55:57 +0200 Subject: [PATCH 412/424] Update tests --- tests/Traits/BashModules/BinariesTest.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 176419d75..0d9909635 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -33,10 +33,10 @@ public function testCanSetPathToPhpAndArtisan() public function testFetchesBinaryIfNotSpecifiedOrNull() { $this->mockConfig(array( - 'rocketeer::paths.php' => '/usr/local/bin/php', + 'rocketeer::paths.php' => $this->binaries['php'], )); - $this->assertEquals('/usr/local/bin/php artisan migrate', $this->task->artisan()->migrate()); + $this->assertEquals($this->binaries['php'].' artisan migrate', $this->task->artisan()->migrate()); } public function testCanGetBinary() From e1c5b26e9c01d86f289534aa7e165cceaabd26fc Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 10:57:28 +0200 Subject: [PATCH 413/424] Fix default for secret questions --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index e2ec124d7..6fce5047c 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -208,7 +208,7 @@ public function askSecretly($question, $default = null) { $question = $this->formatQuestion($question, $default); - return $this->secret($question, $default); + return $this->secret($question) ?: $default; } /** From 16cb84f3c335269ec02fee704cdddd4f2e4546eb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 11:38:51 +0200 Subject: [PATCH 414/424] Fix tests for Travis --- tests/Traits/BashModules/BinariesTest.php | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 0d9909635..4631198f0 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -1,6 +1,7 @@ mock('rocketeer.remote', 'Remote', function ($mock) { + return $mock + ->shouldReceive('run')->with(['which composer'], Mockery::any())->andReturn($this->binaries['composer']) + ->shouldReceive('run')->with('[ -e ] && echo "true"', Mockery::any())->andReturn('false') + ->shouldReceive('run')->with('[ -e foobar ] && echo "true"', Mockery::any())->andReturn('false') + ->shouldReceive('runRaw')->andReturn('false'); + }, false); + $this->localStorage->set('paths.composer', 'foobar'); $this->assertEquals($this->binaries['composer'], $this->task->which('composer')); From 9abdc9fbfd961cbc2ed6cf7420caa8ca684b6cd1 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 11:42:25 +0200 Subject: [PATCH 415/424] Try again --- tests/Traits/BashModules/BinariesTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 4631198f0..a0b9d44bc 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -25,7 +25,7 @@ public function testStoredPathsAreInvalidatedIfIncorrect() $this->localStorage->set('paths.composer', 'foobar'); - $this->assertEquals($this->binaries['composer'], $this->task->which('composer')); + $this->assertEquals($this->binaries['composer'], $this->task->which('composer', $this->binaries['composer'])); $this->assertNull($this->localStorage->get('paths.composer')); } From 8f5ecfcd2fb3232180030a15a3912450a8fec198 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 11:45:50 +0200 Subject: [PATCH 416/424] Lalalala --- tests/Traits/BashModules/BinariesTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index a0b9d44bc..c5cd94459 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -17,7 +17,7 @@ public function testStoredPathsAreInvalidatedIfIncorrect() { $this->mock('rocketeer.remote', 'Remote', function ($mock) { return $mock - ->shouldReceive('run')->with(['which composer'], Mockery::any())->andReturn($this->binaries['composer']) + ->shouldReceive('run')->with(['which '.$this->binaries['composer']], Mockery::any())->andReturn($this->binaries['composer']) ->shouldReceive('run')->with('[ -e ] && echo "true"', Mockery::any())->andReturn('false') ->shouldReceive('run')->with('[ -e foobar ] && echo "true"', Mockery::any())->andReturn('false') ->shouldReceive('runRaw')->andReturn('false'); From ead495ab57ed577c08e3560be2dd5f5fe6c6d9a5 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 12:11:38 +0200 Subject: [PATCH 417/424] Nope --- tests/Traits/BashModules/BinariesTest.php | 1 + 1 file changed, 1 insertion(+) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index c5cd94459..f7f109574 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -17,6 +17,7 @@ public function testStoredPathsAreInvalidatedIfIncorrect() { $this->mock('rocketeer.remote', 'Remote', function ($mock) { return $mock + ->shouldReceive('run')->with('which composer')->andReturn(null) ->shouldReceive('run')->with(['which '.$this->binaries['composer']], Mockery::any())->andReturn($this->binaries['composer']) ->shouldReceive('run')->with('[ -e ] && echo "true"', Mockery::any())->andReturn('false') ->shouldReceive('run')->with('[ -e foobar ] && echo "true"', Mockery::any())->andReturn('false') From 8c0fc372097ca1e1f0ace749804f9ca845106e8f Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 12:42:02 +0200 Subject: [PATCH 418/424] Fuck you Travis, best regards, me --- tests/Traits/BashModules/BinariesTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index f7f109574..c00e915e2 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -17,7 +17,7 @@ public function testStoredPathsAreInvalidatedIfIncorrect() { $this->mock('rocketeer.remote', 'Remote', function ($mock) { return $mock - ->shouldReceive('run')->with('which composer')->andReturn(null) + ->shouldReceive('run')->with(['which composer'])->andReturn(null) ->shouldReceive('run')->with(['which '.$this->binaries['composer']], Mockery::any())->andReturn($this->binaries['composer']) ->shouldReceive('run')->with('[ -e ] && echo "true"', Mockery::any())->andReturn('false') ->shouldReceive('run')->with('[ -e foobar ] && echo "true"', Mockery::any())->andReturn('false') From 5b9e788f6ca5659c7e0e16a6223d4e5e6c0782cb Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 12:47:24 +0200 Subject: [PATCH 419/424] One day my son, all of these tests will pass --- tests/Traits/BashModules/BinariesTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index c00e915e2..7b42d4940 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -17,7 +17,7 @@ public function testStoredPathsAreInvalidatedIfIncorrect() { $this->mock('rocketeer.remote', 'Remote', function ($mock) { return $mock - ->shouldReceive('run')->with(['which composer'])->andReturn(null) + ->shouldReceive('run')->with(['which composer'], Mockery::any())->andReturn(null) ->shouldReceive('run')->with(['which '.$this->binaries['composer']], Mockery::any())->andReturn($this->binaries['composer']) ->shouldReceive('run')->with('[ -e ] && echo "true"', Mockery::any())->andReturn('false') ->shouldReceive('run')->with('[ -e foobar ] && echo "true"', Mockery::any())->andReturn('false') From 099e480d011f2a572e7b79c4dfddc133f486b657 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 12:55:11 +0200 Subject: [PATCH 420/424] =?UTF-8?q?=E0=B2=A0=5F=E0=B2=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- tests/Traits/BashModules/BinariesTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 7b42d4940..045c14383 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -26,7 +26,7 @@ public function testStoredPathsAreInvalidatedIfIncorrect() $this->localStorage->set('paths.composer', 'foobar'); - $this->assertEquals($this->binaries['composer'], $this->task->which('composer', $this->binaries['composer'])); + $this->assertEquals('composer', $this->task->which('composer')); $this->assertNull($this->localStorage->get('paths.composer')); } From 1c22069676aa418604638964fd89a023c5655253 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 14:44:02 +0200 Subject: [PATCH 421/424] Add table helper --- src/Rocketeer/Abstracts/AbstractCommand.php | 7 ++++- src/Rocketeer/Abstracts/AbstractTask.php | 31 ++++++++----------- .../Console/Commands/Plugins/ListCommand.php | 5 +-- .../Console/Commands/StrategiesCommand.php | 7 ++--- .../Services/Connections/RemoteHandler.php | 8 ++--- 5 files changed, 27 insertions(+), 31 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index 6fce5047c..c57c9aff0 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -11,6 +11,7 @@ use Closure; use Illuminate\Console\Command; +use Symfony\Component\Console\Helper\Table; use Symfony\Component\Console\Input\InputOption; /** @@ -172,7 +173,7 @@ protected function fireTasksQueue($tasks) } ////////////////////////////////////////////////////////////////////// - ////////////////////////////// HELPERS /////////////////////////////// + /////////////////////////////// INPUT //////////////////////////////// ////////////////////////////////////////////////////////////////////// /** @@ -235,6 +236,10 @@ protected function formatQuestion($question, $default, $choices = array()) return $question; } + ////////////////////////////////////////////////////////////////////// + ////////////////////////////// HELPERS /////////////////////////////// + ////////////////////////////////////////////////////////////////////// + /** * Time an operation and display it afterwards * diff --git a/src/Rocketeer/Abstracts/AbstractTask.php b/src/Rocketeer/Abstracts/AbstractTask.php index 6de8d37fa..36abe2f55 100644 --- a/src/Rocketeer/Abstracts/AbstractTask.php +++ b/src/Rocketeer/Abstracts/AbstractTask.php @@ -13,7 +13,6 @@ use Illuminate\Support\Str; use Rocketeer\Bash; use Rocketeer\Traits\StepsRunner; -use Symfony\Component\Console\Helper\Table; /** * An abstract AbstractTask with common helpers, from which all Tasks derive @@ -237,36 +236,32 @@ public function getQualifiedEvent($event) */ protected function displayReleases() { - $releases = $this->releasesManager->getValidationFile(); - $this->command->comment('Here are the available releases :'); - - $output = $this->command->getOutput(); - if (!$output) { + if (!$this->command) { return; } - // Build table - $table = new Table($output); - $table->setHeaders(['#', 'Path', 'Deployed at', 'Status']); + $key = 0; + $rows = []; + $releases = $this->releasesManager->getValidationFile(); // Append the rows - $key = 0; - $rows = []; foreach ($releases as $name => $state) { - $date = DateTime::createFromFormat('YmdHis', $name); - $date = $date->format('Y-m-d H:i:s'); $icon = $state ? '✓' : '✘'; $color = $state ? 'green' : 'red'; + $date = DateTime::createFromFormat('YmdHis', $name)->format('Y-m-d H:i:s'); + $date = sprintf('%s', $color, $date, $color); // Add color to row - $row = [$key, $name, $date, $icon]; - $row[3] = sprintf('%s', $color, $row[3], $color); - $rows[] = $row; + $rows[] = [$key, $name, $date, $icon]; $key++; } - $table->addRows($rows); - $table->render(); + // Render table + $this->command->comment('Here are the available releases :'); + $this->command->table( + ['#', 'Path', 'Deployed at', 'Status'], + $rows + ); return $rows; } diff --git a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php index ad638b903..14c96891f 100644 --- a/src/Rocketeer/Console/Commands/Plugins/ListCommand.php +++ b/src/Rocketeer/Console/Commands/Plugins/ListCommand.php @@ -41,9 +41,6 @@ public function fire() $rows[] = [$plugin]; } - $table = new Table($this->getOutput()); - $table->setHeaders(['Plugin']); - $table->addRows($rows); - $table->render(); + $this->table(['Plugin'], $rows); } } diff --git a/src/Rocketeer/Console/Commands/StrategiesCommand.php b/src/Rocketeer/Console/Commands/StrategiesCommand.php index 848bc2514..f332ce1fb 100644 --- a/src/Rocketeer/Console/Commands/StrategiesCommand.php +++ b/src/Rocketeer/Console/Commands/StrategiesCommand.php @@ -48,15 +48,14 @@ public function fire() 'dependencies' => ['Composer', 'Bundler', 'Npm', 'Bower', 'Polyglot'], ); - $table = new Table($this->getOutput()); - $table->setHeaders(['Strategy', 'Implementation', 'Description']); + $rows = []; foreach ($strategies as $strategy => $implementations) { foreach ($implementations as $implementation) { $instance = $this->laravel['rocketeer.builder']->buildStrategy($strategy, $implementation); - $table->addRow([$strategy, $implementation, $instance->getDescription()]); + $rows[] = [$strategy, $implementation, $instance->getDescription()]; } } - $table->render(); + $this->table(['Strategy', 'Implementation', 'Description'], $rows); } } diff --git a/src/Rocketeer/Services/Connections/RemoteHandler.php b/src/Rocketeer/Services/Connections/RemoteHandler.php index 1170e4036..e379fd7d5 100644 --- a/src/Rocketeer/Services/Connections/RemoteHandler.php +++ b/src/Rocketeer/Services/Connections/RemoteHandler.php @@ -110,13 +110,13 @@ protected function makeConnection($name, array $credentials) protected function getAuth(array $config) { if (isset($config['agent']) && $config['agent'] === true) { - return array('agent' => true); + return ['agent' => true]; } elseif (isset($config['key']) && trim($config['key']) != '') { - return array('key' => $config['key'], 'keyphrase' => $config['keyphrase']); + return ['key' => $config['key'], 'keyphrase' => $config['keyphrase']]; } elseif (isset($config['keytext']) && trim($config['keytext']) != '') { - return array('keytext' => $config['keytext']); + return ['keytext' => $config['keytext']]; } elseif (isset($config['password'])) { - return array('password' => $config['password']); + return ['password' => $config['password']]; } throw new MissingCredentialsException('Password / key is required.'); From 2c2819e90106ecb2e074ca6e44694b42443a0dc6 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 20:36:36 +0200 Subject: [PATCH 422/424] Code tweaks --- src/Rocketeer/Abstracts/AbstractCommand.php | 2 +- src/config/hooks.php | 2 +- tests/Traits/BashModules/BinariesTest.php | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Rocketeer/Abstracts/AbstractCommand.php b/src/Rocketeer/Abstracts/AbstractCommand.php index c57c9aff0..aedd97866 100644 --- a/src/Rocketeer/Abstracts/AbstractCommand.php +++ b/src/Rocketeer/Abstracts/AbstractCommand.php @@ -203,7 +203,7 @@ public function askWith($question, $default = null, $choices = array()) * @param string $question * @param string|null $default * - * @return string + * @return string|null */ public function askSecretly($question, $default = null) { diff --git a/src/config/hooks.php b/src/config/hooks.php index 9c9967ec4..05b52ab30 100644 --- a/src/config/hooks.php +++ b/src/config/hooks.php @@ -25,7 +25,7 @@ 'deploy' => array(), 'cleanup' => array(), ), - + // Custom Tasks to register with Rocketeer 'custom' => array(), diff --git a/tests/Traits/BashModules/BinariesTest.php b/tests/Traits/BashModules/BinariesTest.php index 045c14383..0b9674951 100644 --- a/tests/Traits/BashModules/BinariesTest.php +++ b/tests/Traits/BashModules/BinariesTest.php @@ -37,7 +37,7 @@ public function testCanSetPathToPhpAndArtisan() 'rocketeer::paths.artisan' => $this->binaries['php'], )); - $this->assertEquals($this->binaries['php']. ' ' .$this->binaries['php']. ' migrate', $this->task->artisan()->migrate()); + $this->assertEquals($this->binaries['php'].' '.$this->binaries['php'].' migrate', $this->task->artisan()->migrate()); } public function testFetchesBinaryIfNotSpecifiedOrNull() From d9b8f08a1118d19951e7d6d6c9c2e86582505af7 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Sat, 13 Sep 2014 21:38:25 +0200 Subject: [PATCH 423/424] Add releases table test --- tests/Abstracts/AbstractTaskTest.php | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/tests/Abstracts/AbstractTaskTest.php b/tests/Abstracts/AbstractTaskTest.php index dfb0f6d55..2236b65c6 100644 --- a/tests/Abstracts/AbstractTaskTest.php +++ b/tests/Abstracts/AbstractTaskTest.php @@ -122,4 +122,20 @@ public function testCanHookIntoHaltingEvent() $this->pretendTask('Deploy')->fire(); } + + public function testCanDisplayReleasesTable() + { + $headers = ['#', 'Path', 'Deployed at', 'Status']; + $releases = array( + [0, 20000000000000, '1999-11-30 00:00:00', '✓'], + [1, 15000000000000, '1499-11-30 00:00:00', '✘'], + [2, 10000000000000, '0999-11-30 00:00:00', '✓'], + ); + + $this->app['rocketeer.command'] = $this->getCommand() + ->shouldReceive('table')->with($headers, $releases)->andReturn(null)->once() + ->mock(); + + $this->task('CurrentRelease')->execute(); + } } From 4fea468c62e150343239875c4fab6700caf76498 Mon Sep 17 00:00:00 2001 From: Maxime Fabre Date: Wed, 17 Sep 2014 19:46:06 +0200 Subject: [PATCH 424/424] Fix generated PHAR missing required file --- src/Rocketeer/Console/Compiler.php | 1 - 1 file changed, 1 deletion(-) diff --git a/src/Rocketeer/Console/Compiler.php b/src/Rocketeer/Console/Compiler.php index 4e0acaedf..1fd267068 100644 --- a/src/Rocketeer/Console/Compiler.php +++ b/src/Rocketeer/Console/Compiler.php @@ -103,7 +103,6 @@ public function compile() 'mockery', 'nesbot', 'phine', - 'raveren', )); // Add binary