public function _initialize() { if (!isset($this->config['lint'])) { throw new Exception('missing [lint] object in codeception.yml'); } /* Options: -p <php> Specify PHP-CGI executable to run (default: 'php'). -s, --short Set short_open_tag to On (default: Off). -e <ext> Check only files with selected extensions separated by comma. (default: php,php3,php4,php5,phtml) --exclude Exclude directory. If you want exclude multiple directories, use multiple exclude parameters. --ignore-fails Ignore failed tests. */ try { $settings = Settings::parseArguments($this->config['lint']); $manager = new PhpParallelLint\Manager(); $result = $manager->run($settings); $hasError = $result->hasError(); $result = json_decode(json_encode($result)); teamcity_console_logger(MessageTemplate::BlockStart('ParallelLintTeamcityReporter')); teamcity_console_logger(MessageTemplate::TestSuiteStart('Errors')); foreach ($result->errors as $index => $error) { $type = $error->type . "[{$index}]"; teamcity_console_logger(MessageTemplate::TestStart($type . ' ~ ' . $error->file)); teamcity_console_logger(MessageTemplate::TestFailed($error->normalizeMessage, $error->message)); teamcity_console_logger(MessageTemplate::TestEnd($error->file)); } teamcity_console_logger(MessageTemplate::TestSuiteEnd('Errors')); teamcity_console_logger(MessageTemplate::BlockStart('FilesWithSyntaxError')); foreach ($result->filesWithSyntaxError as $index => $value) { $type = $error->type . "[{$index}]"; teamcity_console_logger(MessageTemplate::Log("[{$index}] - {$value}")); } teamcity_console_logger(MessageTemplate::BlockEnd('FilesWithSyntaxError')); teamcity_console_logger(MessageTemplate::BlockStart('CheckedFiles')); foreach ($result->checkedFiles as $index => $value) { $type = $error->type . "[{$index}]"; teamcity_console_logger(MessageTemplate::Log("[{$index}] - {$value}")); } teamcity_console_logger(MessageTemplate::BlockEnd('CheckedFiles')); teamcity_console_logger(MessageTemplate::BlockStart('SkippedFiles')); foreach ($result->skippedFiles as $index => $value) { $type = $error->type . "[{$index}]"; teamcity_console_logger(MessageTemplate::Log("[{$index}] - {$value}")); } teamcity_console_logger(MessageTemplate::BlockEnd('SkippedFiles')); teamcity_console_logger(MessageTemplate::BlockEnd('ParallelLintTeamcityReporter')); } catch (Exception $e) { echo $e->getMessage(), PHP_EOL; die(255); } }
} $files = array(__DIR__ . '/../../autoload.php', __DIR__ . '/vendor/autoload.php'); $autoloadFileFound = false; foreach ($files as $file) { if (file_exists($file)) { require $file; $autoloadFileFound = true; break; } } if (!$autoloadFileFound) { echo 'You need to set up the project dependencies using the following commands:' . PHP_EOL . 'curl -s http://getcomposer.org/installer | php' . PHP_EOL . 'php composer.phar install' . PHP_EOL; die(FAILED); } try { $settings = PhpParallelLint\Settings::parseArguments($_SERVER['argv']); if ($settings->json && PHP_VERSION_ID < 50400) { throw new \Exception('JSON output require PHP version 5.4 and newer.'); } if ($settings->stdin) { $settings->addPaths(PhpParallelLint\Settings::getPathsFromStdIn()); } if (empty($settings->paths)) { showUsage(); } $manager = new PhpParallelLint\Manager(); $result = $manager->run($settings); die($result->hasError() ? WITH_ERRORS : SUCCESS); } catch (PhpParallelLint\InvalidArgumentException $e) { echo "Invalid option {$e->getArgument()}" . PHP_EOL . PHP_EOL; showOptions();