Added a fixed and broken stage
This commit is contained in:
parent
6aea2bdb88
commit
8e0122f6a0
|
@ -188,6 +188,14 @@ class Builder implements LoggerAwareInterface
|
||||||
$this->build->sendStatusPostback();
|
$this->build->sendStatusPostback();
|
||||||
$success = true;
|
$success = true;
|
||||||
|
|
||||||
|
$previous_build = $this->build->getProject()->getPreviousBuild($this->build->getBranch());
|
||||||
|
|
||||||
|
$previous_state = Build::STATUS_NEW;
|
||||||
|
|
||||||
|
if ($previous_build) {
|
||||||
|
$previous_state = $previous_build->getStatus();
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// Set up the build:
|
// Set up the build:
|
||||||
$this->setupBuild();
|
$this->setupBuild();
|
||||||
|
@ -210,9 +218,19 @@ class Builder implements LoggerAwareInterface
|
||||||
|
|
||||||
if ($success) {
|
if ($success) {
|
||||||
$this->pluginExecutor->executePlugins($this->config, 'success');
|
$this->pluginExecutor->executePlugins($this->config, 'success');
|
||||||
|
|
||||||
|
if ($previous_state == Build::STATUS_FAILED) {
|
||||||
|
$this->pluginExecutor->executePlugins($this->config, 'fixed');
|
||||||
|
}
|
||||||
|
|
||||||
$this->buildLogger->logSuccess(Lang::get('build_success'));
|
$this->buildLogger->logSuccess(Lang::get('build_success'));
|
||||||
} else {
|
} else {
|
||||||
$this->pluginExecutor->executePlugins($this->config, 'failure');
|
$this->pluginExecutor->executePlugins($this->config, 'failure');
|
||||||
|
|
||||||
|
if ($previous_state == Build::STATUS_SUCCESS || $previous_state == Build::STATUS_NEW) {
|
||||||
|
$this->pluginExecutor->executePlugins($this->config, 'broken');
|
||||||
|
}
|
||||||
|
|
||||||
$this->buildLogger->logFailure(Lang::get('build_failed'));
|
$this->buildLogger->logFailure(Lang::get('build_failed'));
|
||||||
}
|
}
|
||||||
} catch (\Exception $ex) {
|
} catch (\Exception $ex) {
|
||||||
|
@ -402,4 +420,4 @@ class Builder implements LoggerAwareInterface
|
||||||
|
|
||||||
return $pluginFactory;
|
return $pluginFactory;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -305,7 +305,9 @@ PHPCI',
|
||||||
'stage_test' => 'Test',
|
'stage_test' => 'Test',
|
||||||
'stage_complete' => 'Complete',
|
'stage_complete' => 'Complete',
|
||||||
'stage_success' => 'Success',
|
'stage_success' => 'Success',
|
||||||
'stage_failure' => 'Failure',
|
'stage_failure' => 'Failure'
|
||||||
|
'stage_broken' => 'Broken',
|
||||||
|
'stage_fixed' => 'Fixed',
|
||||||
|
|
||||||
// Installer
|
// Installer
|
||||||
'installation_url' => 'PHPCI Installation URL',
|
'installation_url' => 'PHPCI Installation URL',
|
||||||
|
|
|
@ -50,6 +50,29 @@ class Project extends ProjectBase
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the previous build from a specific branch, for this project.
|
||||||
|
* @param string $branch
|
||||||
|
* @return mixed|null
|
||||||
|
*/
|
||||||
|
public function getPreviousBuild($branch = 'master')
|
||||||
|
{
|
||||||
|
$criteria = array('branch' => $branch, 'project_id' => $this->getId());
|
||||||
|
|
||||||
|
$order = array('id' => 'DESC');
|
||||||
|
$builds = Store\Factory::getStore('Build')->getWhere($criteria, 1, 1, array(), $order);
|
||||||
|
|
||||||
|
if (is_array($builds['items']) && count($builds['items'])) {
|
||||||
|
$previous = array_shift($builds['items']);
|
||||||
|
|
||||||
|
if (isset($previous) && $previous instanceof Build) {
|
||||||
|
return $previous;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Store this project's access_information data
|
* Store this project's access_information data
|
||||||
* @param string|array $value
|
* @param string|array $value
|
||||||
|
@ -131,4 +154,4 @@ class Project extends ProjectBase
|
||||||
|
|
||||||
return $icon;
|
return $icon;
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue