pluginFactory = $pluginFactory; $this->logger = $logger; } /** * Execute a the appropriate set of plugins for a given build stage. * @param array $config PHPCI configuration * @param string $stage * @return bool */ public function executePlugins(&$config, $stage) { $success = true; // Ignore any stages for which we don't have plugins set: if (!array_key_exists($stage, $config) || !is_array($config[$stage])) { return $success; } foreach ($config[$stage] as $plugin => $options) { $this->logger->log(Lang::get('running_plugin', $plugin)); // Try and execute it: if ($this->executePlugin($plugin, $options)) { // Execution was successful: $this->logger->logSuccess(Lang::get('plugin_success')); } elseif ($stage == 'setup') { // If we're in the "setup" stage, execution should not continue after // a plugin has failed: throw new \Exception('Plugin failed: ' . $plugin); } else { // If we're in the "test" stage and the plugin is not allowed to fail, // then mark the build as failed: if ($stage == 'test' && (!isset($options['allow_failures']) || !$options['allow_failures'])) { $success = false; } $this->logger->logFailure(Lang::get('plugin_failed')); } } return $success; } /** * Executes a given plugin, with options and returns the result. */ public function executePlugin($plugin, $options) { // Any plugin name without a namespace separator is a PHPCI built in plugin // if not we assume it's a fully name-spaced class name that implements the plugin interface. // If not the factory will throw an exception. if (strpos($plugin, '\\') === false) { $class = str_replace('_', ' ', $plugin); $class = ucwords($class); $class = 'PHPCI\\Plugin\\' . str_replace(' ', '', $class); } else { $class = $plugin; } if (!class_exists($class)) { $this->logger->logFailure(Lang::get('plugin_missing', $plugin)); return false; } $rtn = true; // Try running it: try { $obj = $this->pluginFactory->buildPlugin($class, $options); if (!$obj->execute()) { $rtn = false; } } catch (\Exception $ex) { $this->logger->logFailure(Lang::get('exception') . $ex->getMessage(), $ex); $rtn = false; } return $rtn; } }