| @@ -112,8 +112,7 @@ | ||
| 112 | 112 |          if (isset($engine->options->readOnlyTestUsers) && $engine->options->readOnlyTestUsers) { | 
| 113 | 113 | usingUsers()->setUsersFileIsReadOnly(); | 
| 114 | 114 | } | 
| 115 | - else | |
| 116 | -        { | |
| 115 | +        else { | |
| 117 | 116 |              $setting = fromTestEnvironment()->getModuleSetting("users.readOnly"); | 
| 118 | 117 |              if ($setting === true) { | 
| 119 | 118 | usingUsers()->setUsersFileIsReadOnly(); | 
| @@ -123,43 +123,43 @@ | ||
| 123 | 123 | $downloader = new FileDownloader(); | 
| 124 | 124 | |
| 125 | 125 | // let's get the files downloaded | 
| 126 | -        foreach ($filesToDownload as $file){ | |
| 126 | +        foreach ($filesToDownload as $file) { | |
| 127 | 127 | |
| 128 | -            if (!is_object($file->url)){ | |
| 128 | +            if (!is_object($file->url)) { | |
| 129 | 129 | $url = $file->url; | 
| 130 | 130 |              } else { | 
| 131 | 131 |                  $platform = strtolower(php_uname("s") . '/' . php_uname("m")); | 
| 132 | -                if (isset($file->url->{$platform})){ | |
| 132 | +                if (isset($file->url->{$platform})) { | |
| 133 | 133 |                      $url = $file->url->{$platform}; | 
| 134 | -                } else if (isset($file->url->generic)){ | |
| 135 | - $url = $file->url->generic; | |
| 134 | +                } else if (isset($file->url->generic)) { | |
| 135 | + $url = $file->url->generic; | |
| 136 | 136 | } | 
| 137 | 137 | } | 
| 138 | 138 | |
| 139 | -            if (!isset($url)){ | |
| 140 | -                throw new Exception("No supported downloads for ".$file->name); | |
| 139 | +            if (!isset($url)) { | |
| 140 | +                throw new Exception("No supported downloads for " . $file->name); | |
| 141 | 141 | } | 
| 142 | 142 | |
| 143 | 143 | // How big is the file? | 
| 144 | 144 | // via http://www.php.net/manual/en/function.filesize.php#84130 | 
| 145 | - $headers = array_change_key_case(get_headers($url, 1),CASE_LOWER); | |
| 146 | -            if ( !preg_match('/HTTP\/1\.(0|1) 200 OK/', $headers[0] ) ) { | |
| 145 | + $headers = array_change_key_case(get_headers($url, 1), CASE_LOWER); | |
| 146 | +            if (!preg_match('/HTTP\/1\.(0|1) 200 OK/', $headers[0])) { | |
| 147 | 147 | $fileSize = $headers['content-length'][1]; | 
| 148 | 148 |              } else { | 
| 149 | 149 | $fileSize = $headers['content-length']; | 
| 150 | 150 | } | 
| 151 | 151 | |
| 152 | 152 | // Update the user on what's going on | 
| 153 | -            echo "Downloading: " . $url.' ('.round($fileSize/1024/1024, 3).'mb)'.PHP_EOL; | |
| 153 | +            echo "Downloading: " . $url . ' (' . round($fileSize / 1024 / 1024, 3) . 'mb)' . PHP_EOL; | |
| 154 | 154 | |
| 155 | 155 | // Download it | 
| 156 | 156 | $fileBase = basename($url); | 
| 157 | - $downloader->download($url, "./vendor/bin/".$fileBase); | |
| 157 | + $downloader->download($url, "./vendor/bin/" . $fileBase); | |
| 158 | 158 | |
| 159 | 159 | // Make sure that the relevant files are executable | 
| 160 | 160 |              if (isset($file->makeExecutable)) { | 
| 161 | -                foreach ($file->makeExecutable as $exec){ | |
| 162 | -                    chmod("./vendor/bin/".$exec, 0755); | |
| 161 | +                foreach ($file->makeExecutable as $exec) { | |
| 162 | +                    chmod("./vendor/bin/" . $exec, 0755); | |
| 163 | 163 | } | 
| 164 | 164 | } | 
| 165 | 165 | } | 
| @@ -123,20 +123,22 @@ discard block | ||
| 123 | 123 | $downloader = new FileDownloader(); | 
| 124 | 124 | |
| 125 | 125 | // let's get the files downloaded | 
| 126 | -        foreach ($filesToDownload as $file){ | |
| 126 | +        foreach ($filesToDownload as $file) { | |
| 127 | 127 | |
| 128 | -            if (!is_object($file->url)){ | |
| 128 | +            if (!is_object($file->url)) { | |
| 129 | 129 | $url = $file->url; | 
| 130 | -            } else { | |
| 130 | + } | |
| 131 | +            else { | |
| 131 | 132 |                  $platform = strtolower(php_uname("s") . '/' . php_uname("m")); | 
| 132 | -                if (isset($file->url->{$platform})){ | |
| 133 | +                if (isset($file->url->{$platform})) { | |
| 133 | 134 |                      $url = $file->url->{$platform}; | 
| 134 | -                } else if (isset($file->url->generic)){ | |
| 135 | + } | |
| 136 | +                else if (isset($file->url->generic)) { | |
| 135 | 137 | $url = $file->url->generic; | 
| 136 | 138 | } | 
| 137 | 139 | } | 
| 138 | 140 | |
| 139 | -            if (!isset($url)){ | |
| 141 | +            if (!isset($url)) { | |
| 140 | 142 |                  throw new Exception("No supported downloads for ".$file->name); | 
| 141 | 143 | } | 
| 142 | 144 | |
| @@ -145,7 +147,8 @@ discard block | ||
| 145 | 147 | $headers = array_change_key_case(get_headers($url, 1),CASE_LOWER); | 
| 146 | 148 |              if ( !preg_match('/HTTP\/1\.(0|1) 200 OK/', $headers[0] ) ) { | 
| 147 | 149 | $fileSize = $headers['content-length'][1]; | 
| 148 | -            } else { | |
| 150 | + } | |
| 151 | +            else { | |
| 149 | 152 | $fileSize = $headers['content-length']; | 
| 150 | 153 | } | 
| 151 | 154 | |
| @@ -158,7 +161,7 @@ discard block | ||
| 158 | 161 | |
| 159 | 162 | // Make sure that the relevant files are executable | 
| 160 | 163 |              if (isset($file->makeExecutable)) { | 
| 161 | -                foreach ($file->makeExecutable as $exec){ | |
| 164 | +                foreach ($file->makeExecutable as $exec) { | |
| 162 | 165 |                      chmod("./vendor/bin/".$exec, 0755); | 
| 163 | 166 | } | 
| 164 | 167 | } | 
| @@ -67,7 +67,7 @@ | ||
| 67 | 67 | $this->setLongDescription( | 
| 68 | 68 | "Use this command to get a list of all of the machines (physical or VM)" | 
| 69 | 69 | . " that are currently listed in Storyplayer's hoststable." | 
| 70 | - .PHP_EOL .PHP_EOL | |
| 70 | + .PHP_EOL . PHP_EOL | |
| 71 | 71 | ."This can help you to identify VMs that have been left running after " | 
| 72 | 72 | ."a test has completed." | 
| 73 | 73 | .PHP_EOL | 
| @@ -67,10 +67,10 @@ | ||
| 67 | 67 | $this->setLongDesc( | 
| 68 | 68 | "Use this command to get a list of all of the processes that Storyplayer " | 
| 69 | 69 | ."has started in the background." | 
| 70 | - .PHP_EOL .PHP_EOL | |
| 70 | + .PHP_EOL . PHP_EOL | |
| 71 | 71 | ."This can help you to identify processes that have been left running after " | 
| 72 | 72 | ."a test has completed." | 
| 73 | - .PHP_EOL .PHP_EOL | |
| 73 | + .PHP_EOL . PHP_EOL | |
| 74 | 74 | ."You can use the '--kill-processes' switch to stop these processes." | 
| 75 | 75 | ); | 
| 76 | 76 | |
| @@ -359,7 +359,7 @@ discard block | ||
| 359 | 359 | // do we have any parameters at this point? | 
| 360 | 360 |          if (empty($cliParams)) { | 
| 361 | 361 | $msg = "no stories listed on the command-line." . PHP_EOL . PHP_EOL | 
| 362 | - . "see 'storyplayer help play-story' for required params" . PHP_EOL; | |
| 362 | + . "see 'storyplayer help play-story' for required params" . PHP_EOL; | |
| 363 | 363 | $this->output->logCliError($msg); | 
| 364 | 364 | exit(1); | 
| 365 | 365 | } | 
| @@ -438,7 +438,7 @@ discard block | ||
| 438 | 438 | // did we find anything? | 
| 439 | 439 |          if (!count($filenames)) { | 
| 440 | 440 |              $msg = "no stories found in '{$folder}'" . PHP_EOL . PHP_EOL | 
| 441 | - . "do your stories' filenames end in 'Story.php'?"; | |
| 441 | + . "do your stories' filenames end in 'Story.php'?"; | |
| 442 | 442 | $this->output->logCliError($msg); | 
| 443 | 443 | exit(1); | 
| 444 | 444 | } | 
| @@ -494,7 +494,7 @@ discard block | ||
| 494 | 494 | // do we skip destroying the test environment? | 
| 495 | 495 |          if ($this->st->getPersistTestEnvironment()) { | 
| 496 | 496 | echo PHP_EOL . "* Warning: NOT destroying test environment" . PHP_EOL | 
| 497 | - . " --reuse-target flag is set" . PHP_EOL; | |
| 497 | + . " --reuse-target flag is set" . PHP_EOL; | |
| 498 | 498 | } | 
| 499 | 499 | |
| 500 | 500 | // cleanup | 
| @@ -317,7 +317,7 @@ discard block | ||
| 317 | 317 | foreach ($engine->options->reports as $reportName => $reportFilename) | 
| 318 | 318 |          { | 
| 319 | 319 |              try { | 
| 320 | - $report = $injectables->reportLoader->loadReport($reportName, [ 'filename' => $reportFilename]); | |
| 320 | + $report = $injectables->reportLoader->loadReport($reportName, ['filename' => $reportFilename]); | |
| 321 | 321 | } | 
| 322 | 322 |              catch (E4xx_NoSuchReport $e) { | 
| 323 | 323 |                  $injectables->output->logCliError("no such report '{$reportName}'"); | 
| @@ -341,7 +341,7 @@ discard block | ||
| 341 | 341 | |
| 342 | 342 | // setup signal handling | 
| 343 | 343 | pcntl_signal(SIGTERM, array($this, 'sigtermHandler')); | 
| 344 | - pcntl_signal(SIGINT , array($this, 'sigtermHandler')); | |
| 344 | + pcntl_signal(SIGINT, array($this, 'sigtermHandler')); | |
| 345 | 345 | } | 
| 346 | 346 | |
| 347 | 347 | /** | 
| @@ -261,8 +261,7 @@ discard block | ||
| 261 | 261 | // $this->playerList contains one or more things to play | 
| 262 | 262 | // | 
| 263 | 263 | // let's play each of them in order | 
| 264 | - foreach ($this->playerList as $player) | |
| 265 | -        { | |
| 264 | +        foreach ($this->playerList as $player) { | |
| 266 | 265 | // execute each player in turn | 
| 267 | 266 | // | 
| 268 | 267 | // they may also have their own list of nested players | 
| @@ -314,8 +313,7 @@ discard block | ||
| 314 | 313 | |
| 315 | 314 | // setup the reports that have been requested | 
| 316 | 315 | $injectables->initReportLoaderSupport($injectables); | 
| 317 | - foreach ($engine->options->reports as $reportName => $reportFilename) | |
| 318 | -        { | |
| 316 | +        foreach ($engine->options->reports as $reportName => $reportFilename) { | |
| 319 | 317 |              try { | 
| 320 | 318 | $report = $injectables->reportLoader->loadReport($reportName, [ 'filename' => $reportFilename]); | 
| 321 | 319 | } | 
| @@ -532,8 +530,7 @@ discard block | ||
| 532 | 530 | echo "FINAL RESULTS\n"; | 
| 533 | 531 | echo "\n"; | 
| 534 | 532 | |
| 535 | - foreach ($storyResults as $result) | |
| 536 | -        { | |
| 533 | +        foreach ($storyResults as $result) { | |
| 537 | 534 | echo Story_Player::$outcomeToText[$result->resultCode] . " :: " . $result->story->getName() . "\n"; | 
| 538 | 535 | } | 
| 539 | 536 | } | 
| @@ -69,8 +69,7 @@ discard block | ||
| 69 | 69 | static $configDir = null; | 
| 70 | 70 | |
| 71 | 71 | // do we have a configDir remembered yet? | 
| 72 | - if (!$configDir) | |
| 73 | -        { | |
| 72 | +        if (!$configDir) { | |
| 74 | 73 | $configDir = getcwd() . '/.storyplayer'; | 
| 75 | 74 | } | 
| 76 | 75 | |
| @@ -87,11 +86,9 @@ discard block | ||
| 87 | 86 | $configDir = $this->getConfigDir(); | 
| 88 | 87 | |
| 89 | 88 | // does it exist? | 
| 90 | - if (!file_exists($configDir)) | |
| 91 | -        { | |
| 89 | +        if (!file_exists($configDir)) { | |
| 92 | 90 | $success = mkdir($configDir, 0700, true); | 
| 93 | - if (!$success) | |
| 94 | -            { | |
| 91 | +            if (!$success) { | |
| 95 | 92 | // cannot create it - bail out now | 
| 96 | 93 |                  $output->logCliError("unable to create config directory '{$configDir}'"); | 
| 97 | 94 | exit(1); | 
| @@ -231,7 +231,7 @@ | ||
| 231 | 231 | |
| 232 | 232 | // setup signal handling | 
| 233 | 233 | pcntl_signal(SIGTERM, array($this, 'sigtermHandler')); | 
| 234 | - pcntl_signal(SIGINT , array($this, 'sigtermHandler')); | |
| 234 | + pcntl_signal(SIGINT, array($this, 'sigtermHandler')); | |
| 235 | 235 | } | 
| 236 | 236 | |
| 237 | 237 | /** | 
| @@ -194,8 +194,7 @@ | ||
| 194 | 194 | // $this->scriptList contains one or more things to run | 
| 195 | 195 | // | 
| 196 | 196 | // let's play each of them in order | 
| 197 | - foreach ($this->scriptList as $player) | |
| 198 | -        { | |
| 197 | +        foreach ($this->scriptList as $player) { | |
| 199 | 198 | // play the story(ies) | 
| 200 | 199 | $player->play($st, $injectables); | 
| 201 | 200 | } | 
| @@ -67,7 +67,7 @@ | ||
| 67 | 67 | $this->setLongDescription( | 
| 68 | 68 | "Use this command to see what Storyplayer will use as the default " | 
| 69 | 69 | ."environment to test against." | 
| 70 | - .PHP_EOL.PHP_EOL | |
| 70 | + .PHP_EOL . PHP_EOL | |
| 71 | 71 | ."This command mostly exists to assist tab-completion scripts for UNIX shells." | 
| 72 | 72 | ); | 
| 73 | 73 | } | 
| @@ -59,87 +59,87 @@ | ||
| 59 | 59 | */ | 
| 60 | 60 | class StaticConfigManager extends ConfigManagerBase | 
| 61 | 61 |  { | 
| 62 | - const USER_DOTFILE = 'storyplayer.json'; | |
| 62 | + const USER_DOTFILE = 'storyplayer.json'; | |
| 63 | 63 | |
| 64 | - /** | |
| 65 | - * load the default config file | |
| 66 | - * | |
| 67 | - * @param StaticConfig $config | |
| 68 | - * @return void | |
| 69 | - */ | |
| 70 | - public function loadDefaultConfig($config, $defaultConfigFilename) | |
| 71 | -	{ | |
| 72 | - // load the default config file | |
| 73 | - $this->configHelper->loadConfigFile($config, $defaultConfigFilename); | |
| 74 | - } | |
| 64 | + /** | |
| 65 | + * load the default config file | |
| 66 | + * | |
| 67 | + * @param StaticConfig $config | |
| 68 | + * @return void | |
| 69 | + */ | |
| 70 | + public function loadDefaultConfig($config, $defaultConfigFilename) | |
| 71 | +    { | |
| 72 | + // load the default config file | |
| 73 | + $this->configHelper->loadConfigFile($config, $defaultConfigFilename); | |
| 74 | + } | |
| 75 | 75 | |
| 76 | - /** | |
| 77 | - * @param StaticConfig $config | |
| 78 | - * @return void | |
| 79 | - */ | |
| 80 | - public function loadUserConfig($config) | |
| 81 | -	{ | |
| 82 | -		try { | |
| 83 | - // We start with an empty config | |
| 84 | - $this->configHelper->loadDotFileConfig($config, self::APP_NAME, self::USER_DOTFILE); | |
| 85 | - } | |
| 86 | -		catch (E4xx_ConfigFileNotFound $e) { | |
| 87 | - // we don't care - user configs are optional | |
| 88 | - } | |
| 89 | - // all done | |
| 90 | - } | |
| 76 | + /** | |
| 77 | + * @param StaticConfig $config | |
| 78 | + * @return void | |
| 79 | + */ | |
| 80 | + public function loadUserConfig($config) | |
| 81 | +    { | |
| 82 | +        try { | |
| 83 | + // We start with an empty config | |
| 84 | + $this->configHelper->loadDotFileConfig($config, self::APP_NAME, self::USER_DOTFILE); | |
| 85 | + } | |
| 86 | +        catch (E4xx_ConfigFileNotFound $e) { | |
| 87 | + // we don't care - user configs are optional | |
| 88 | + } | |
| 89 | + // all done | |
| 90 | + } | |
| 91 | 91 | |
| 92 | - /** | |
| 93 | - * | |
| 94 | - * @return array<string> | |
| 95 | - */ | |
| 96 | - public function getListOfConfigFiles($dirs) | |
| 97 | -	{ | |
| 98 | - // do we have a credible search list? | |
| 99 | -		if (!is_array($dirs)) { | |
| 100 | - // fraid not | |
| 101 | - return []; | |
| 102 | - } | |
| 92 | + /** | |
| 93 | + * | |
| 94 | + * @return array<string> | |
| 95 | + */ | |
| 96 | + public function getListOfConfigFiles($dirs) | |
| 97 | +    { | |
| 98 | + // do we have a credible search list? | |
| 99 | +        if (!is_array($dirs)) { | |
| 100 | + // fraid not | |
| 101 | + return []; | |
| 102 | + } | |
| 103 | 103 | |
| 104 | - $return = []; | |
| 105 | - foreach ($dirs as $dirToSearch) | |
| 106 | -		{ | |
| 107 | - // find JSON config files | |
| 108 | - $files = $this->configHelper->getListOfConfigFilesIn($dirToSearch, 'json'); | |
| 109 | -			foreach ($files as $filename) { | |
| 110 | - $return[basename($filename, '.json')] = $filename; | |
| 111 | - } | |
| 112 | - } | |
| 104 | + $return = []; | |
| 105 | + foreach ($dirs as $dirToSearch) | |
| 106 | +        { | |
| 107 | + // find JSON config files | |
| 108 | + $files = $this->configHelper->getListOfConfigFilesIn($dirToSearch, 'json'); | |
| 109 | +            foreach ($files as $filename) { | |
| 110 | + $return[basename($filename, '.json')] = $filename; | |
| 111 | + } | |
| 112 | + } | |
| 113 | 113 | |
| 114 | - // all done | |
| 115 | - return $return; | |
| 116 | - } | |
| 114 | + // all done | |
| 115 | + return $return; | |
| 116 | + } | |
| 117 | 117 | |
| 118 | - public function loadConfigFilesFrom($dirs) | |
| 119 | -	{ | |
| 120 | - // our list of loaded config files | |
| 121 | - $return = []; | |
| 118 | + public function loadConfigFilesFrom($dirs) | |
| 119 | +    { | |
| 120 | + // our list of loaded config files | |
| 121 | + $return = []; | |
| 122 | 122 | |
| 123 | - // the files to load | |
| 124 | - $filenames = $this->getListOfConfigFiles($dirs); | |
| 123 | + // the files to load | |
| 124 | + $filenames = $this->getListOfConfigFiles($dirs); | |
| 125 | 125 | |
| 126 | - // load the files | |
| 127 | - foreach ($filenames as $filename) | |
| 128 | -		{ | |
| 129 | - $config = new BaseObject(); | |
| 130 | - $this->configHelper->loadConfigFile($config, $filename); | |
| 131 | - $return[basename($filename, '.json')] = $config; | |
| 132 | - } | |
| 126 | + // load the files | |
| 127 | + foreach ($filenames as $filename) | |
| 128 | +        { | |
| 129 | + $config = new BaseObject(); | |
| 130 | + $this->configHelper->loadConfigFile($config, $filename); | |
| 131 | + $return[basename($filename, '.json')] = $config; | |
| 132 | + } | |
| 133 | 133 | |
| 134 | - // all done | |
| 135 | - return $return; | |
| 136 | - } | |
| 134 | + // all done | |
| 135 | + return $return; | |
| 136 | + } | |
| 137 | 137 | |
| 138 | - public function loadConfigFile($filename) | |
| 139 | -	{ | |
| 140 | - $config = new BaseObject(); | |
| 141 | - $this->configHelper->loadConfigFile($config, $filename); | |
| 138 | + public function loadConfigFile($filename) | |
| 139 | +    { | |
| 140 | + $config = new BaseObject(); | |
| 141 | + $this->configHelper->loadConfigFile($config, $filename); | |
| 142 | 142 | |
| 143 | - return $config; | |
| 144 | - } | |
| 143 | + return $config; | |
| 144 | + } | |
| 145 | 145 | } | 
| @@ -102,8 +102,7 @@ discard block | ||
| 102 | 102 | } | 
| 103 | 103 | |
| 104 | 104 | $return = []; | 
| 105 | - foreach ($dirs as $dirToSearch) | |
| 106 | -		{ | |
| 105 | +		foreach ($dirs as $dirToSearch) { | |
| 107 | 106 | // find JSON config files | 
| 108 | 107 | $files = $this->configHelper->getListOfConfigFilesIn($dirToSearch, 'json'); | 
| 109 | 108 |  			foreach ($files as $filename) { | 
| @@ -124,8 +123,7 @@ discard block | ||
| 124 | 123 | $filenames = $this->getListOfConfigFiles($dirs); | 
| 125 | 124 | |
| 126 | 125 | // load the files | 
| 127 | - foreach ($filenames as $filename) | |
| 128 | -		{ | |
| 126 | +		foreach ($filenames as $filename) { | |
| 129 | 127 | $config = new BaseObject(); | 
| 130 | 128 | $this->configHelper->loadConfigFile($config, $filename); | 
| 131 | 129 | $return[basename($filename, '.json')] = $config; |