mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-08 13:51:02 +01:00
ac19c55822
Summary: Ref T1049. Generally, it's useful to separate test/trial/manual runs from production/automatic runs. For example, you don't want to email a bunch of people that the build is broken just because you messed something up when writing a new build plan. You'd rather try it first, then promote it into production once you have some good runs. Similarly, test runs generally should not affect the outside world, etc. Finally, some build steps (like "wait for other buildables") may want to behave differently when run in production/automation than when run in a testing environment (where they should probably continue immediately). So, formalize the distinction between automatic buildables (those created passively by the system in response to events) and manual buildables (those created explicitly by users). Add filtering, and stop the automated parts of the system from interacting with the manual parts (for example, we won't show manual results on revisions). This also moves the "Apply Build Plan" to a third, new home: instead of the sidebar or Buildables, it's now on plans. I think this generally makes more sense given how things have developed. Broadly, this improves isolation of test environments. Test Plan: Created some builds, browsed around, used filters, etc. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T1049 Differential Revision: https://secure.phabricator.com/D7824
237 lines
6.7 KiB
PHP
237 lines
6.7 KiB
PHP
<?php
|
|
|
|
final class HarbormasterPlanViewController
|
|
extends HarbormasterPlanController {
|
|
|
|
private $id;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = $data['id'];
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$viewer = $request->getUser();
|
|
|
|
$id = $this->id;
|
|
|
|
$plan = id(new HarbormasterBuildPlanQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($id))
|
|
->executeOne();
|
|
if (!$plan) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$xactions = id(new HarbormasterBuildPlanTransactionQuery())
|
|
->setViewer($viewer)
|
|
->withObjectPHIDs(array($plan->getPHID()))
|
|
->execute();
|
|
|
|
$engine = id(new PhabricatorMarkupEngine())
|
|
->setViewer($viewer);
|
|
|
|
$xaction_view = id(new PhabricatorApplicationTransactionView())
|
|
->setUser($viewer)
|
|
->setObjectPHID($plan->getPHID())
|
|
->setTransactions($xactions)
|
|
->setMarkupEngine($engine);
|
|
|
|
$title = pht("Plan %d", $id);
|
|
|
|
$header = id(new PHUIHeaderView())
|
|
->setHeader($title)
|
|
->setUser($viewer)
|
|
->setPolicyObject($plan);
|
|
|
|
$box = id(new PHUIObjectBoxView())
|
|
->setHeader($header);
|
|
|
|
$actions = $this->buildActionList($plan);
|
|
$this->buildPropertyLists($box, $plan, $actions);
|
|
|
|
$crumbs = $this->buildApplicationCrumbs();
|
|
$crumbs->addTextCrumb(pht("Plan %d", $id));
|
|
|
|
$step_list = $this->buildStepList($plan);
|
|
|
|
return $this->buildApplicationPage(
|
|
array(
|
|
$crumbs,
|
|
$box,
|
|
$step_list,
|
|
$xaction_view,
|
|
),
|
|
array(
|
|
'title' => $title,
|
|
'device' => true,
|
|
));
|
|
}
|
|
|
|
private function buildStepList(HarbormasterBuildPlan $plan) {
|
|
$request = $this->getRequest();
|
|
$viewer = $request->getUser();
|
|
|
|
$list_id = celerity_generate_unique_node_id();
|
|
|
|
$steps = id(new HarbormasterBuildStepQuery())
|
|
->setViewer($viewer)
|
|
->withBuildPlanPHIDs(array($plan->getPHID()))
|
|
->execute();
|
|
|
|
$can_edit = $this->hasApplicationCapability(
|
|
HarbormasterCapabilityManagePlans::CAPABILITY);
|
|
|
|
$i = 1;
|
|
$step_list = id(new PHUIObjectItemListView())
|
|
->setUser($viewer)
|
|
->setID($list_id);
|
|
Javelin::initBehavior(
|
|
'harbormaster-reorder-steps',
|
|
array(
|
|
'listID' => $list_id,
|
|
'orderURI' => '/harbormaster/plan/order/'.$plan->getID().'/',
|
|
));
|
|
foreach ($steps as $step) {
|
|
$implementation = null;
|
|
try {
|
|
$implementation = $step->getStepImplementation();
|
|
} catch (Exception $ex) {
|
|
// We can't initialize the implementation. This might be because
|
|
// it's been renamed or no longer exists.
|
|
$item = id(new PHUIObjectItemView())
|
|
->setObjectName("Step ".$i++)
|
|
->setHeader(pht('Unknown Implementation'))
|
|
->setBarColor('red')
|
|
->addAttribute(pht(
|
|
'This step has an invalid implementation (%s).',
|
|
$step->getClassName()))
|
|
->addAction(
|
|
id(new PHUIListItemView())
|
|
->setIcon('delete')
|
|
->addSigil('harbormaster-build-step-delete')
|
|
->setWorkflow(true)
|
|
->setRenderNameAsTooltip(true)
|
|
->setName(pht("Delete"))
|
|
->setHref(
|
|
$this->getApplicationURI("step/delete/".$step->getID()."/")));
|
|
$step_list->addItem($item);
|
|
continue;
|
|
}
|
|
$item = id(new PHUIObjectItemView())
|
|
->setObjectName("Step ".$i++)
|
|
->setHeader($implementation->getName());
|
|
|
|
if (!$implementation->validateSettings()) {
|
|
$item
|
|
->setBarColor('red')
|
|
->addAttribute(pht('This step is not configured correctly.'));
|
|
} else {
|
|
$item->addAttribute($implementation->getDescription());
|
|
}
|
|
|
|
if ($can_edit) {
|
|
$edit_uri = $this->getApplicationURI("step/edit/".$step->getID()."/");
|
|
$item
|
|
->setHref($edit_uri)
|
|
->addAction(
|
|
id(new PHUIListItemView())
|
|
->setIcon('delete')
|
|
->addSigil('harbormaster-build-step-delete')
|
|
->setWorkflow(true)
|
|
->setRenderNameAsTooltip(true)
|
|
->setName(pht("Delete"))
|
|
->setHref(
|
|
$this->getApplicationURI("step/delete/".$step->getID()."/")));
|
|
$item->setGrippable(true);
|
|
$item->addSigil('build-step');
|
|
$item->setMetadata(
|
|
array(
|
|
'stepID' => $step->getID(),
|
|
));
|
|
}
|
|
|
|
$step_list->addItem($item);
|
|
}
|
|
|
|
return $step_list;
|
|
}
|
|
|
|
private function buildActionList(HarbormasterBuildPlan $plan) {
|
|
$request = $this->getRequest();
|
|
$viewer = $request->getUser();
|
|
$id = $plan->getID();
|
|
|
|
$list = id(new PhabricatorActionListView())
|
|
->setUser($viewer)
|
|
->setObject($plan)
|
|
->setObjectURI($this->getApplicationURI("plan/{$id}/"));
|
|
|
|
$can_edit = $this->hasApplicationCapability(
|
|
HarbormasterCapabilityManagePlans::CAPABILITY);
|
|
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Edit Plan'))
|
|
->setHref($this->getApplicationURI("plan/edit/{$id}/"))
|
|
->setWorkflow(!$can_edit)
|
|
->setDisabled(!$can_edit)
|
|
->setIcon('edit'));
|
|
|
|
if ($plan->isDisabled()) {
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Enable Plan'))
|
|
->setHref($this->getApplicationURI("plan/disable/{$id}/"))
|
|
->setWorkflow(true)
|
|
->setDisabled(!$can_edit)
|
|
->setIcon('enable'));
|
|
} else {
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Disable Plan'))
|
|
->setHref($this->getApplicationURI("plan/disable/{$id}/"))
|
|
->setWorkflow(true)
|
|
->setDisabled(!$can_edit)
|
|
->setIcon('disable'));
|
|
}
|
|
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Add Build Step'))
|
|
->setHref($this->getApplicationURI("step/add/{$id}/"))
|
|
->setWorkflow(true)
|
|
->setDisabled(!$can_edit)
|
|
->setIcon('new'));
|
|
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Run Plan Manually'))
|
|
->setHref($this->getApplicationURI("plan/run/{$id}/"))
|
|
->setWorkflow(true)
|
|
->setDisabled(!$can_edit)
|
|
->setIcon('start-sandcastle'));
|
|
|
|
return $list;
|
|
}
|
|
|
|
private function buildPropertyLists(
|
|
PHUIObjectBoxView $box,
|
|
HarbormasterBuildPlan $plan,
|
|
PhabricatorActionListView $actions) {
|
|
$request = $this->getRequest();
|
|
$viewer = $request->getUser();
|
|
|
|
$properties = id(new PHUIPropertyListView())
|
|
->setUser($viewer)
|
|
->setObject($plan)
|
|
->setActionList($actions);
|
|
$box->addPropertyList($properties);
|
|
|
|
$properties->addProperty(
|
|
pht('Created'),
|
|
phabricator_datetime($plan->getDateCreated(), $viewer));
|
|
|
|
}
|
|
|
|
}
|